/* ============================================================
   FORWARD PACKAGING — Section styles
   ============================================================ */

/* image placeholder utility */
.img-ph{ position:relative; background:
    repeating-linear-gradient(135deg, rgba(22,26,90,.05) 0 2px, transparent 2px 13px),
    var(--bg-soft2);
  border:1px solid var(--line); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.img-ph .cap{ font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.04em; color:var(--slate);
  background:rgba(255,255,255,.82); padding:5px 11px; border-radius:6px; border:1px solid var(--line); }

/* ============================================================
   HERO B — full-bleed + navy overlay
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; isolation:isolate; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:2; }
.hero__media image-slot{ width:100%; height:100%; display:block; }
.hero__fallback{ position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(120% 90% at 80% 10%, var(--navy-soft) 0%, transparent 55%),
    linear-gradient(135deg, var(--navy-900) 0%, var(--navy) 55%, var(--navy-700) 100%); }
/* subtle moving line texture suggesting logistics */
.hero__grid{ position:absolute; inset:0; z-index:3; opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 80% at 70% 40%, #000 30%, transparent 80%); }
.hero__overlay{ position:absolute; inset:0; z-index:4;
  background:linear-gradient(100deg, rgba(10,12,43,.94) 0%, rgba(16,20,63,.86) 42%, rgba(16,20,63,.55) 100%); }
/* orange chevron flare */
.hero__chev{ position:absolute; right:-4%; top:50%; transform:translateY(-50%); z-index:4; width:48vw; max-width:760px; opacity:.32; pointer-events:none; }
.hero__chev svg{ width:100%; height:auto; filter:drop-shadow(0 20px 50px rgba(255,133,0,.25)); }

.hero__inner{ padding-top:120px; padding-bottom:64px; width:100%; position:relative; z-index:5; display:flex; align-items:center; gap:clamp(32px,5vw,72px); }
.hero__content{ max-width:780px; color:#fff; flex:1 1 auto; }
.hero__aside{ flex:0 0 auto; display:flex; align-items:center; justify-content:center; }
.hero__logo{ height:clamp(120px,15vw,210px); width:auto; display:block; filter:drop-shadow(0 24px 60px rgba(0,0,0,.35)); }
@media (max-width:920px){ .hero__aside{ display:none; } }
.hero h1{ color:#fff; }
.hero .lead{ color:rgba(255,255,255,.84); max-width:620px; margin-top:1.1em; }
.hero__desc{ color:rgba(255,255,255,.66); font-size:1.02rem; max-width:600px; margin-top:1em; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2.2em; }
.hero__chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:2.6em; }
.chip{ display:inline-flex; align-items:center; gap:.55em; font-size:.9rem; font-weight:600; color:#fff;
  padding:.5em .95em; border:1px solid rgba(255,255,255,.22); border-radius:40px; background:rgba(255,255,255,.05); backdrop-filter:blur(4px); }
.chip svg{ color:var(--accent); flex:0 0 auto; }
.hero__scroll{ position:absolute; bottom:22px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.5);
  font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:8px; z-index:1; }
.hero__scroll .line{ width:1px; height:34px; background:linear-gradient(rgba(255,255,255,.5), transparent); animation:scrolldn 1.8s var(--ease) infinite; }
@keyframes scrolldn{ 0%{transform:scaleY(0);transform-origin:top;} 50%{transform:scaleY(1);transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* ============================================================
   PILLARS strip (overlaps hero)
   ============================================================ */
.pillars{ position:relative; z-index:2; margin-top:-72px; }
.pillars__card{ background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-lg);
  display:grid; grid-template-columns:repeat(4,1fr); overflow:hidden; }
.pillar{ padding:30px 28px; border-right:1px solid var(--line); transition:background .3s; }
.pillar:last-child{ border-right:none; }
.pillar:hover{ background:var(--bg-soft); }
.pillar .ic{ width:44px; height:44px; border-radius:10px; background:var(--navy); color:#fff; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.pillar h4{ font-size:1.05rem; font-weight:700; margin-bottom:5px; }
.pillar p{ font-size:.9rem; color:var(--slate); margin:0; line-height:1.45; }
@media (max-width:860px){ .pillars__card{ grid-template-columns:1fr 1fr; } .pillar:nth-child(2){border-right:none;} .pillar:nth-child(1),.pillar:nth-child(2){border-bottom:1px solid var(--line);} }
@media (max-width:480px){ .pillars__card{ grid-template-columns:1fr; } .pillar{border-right:none; border-bottom:1px solid var(--line);} .pillar:last-child{border-bottom:none;} }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.about-media{ display:grid; grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:14px; }
.about-media image-slot:first-child{ grid-column:1 / -1; height:260px; }
.about-media image-slot{ height:175px; border-radius:14px; }
.about-stat{ position:absolute; }
.about-points{ list-style:none; margin:1.6em 0 2em; padding:0; display:grid; gap:14px; }
.about-points li{ display:flex; gap:13px; align-items:flex-start; font-weight:500; }
.about-points .tick{ flex:0 0 auto; width:24px; height:24px; border-radius:6px; background:rgba(255,133,0,.12); color:var(--accent); display:flex; align-items:center; justify-content:center; margin-top:2px; }
@media (max-width:820px){ .about-grid{ grid-template-columns:1fr; } }

/* ============================================================
   SERVICES (grouped by family)
   ============================================================ */
.serv-family{ margin-bottom:clamp(40px,5vw,64px); }
.serv-family:last-child{ margin-bottom:0; }
.serv-family__head{ display:flex; align-items:baseline; gap:16px; margin-bottom:22px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.serv-family__head .idx{ font-family:var(--ff-mono); font-size:.85rem; color:var(--accent); font-weight:600; }
.serv-family__head h3{ font-size:clamp(1.3rem,2.2vw,1.7rem); }
.serv-family__head .count{ margin-left:auto; font-family:var(--ff-mono); font-size:.78rem; color:var(--slate); letter-spacing:.05em; }
.serv-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media (max-width:980px){ .serv-grid{ grid-template-columns:repeat(3,1fr);} }
@media (max-width:680px){ .serv-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:430px){ .serv-grid{ grid-template-columns:1fr;} }

.serv-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:22px 20px 20px;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; position:relative; overflow:hidden; cursor:default; }
.serv-card::before{ content:""; position:absolute; left:0; top:0; height:3px; width:100%; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease); }
.serv-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:transparent; }
.serv-card:hover::before{ transform:scaleX(1); }
.serv-card .ic{ width:46px; height:46px; border-radius:10px; background:var(--bg-soft); color:var(--navy);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px; transition:background .3s,color .3s; }
.serv-card:hover .ic{ background:var(--navy); color:#fff; }
.serv-card h4{ font-size:1.06rem; font-weight:700; margin-bottom:6px; letter-spacing:-.01em; }
.serv-card p{ font-size:.88rem; color:var(--slate); margin:0; line-height:1.45; }

/* clickable service card (e.g. Armado PDQ) */
.serv-card--link{ cursor:pointer; display:block; }
.serv-card--link h4{ display:flex; align-items:center; gap:8px; }
.serv-card--link .serv-go{ display:inline-flex; color:var(--accent); transform:translateX(-3px); opacity:0; transition:transform .3s var(--ease), opacity .3s; }
.serv-card--link:hover .serv-go{ transform:translateX(0); opacity:1; }

/* ============================================================
   WHY US
   ============================================================ */
.why{ background:var(--navy); color:#fff; position:relative; overflow:hidden; }
.why::after{ content:""; position:absolute; right:-10%; bottom:-30%; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,133,0,.16), transparent 60%); pointer-events:none; }
.why h2.title, .why .eyebrow{ color:#fff; }
.why .lead{ color:rgba(255,255,255,.72); }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.1); border-radius:16px; overflow:hidden; }
.why-card{ background:var(--navy); padding:34px 30px; transition:background .3s; }
.why-card:hover{ background:var(--navy-soft); }
.why-card .ic{ width:50px; height:50px; border-radius:12px; background:rgba(255,255,255,.08); color:var(--accent); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.why-card h3{ color:#fff; font-size:1.2rem; margin-bottom:8px; }
.why-card p{ color:rgba(255,255,255,.68); font-size:.95rem; margin:0; }
@media (max-width:860px){ .why-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .why-grid{ grid-template-columns:1fr; } }

/* ============================================================
   INDUSTRIES
   ============================================================ */
.ind-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:14px; }
.ind-tile{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:26px 14px; text-align:center;
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.ind-tile:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:var(--accent); }
.ind-tile .ic{ width:48px; height:48px; margin:0 auto 14px; color:var(--navy); display:flex; align-items:center; justify-content:center; transition:color .3s; }
.ind-tile:hover .ic{ color:var(--accent); }
.ind-tile span{ font-weight:700; font-size:.92rem; color:var(--navy); display:block; line-height:1.2; }
@media (max-width:980px){ .ind-grid{ grid-template-columns:repeat(4,1fr);} }
@media (max-width:560px){ .ind-grid{ grid-template-columns:repeat(2,1fr);} }

/* ============================================================
   PROCESS timeline
   ============================================================ */
.proc{ position:relative; }
.proc-track{ display:grid; grid-template-columns:repeat(7,1fr); gap:0; position:relative; margin-top:30px; }
.proc-track::before{ content:""; position:absolute; left:0; right:0; top:23px; height:2px; background:var(--line-2); }
.proc-prog{ content:""; position:absolute; left:0; top:23px; height:2px; background:var(--accent); width:0; transition:width 1.4s var(--ease); z-index:1; }
.proc-step{ position:relative; padding:0 10px; text-align:center; }
.proc-step .num{ width:48px; height:48px; margin:0 auto 16px; border-radius:50%; background:#fff; border:2px solid var(--line-2);
  display:flex; align-items:center; justify-content:center; font-family:var(--ff-display); font-weight:800; color:var(--navy); position:relative; z-index:2; transition:.4s var(--ease); }
.proc-step.on .num{ background:var(--navy); color:#fff; border-color:var(--navy); }
.proc-step h4{ font-size:.95rem; font-weight:700; line-height:1.2; }
.proc-step p{ font-size:.8rem; color:var(--slate); margin:.4em 0 0; }
@media (max-width:820px){
  .proc-track{ grid-template-columns:1fr; gap:0; }
  .proc-track::before{ left:23px; right:auto; top:0; bottom:0; width:2px; height:auto; }
  .proc-prog{ left:23px; top:0; width:2px; height:0; transition:height 1.4s var(--ease); }
  .proc-step{ display:grid; grid-template-columns:48px 1fr; gap:18px; text-align:left; padding:0 0 30px; align-items:start; }
  .proc-step .num{ margin:0; }
  .proc-step h4{ margin-top:10px; }
}

/* ============================================================
   CONFIANZA band
   ============================================================ */
.trust-band{ background:var(--bg-soft); }
.trust-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:10px; }
.trust-item{ display:flex; gap:15px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; transition:transform .3s var(--ease), box-shadow .3s; }
.trust-item:hover{ transform:translateX(4px); box-shadow:var(--shadow-sm); }
.trust-item .tk{ flex:0 0 auto; width:42px; height:42px; border-radius:10px; background:var(--navy); color:#fff; display:flex; align-items:center; justify-content:center; }
.trust-item span{ font-weight:700; color:var(--navy); font-size:1.02rem; }
@media (max-width:820px){ .trust-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .trust-grid{ grid-template-columns:1fr; } }

/* logos band */
.logos{ padding:40px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.logos .lbl{ text-align:center; font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--slate); margin-bottom:24px; }
.logos-row{ display:flex; flex-wrap:wrap; gap:30px 56px; align-items:center; justify-content:center; }
.client-logo{ width:auto; opacity:.62; transition:opacity .28s var(--ease), transform .28s var(--ease); }
.client-logo:hover{ opacity:1; transform:translateY(-2px); }
@media (max-width:680px){ .logos-row{ gap:24px 36px; } .client-logo{ transform:scale(.86); } }

/* ============================================================
   CTA band
   ============================================================ */
.cta{ position:relative; overflow:hidden; background:linear-gradient(120deg, var(--navy-900), var(--navy) 60%, var(--navy-700)); color:#fff; }
.cta .container{ position:relative; z-index:2; text-align:center; }
.cta__chev{ position:absolute; left:-6%; bottom:-40%; width:40vw; max-width:560px; opacity:.5; z-index:1; pointer-events:none; }
.cta h2{ color:#fff; max-width:780px; margin:0 auto; }
.cta p{ color:rgba(255,255,255,.78); max-width:560px; margin:1em auto 2em; }
.cta__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,4vw,56px); }
.form{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-size:.84rem; font-weight:600; color:var(--navy); }
.field label .req{ color:var(--accent); }
.field input, .field select, .field textarea{
  font-family:inherit; font-size:1rem; padding:.8em .9em; border:1.5px solid var(--line-2); border-radius:8px;
  background:#fff; color:var(--ink); transition:border-color .2s, box-shadow .2s; width:100%; }
.field textarea{ resize:vertical; min-height:110px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--navy); box-shadow:0 0 0 4px rgba(22,26,90,.08); }
.form .actions{ grid-column:1/-1; display:flex; flex-wrap:wrap; gap:14px; align-items:center; margin-top:4px; }
.form .privacy{ font-size:.8rem; color:var(--slate); }
.form-note{ grid-column:1/-1; font-size:.86rem; padding:12px 16px; border-radius:8px; background:rgba(37,211,102,.12); color:#0a6b34; display:none; }
.form-note.show{ display:block; }

.contact-side{ display:flex; flex-direction:column; gap:18px; }
.contact-card{ background:var(--navy); color:#fff; border-radius:16px; padding:30px; }
.contact-card h3{ color:#fff; margin-bottom:18px; }
.contact-line{ display:flex; gap:14px; align-items:flex-start; padding:13px 0; border-top:1px solid rgba(255,255,255,.12); }
.contact-line:first-of-type{ border-top:none; }
.contact-line .ic{ width:40px; height:40px; border-radius:10px; background:rgba(255,255,255,.08); color:var(--accent); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.contact-line .meta b{ display:block; font-size:.7rem; font-family:var(--ff-mono); letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.55); font-weight:600; margin-bottom:3px; }
.contact-line .meta span{ font-weight:600; font-size:1rem; }
.contact-map{ flex:1; min-height:180px; border-radius:16px; }
@media (max-width:820px){ .contact-grid{ grid-template-columns:1fr; } .form{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .form{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy-900); color:rgba(255,255,255,.7); padding:70px 0 30px; }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer .f-brand img{ height:42px; margin-bottom:18px; }
.footer .f-brand p{ font-size:.92rem; max-width:300px; }
.footer h5{ color:#fff; font-family:var(--ff-display); font-size:.95rem; letter-spacing:.02em; margin:0 0 16px; text-transform:uppercase; }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.footer ul a{ font-size:.92rem; color:rgba(255,255,255,.7); transition:color .2s, padding .2s; }
.footer ul a:hover{ color:#fff; padding-left:5px; }
.footer .socials{ display:flex; gap:10px; margin-top:16px; }
.footer .socials a{ width:38px; height:38px; border-radius:9px; background:rgba(255,255,255,.07); display:flex; align-items:center; justify-content:center; color:#fff; transition:background .25s; }
.footer .socials a:hover{ background:var(--accent); }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; padding-top:24px; font-size:.84rem; }
.footer-bottom a{ color:rgba(255,255,255,.7); } .footer-bottom a:hover{ color:#fff; }
@media (max-width:820px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .footer-top{ grid-template-columns:1fr; gap:30px; } }

/* ============================================================
   Floating WhatsApp
   ============================================================ */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:80; display:flex; align-items:center; gap:0; }
.wa-float a{ display:flex; align-items:center; gap:10px; background:#25D366; color:#fff; font-weight:700; text-decoration:none;
  padding:14px; border-radius:50px; box-shadow:0 10px 30px rgba(37,211,102,.4); transition:transform .3s var(--ease), padding .3s; }
.wa-float a .txt{ max-width:0; overflow:hidden; white-space:nowrap; transition:max-width .35s var(--ease), margin .35s; font-size:.95rem; }
.wa-float a:hover{ transform:scale(1.04); }
.wa-float a:hover .txt{ max-width:170px; margin-right:4px; }
.wa-float a svg{ flex:0 0 auto; }
@media (max-width:520px){ .wa-float{ right:16px; bottom:16px; } }

/* small util */
.tag-line{ display:inline-flex; align-items:center; gap:8px; }
.split-stat{ font-family:var(--ff-display); font-weight:800; color:var(--accent); }
