/* ALL LAB · Site V1 — Premium Redesign V2 · Brand LOCK V1 (dark premium institucional)
   Paleta canônica (ALL_LAB_COLOR_TOKENS_V1): Jet Black #0A0A0A · Charcoal #141414 · Slate #333 · Text #F2F2F0
           Institutional Green #6BA36B (acento) · Light Green #8BB48F · Deep Green #2E7D32 · Gold #DCC59A (acento institucional pontual)
   Direção: aderente ao Brand Board aprovado (verde como ACENTO, base preto+off-white, motivo corner-bracket, sensação arquitetura+dados)
   Tipografia: Space Grotesk (display, 300–700) + Inter (body) — máx. 2 famílias
   Fontes carregadas via <link preconnect> no <head> (não @import — evita render-block) */

:root{
  --bg:#0A0A0A;            /* Jet Black (canônico) */
  --bg-alt:#141414;        /* Charcoal */
  --panel:#161616;         /* card surface */
  --panel-2:#1C1C1C;
  --glass:rgba(22,22,22,.66);
  --slate:#333333;         /* Slate */
  --hair:rgba(255,255,255,.07);
  --hair-green:rgba(107,163,107,.24);
  --text:#F2F2F0;
  --txt2:#BCC0BD;
  --txt3:#8C918D;
  --txt4:#7E837F;         /* meta/label — AA 4.5:1 sobre #0A0A0A */
  --green:#6BA36B;         /* Institutional Green — acento principal */
  --green-2:#8BB48F;       /* Light Green — hover/acento suave */
  --green-deep:#2E7D32;    /* Deep Green */
  --green-soft:rgba(107,163,107,.10);
  --green-line:rgba(107,163,107,.30);
  --gold:#DCC59A;          /* Gold — acento institucional pontual */
  --gold-soft:rgba(220,197,154,.10);
  --ink:#08130A;           /* texto sobre verde */
  --maxw:1180px;
  --nav-offset:88px;       /* altura da nav fixa + folga — compensa âncoras (scroll-margin-top) */
  --fd:'Space Grotesk',system-ui,-apple-system,'Segoe UI',sans-serif;
  --fb:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:var(--fb);line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
/* faint architectural grid — subtle */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.6;
  background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:72px 72px;mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000,transparent 80%)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 30px;position:relative;z-index:1}
section{padding:100px 0;position:relative;z-index:1;scroll-margin-top:var(--nav-offset)}
.alt{background:var(--bg-alt);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}

/* typography */
h1,h2,h3{font-family:var(--fd);font-weight:600;letter-spacing:-.5px;line-height:1.12}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--fb);font-size:12px;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--green);margin-bottom:20px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--green)}
h2.title{font-size:clamp(26px,3.4vw,42px);margin-bottom:16px}
.g{color:var(--green)}
.lead{font-size:clamp(15px,1.4vw,18px);color:var(--txt2);max-width:720px;line-height:1.7}

/* nav */
nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:14px 30px;background:rgba(10,10,10,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--hair)}
nav .logo img{height:44px;width:auto;display:block}
/* header wordmark — aderente ao Brand Board aprovado: ALL fino/off-white dominante · LAB menor/verde espaçado
   · corner-bracket verde (motivo-assinatura) · sem by-Five · sem imagem raster */
