/* ============================================================
   REFORCEL — PREMIUM DIRECTION
   Same Archivo + brand colors, elevated to a modern, premium feel.
   Pulls base tokens from ../../colors_and_type.css, then refines.
   ============================================================ */

:root{
  /* Deeper, richer navies for a premium dark canvas */
  --navy-1:#0A1A38;   /* deepest — page base on dark */
  --navy-2:#0E2147;   /* card / panel on dark */
  --navy-3:#16305E;   /* raised panel */
  --hair:rgba(255,255,255,.10);   /* hairline on dark */
  --hair-strong:rgba(255,255,255,.18);
  --ink-soft:#AFC0DE;  /* secondary text on dark */
  --ink-faint:#7F93B8;

  --paper:#F4F6FA;     /* premium light section */
  --paper-ink:#0A1A38;
  --paper-soft:#5A6B86;

  --grad-energy:linear-gradient(90deg,var(--brand-red),var(--brand-orange));
  --maxw:1240px;
  --gut:clamp(20px,4vw,56px);
}

*{box-sizing:border-box}
html{scroll-behavior:auto}
html,body{margin:0}
body{
  font-family:var(--font-body);
  background:var(--navy-1);
  color:#fff;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.shell{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}

/* ---------- speed-stripe motif (from logo checkered flag) ---------- */
.stripe{
  display:inline-block;width:34px;height:10px;
  background:
    repeating-linear-gradient(135deg,var(--brand-red) 0 4px,transparent 4px 8px) 0 0/100% 50% no-repeat,
    repeating-linear-gradient(135deg,var(--brand-orange) 0 4px,transparent 4px 8px) 0 100%/100% 50% no-repeat;
  flex:0 0 auto;
}

/* ---------- kicker / eyebrow ---------- */
.kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-weight:700;font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brand-orange);
}
.kicker.on-light{color:var(--brand-red)}
.kicker .ln{width:30px;height:2px;background:currentColor;display:inline-block}

/* ---------- display type ---------- */
.h-xl{font-family:var(--font-display);font-weight:900;text-transform:uppercase;
  letter-spacing:-.025em;line-height:.94;font-size:clamp(44px,7vw,104px);}
.h-lg{font-family:var(--font-display);font-weight:900;text-transform:uppercase;
  letter-spacing:-.02em;line-height:.98;font-size:clamp(34px,4.6vw,64px);}
.h-md{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;
  line-height:1.04;font-size:clamp(26px,2.8vw,40px);}
.lede{font-size:clamp(16px,1.4vw,19px);line-height:1.6;color:var(--ink-soft);max-width:54ch}
.tabnum{font-variant-numeric:tabular-nums}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);
  font-weight:700;font-size:15px;border:none;border-radius:999px;padding:15px 28px;
  cursor:pointer;transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s,color .18s;}
.btn svg{width:18px;height:18px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand-green);color:#fff;box-shadow:0 10px 30px rgba(0,172,24,.32)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,172,24,.42)}
.btn-orange{background:var(--brand-orange);color:#fff;box-shadow:0 10px 30px rgba(243,129,32,.3)}
.btn-orange:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1.5px var(--hair-strong)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px #fff;background:rgba(255,255,255,.06)}
.btn-ghost.on-light{color:var(--paper-ink);box-shadow:inset 0 0 0 1.5px rgba(10,26,56,.2)}
.btn-ghost.on-light:hover{box-shadow:inset 0 0 0 1.5px var(--brand-blue)}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,backdrop-filter .3s,border-color .3s,padding .3s;
  border-bottom:1px solid transparent;padding:18px 0}
