/* ============================================================
   LifeTracer · Fogo skin — site styles
   Built on top of /css/colors_and_type.css (Fogo tokens)
   Adapts the Fogo marketing kit to the LifeTracer site layout
   ============================================================ */

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--tx-2);
  font-family:var(--body); font-weight:300; font-size:var(--fs-body); line-height:1.55;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  min-height:100vh;
}

/* ambient amber/ember glow that bleeds behind content */
body::before{
  content:"";position:fixed;inset:0 0 auto 0;height:62vh;z-index:0;pointer-events:none;
  background:radial-gradient(120% 80% at 70% -10%, rgba(255,122,26,.18), rgba(228,69,43,.07) 40%, transparent 70%);
}

.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.page-root{min-height:100vh;display:flex;flex-direction:column}
main.content{flex:1;position:relative;z-index:1}

/* ----- typography helpers ----- */
h1,h2,h3,h4{font-family:var(--display);color:var(--tx);letter-spacing:-.02em;line-height:1.05;font-weight:700}
.eyebrow{font-family:var(--body);font-size:var(--fs-eyebrow);letter-spacing:.18em;text-transform:uppercase;color:var(--tx-3);font-weight:600;display:inline-block}
.eyebrow.amber{color:var(--amber-2)}
.mono{font-family:var(--mono);font-size:var(--fs-mono);color:var(--tx-3)}
.lede{font-size:var(--fs-lg);color:var(--tx-2);max-width:60ch;line-height:1.55}
.muted{color:var(--tx-3)}
.grad-text{background:var(--grad-fire);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.center{text-align:center}

/* ----- BUTTONS ----- */
.btn{font-family:var(--body);font-weight:500;font-size:14px;border:none;cursor:pointer;border-radius:var(--r-pill);
  white-space:nowrap;padding:12px 22px;display:inline-flex;align-items:center;gap:8px;text-decoration:none;
  transition:transform var(--t-slow) var(--ease),box-shadow var(--t-slow) var(--ease),background var(--t-slow) var(--ease),color var(--t-base) var(--ease)}
.btn-amber{background:var(--grad-amber);color:#231100;box-shadow:var(--glow-amber);font-weight:600}
.btn-amber:hover{transform:translateY(-2px);box-shadow:var(--glow-amber-hi);color:#231100}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--tx);border:1px solid var(--line-2)}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-link{background:transparent;color:var(--tx-2);padding:10px 4px}
.btn-link:hover{color:var(--amber-2)}
.btn:active{transform:translateY(0) scale(.98)}
.btn .ic{display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center}
.btn-lg{padding:14px 28px;font-size:15px}
.btn-block{width:100%;justify-content:center}

/* ----- TOP NAV ----- */
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(7,7,11,.62);border-bottom:1px solid var(--line)}
.topbar .nav{display:flex;align-items:center;justify-content:space-between;height:68px;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:800;color:var(--tx);font-size:18px;letter-spacing:-.02em;text-decoration:none}
.brand img{width:30px;height:30px;display:block}
.brand .name{display:inline-block}
.brand .name b{background:var(--grad-fire);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:900}
.nav-links{display:flex;gap:26px;font-size:14px;list-style:none;align-items:center}
.nav-links a{color:var(--tx-3);text-decoration:none;transition:color var(--t-base) var(--ease);cursor:pointer;padding:6px 0}
.nav-links a:hover,.nav-links a.active{color:var(--tx)}
.nav-cta{display:flex;align-items:center;gap:12px}
.menu-toggle{display:none;width:42px;height:42px;background:transparent;border:1px solid var(--line-2);border-radius:var(--r-pill);color:var(--tx);align-items:center;justify-content:center;cursor:pointer}
.menu-toggle span{display:block;width:18px;height:1.5px;background:var(--tx);position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--tx);transition:transform var(--t-base) var(--ease)}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}

