/* ============================================================
   GAÚCHO MOLAS DE CAXIAS — Site
   Identidade: Pantone 7547 C (azul-marinho) + Pantone 9064 C (bege)
   Tipografia de marca: Matrice Extra Bold → substituta web: Archivo
   ============================================================ */

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ---------- Tokens ---------- */
:root{
  --navy:#14202E;        /* Pantone 7547 C aprox. */
  --navy-2:#1C2E42;
  --navy-3:#0E1825;
  --cream:#F6EED6;       /* Pantone 9064 C aprox. */
  --cream-2:#FBF6E6;
  --paper:#FFFFFF;
  --line:#E6DCBE;
  --line-dark:rgba(246,238,214,.16);
  --ink:#14202E;
  --muted:#5C6A79;
  --muted-on-dark:#AEB9C6;
  --wa:#25D366;
  --maxw:1180px;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 18px 40px -22px rgba(20,32,46,.45);
  --shadow-soft:0 10px 30px -18px rgba(20,32,46,.35);
  --font-display:'Archivo', system-ui, sans-serif;
  --font-body:'Archivo', system-ui, sans-serif;
}

/* ---------- Base ---------- */
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream-2);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ font-family:var(--font-display); line-height:1.08; letter-spacing:-.01em; }
h1{ font-weight:800; font-size:clamp(2.1rem,5.2vw,4rem); }
h2{ font-weight:800; font-size:clamp(1.7rem,3.6vw,2.7rem); }
h3{ font-weight:700; font-size:1.25rem; }
.eyebrow{
  font-family:var(--font-display);
  font-weight:700; text-transform:uppercase;
  letter-spacing:.18em; font-size:.78rem;
  color:#9A7B33;
  display:inline-flex; align-items:center; gap:.55rem;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:currentColor; display:inline-block; }
.eyebrow.center{ justify-content:center; }
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
section{ padding:84px 0; }
.lead{ font-size:1.12rem; color:var(--muted); max-width:62ch; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-display); font-weight:700;
  font-size:.95rem; letter-spacing:.01em;
  padding:14px 26px; border-radius:50px; border:2px solid transparent;
  cursor:pointer; transition:transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--navy); color:var(--cream); }