.nav.scrolled{background:rgba(10,26,56,.82);backdrop-filter:blur(14px);border-bottom-color:var(--hair);padding:12px 0}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);display:flex;align-items:center;gap:28px}
.nav .logo{flex-shrink:1;min-width:0}
.nav .logo img{display:block;height:auto;width:auto;max-height:38px;max-width:100%;aspect-ratio:760/130}
.nav-links{display:flex;gap:30px;margin-left:auto}
.nav-links a{font-size:14px;font-weight:600;color:var(--ink-soft);letter-spacing:.01em;transition:color .15s;position:relative}
.nav-links a:hover{color:#fff}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--brand-orange);transition:right .25s var(--ease)}
.nav-links a:hover::after{right:0}
.nav .btn{padding:11px 20px;font-size:14px}
.nav-cta{margin-left:6px;flex-shrink:0}
.burger{display:none;margin-left:auto;background:none;border:none;color:#fff;cursor:pointer}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,26,56,.55) 0%,rgba(10,26,56,.42) 40%,rgba(10,26,56,.92) 95%),
            linear-gradient(90deg,rgba(10,26,56,.78),transparent 62%)}
.hero-inner{position:relative;width:100%;padding-top:128px;padding-bottom:56px}
.hero .kicker{margin-bottom:24px}
.hero h1{margin:0 0 26px;max-width:16ch}
.hero h1 em{font-style:normal;color:var(--brand-orange)}
.hero .lede{margin-bottom:36px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* hero stat rail */
.statrail{margin-top:clamp(40px,6vh,72px);display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:16px;overflow:hidden}
.statrail .cell{background:rgba(10,26,56,.55);backdrop-filter:blur(6px);padding:22px 24px}
.statrail .num{font-family:var(--font-display);font-weight:900;font-size:clamp(28px,3vw,40px);line-height:1;letter-spacing:-.02em}
.statrail .num .u{color:var(--brand-orange)}
.statrail .lab{margin-top:8px;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink-faint);text-transform:uppercase}

/* ---------- MARQUEE category strip ---------- */
.marquee{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:var(--navy-2);overflow:hidden;padding:18px 0}
.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:scrollx 32s linear infinite;width:max-content}
.marquee-track span{display:inline-flex;align-items:center;gap:48px;font-family:var(--font-display);font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;font-size:18px;color:var(--ink-soft)}
.marquee .dot{color:var(--brand-red);font-size:12px}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- SECTION scaffolding ---------- */
.section{padding:clamp(72px,11vh,140px) 0}
.section.light{background:#fff;color:var(--paper-ink)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:clamp(40px,6vh,68px);flex-wrap:wrap}
.sec-head .t{max-width:clamp(300px,44vw,560px)}
.sec-head .t h2{margin:18px 0 0}
.sec-head .d{max-width:40ch;color:var(--paper-soft);font-size:16px;line-height:1.6}
.section:not(.light) .sec-head .d{color:var(--ink-soft)}

/* ---------- BENTO product grid ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;grid-auto-rows:230px}
.tile{position:relative;border-radius:20px;overflow:hidden;display:block;isolation:isolate;
  box-shadow:0 18px 44px rgba(10,26,56,.16)}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.tile::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,26,56,.05) 0%,rgba(10,26,56,.18) 45%,rgba(10,26,56,.9) 100%)}
.tile:hover img{transform:scale(1.07)}
.tile .body{position:absolute;inset:0;z-index:2;padding:24px;display:flex;flex-direction:column;justify-content:flex-end}
.tile .cat{position:absolute;top:22px;left:24px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:.85}
.tile h3{font-family:var(--font-display);font-weight:800;letter-spacing:-.01em;font-size:23px;line-height:1.05;margin:0 0 6px;color:#fff}
.tile p{margin:0;font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.8);max-width:34ch;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .4s var(--ease),opacity .3s,margin .4s}
.tile:hover p{max-height:80px;opacity:1;margin-top:4px}
.tile .arrow{position:absolute;top:20px;right:22px;width:40px;height:40px;border-radius:999px;
  background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .25s var(--ease)}
.tile .arrow svg{width:18px;height:18px;color:#fff;transition:transform .25s var(--ease)}
.tile:hover .arrow{background:var(--brand-orange)}
.tile:hover .arrow svg{transform:translate(2px,-2px)}
.tile.feature{grid-column:span 2;grid-row:span 2}
.tile.feature h3{font-size:34px}
.tile.wide{grid-column:span 2}

/* ---------- PILLARS (why) ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hair);
  border:1px solid var(--hair);border-radius:20px;overflow:hidden;margin-top:46px}
.pillar{background:var(--navy-1);padding:38px 34px;transition:background .3s}
.pillar:hover{background:var(--navy-2)}
.pillar .pn{font-family:var(--font-display);font-weight:900;font-size:15px;
  letter-spacing:.05em;background:var(--grad-energy);-webkit-background-clip:text;background-clip:text;color:transparent}
.pillar h4{font-family:var(--font-display);font-weight:800;font-size:22px;margin:18px 0 12px;line-height:1.12;color:#fff}
.pillar p{margin:0;font-size:14.5px;line-height:1.62;color:var(--ink-soft)}
/* pillars on light background — keep navy style unchanged */

.why{position:relative}
.why .frame{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.45);margin-bottom:8px}
.why .frame img{width:100%;height:clamp(280px,46vh,520px);object-fit:cover}
.why .frame .tagline{position:absolute;left:0;bottom:0;right:0;padding:40px;
  background:linear-gradient(0deg,rgba(10,26,56,.92),transparent);
  font-family:var(--font-display);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;
  font-size:clamp(22px,3vw,40px);line-height:1.02;max-width:18ch}