.logo{display:inline-flex;align-items:baseline;margin-right:56px;text-decoration:none}
/* logo oficial (kit canonico) — header AL-LOGO-05 · footer AL-LOGO-03 */
.logo-img{height:34px;width:auto;display:block}
footer .logo-img{height:96px;width:auto;margin-bottom:6px}
@media(max-width:560px){.logo-img{height:28px}footer .logo-img{height:74px}}
.logo .brand{position:relative;font-family:var(--fd);line-height:1;display:inline-flex;align-items:baseline;gap:14px;white-space:nowrap;padding-right:16px;padding-left:20px}
/* barra vertical verde — assinatura do wordmark (referência aprovada) */
.logo .brand::before{content:"";position:absolute;left:0;top:1px;bottom:1px;width:3px;border-radius:2px;background:var(--green);box-shadow:0 0 12px rgba(107,163,107,.5)}
.logo .brand-all{font-size:33px;font-weight:600;color:#FFFFFF;letter-spacing:.5px}
.logo .brand-lab{font-size:16px;font-weight:600;color:var(--green);letter-spacing:.46em;text-transform:uppercase;text-shadow:0 0 18px rgba(107,163,107,.28)}
/* corner-bracket motif (assinatura da marca aprovada) */
.logo .brand::after{content:"";position:absolute;top:-4px;right:0;width:9px;height:9px;border-top:1.5px solid var(--green);border-right:1.5px solid var(--green);opacity:.92;transition:top .25s,opacity .25s}
.logo:hover .brand::after{top:-6px;opacity:1}
footer .logo{margin-right:0;margin-bottom:12px}
footer .logo .brand-all{font-size:28px;font-weight:600;letter-spacing:.5px;color:#FFFFFF}
footer .logo .brand-lab{font-size:14px;font-weight:600;letter-spacing:.44em}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-size:14px;color:var(--txt2);transition:color .2s;position:relative}
.nav-links a:not(.btn):hover{color:var(--text)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--green);transition:width .25s}
.nav-links a:not(.btn):hover::after{width:100%}
.lang{display:inline-flex;gap:2px;border:1px solid var(--hair);border-radius:6px;padding:2px}
.lang a{font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 8px;border-radius:4px;color:var(--txt3)}
.lang a.on{background:var(--green);color:#08150a}
.lang a:hover{color:var(--text)}
#burger{display:none;background:none;border:0;color:var(--text);cursor:pointer}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--fb);font-size:14px;font-weight:600;
  letter-spacing:.2px;padding:13px 22px;border-radius:8px;cursor:pointer;transition:.2s;border:1px solid transparent;line-height:1}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--green);border-color:var(--green);color:var(--ink);box-shadow:0 6px 22px rgba(107,163,107,.14)}
.btn-primary:hover{background:var(--green-2);border-color:var(--green-2);transform:translateY(-1px);box-shadow:0 10px 30px rgba(107,163,107,.22)}
.btn-ghost{border-color:var(--slate);color:var(--text);background:transparent}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}

/* hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;padding:120px 0 80px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 48% 44% at 80% 38%,rgba(107,163,107,.07),transparent 66%),
             radial-gradient(ellipse 40% 30% at 12% 92%,rgba(220,197,154,.03),transparent 70%)}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:56px;align-items:center;width:100%}
.hero-copy{position:relative}
.hero h1{font-size:clamp(34px,5.1vw,66px);font-weight:500;letter-spacing:-1.6px;line-height:1.04;margin-bottom:22px}
.hero h1 .g{font-weight:600}
.hero .sub{font-size:clamp(16px,1.5vw,19px);color:var(--txt2);max-width:530px;margin-bottom:32px;line-height:1.65}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.caps{display:flex;gap:18px;flex-wrap:wrap}
.cap{flex:1;min-width:150px;border-top:1.5px solid var(--green-line);padding:16px 6px 0;background:linear-gradient(180deg,var(--green-soft),transparent 62%);transition:border-color .25s,transform .25s}
.cap:hover{border-top-color:var(--green);transform:translateY(-3px)}
.cap b{display:block;font-family:var(--fd);font-size:14.5px;font-weight:600;letter-spacing:.1px;color:var(--text);margin-bottom:5px}
.cap span{font-size:12.5px;color:var(--txt3);line-height:1.5}

/* hero visual — Applied-Intelligence Console (sensação de arquitetura + dados, sem imagem literal/imobiliária) */
.hero-visual{position:relative;min-height:470px;display:flex;align-items:center;justify-content:center}
/* architectural / data blueprint backdrop — abstrato */
.blueprint{position:absolute;inset:-8% -5%;width:110%;height:116%;z-index:0;opacity:.55;color:var(--green);pointer-events:none;
  -webkit-mask-image:radial-gradient(ellipse 86% 80% at 55% 46%,#000 26%,transparent 84%);
          mask-image:radial-gradient(ellipse 86% 80% at 55% 46%,#000 26%,transparent 84%)}
.blueprint .ln{stroke:currentColor;stroke-width:1;fill:none;opacity:.5}
.blueprint .ln.dim{opacity:.2}
.blueprint .nd{fill:currentColor}
/* corner brackets — motivo-assinatura da marca */
.cbr{position:absolute;width:26px;height:26px;z-index:4;pointer-events:none;opacity:.7}
.cbr.tl{top:2px;left:8px;border-top:1.5px solid var(--green);border-left:1.5px solid var(--green)}
.cbr.tr{top:2px;right:8px;border-top:1.5px solid var(--green);border-right:1.5px solid var(--green)}
.cbr.bl{bottom:2px;left:8px;border-bottom:1.5px solid var(--green);border-left:1.5px solid var(--green)}
.cbr.br{bottom:2px;right:8px;border-bottom:1.5px solid var(--green);border-right:1.5px solid var(--green)}
/* transformation spine — glass panel flutuante */
.stack{position:relative;z-index:2;width:100%;max-width:404px;border:1px solid var(--hair-green);border-radius:16px;
  background:linear-gradient(160deg,rgba(255,255,255,.035),transparent 46%),var(--glass);
  backdrop-filter:blur(11px);-webkit-backdrop-filter:blur(11px);box-shadow:0 34px 90px rgba(0,0,0,.55);overflow:hidden;padding:32px 28px}
.stack::before{content:"";position:absolute;left:48px;top:50px;bottom:50px;width:1px;background:linear-gradient(180deg,var(--green),var(--green-line) 62%,transparent)}
.stack .signal{position:absolute;left:44px;top:44px;width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px var(--green-soft),0 0 14px var(--green)}
.layer{position:relative;margin-left:34px;margin-bottom:14px;background:linear-gradient(90deg,var(--green-soft),transparent 72%),var(--panel);
  border:1px solid var(--hair);border-left:2px solid var(--green-line);border-radius:10px;padding:15px 18px;transition:transform .3s,border-color .3s}
.layer:last-child{margin-bottom:0}
.layer .lb{font-family:var(--fd);font-size:14px;font-weight:600;color:var(--text)}
.layer .ds{font-size:12px;color:var(--txt3);margin-top:3px}
.layer.l1{margin-top:6px}
.layer.l4{border-left-color:var(--green);background:linear-gradient(90deg,rgba(107,163,107,.16),transparent 75%),var(--panel);box-shadow:inset 0 0 0 1px var(--hair-green)}
.stack:hover .layer{border-left-color:var(--green)}
/* floating data chip — glass, qualitativo (sem números, sem claim) */
.chip{position:absolute;z-index:5;top:26px;right:2px;display:flex;align-items:center;gap:11px;padding:11px 14px;
  border:1px solid var(--hair-green);border-radius:13px;background:var(--glass);backdrop-filter:blur(11px);-webkit-backdrop-filter:blur(11px);
  box-shadow:0 18px 46px rgba(0,0,0,.5)}
.chip .ring{width:32px;height:32px;flex:0 0 auto;color:var(--green)}
.chip .ring circle{fill:none;stroke-width:3}
.chip .ring .trk{stroke:var(--hair)}
.chip .ring .val{stroke:currentColor;stroke-linecap:round;stroke-dasharray:88;stroke-dashoffset:26;transform:rotate(-90deg);transform-origin:center}
.chip .ct b{display:block;font-family:var(--fd);font-size:12px;font-weight:600;color:var(--text);letter-spacing:.2px}
.chip .ct em{font-style:normal;font-size:9.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--green)}

/* essence — 3-step transformation (no neon flow) */
.steps{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch;margin-top:28px}
.step{flex:1;min-width:200px;background:var(--panel);border:1px solid var(--hair);border-radius:12px;padding:22px}
.step .n{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--green);margin-bottom:8px}
.step h3{font-size:18px;margin-bottom:6px}
.step p{font-size:13.5px;color:var(--txt3)}
.step .arw{align-self:center;color:var(--slate);font-size:20px;flex:0 0 auto}

/* pillars (o que é a ALL LAB) */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.pillar{background:var(--panel);border:1px solid var(--hair);border-radius:12px;padding:26px}
.pillar .ic{width:40px;height:40px;border-radius:10px;background:var(--green-soft);border:1px solid var(--hair-green);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.pillar .ic svg{width:20px;height:20px;stroke:var(--green)}
.pillar h3{font-size:17px;margin-bottom:8px}
.pillar p{font-size:13.5px;color:var(--txt2);line-height:1.6}

/* cards grid (verticais / capacidades) */
.grid{display:grid;gap:18px;margin-top:32px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.card{position:relative;background:var(--panel);border:1px solid var(--hair);border-radius:12px;padding:24px;
  transition:border-color .25s,transform .25s,background .25s}
.card::before{content:"";position:absolute;top:0;left:24px;width:28px;height:2px;background:var(--slate);border-radius:0 0 2px 2px;transition:width .25s,background .25s}
.card:hover{border-color:var(--hair-green);transform:translateY(-3px);background:var(--panel-2)}
.card:hover::before{width:44px;background:var(--green)}
.card .ic{width:38px;height:38px;border-radius:9px;background:var(--green-soft);border:1px solid var(--hair-green);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card .ic svg{width:19px;height:19px;stroke:var(--green);fill:none}
.card h3{font-size:16.5px;margin-bottom:8px;letter-spacing:-.2px}
.card p{font-size:13.5px;color:var(--txt2);line-height:1.6;margin-bottom:12px}
.card .why{font-size:12.5px;color:var(--green);font-weight:600;display:flex;align-items:center;gap:7px}
.card .why::before{content:"";width:14px;height:1px;background:var(--green)}

/* model timeline */
.timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:38px;position:relative}
.tl{position:relative;padding:0 18px}
.tl::before{content:"";position:absolute;top:11px;left:0;right:0;height:2px;background:var(--slate)}
.tl:first-child::before{left:50%}
.tl:last-child::before{right:50%}
.tl .dot{position:relative;width:24px;height:24px;border-radius:50%;background:var(--bg);border:2px solid var(--green);
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.tl .dot::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--green)}
.tl h3{font-size:16px;text-align:center;margin-bottom:6px}
.tl p{font-size:12.5px;color:var(--txt3);text-align:center;line-height:1.5}

/* ecosystem */
.eco-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.eco-row .s{font-size:13px;color:var(--txt2);background:var(--panel);border:1px solid var(--hair);border-radius:8px;padding:11px 16px;transition:.2s}
.eco-row .s:hover{border-color:var(--hair-green);color:var(--text)}
.eco-row .s b{color:var(--green);margin-right:8px;font-weight:600}

/* contact */
.contact .box{background:linear-gradient(160deg,var(--green-soft),transparent 55%),var(--bg-alt);
  border:1px solid var(--hair-green);border-radius:18px;padding:60px 32px;max-width:820px;margin:0 auto;text-align:center}
.contact h2{font-size:clamp(24px,3vw,38px);margin-bottom:14px}
.contact .lead{margin:0 auto 30px;text-align:center}

/* footer */
footer{border-top:1px solid var(--hair);background:var(--bg-alt);padding:52px 0 40px}
footer .frow{display:flex;justify-content:space-between;align-items:flex-start;gap:28px;flex-wrap:wrap}
footer img{height:40px;width:auto;margin-bottom:16px}
footer .tag{font-size:12px;letter-spacing:1.5px;color:var(--green);text-transform:uppercase;margin-bottom:10px}
footer p{font-size:13px;color:var(--txt3);max-width:420px}
footer .legal{font-size:12px;color:var(--txt4);margin-top:20px}
/* footer social + legal links (referência aprovada) */
.foot-social{display:flex;gap:12px;margin:16px 0 0;justify-content:flex-end}
.foot-social a{width:42px;height:42px;border-radius:50%;border:1px solid var(--green-line);display:inline-flex;align-items:center;justify-content:center;color:var(--green);transition:background .2s,color .2s,transform .2s}
.foot-social a:hover{background:var(--green);color:var(--ink);transform:translateY(-2px)}
.foot-social svg{width:18px;height:18px}
.foot-links{display:flex;gap:24px;flex-wrap:wrap;margin-top:14px}
.foot-links a{font-size:12px;color:var(--txt4)}
.foot-links a:hover{color:var(--green)}
/* benefits strip — ícones em círculo (referência aprovada) */
.benefits{border-top:1px solid var(--hair);background:var(--bg)}
.brow{display:flex;gap:14px;flex-wrap:wrap;padding:30px 0}
.bitem{flex:1;min-width:190px;display:flex;gap:13px;align-items:center;position:relative;padding-left:0}
.bitem+.bitem{border-left:1px solid var(--hair);padding-left:22px}
.bitem .bi{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:1px solid var(--green-line);display:inline-flex;align-items:center;justify-content:center;color:var(--green)}
.bitem .bi svg{width:20px;height:20px}
.bitem p{font-size:13px;color:var(--txt2);line-height:1.42}

/* WhatsApp FAB */
.fab{position:fixed;right:22px;bottom:22px;z-index:120;width:56px;height:56px;border-radius:50%;
  background:var(--green);color:#08150a;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 26px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.15);transition:transform .2s}
.fab:hover{transform:translateY(-2px) scale(1.03)}
.fab svg{width:28px;height:28px}

/* credibility strip (após hero) — qualitativa, sem logos de terceiros */
.credband{padding:30px 0;background:var(--bg-alt);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.credband .cred-intro{font-size:12.5px;letter-spacing:.4px;color:var(--txt3);text-align:center;margin-bottom:16px}
.cred-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 26px}
.cred-row span{font-family:var(--fd);font-size:13px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--txt2);position:relative;display:inline-flex;align-items:center}
.cred-row span:not(:last-child)::after{content:"";width:4px;height:4px;border-radius:50%;background:var(--green);
  opacity:.7;margin-left:26px}

/* use-case patterns (frentes de aplicação — não cases executados) */
.usecase{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
.uc{background:var(--panel);border:1px solid var(--hair);border-radius:12px;padding:24px;transition:border-color .25s,transform .25s}
.uc:hover{border-color:var(--hair-green);transform:translateY(-3px)}
.uc .sect{display:inline-flex;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);
  border:1px solid var(--hair-green);background:var(--green-soft);border-radius:6px;padding:4px 10px;margin-bottom:16px}
.uc dl{margin:0}
.uc dt{font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--txt4);margin-top:12px}
.uc dt:first-child{margin-top:0}
.uc dd{font-size:13.5px;color:var(--txt2);line-height:1.55;margin:3px 0 0}
.pattern-note{font-size:12.5px;color:var(--txt4);margin-top:20px;font-style:italic}

/* insights — cards institucionais (conteúdo em preparação) */
.insight{position:relative}
.insight .soon{position:absolute;top:20px;right:20px;font-size:10.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  color:var(--txt3);border:1px solid var(--hair);border-radius:20px;padding:3px 10px}
.insight h3{padding-right:64px}

@media(max-width:960px){.usecase{grid-template-columns:1fr}}

/* reveal on scroll — progressive enhancement:
   hidden state applies ONLY when JS is active (html.js). Without JS the
   content stays fully visible. */
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal.in{opacity:1;transform:none}

/* accessibility */
a:focus-visible,.btn:focus-visible,button:focus-visible,.lang a:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:8px}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  html.js .reveal{opacity:1;transform:none}
}

