/* ===========================================================
   Mecânica Blau — Design System
   Rebrand: navy (Blau = azul) + signal amber. Honest, industrial.
   Fonts: Archivo (headings, technical grotesque) · Barlow (body)
   =========================================================== */

:root{
  /* Brand — padrão Blau: vermelho + preto + branco */
  /* (nomes --navy-* mantidos = superfícies escuras/carvão) */
  --navy-950:#0e0e0f;
  --navy-900:#161617;
  --navy-800:#212123;
  --navy-700:#2a2a2d;   /* carvão p/ ícones e texto sobre claro */
  --navy-600:#3a3a3e;

  /* (nomes --amber* mantidos = vermelho da marca) */
  --amber:#c8202e;      /* vermelho Blau */
  --amber-600:#a3141f;
  --amber-soft:#f7d4d7;

  --paper:#f5f5f6;     /* cinza claro neutro */
  --paper-2:#ebebed;
  --card:#ffffff;

  --wa:#1eae54;        /* WhatsApp green (functional brand) */
  --wa-600:#178f45;

  /* Ink / text */
  --ink:#161617;
  --ink-soft:#43434a;
  --muted:#6c6c74;
  --on-navy:#f3f3f4;
  --on-navy-soft:#b4b4bb;

  /* Lines */
  --line:#e3e3e6;          /* hairline cinza sobre claro */
  --line-navy:rgba(255,255,255,.12);

  /* Radii / shadow */
  --r-sm:8px;
  --r:12px;
  --r-lg:18px;
  --shadow:0 1px 2px rgba(20,20,22,.07), 0 8px 28px rgba(20,20,22,.10);
  --shadow-lg:0 2px 6px rgba(20,20,22,.09), 0 24px 60px rgba(20,20,22,.18);

  --maxw:1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:"Barlow",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-wrap:break-word;   /* herdado: e-mails/URLs longos quebram em vez de estourar */
}
img{ max-width:100%; display:block; }
iframe{ max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{
  font-family:"Archivo",system-ui,sans-serif;
  margin:0;
  line-height:1.04;
  letter-spacing:-0.02em;
  font-weight:800;
}
p{ margin:0; text-wrap:pretty; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:22px; }
.section{ padding:72px 0; }
.section-tight{ padding:48px 0; }

/* ---------- Accessibility: skip link + focus styles ---------- */
.skip-link{
  position:absolute; top:-100px; left:0; z-index:200;
  background:var(--navy-900); color:#fff;
  padding:14px 22px; font-family:"Archivo",sans-serif; font-weight:700;
  text-decoration:none; border-radius:0 0 8px 0;
  transition:top .2s ease;
}
.skip-link:focus{ top:0; outline:3px solid var(--amber); outline-offset:0; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
:where(a,button,details summary,.svc,.svc-link,.rel-card,.chip,.menu-btn,.close-btn,input,textarea):focus-visible{
  outline:2px solid var(--amber); outline-offset:3px; border-radius:4px;
}
.on-navy :where(a,button):focus-visible{ outline-color:#fff; }
.nav > a[aria-current="page"], .nav-item > a[aria-current="page"]{ color:var(--ink); }
.nav > a[aria-current="page"]::after, .nav-item > a[aria-current="page"]::after{ width:100%; }
.subnav a[aria-current="page"]{ color:var(--amber-600); background:rgba(200,32,46,.06); }
.mlink[aria-current="page"], .msub[aria-current="page"]{ color:var(--amber-600); }

/* eyebrow / kicker label */
.kicker{
  display:inline-flex; align-items:center; gap:9px;
  font-family:"Barlow",sans-serif; font-weight:700;
  text-transform:uppercase; letter-spacing:.14em;
  font-size:.72rem; color:var(--amber-600);
}
.kicker::before{ content:""; width:22px; height:2px; background:var(--amber); display:block; }
.on-navy .kicker{ color:var(--amber); }

.h-sec{ font-size:clamp(1.7rem,3.4vw,2.6rem); margin-top:14px; }
.lead{ font-size:1.12rem; color:var(--ink-soft); max-width:60ch; }
.on-navy .lead{ color:var(--on-navy-soft); }

/* ---------- Buttons ---------- */
.btn{
  --bh:54px;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  min-height:var(--bh); padding:0 22px;
  border-radius:var(--r-sm); border:2px solid transparent;
  font-family:"Archivo",sans-serif; font-weight:700; font-size:1rem;
  letter-spacing:.01em; cursor:pointer; white-space:nowrap;
  transition:transform .12s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.btn:active{ transform:translateY(1px); }
.btn svg{ width:20px; height:20px; flex:none; }
.btn-amber{ background:var(--amber); color:#fff; box-shadow:0 6px 18px rgba(200,32,46,.30); }
.btn-amber:hover{ background:var(--amber-600); color:#fff; }
.btn-wa{ background:var(--wa); color:#fff; box-shadow:0 6px 18px rgba(30,174,84,.30); }
.btn-wa:hover{ background:var(--wa-600); }
.btn-ghost{ background:transparent; color:var(--on-navy); border-color:var(--line-navy); }
.btn-ghost:hover{ border-color:var(--on-navy); }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-outline:hover{ border-color:var(--ink); }
.btn-sm{ --bh:44px; padding:0 16px; font-size:.95rem; }
.btn-block{ width:100%; }

/* ---------- Brand (logo PNG) ---------- */
.brand{ display:inline-flex; align-items:center; gap:0; }
.brand-logo{
  display:block;
  height:46px; width:auto;
  aspect-ratio: 1080 / 974;
  /* fallback PNG p/ navegadores sem image-set */
  background: center/contain no-repeat url("logo-vermelha.png");
  background-image: image-set(url("logo-vermelha.webp") type("image/webp"), url("logo-vermelha.png") type("image/png"));
}
.on-dark .brand-logo{
  background-image: url("logo-branca.png");
  background-image: image-set(url("logo-branca.webp") type("image/webp"), url("logo-branca.png") type("image/png"));
}
.brand:focus-visible{ outline:2px solid var(--amber); outline-offset:4px; border-radius:4px; }
.foot-about .brand-logo{ height:62px; margin-bottom:6px; }
.mobile-menu .mhead .brand-logo{ height:54px; }

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--navy-950); color:var(--on-navy-soft);
  font-size:.82rem; border-bottom:1px solid var(--line-navy);
}
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:38px; }
.topbar a{ color:var(--on-navy); font-weight:600; }
.topbar .tb-left{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.topbar .dot{ width:4px;height:4px;border-radius:50%;background:var(--on-navy-soft);opacity:.5; }
.status{ display:inline-flex; align-items:center; gap:7px; font-weight:700; }
.status .led{ width:8px; height:8px; border-radius:50%; background:#9aa7b4; box-shadow:0 0 0 0 rgba(0,0,0,0); }
.status.open .led{ background:#34d36b; box-shadow:0 0 0 4px rgba(52,211,107,.18); }
.status.open{ color:#7ee29a; }
.status.closed{ color:#f4b6b6; }
.status.closed .led{ background:#e36a6a; box-shadow:0 0 0 4px rgba(227,106,106,.16); }
.tb-right{ display:flex; align-items:center; gap:16px; }

/* ---------- Header ---------- */
.site-header{ position:sticky; top:0; z-index:50; background:rgba(246,243,236,.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; min-height:72px; gap:18px; }
.nav{ display:flex; align-items:center; gap:26px; }
.nav a{ font-weight:600; font-size:1rem; color:var(--ink-soft); }
.nav > a, .nav-item > a{ position:relative; padding:6px 0; display:inline-flex; align-items:center; gap:5px; }
.nav > a:hover, .nav-item > a:hover{ color:var(--ink); }
.nav > a::after, .nav-item > a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--amber); transition:width .18s ease; }
.nav > a:hover::after, .nav-item:hover > a::after{ width:100%; }
/* dropdown desktop */
.nav-item{ position:relative; display:inline-flex; align-items:center; }
.nav .caret{ width:13px; height:13px; opacity:.55; transition:transform .16s ease; }
.nav-item:hover .caret, .nav-item:focus-within .caret{ transform:rotate(180deg); }
.subnav{
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(8px);
  min-width:236px; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r); box-shadow:var(--shadow-lg); padding:8px;
  display:flex; flex-direction:column;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .16s ease, transform .16s ease, visibility .16s; z-index:60;
}
.subnav::before{ content:""; position:absolute; top:-14px; left:0; right:0; height:14px; }
.nav-item:hover .subnav, .nav-item:focus-within .subnav{ opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.subnav a{ padding:10px 14px; border-radius:8px; font-size:.95rem; font-weight:600; color:var(--ink-soft); white-space:nowrap; }
.subnav a:hover{ background:var(--paper-2); color:var(--ink); }
.subnav a::after{ display:none; }
.subnav .subnav-all{ color:var(--amber-600); font-weight:700; border-top:1px solid var(--line); margin-top:5px; padding-top:11px; }
.header-cta{ display:flex; align-items:center; gap:12px; }
.menu-btn{ display:none; width:46px; height:46px; border:1px solid var(--line); background:var(--card); border-radius:var(--r-sm); align-items:center; justify-content:center; cursor:pointer; }
.menu-btn svg{ width:24px; height:24px; }

/* ---------- Hero ---------- */
.hero{ background:var(--navy-900); color:var(--on-navy); position:relative; overflow:hidden; }
.hero::before{ /* faint engineering grid */
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(var(--line-navy) 1px,transparent 1px),linear-gradient(90deg,var(--line-navy) 1px,transparent 1px);
  background-size:46px 46px; mask-image:radial-gradient(120% 90% at 75% 10%,#000 30%,transparent 75%); opacity:.6;
}
.hero .wrap{ position:relative; display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; padding-top:64px; padding-bottom:64px; }
.hero h1{ font-size:clamp(2.2rem,5vw,4rem); letter-spacing:-0.03em; }
.hero h1 .accent{ color:var(--amber); }
.hero .lead{ margin-top:20px; font-size:1.18rem; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.hero-since{ display:inline-flex; align-items:center; gap:12px; margin-bottom:8px; }
.since-badge{
  font-family:"Archivo",sans-serif; font-weight:900; font-size:.78rem; letter-spacing:.1em;
  color:#fff; background:var(--amber); border-radius:100px; padding:6px 13px;
}

/* hero side panel */
.hero-panel{ background:var(--navy-800); border:1px solid var(--line-navy); border-radius:var(--r-lg); padding:8px; box-shadow:var(--shadow-lg); }
.hero-photo{ position:relative; border-radius:13px; overflow:hidden; aspect-ratio:4/3; }
.hero-panel .info{ padding:16px 14px 8px; }
.info-row{ display:flex; align-items:flex-start; gap:12px; padding:11px 0; border-top:1px solid var(--line-navy); }
.info-row:first-child{ border-top:0; }
.info-row svg{ width:20px; height:20px; color:var(--amber); flex:none; margin-top:2px; }
.info-row .k{ font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--on-navy-soft); font-weight:700; }
.info-row .v{ color:#fff; font-weight:600; }

/* photo placeholder treatment (branded, intentional) */
.ph{
  position:relative; background:
    radial-gradient(120% 120% at 80% 0%,rgba(200,32,46,.16),transparent 55%),
    linear-gradient(140deg,#26262a,#161617 70%);
  display:grid; place-items:center; color:var(--on-navy-soft);
  overflow:hidden;
}
.ph::before{ content:""; position:absolute; inset:0;
  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:28px 28px; }
.ph-inner{ position:relative; text-align:center; padding:18px; }
.ph-inner svg{ width:40px; height:40px; color:rgba(200,32,46,.85); margin-bottom:10px; }
.ph-inner .cap{ font-family:"Barlow",sans-serif; font-size:.78rem; font-weight:600; letter-spacing:.04em; color:var(--on-navy-soft); max-width:24ch; margin-inline:auto; }
.ph-tag{ position:absolute; left:10px; bottom:10px; z-index:2; font-family:"Barlow",sans-serif; font-size:.66rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#fff; background:var(--amber); padding:4px 8px; border-radius:5px; }

/* ---------- Trust strip ---------- */
.trust{ background:var(--paper-2); border-block:1px solid var(--line); }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.trust-item{ display:flex; flex-direction:column; gap:8px; }
.trust-item .ic{ width:42px; height:42px; border-radius:10px; background:var(--navy-900); color:var(--amber); display:grid; place-items:center; }
.trust-item .ic svg{ width:22px; height:22px; }
.trust-item h3{ font-size:1.12rem; }
.trust-item p{ font-size:.96rem; color:var(--ink-soft); }

/* ---------- Section header ---------- */
.sec-head{ max-width:62ch; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head.center .kicker{ justify-content:center; }

/* ---------- Services ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:40px; }
.svc{
  background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px 22px;
  display:flex; flex-direction:column; gap:12px; position:relative; overflow:hidden;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.svc::after{ content:""; position:absolute; left:0; top:0; width:100%; height:3px; background:var(--amber); transform:scaleX(0); transform-origin:left; transition:transform .2s ease; }
.svc:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:#cdc5b4; }
.svc:hover::after{ transform:scaleX(1); }
.svc .ic{ width:48px; height:48px; border-radius:11px; background:var(--paper); border:1px solid var(--line); color:var(--navy-700); display:grid; place-items:center; }
.svc .ic svg{ width:26px; height:26px; }
.svc h3{ font-size:1.18rem; }
.svc p{ font-size:.95rem; color:var(--ink-soft); }
.svc .more{ margin-top:auto; padding-top:6px; font-family:"Archivo",sans-serif; font-weight:700; font-size:.86rem; color:var(--navy-700); display:inline-flex; align-items:center; gap:6px; }
.svc .more svg{ width:16px; height:16px; transition:transform .15s ease; }
.svc:hover .more svg{ transform:translateX(3px); }

.note-auto{
  margin-top:26px; display:flex; gap:16px; align-items:flex-start;
  background:var(--card); border:1px solid var(--line); border-left:4px solid var(--amber);
  border-radius:var(--r); padding:20px 22px;
}
.note-auto svg{ width:26px; height:26px; color:var(--amber-600); flex:none; margin-top:2px; }
.note-auto strong{ color:var(--ink); }
.note-auto p{ color:var(--ink-soft); font-size:.98rem; }

/* ---------- About ---------- */
.about{ background:var(--navy-900); color:var(--on-navy); }
.about .wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:center; }
.about-photo{ border-radius:var(--r-lg); overflow:hidden; aspect-ratio:5/6; box-shadow:var(--shadow-lg); }
.about h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); }
.about p{ color:var(--on-navy-soft); margin-top:16px; font-size:1.06rem; }
.about p strong{ color:#fff; }
.stat-row{ display:flex; gap:34px; margin-top:30px; flex-wrap:wrap; }
.stat .n{ font-family:"Archivo",sans-serif; font-weight:900; font-size:2.4rem; color:var(--amber); line-height:1; }
.stat .l{ font-size:.86rem; color:var(--on-navy-soft); margin-top:6px; text-transform:uppercase; letter-spacing:.08em; font-weight:600; }

/* ---------- Áreas ---------- */
.areas .wrap{ }
.area-group{ margin-top:28px; }
.area-group h3{ font-size:1.05rem; display:flex; align-items:center; gap:10px; color:var(--ink); margin-bottom:14px; }
.area-group h3 .pin{ width:26px;height:26px;border-radius:7px;background:var(--navy-900);color:var(--amber);display:grid;place-items:center; }
.area-group h3 .pin svg{ width:15px;height:15px; }
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  display:inline-flex; align-items:center; gap:7px;
  background:var(--card); border:1px solid var(--line); border-radius:100px;
  padding:8px 15px; font-weight:600; font-size:.94rem; color:var(--ink-soft);
  transition:all .14s ease;
}
.chip:hover{ border-color:var(--navy-700); color:var(--ink); background:#fff; }
.chip.home{ background:var(--navy-900); color:#fff; border-color:var(--navy-900); }
.areas-cta{ margin-top:34px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* ---------- Reviews (Google) ---------- */
.reviews{ background:var(--paper-2); border-block:1px solid var(--line); }
.gpanel{
  background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:34px; display:grid; grid-template-columns:auto 1fr auto; gap:30px; align-items:center;
}
.gscore{ text-align:center; padding-right:30px; border-right:1px solid var(--line); }
.gscore .num{ font-family:"Archivo",sans-serif; font-weight:900; font-size:3.2rem; color:var(--ink); line-height:1; }
.stars{ display:inline-flex; gap:3px; margin-top:8px; }
.stars svg{ width:20px; height:20px; color:var(--amber); }
.gscore .src{ font-size:.82rem; color:var(--muted); margin-top:8px; }
.gtext h3{ font-size:1.4rem; }
.gtext p{ color:var(--ink-soft); margin-top:8px; font-size:1rem; }
.gnote{ font-size:.82rem; color:var(--muted); margin-top:10px; font-style:italic; }

/* ---------- Contato / mapa ---------- */
.contact .wrap{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:40px; align-items:stretch; }
.contact-card, .map-embed{ min-width:0; }
.contact-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); padding:32px; box-shadow:var(--shadow); }
.c-row{ display:flex; gap:14px; padding:16px 0; border-top:1px solid var(--line); }
/* deixa o conteúdo (e-mail/endereço) encolher e quebrar dentro do flex em vez de estourar */
.c-row > *, .info-row > *{ min-width:0; }
.c-row:first-of-type{ border-top:0; }
.c-row .ic{ width:42px;height:42px;border-radius:10px;background:var(--paper);border:1px solid var(--line);color:var(--navy-700);display:grid;place-items:center;flex:none; }
.c-row .ic svg{ width:20px;height:20px; }
.c-row .k{ font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); font-weight:700; }
.c-row .v{ font-weight:600; font-size:1.05rem; color:var(--ink); }
.c-row .v a:hover{ color:var(--navy-700); }
.hours{ width:100%; border-collapse:collapse; margin-top:4px; }
.hours td{ padding:5px 0; font-size:.98rem; }
.hours td:last-child{ text-align:right; font-weight:600; }
.hours tr.today td{ color:var(--navy-700); }
.hours tr.today td:last-child{ color:var(--navy-700); }
.map-embed{ border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); min-height:360px; box-shadow:var(--shadow); }
.map-embed iframe{ width:100%; height:100%; min-height:360px; border:0; display:block; filter:saturate(.95); }
.contact-cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:22px; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-950); color:var(--on-navy-soft); padding:56px 0 28px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; }
.foot-grid h3{ font-family:"Archivo",sans-serif; font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; color:#fff; margin-bottom:16px; font-weight:700; }
.foot-grid a{ display:block; padding:5px 0; color:var(--on-navy-soft); font-size:.96rem; }
.foot-grid a:hover{ color:#fff; }
.foot-about p{ font-size:.94rem; margin-top:16px; line-height:1.6; }
.foot-bottom{ margin-top:40px; padding-top:22px; border-top:1px solid var(--line-navy); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.82rem; }
.foot-bottom .cnpj{ color:var(--on-navy-soft); }
.gmb-link{ display:inline-flex; align-items:center; gap:8px; color:#fff !important; font-weight:600; }
.gmb-link svg{ width:18px;height:18px; color:var(--amber); }

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed; right:18px; bottom:18px; z-index:80;
  width:60px; height:60px; border-radius:50%;
  background:var(--wa); color:#fff; display:grid; place-items:center;
  box-shadow:0 10px 30px rgba(30,174,84,.4); transition:transform .15s ease;
}
.wa-float:hover{ transform:scale(1.06); }
.wa-float svg{ width:32px; height:32px; }
.wa-float .pulse{ position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(30,174,84,.5); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(30,174,84,.45);} 70%{box-shadow:0 0 0 16px rgba(30,174,84,0);} 100%{box-shadow:0 0 0 0 rgba(30,174,84,0);} }

/* gauge tick divider */
.ticks{ display:flex; gap:6px; align-items:flex-end; height:14px; margin-top:18px; }
.ticks i{ width:2px; background:var(--line); height:7px; display:block; }
.ticks i:nth-child(5n+1){ height:14px; background:var(--amber); }
.on-navy .ticks i{ background:var(--line-navy); }
.on-navy .ticks i:nth-child(5n+1){ background:var(--amber); }

/* ---------- Mobile menu ---------- */
.mobile-menu{ display:none; position:fixed; inset:0; z-index:100; }
.mobile-menu.open{ display:block; }
.mobile-menu .scrim{ position:absolute; inset:0; background:rgba(7,26,48,.5); }
.mobile-menu .panel{ position:absolute; top:0; right:0; width:min(82vw,340px); height:100%; background:var(--paper); padding:22px; box-shadow:var(--shadow-lg); display:flex; flex-direction:column; gap:6px; overflow:auto; }
.mobile-menu .panel .mhead{ display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.mobile-menu .panel .mnav{ display:flex; flex-direction:column; }
.mobile-menu .panel a.mlink{ padding:13px 8px; font-family:"Archivo",sans-serif; font-weight:800; font-size:1.1rem; border-bottom:1px solid var(--line); color:var(--ink); }
.mobile-menu .panel .mgroup{ font-family:"Archivo",sans-serif; font-weight:800; font-size:.7rem; text-transform:uppercase; letter-spacing:.13em; color:var(--amber-600); padding:18px 8px 4px; }
.mobile-menu .panel a.msub{ padding:11px 8px 11px 16px; font-family:"Barlow",sans-serif; font-weight:600; font-size:1.02rem; color:var(--ink-soft); border-bottom:1px solid var(--line); }
.mobile-menu .panel a.msub:hover{ color:var(--ink); }
.mobile-menu .panel a.msub-all{ color:var(--amber-600); font-weight:700; }
.mobile-menu .panel .mcta{ margin-top:18px; display:flex; flex-direction:column; gap:10px; position:sticky; bottom:0; background:var(--paper); padding-top:14px; }
.close-btn{ width:44px;height:44px;border:1px solid var(--line);background:var(--card);border-radius:8px;display:grid;place-items:center;cursor:pointer; }
.close-btn svg{ width:22px;height:22px; }

/* ===========================================================
   Responsive
   =========================================================== */
@media (max-width:980px){
  .hero .wrap{ grid-template-columns:1fr; gap:32px; }
  .hero-panel{ max-width:480px; }
  .about .wrap{ grid-template-columns:1fr; gap:30px; }
  .about-photo{ aspect-ratio:16/10; max-height:340px; }
  .trust-grid{ grid-template-columns:repeat(2,1fr); gap:22px; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .contact .wrap{ grid-template-columns:1fr; }
  .gpanel{ grid-template-columns:1fr; text-align:center; gap:20px; }
  .gscore{ border-right:0; border-bottom:1px solid var(--line); padding-right:0; padding-bottom:22px; }
  .stars{ justify-content:center; }
}
@media (max-width:720px){
  body{ font-size:16px; }
  .section{ padding:54px 0; }
  .nav{ display:none; }
  .header-cta .btn-desktop{ display:none; }
  .menu-btn{ display:flex; }
  .topbar .tb-right{ display:none; }
  .topbar .tb-left{ gap:6px 14px; justify-content:center; width:100%; text-align:center; }
  .topbar .tb-left .dot{ display:none; }
  .topbar .wrap{ justify-content:center; padding-block:5px; }
  /* botões longos quebram o texto em vez de estourar a largura da tela */
  .btn{ white-space:normal; }
  .areas-cta .btn, .contact-cta .btn{ width:100%; }
  .hero h1{ font-size:clamp(2rem,8vw,2.6rem); }
  .svc-grid{ grid-template-columns:1fr; }
  .trust-grid{ grid-template-columns:1fr; gap:18px; }
  .foot-grid{ grid-template-columns:1fr; }
  .stat-row{ gap:24px; }
  .gscore .num{ font-size:2.6rem; }
}