/* storefront divider between "por que nós" and contato */
.storefront-divider{position:relative;overflow:hidden}
.storefront-divider img{display:block;width:100%;height:clamp(300px,48vh,540px);object-fit:cover;object-position:center 30%}
.storefront-divider::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,26,56,.18) 0%,rgba(10,26,56,.72) 100%)}
.storefront-divider .tagline{
  position:absolute;left:0;bottom:0;right:0;z-index:2;
  padding:clamp(32px,5vw,60px);
  background:linear-gradient(0deg,rgba(10,26,56,.88),transparent);
  font-family:var(--font-display);font-weight:900;text-transform:uppercase;
  letter-spacing:-.025em;line-height:1.02;
  font-size:clamp(28px,3.8vw,56px);
  max-width:22ch;
  color:#fff;
}
.storefront-divider .tagline em{font-style:normal;color:var(--brand-orange)}
.why .frame .tagline em{font-style:normal;color:var(--brand-orange)}

/* ---------- STORES ---------- */
.stores-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.store{background:var(--navy-2);border:1px solid var(--hair);border-radius:18px;padding:30px 28px;
  transition:transform .22s var(--ease),border-color .22s}
.store:hover{transform:translateY(-4px);border-color:var(--hair-strong)}
.store .badge{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-orange)}
.store h4{font-family:var(--font-display);font-weight:800;font-size:22px;margin:12px 0 14px}
.store .addr{font-size:14px;line-height:1.6;color:var(--ink-soft);margin:0 0 22px;min-height:66px}
.store .phones{display:flex;flex-direction:column;gap:10px}
.store .ph{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:14.5px;color:#fff}
.store .ph svg{width:17px;height:17px;color:var(--brand-green)}
.store .ph:hover{color:var(--brand-orange)}
/* stores on light background */
.section.light .store{background:#fff;border-color:var(--gray-200);box-shadow:0 8px 24px rgba(10,26,56,.07)}
.section.light .store:hover{border-color:var(--brand-blue);box-shadow:0 16px 40px rgba(10,26,56,.12)}
.section.light .store h4{color:var(--paper-ink)}
.section.light .store .addr{color:var(--paper-soft)}
.section.light .store .ph{color:var(--paper-ink)}
.section.light .store .ph:hover{color:var(--brand-blue)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--brand-blue);border-radius:28px;
  padding:clamp(48px,8vw,86px);text-align:center;margin:0 auto}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(120% 140% at 50% -20%,rgba(243,129,32,.35),transparent 55%)}
.cta-band .inner{position:relative}
.cta-band h2{margin:0 auto 18px;max-width:18ch}
.cta-band p{color:var(--ink-soft);font-size:17px;margin:0 auto 34px;max-width:46ch}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- CONTACT UNIFIED (lojas + fale conosco) ---------- */
.contact-unified{
  background:var(--brand-blue);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.contact-unified::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(130% 120% at 80% -10%,rgba(243,129,32,.22),transparent 55%),
             radial-gradient(80% 80% at -10% 110%,rgba(255,255,255,.06),transparent 60%);
}
.contact-unified .shell{position:relative}

/* CTA hero */
.contact-hero{margin-bottom:clamp(48px,7vh,80px)}
.contact-copy h2{margin:18px 0 16px;max-width:20ch}
.contact-copy p{color:var(--ink-soft);font-size:17px;line-height:1.62;max-width:48ch}

/* divisor */
.contact-divider{
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.14);
  padding-top:clamp(40px,5vh,60px);
  margin-bottom:clamp(32px,4vh,48px);
}
.contact-divider .kicker{flex:0 0 auto}
.contact-divider p{margin:0;color:var(--ink-soft);font-size:15px;line-height:1.5}