/* ----- SECTIONS ----- */
section.block{padding:var(--s9) 0;border-top:1px solid var(--line);position:relative;z-index:1}
section.block.no-line{border-top:none}
section.block.alt{background:var(--bg-2)}
.sec-head{margin-bottom:var(--s7);max-width:760px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:var(--fs-h2);font-weight:700;margin:12px 0 12px;color:var(--tx);letter-spacing:-.02em}
.sec-head p{max-width:60ch;color:var(--tx-2);font-size:var(--fs-lg)}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* ----- HERO ----- */
.hero{padding:var(--s9) 0 var(--s8);display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s7);align-items:center}
.hero .badge{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font-size:12.5px;color:var(--tx-2);background:rgba(255,255,255,.04);border:1px solid var(--line-2);padding:7px 14px;border-radius:var(--r-pill);margin-bottom:var(--s5)}
.hero .badge .dot{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 10px var(--amber);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.92)}}
.hero h1{font-size:clamp(40px,5.4vw,74px);font-weight:800;letter-spacing:-.035em;text-transform:uppercase;line-height:.98;color:var(--tx)}
.hero p.sub{font-size:var(--fs-lg);color:var(--tx-2);max-width:46ch;margin:var(--s5) 0 var(--s6)}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* aurora stage with LifeTracer fire-coin */
.stage{position:relative;border:1px solid var(--line);border-radius:var(--r-xl);background:var(--grad-surface);overflow:hidden;aspect-ratio:1/1.04;min-height:440px}
.aurora{position:absolute;inset:0;filter:blur(34px);opacity:.95}
.aurora i{position:absolute;border-radius:50%;mix-blend-mode:screen;animation:drift 9s ease-in-out infinite}
.aurora .core{left:50%;top:8%;width:120px;height:88%;border-radius:60px;background:linear-gradient(180deg,#fff,var(--gold),var(--amber),var(--ember));filter:blur(28px);transform:translateX(-50%);animation:sway 7s ease-in-out infinite}
.aurora .b1{left:30%;top:30%;width:260px;height:260px;background:radial-gradient(circle,var(--amber),transparent 65%)}
.aurora .b2{left:55%;top:50%;width:300px;height:300px;background:radial-gradient(circle,var(--ember),transparent 60%);animation-delay:-3s}
.aurora .b3{left:40%;top:62%;width:220px;height:220px;background:radial-gradient(circle,var(--gold),transparent 60%);animation-delay:-5s}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(14px,-22px) scale(1.08)}}
@keyframes sway{0%,100%{transform:translateX(-50%) scaleY(1)}50%{transform:translateX(-42%) scaleY(.94)}}
.stage::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 100%, rgba(0,0,0,.55), transparent 55%);pointer-events:none}

/* foreground LifeTracer coin floating over the aurora */
.coin-stage{position:absolute;inset:0;display:grid;place-items:center;z-index:2}
.coin-stage img{width:62%;max-width:300px;filter:drop-shadow(0 22px 60px rgba(255,122,26,.55))}

/* floating glass card */
.float-card{position:absolute;right:18px;bottom:24px;width:64%;max-width:280px;background:rgba(14,14,20,.78);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:var(--r-md);padding:18px;z-index:3;box-shadow:var(--sh-lg)}
.float-card .tag{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);display:flex;align-items:center;gap:6px;font-weight:600}
.float-card h4{font-size:16px;margin:10px 0 4px;font-weight:600;color:var(--tx);font-family:var(--display);letter-spacing:-.01em}
.float-card .desc{font-size:12px;color:var(--tx-3);line-height:1.45}
.float-card .stat{font-family:var(--display);font-weight:800;font-size:38px;color:var(--tx);margin:12px 0 2px;letter-spacing:-.03em;display:flex;align-items:baseline;gap:8px}
.float-card .stat small{color:var(--jade);font-size:12px;font-weight:600;font-family:var(--body)}
.spark{height:42px;margin-top:6px;width:100%}
.float-card .row{display:flex;justify-content:space-between;font-size:12px;color:var(--tx-3);margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}
.float-card .row b{color:var(--tx);font-weight:600}