/* responsive */
@media(max-width:960px){
  .hero-grid{grid-template-columns:minmax(0,1fr);gap:40px}
  .hero-visual{order:-1;min-height:400px}
  .blueprint{opacity:.4}
  .stack{max-width:440px}
  .pillars{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr 1fr;gap:28px 0}
  .tl::before{display:none}
}
@media(max-width:560px){
  .hero-visual{min-height:320px}
  .chip{display:none}                 /* decorativo — evita overflow lateral em telas estreitas */
  .cbr{width:18px;height:18px}
  .blueprint{opacity:.3}
  .hero h1{font-size:clamp(28px,8.4vw,34px);letter-spacing:-.6px;overflow-wrap:break-word}
}
/* nav collapses to burger antes do menu denso estourar (≈900–1050px) */
@media(max-width:1024px){
  .nav-links{position:fixed;inset:60px 0 auto 0;flex-direction:column;align-items:flex-start;gap:18px;
    background:var(--bg-alt);border-bottom:1px solid var(--hair);padding:22px 30px;transform:translateY(-140%);transition:transform .3s}
  .nav-links.open{transform:translateY(0)}
  #burger{display:block}
  .nav-links .btn{width:auto}
}
@media(max-width:900px){
  section{padding:72px 0}
  .hero{min-height:auto;padding:108px 0 64px}
  .g2,.g3{grid-template-columns:1fr}
  .btn{width:100%}
  .cta-row .btn{flex:1}
}
@media(max-width:560px){
  .container{padding:0 20px}
  .caps{flex-direction:column}
  .cap{min-width:0}
  .timeline{grid-template-columns:1fr}
  .cta-row{flex-direction:column}
  .cta-row .btn{width:100%}
  .btn{min-height:48px}
}