/* stores on blue bg */
.contact-unified .store{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.14);
}
.contact-unified .store:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.28);
  transform:translateY(-4px);
}
.contact-unified .store h4{color:#fff}
.contact-unified .store .addr{color:var(--ink-soft)}
.contact-unified .store .ph{color:#fff}
.contact-unified .store .ph:hover{color:var(--brand-orange)}
/* mapa Google por loja */
.store-map{margin-top:22px;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.16);line-height:0}
.store-map iframe{width:100%;height:180px;border:0;display:block}

/* ---------- FOOTER ---------- */
.footer{background:var(--navy-1);border-top:1px solid var(--hair);padding:64px 0 40px}
.footer-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:48px}
.footer .logo img{display:block;height:auto;width:auto;max-height:42px;max-width:100%;margin-bottom:18px;aspect-ratio:760/130}
.footer .blurb{color:var(--ink-faint);font-size:14px;line-height:1.6;max-width:34ch}
.footer-cols{display:flex;gap:64px;flex-wrap:wrap}
.footer-cols h5{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 16px;font-weight:700}
.footer-cols a{display:block;color:var(--ink-soft);font-size:14.5px;margin-bottom:11px;transition:color .15s}
.footer-cols a:hover{color:#fff}
.footer-bottom{border-top:1px solid var(--hair);padding-top:26px;display:flex;justify-content:space-between;
  gap:16px;flex-wrap:wrap;color:var(--ink-faint);font-size:13px}

/* ---------- reveal anim (progressive-enhancement: visible by default) ---------- */
.reveal{transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js-ready .reveal{opacity:0;transform:translateY(26px)}
html.js-ready .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html.js-ready .reveal{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  .hero-media img{transform:none}
}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .nav-links{display:none}
  .nav-inner{gap:12px}
  .nav .btn{padding:9px 16px;font-size:13px}
  .bento{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .tile.feature{grid-column:span 2;grid-row:span 2}
  .pillars{grid-template-columns:1fr}
  .stores-grid{grid-template-columns:1fr}
  .statrail{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .bento{grid-template-columns:1fr;grid-auto-rows:210px}
  .tile.feature,.tile.wide{grid-column:span 1}
  .tile.feature{grid-row:span 1}
  .tile p{max-height:none;opacity:1;margin-top:4px}
  .sec-head{flex-direction:column;align-items:flex-start}
}

/* ---------- ORÇAMENTO MODAL ---------- */
.orc-overlay{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(10,26,56,.72);backdrop-filter:blur(6px);
  opacity:0;transition:opacity .22s var(--ease);
}
.orc-overlay.open{opacity:1}
.orc-overlay[hidden]{display:none}
.orc-modal{
  position:relative;width:100%;max-width:440px;
  background:#fff;color:var(--paper-ink);border-radius:22px;
  padding:clamp(28px,4vw,40px);box-shadow:0 40px 90px rgba(0,0,0,.45);
  transform:translateY(16px) scale(.98);transition:transform .26s var(--ease);
}
.orc-overlay.open .orc-modal{transform:none}
.orc-close{
  position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:999px;
  border:none;cursor:pointer;background:var(--gray-100);color:var(--gray-600);
  font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;
}
.orc-close:hover{background:var(--gray-200);color:var(--paper-ink)}
.orc-kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brand-red);margin-bottom:14px;
}
.orc-kicker .ln{width:26px;height:2px;background:currentColor;display:inline-block}
.orc-modal h3{
  font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;
  font-size:clamp(24px,3vw,30px);line-height:1.05;margin:0 0 8px;color:var(--paper-ink);
}
.orc-sub{margin:0 0 24px;font-size:14.5px;line-height:1.55;color:var(--paper-soft)}
.orc-label{
  display:block;font-size:12.5px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--gray-600);margin:0 0 8px;
}
.orc-field{position:relative;margin-bottom:20px}
.orc-field::after{
  content:"";position:absolute;right:18px;top:50%;width:9px;height:9px;
  border-right:2px solid var(--gray-500);border-bottom:2px solid var(--gray-500);
  transform:translateY(-65%) rotate(45deg);pointer-events:none;
}
.orc-field select{
  width:100%;appearance:none;-webkit-appearance:none;
  font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--paper-ink);
  background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:12px;
  padding:14px 44px 14px 16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;
}
.orc-field select:focus{
  outline:none;border-color:var(--brand-blue);box-shadow:0 0 0 3px rgba(34,70,130,.14);
}
.orc-go{width:100%;justify-content:center;margin-top:6px}

/* ---------- BOTÃO FLUTUANTE WHATSAPP ---------- */
.wa-fab{
  position:fixed;right:22px;bottom:22px;z-index:150;
  width:60px;height:60px;border-radius:999px;border:none;cursor:pointer;
  background:var(--brand-green);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px rgba(0,172,24,.42);
  transition:transform .2s var(--ease),box-shadow .2s;
}
.wa-fab svg{width:32px;height:32px;position:relative}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 18px 44px rgba(0,172,24,.55)}
.wa-fab:active{transform:translateY(0) scale(1)}
.wa-fab::before{
  content:"";position:absolute;inset:0;border-radius:999px;
  background:var(--brand-green);z-index:-1;
  animation:waPulse 2.6s ease-out infinite;
}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.55}
  70%{transform:scale(1.7);opacity:0}
  100%{opacity:0}
}
@media (prefers-reduced-motion:reduce){.wa-fab::before{animation:none}}
@media (max-width:600px){.wa-fab{width:54px;height:54px;right:16px;bottom:16px}.wa-fab svg{width:28px;height:28px}}