/* ----- feature cards ----- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.feature-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.feature-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.feature{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;transition:transform var(--t-slow) var(--ease),border-color var(--t-slow) var(--ease)}
.feature:hover{transform:translateY(-4px);border-color:var(--line-2)}
.feature .ic{width:44px;height:44px;border-radius:var(--r-md);display:grid;place-items:center;background:var(--amber-wash);border:1px solid var(--amber-line);color:var(--amber-2);margin-bottom:18px;font-size:20px}
.feature h3{font-size:18px;font-weight:600;color:var(--tx);margin-bottom:8px;font-family:var(--display);letter-spacing:-.01em}
.feature p{font-size:14px;color:var(--tx-3);line-height:1.55}

/* areas-grid : the 12 áreas da vida tiles, denser */
.areas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.area-tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;display:flex;align-items:center;gap:12px;transition:border-color var(--t-base) var(--ease),background var(--t-base) var(--ease)}
.area-tile:hover{border-color:var(--amber-line);background:var(--surface-2)}
.area-tile .dot{width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 12px var(--amber);flex-shrink:0}
.area-tile span{font-size:14px;color:var(--tx);font-weight:500}

/* numbered steps */
.steps{display:grid;gap:18px}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 28px;display:flex;align-items:flex-start;gap:24px;transition:border-color var(--t-base) var(--ease)}
.step:hover{border-color:var(--line-2)}
.step .num{font-family:var(--display);font-weight:800;font-size:46px;color:var(--amber);letter-spacing:-.03em;min-width:52px;line-height:1;background:var(--grad-fire);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.step h3{font-family:var(--display);font-size:20px;font-weight:600;color:var(--tx);margin-bottom:6px;letter-spacing:-.01em}
.step p{font-size:15px;color:var(--tx-3);line-height:1.55}

/* gallery (screenshots) */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.gallery .shot{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform var(--t-slow) var(--ease),border-color var(--t-slow) var(--ease)}
.gallery .shot:hover{transform:translateY(-4px);border-color:var(--amber-line)}
.gallery .shot img{display:block;width:100%;height:auto}

/* pricing/plan cards */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5);align-items:start}
.plan{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;transition:transform var(--t-slow) var(--ease),border-color var(--t-slow) var(--ease);position:relative}
.plan:hover{transform:translateY(-4px);border-color:var(--line-2)}
.plan.glow{background:linear-gradient(180deg,#16161F,#101017);box-shadow:var(--glow-amber);border-color:var(--amber-line)}
.plan .ribbon{position:absolute;top:18px;right:18px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;background:var(--grad-amber);color:#231100;padding:5px 12px;border-radius:var(--r-pill);font-weight:700}
.plan .pk{font-size:12px;color:var(--tx-3);text-transform:uppercase;letter-spacing:.14em;font-weight:600}
.plan .price{font-family:var(--display);font-weight:800;font-size:46px;color:var(--tx);letter-spacing:-.03em;margin:14px 0 2px;line-height:1}
.plan .price small{font-size:14px;color:var(--tx-3);font-weight:400;font-family:var(--body)}
.plan .feat{font-size:14px;color:var(--tx-2);margin:18px 0;display:flex;flex-direction:column;gap:10px}
.plan .feat span{display:flex;gap:9px;align-items:flex-start}
.plan .feat span::before{content:"✓";color:var(--jade);font-size:13px;line-height:1.4;flex-shrink:0}
.plan .btn{width:100%;justify-content:center}

/* comparison table */
.compare{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.compare th,.compare td{padding:14px 18px;text-align:left;font-size:14px;border-bottom:1px solid var(--line)}
.compare thead th{background:var(--surface-2);color:var(--tx);font-family:var(--body);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.compare thead th.us{color:var(--amber-2)}
.compare tbody td{color:var(--tx-2)}
.compare tbody td.cell{text-align:center}
.compare tbody td.cell.yes{color:var(--jade);font-weight:600}
.compare tbody td.cell.no{color:var(--tx-4)}
.compare tbody td.cell.partial{color:var(--gold);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
.compare tbody td.first{color:var(--tx);font-weight:500}
.compare tbody tr:last-child td{border-bottom:none}

/* FAQ accordion */
.faq{display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:0;overflow:hidden;transition:border-color var(--t-base) var(--ease)}
.faq-item:hover{border-color:var(--line-2)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;gap:18px;align-items:flex-start;font-family:var(--display);font-weight:600;color:var(--tx);font-size:17px;letter-spacing:-.01em}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:var(--body);font-weight:300;font-size:24px;color:var(--amber);line-height:1;flex-shrink:0;transition:transform var(--t-base) var(--ease)}
.faq-item[open] summary::after{content:"−";transform:rotate(0)}
.faq-item .answer{padding:0 26px 22px;color:var(--tx-2);font-size:15px;line-height:1.6}
.faq-item .answer p{margin-bottom:10px}
.faq-item .answer p:last-child{margin-bottom:0}
.faq-item .answer ul{list-style:none;padding:0;margin:8px 0;display:flex;flex-direction:column;gap:8px}
.faq-item .answer ul li{display:flex;gap:10px;font-size:14px;color:var(--tx-2)}
.faq-item .answer ul li::before{content:"✓";color:var(--jade);font-weight:600;flex-shrink:0}

/* download row of two big buttons */
.download-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.download-row .btn{padding:14px 24px}

/* contact form */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.contact-grid .form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px}
.contact-grid .form h3{font-family:var(--display);font-weight:700;font-size:22px;color:var(--tx);margin-bottom:6px;letter-spacing:-.01em}
.contact-grid .form p.help{color:var(--tx-3);font-size:14px;margin-bottom:22px}
.contact-grid .info{display:flex;flex-direction:column;gap:18px}
.contact-grid .info .row{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface)}
.contact-grid .info .row .ic{width:38px;height:38px;border-radius:var(--r-md);background:var(--amber-wash);border:1px solid var(--amber-line);color:var(--amber-2);display:grid;place-items:center;font-size:16px;flex-shrink:0}
.contact-grid .info .row .label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-3);margin-bottom:4px}
.contact-grid .info .row .val{color:var(--tx);font-size:15px}
.contact-grid .info .row .val a{color:var(--tx);text-decoration:none}
.contact-grid .info .row .val a:hover{color:var(--amber-2)}

.field-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field-group label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-3);font-weight:600}
.field{width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--r-md);padding:13px 16px;font-size:14px;color:var(--tx);font-family:var(--body);outline:none;transition:border-color var(--t-base) var(--ease),background var(--t-base) var(--ease)}
.field:focus{border-color:var(--amber-line);background:var(--bg)}
.field.is-invalid{border-color:var(--ember)}
.field-error{color:var(--ember);font-size:12px;margin-top:4px;display:block}
textarea.field{resize:vertical;min-height:140px;font-family:var(--body)}