.btn-primary:hover{ background:var(--navy-3); transform:translateY(-2px); box-shadow:var(--shadow-soft); }
.btn-cream{ background:var(--cream); color:var(--navy); }
.btn-cream:hover{ background:#fff; transform:translateY(-2px); }
.btn-outline{ border-color:var(--navy); color:var(--navy); background:transparent; }
.btn-outline:hover{ background:var(--navy); color:var(--cream); transform:translateY(-2px); }
.btn-outline-cream{ border-color:var(--cream); color:var(--cream); background:transparent; }
.btn-outline-cream:hover{ background:var(--cream); color:var(--navy); }
.btn-wa{ background:var(--wa); color:#fff; }
.btn-wa:hover{ background:#1ebe5a; transform:translateY(-2px); box-shadow:var(--shadow-soft); }

/* ---------- Header ---------- */
.topbar{
  background:var(--navy-3); color:var(--cream);
  font-size:.85rem; letter-spacing:.01em;
}
.topbar .container{ display:flex; flex-wrap:wrap; gap:8px 24px; justify-content:space-between; align-items:center; padding-top:9px; padding-bottom:9px; }
.topbar a{ display:inline-flex; align-items:center; gap:.45rem; color:var(--cream); opacity:.9; }
.topbar a:hover{ opacity:1; }
.topbar .tb-group{ display:flex; flex-wrap:wrap; gap:6px 22px; align-items:center; }
.topbar svg{ width:15px; height:15px; opacity:.85; }

.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,246,230,.92);
  backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding:14px 0; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:46px; width:auto; }
.brand .brand-txt{ font-family:var(--font-display); font-weight:800; line-height:1; color:var(--navy); }
.brand .brand-txt span{ display:block; font-size:1.02rem; letter-spacing:-.01em; }
.brand .brand-txt small{ font-weight:600; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:#9A7B33; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-family:var(--font-display); font-weight:600; font-size:.95rem;
  padding:9px 14px; border-radius:50px; color:var(--navy); transition:background .2s, color .2s;
}
.nav-links a:hover{ background:var(--cream); }
.nav-links a.active{ background:var(--navy); color:var(--cream); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:6px; }
.nav-toggle span{ display:block; width:26px; height:2.5px; background:var(--navy); margin:5px 0; border-radius:2px; transition:.25s; }

/* ---------- Hero ---------- */
.hero{
  position:relative; color:var(--cream);
  background:var(--navy-3);
  overflow:hidden;
}
.hero .hero-bg{
  position:absolute; inset:0; z-index:0;
  background-size:cover; background-position:center;
  opacity:.32;
}
.hero::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(100deg, rgba(14,24,37,.96) 0%, rgba(14,24,37,.82) 42%, rgba(14,24,37,.45) 100%);
}
.hero .container{ position:relative; z-index:2; }
.hero-inner{ padding:96px 0 104px; max-width:730px; }
.hero h1{ color:var(--cream); margin:18px 0 0; }
.hero h1 em{ font-style:normal; color:#E9C877; }
.hero p{ margin:22px 0 32px; font-size:1.18rem; color:#DCE3EC; max-width:56ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; }
.hero-badges{ display:flex; flex-wrap:wrap; gap:10px 26px; margin-top:40px; padding-top:28px; border-top:1px solid var(--line-dark); }
.hero-badges li{ display:flex; align-items:center; gap:10px; font-weight:600; font-size:.95rem; color:#E7EDF4; }
.hero-badges svg{ width:22px; height:22px; color:#E9C877; flex:none; }

/* ---------- Quick service strip ---------- */
.quickbar{ background:var(--navy); color:var(--cream); padding:0; }
.quickbar .container{ display:grid; grid-template-columns:repeat(3,1fr); }
.quickbar .qb{ display:flex; gap:14px; align-items:flex-start; padding:30px 26px; border-right:1px solid var(--line-dark); }
.quickbar .qb:last-child{ border-right:0; }
.quickbar .qb svg{ width:30px; height:30px; color:#E9C877; flex:none; margin-top:3px; }
.quickbar .qb h3{ color:var(--cream); font-size:1.05rem; margin-bottom:3px; }
.quickbar .qb p{ font-size:.9rem; color:var(--muted-on-dark); }

/* ---------- Section heading ---------- */
.sec-head{ max-width:640px; margin-bottom:46px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head h2{ margin:14px 0 14px; }

/* ---------- Service cards ---------- */
.grid{ display:grid; gap:22px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:var(--paper); border:1px solid var(--line);
  border-radius:var(--radius); padding:30px 26px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:#D9CCA6; }
.card .ico{
  width:58px; height:58px; border-radius:14px;
  background:var(--cream); display:grid; place-items:center; margin-bottom:18px;
}
.card .ico svg{ width:30px; height:30px; color:var(--navy); }
.card h3{ color:var(--navy); margin-bottom:8px; }
.card p{ color:var(--muted); font-size:.98rem; }

/* ---------- Feature / why-us ---------- */
.feature{ background:var(--cream); }
.feature .grid-3 .card{ background:var(--paper); }

/* ---------- Split (image + text) ---------- */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:54px; align-items:center; }
.split .media{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.split .media img{ width:100%; height:100%; object-fit:cover; }
.split.reverse .media{ order:2; }
.split ul.checks{ margin-top:22px; display:grid; gap:12px; }
.split ul.checks li{ display:flex; gap:12px; align-items:flex-start; font-weight:500; }
.split ul.checks svg{ width:22px; height:22px; color:#9A7B33; flex:none; margin-top:3px; }

/* ---------- Stats ---------- */
.stats{ background:var(--navy); color:var(--cream); }
.stats .grid-4{ gap:20px; text-align:center; }
.stats .stat .num{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.2rem,4vw,3.2rem); color:#E9C877; line-height:1; }
.stats .stat p{ margin-top:8px; color:var(--muted-on-dark); font-weight:500; }

/* ---------- Brands strip ---------- */
.brands{ background:var(--cream-2); }
.brands .logos{ display:flex; flex-wrap:wrap; gap:18px; justify-content:center; }
.brands .logos span{
  font-family:var(--font-display); font-weight:800; letter-spacing:.02em;
  color:var(--navy); background:var(--paper); border:1px solid var(--line);
  padding:16px 26px; border-radius:12px; font-size:1.05rem;
}

/* ---------- CTA band ---------- */
.cta{ background:linear-gradient(120deg,var(--navy-3),var(--navy-2)); color:var(--cream); border-radius:0; }
.cta .container{ text-align:center; }
.cta h2{ color:var(--cream); }
.cta p{ color:#DCE3EC; max-width:58ch; margin:14px auto 28px; font-size:1.1rem; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Page hero (interior pages) ---------- */
.page-hero{ background:var(--navy-3); color:var(--cream); position:relative; overflow:hidden; }
.page-hero::before{
  content:""; position:absolute; right:-60px; top:-60px; width:380px; height:380px;
  background:radial-gradient(circle,rgba(233,200,119,.16),transparent 70%);
}
.page-hero .container{ position:relative; padding:70px 24px 64px; }
.page-hero h1{ color:var(--cream); margin:14px 0 12px; }
.page-hero p{ color:#DCE3EC; max-width:60ch; }
.crumbs{ font-size:.85rem; color:var(--muted-on-dark); }
.crumbs a:hover{ color:var(--cream); }

/* ---------- Map ---------- */
.map-wrap{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-soft); min-height:380px; }
.map-wrap iframe{ width:100%; height:100%; min-height:420px; border:0; display:block; }

/* ---------- Info cards (contato) ---------- */
.info-card{ display:flex; gap:16px; align-items:flex-start; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }
.info-card .ico{ width:48px; height:48px; border-radius:12px; background:var(--cream); display:grid; place-items:center; flex:none; }
.info-card .ico svg{ width:24px; height:24px; color:var(--navy); }
.info-card h3{ color:var(--navy); font-size:1.05rem; margin-bottom:4px; }
.info-card p, .info-card a{ color:var(--muted); font-size:.98rem; }
.info-card a:hover{ color:var(--navy); }

/* ---------- Form ---------- */
.form{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-family:var(--font-display); font-weight:600; font-size:.85rem; margin-bottom:6px; color:var(--navy); }
.field input, .field select, .field textarea{
  width:100%; padding:13px 14px; border:1.5px solid var(--line); border-radius:10px;
  font-family:var(--font-body); font-size:1rem; background:var(--cream-2); color:var(--ink);
  transition:border-color .2s, background .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--navy); background:#fff; }
.field textarea{ resize:vertical; min-height:120px; }

/* ---------- Products ---------- */
.prod{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:26px; transition:transform .18s, box-shadow .18s; }
.prod:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.prod .ico{ width:54px;height:54px;border-radius:14px;background:var(--cream);display:grid;place-items:center;margin-bottom:16px; }
.prod .ico svg{ width:28px;height:28px;color:var(--navy); }
.prod h3{ color:var(--navy); font-size:1.1rem; margin-bottom:8px; }
.prod ul{ display:grid; gap:7px; }
.prod ul li{ display:flex; gap:9px; align-items:flex-start; color:var(--muted); font-size:.95rem; }
.prod ul li::before{ content:""; width:7px;height:7px;border-radius:2px;background:#9A7B33;margin-top:9px;flex:none; }

/* ---------- Steps ---------- */
.steps{ counter-reset:step; display:grid; gap:22px; }
.step{ display:flex; gap:18px; align-items:flex-start; }
.step .n{ counter-increment:step; flex:none; width:46px;height:46px;border-radius:50%;background:var(--navy);color:var(--cream);display:grid;place-items:center;font-family:var(--font-display);font-weight:800; }
.step .n::before{ content:counter(step); }
.step h3{ color:var(--navy); font-size:1.1rem; margin-bottom:4px; }
.step p{ color:var(--muted); font-size:.97rem; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-3); color:var(--cream); padding:64px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.site-footer img.flogo{ height:84px; width:auto; margin-bottom:16px; }
.site-footer p{ color:var(--muted-on-dark); font-size:.95rem; }
.site-footer h4{ font-family:var(--font-display); font-weight:700; font-size:.85rem; letter-spacing:.14em; text-transform:uppercase; color:#E9C877; margin-bottom:16px; }
.site-footer ul li{ margin-bottom:10px; }
.site-footer ul a, .site-footer .fcontact div{ color:var(--muted-on-dark); font-size:.95rem; }
.site-footer ul a:hover{ color:var(--cream); }
.fcontact div{ display:flex; gap:10px; align-items:flex-start; margin-bottom:12px; }
.fcontact svg{ width:18px;height:18px;color:#E9C877;flex:none;margin-top:3px; }
.fsocial{ display:flex; gap:10px; margin-top:6px; }
.fsocial a{ width:40px;height:40px;border-radius:50%;border:1px solid var(--line-dark);display:grid;place-items:center;transition:.2s; }
.fsocial a:hover{ background:var(--cream); color:var(--navy); }
.fsocial svg{ width:18px;height:18px; }
.footer-bottom{ border-top:1px solid var(--line-dark); margin-top:48px; padding:22px 0; font-size:.85rem; color:var(--muted-on-dark); }
.footer-bottom .container{ display:flex; flex-wrap:wrap; gap:8px 20px; justify-content:space-between; align-items:center; }

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:80;
  width:62px; height:62px; border-radius:50%;
  background:var(--wa); color:#fff; display:grid; place-items:center;
  box-shadow:0 12px 28px -8px rgba(37,211,102,.65);
  transition:transform .2s; animation:wapulse 2.6s infinite;
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:34px; height:34px; }
@keyframes wapulse{ 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.45);} 70%{ box-shadow:0 0 0 16px rgba(37,211,102,0);} 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0);} }

/* ---------- Reveal anim ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
  .quickbar .container{ grid-template-columns:1fr; }
  .quickbar .qb{ border-right:0; border-bottom:1px solid var(--line-dark); }
  .quickbar .qb:last-child{ border-bottom:0; }
  .split{ grid-template-columns:1fr; gap:30px; }
  .split.reverse .media{ order:0; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:760px){
  section{ padding:60px 0; }
  .nav-links, .nav-cta .btn{ display:none; }
  .nav-toggle{ display:block; }
  .nav-links.open{
    display:flex; flex-direction:column; align-items:stretch;
    position:absolute; top:100%; left:0; right:0;
    background:var(--cream-2); border-bottom:1px solid var(--line);
    padding:14px 20px; gap:4px; box-shadow:var(--shadow-soft);
  }
  .site-header{ position:sticky; }
  .nav{ position:relative; }
  .grid-3,.grid-4,.grid-2,.form .row{ grid-template-columns:1fr; }
  .hero-inner{ padding:70px 0 76px; }
  .footer-grid{ grid-template-columns:1fr; }
  .topbar{ display:none; }
}