/* CTA band */
.cta-band{text-align:center;padding:var(--s9) 0;border-top:1px solid var(--line)}
.cta-band h2{font-size:clamp(34px,4vw,56px);text-transform:uppercase;letter-spacing:-.035em;font-weight:800;margin-bottom:18px;color:var(--tx)}
.cta-band p{max-width:54ch;margin:0 auto var(--s6);font-size:var(--fs-lg);color:var(--tx-2)}

/* footer */
.site-footer{padding:var(--s8) 0 var(--s7);border-top:1px solid var(--line);position:relative;z-index:1}
.site-footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;align-items:start}
.site-footer .col h5{font-family:var(--body);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx-3);font-weight:600;margin-bottom:14px}
.site-footer .col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.site-footer .col a{color:var(--tx-2);text-decoration:none;font-size:14px;transition:color var(--t-base) var(--ease)}
.site-footer .col a:hover{color:var(--amber-2)}
.site-footer .brand{font-size:18px}
.site-footer .blurb{color:var(--tx-3);font-size:14px;margin-top:14px;max-width:36ch;line-height:1.55}
.site-footer .social{display:flex;gap:10px;margin-top:18px}
.site-footer .social a{width:36px;height:36px;border-radius:var(--r-pill);background:rgba(255,255,255,.04);border:1px solid var(--line-2);color:var(--tx-2);display:grid;place-items:center;transition:background var(--t-base) var(--ease),color var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}
.site-footer .social a:hover{background:var(--amber-wash);border-color:var(--amber-line);color:var(--amber-2)}
.site-footer .legal{margin-top:var(--s7);padding-top:var(--s5);border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--tx-4);font-size:12px}
.site-footer .legal a{color:var(--tx-3);text-decoration:none;margin-left:18px}
.site-footer .legal a:hover{color:var(--amber-2)}

/* long-form prose pages (Privacy / Terms / detalhes) */
.prose{max-width:780px;margin:0 auto}
.prose h2{font-family:var(--display);font-size:32px;color:var(--tx);letter-spacing:-.02em;margin:48px 0 16px;font-weight:700}
.prose h3{font-family:var(--display);font-size:22px;color:var(--tx);letter-spacing:-.01em;margin:36px 0 12px;font-weight:600}
.prose p{color:var(--tx-2);font-size:15px;line-height:1.7;margin-bottom:14px}
.prose ul,.prose ol{padding-left:22px;margin-bottom:14px;color:var(--tx-2)}
.prose ul li,.prose ol li{margin-bottom:8px;line-height:1.6}
.prose a{color:var(--amber-2);text-decoration:none}
.prose a:hover{text-decoration:underline}
.prose strong{color:var(--tx)}
.prose hr{border:none;border-top:1px solid var(--line);margin:32px 0}
.prose .lede{margin:6px 0 22px}

/* utilidades de pagina de conteudo (Detalhes/News) */
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;align-items:center}
.video-frame{width:100%;max-width:760px;margin:30px auto;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--amber-line);box-shadow:var(--sh-lg)}
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:8px 0 8px}
.benefit-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:22px}
.benefit-card .ico{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:10px;background:var(--amber-wash);color:var(--amber-2);font-size:16px;margin-bottom:12px}
.benefit-card p{color:var(--tx-2);font-size:14px;line-height:1.55;margin:0}
@media(max-width:760px){.benefit-grid{grid-template-columns:1fr}}

/* toast / success/info banner */
.banner{padding:14px 18px;border:1px solid var(--line-2);border-radius:var(--r-md);font-size:14px;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.banner.success{border-color:var(--jade-line);background:var(--jade-wash);color:var(--tx)}
.banner.error{border-color:rgba(228,69,43,.34);background:rgba(228,69,43,.12);color:var(--tx)}

/* modal scrim */
.modal-scrim{position:fixed;inset:0;z-index:100;background:rgba(4,4,8,.7);backdrop-filter:blur(6px);display:grid;place-items:center;padding:24px}
.modal{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:32px;box-shadow:var(--sh-lg);position:relative}
.modal h3{font-family:var(--display);font-size:22px;font-weight:700;color:var(--tx);margin-bottom:8px;letter-spacing:-.01em}
.modal p{font-size:14px;color:var(--tx-3);margin-bottom:18px;line-height:1.5}
.modal .x{position:absolute;top:16px;right:18px;color:var(--tx-3);cursor:pointer;font-size:20px;background:none;border:none;line-height:1}
.modal .x:hover{color:var(--tx)}

/* utility */
.row-buttons{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.row-buttons.center{justify-content:center}

/* responsive */
@media(max-width:960px){
  .site-footer .wrap{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .hero{grid-template-columns:1fr;gap:var(--s6)}
  .stage{min-height:380px}
  .feature-grid,.feature-grid.cols-2,.feature-grid.cols-4,.price-grid,.gallery,.contact-grid{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
  .menu-toggle{display:inline-flex}
  .topbar.is-open .nav-links{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:rgba(7,7,11,.95);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:18px 28px;gap:16px}
  .nav-cta .btn{padding:9px 16px;font-size:13px}
  section.block{padding:var(--s8) 0}
}
@media(max-width:520px){
  .areas-grid{grid-template-columns:1fr}
  .float-card{width:auto;left:18px;right:18px;max-width:none}
  .site-footer .wrap{grid-template-columns:1fr;gap:32px}
}

/* Remove o anel de foco AZUL do heading auto-focado (FocusOnNavigate Selector="h1") */
h1:focus, h1[tabindex]:focus, [tabindex="-1"]:focus, [tabindex="-1"]:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}
