/* ============================================================
   ABUNDANCE BRASIL — Design System Wabi Sabi · ecossistema v3
   Direção: infraestrutura cartográfica / nature-tech institucional
   Tokens: Bai Jamjuree + Roboto Mono (numerais) · #1ABF6E · off-white · radius 10
   Craft: grão, contornos topográficos, polígonos SVG, device-frames, reveals
   Mockup local — não-produção.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bai+Jamjuree:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Roboto+Mono:wght@400;500;600&display=swap');

:root{
  --green:#1ABF6E; --green-d:#15994f; --green-dd:#0f7a3f; --teal:#19C6A1; --purple:#588293;
  --bg:#f6f8f6; --card:#fff; --ink:#101913; --ink2:#46514a; --ink3:#8a948c;
  --line:#e4e9e4; --line2:#d6ddd6;
  --dark:#081209; --dark2:#0c1a12; --dark3:#102a1d;
  --radius:.625rem;
  --mono:'Roboto Mono',ui-monospace,monospace;
  --shadow-sm:0 1px 2px rgba(16,25,19,.05);
  --shadow-md:0 6px 20px -6px rgba(16,25,19,.12);
  --shadow-lg:0 26px 60px -18px rgba(16,25,19,.22);
  --shadow-xl:0 40px 90px -24px rgba(16,25,19,.28);
  --grad:linear-gradient(135deg,#1ABF6E,#19C6A1 55%,#588293);
  --grad-dark:linear-gradient(160deg,#0f7a3f,#19C6A1);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Bai Jamjuree',sans-serif;color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
/* global grain */
body::before{content:"";position:fixed;inset:0;background-image:var(--grain);background-size:200px;opacity:.022;pointer-events:none;z-index:9999;mix-blend-mode:multiply}
h1,h2,h3,h4{letter-spacing:-.025em;line-height:1.05;font-weight:700}
img{display:block;max-width:100%}
a{color:inherit}
::selection{background:rgba(26,191,110,.22)}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:940px;margin:0 auto;padding:0 28px}
.mono{font-family:var(--mono);font-feature-settings:"tnum"}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;padding:13px 24px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;text-decoration:none;transition:transform .18s,box-shadow .18s,background .18s,border-color .18s}
.btn-p{background:var(--green);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.3) inset,0 8px 22px -10px rgba(26,191,110,.6)}
.btn-p:hover{background:var(--green-d);transform:translateY(-2px);box-shadow:0 0 0 1px rgba(26,191,110,.3),0 14px 30px -10px rgba(26,191,110,.55)}
.btn-o{background:transparent;color:var(--ink);border-color:var(--line2)}.btn-o:hover{border-color:var(--green);color:var(--green-d);transform:translateY(-2px)}
.btn-w{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.35);backdrop-filter:blur(6px)}.btn-w:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}
.btn-d{background:#fff;color:var(--ink)}.btn-d:hover{transform:translateY(-2px)}
.btn-lg{padding:16px 30px;font-size:16px}
.arrow{transition:transform .2s}.btn:hover .arrow{transform:translateX(3px)}

/* ---------- Eyebrow ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--green-d)}
.eyebrow::before{content:"";width:18px;height:1.5px;background:currentColor;opacity:.6}
.eyebrow.solo::before{display:none}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:100;background:rgba(246,248,246,.8);backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--line)}
.nav{height:70px;display:flex;align-items:center;justify-content:space-between}
.nav .brand img{height:30px}
.nav nav{display:flex;gap:30px}
.nav nav a{color:var(--ink2);text-decoration:none;font-size:15px;font-weight:500;position:relative}
.nav nav a:hover{color:var(--ink)}
.nav nav a.on{color:var(--ink);font-weight:600}
.nav nav a.on::after{content:"";position:absolute;left:0;right:0;bottom:-25px;height:2px;background:var(--green)}
.nav .right{display:flex;gap:10px;align-items:center}

/* ---------- Mobile nav toggle (hamburger) ---------- */
.nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--line2);border-radius:var(--radius);background:var(--card);color:var(--ink);cursor:pointer;padding:0;transition:border-color .18s,color .18s}
.nav-toggle:hover{border-color:var(--green);color:var(--green-d)}
.nav-toggle svg{width:22px;height:22px;display:block}
.nav-toggle .x{display:none}
.nav-toggle[aria-expanded="true"]{border-color:var(--green);color:var(--green-d)}
.nav-toggle[aria-expanded="true"] .bars{display:none}
.nav-toggle[aria-expanded="true"] .x{display:block}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:580px;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--dark2)}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center 42%;background-repeat:no-repeat}
.hero .ov{position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(8,28,16,.82) 0%,rgba(8,28,16,.58) 38%,rgba(10,30,18,.24) 68%,rgba(12,34,20,.06) 100%),
  linear-gradient(0deg,rgba(7,20,11,.5) 0%,rgba(7,20,11,.12) 32%,transparent 60%)}
.hero .grid-lines{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(rgba(25,198,161,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(25,198,161,.07) 1px,transparent 1px);background-size:54px 54px;mask:radial-gradient(120% 80% at 70% 60%,#000,transparent 75%)}
.hero .inner{position:relative;padding:72px 0;z-index:2}
.hero .eyebrow{color:var(--teal)}
.hero h1{font-size:clamp(36px,5.4vw,64px);font-weight:700;max-width:17ch;margin-top:18px;letter-spacing:-.03em}
.hero h1 .g{background:linear-gradient(120deg,#7ef0c0,#19C6A1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.sub{font-size:clamp(17px,1.7vw,21px);color:rgba(255,255,255,.84);max-width:56ch;margin-top:20px;font-weight:400}
.hero .cta{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap}
.hero .proof{display:flex;gap:38px;flex-wrap:wrap;margin-top:46px;padding-top:26px;border-top:1px solid rgba(255,255,255,.14)}
.hero .proof .n{font-family:var(--mono);font-size:26px;font-weight:600;letter-spacing:-.02em}
.hero .proof .n.g{color:var(--teal)}
.hero .proof .l{font-size:12.5px;color:rgba(255,255,255,.6);margin-top:3px;max-width:18ch}
.hero.compact{min-height:420px}
.hero.compact h1{font-size:clamp(32px,4.4vw,52px)}

/* ---------- Trust bar ---------- */
.trust{background:var(--card);border-bottom:1px solid var(--line)}
.trust .row{display:flex;align-items:center;gap:34px;flex-wrap:wrap;padding:22px 0}
.trust .lbl{font-size:13px;color:var(--ink3);font-weight:500;letter-spacing:.01em}
.trust img{height:24px;opacity:.72;filter:grayscale(.2)}
.trust .b3{font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink);border:2px solid var(--ink);border-radius:6px;padding:0 8px}

/* ---------- Sections ---------- */
.sec{padding:80px 0;position:relative}
.sec.tight{padding:54px 0}
.sec.dark{background:var(--dark2);color:#fff;overflow:hidden}
.sec.dark::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 80% 10%,rgba(25,198,161,.12),transparent 60%);pointer-events:none}
.sec.alt{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-h{max-width:60ch}
.sec-h.center{margin:0 auto;text-align:center}
.sec-h h2{font-size:clamp(28px,3.6vw,42px);font-weight:700;margin-top:14px;letter-spacing:-.03em}
.sec-h p{color:var(--ink2);margin-top:14px;font-size:18px;line-height:1.55}
.sec.dark .sec-h p{color:rgba(255,255,255,.72)}
.lead{font-size:clamp(18px,1.8vw,24px);line-height:1.5;max-width:64ch;font-weight:400}
.lead b{color:var(--green-d);font-weight:600}
.sec.dark .lead b{color:var(--teal)}

/* ---------- Grid + cards ---------- */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm);transition:transform .22s,box-shadow .22s,border-color .22s}
.card.lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line2)}
.card h3{font-size:20px;font-weight:600;margin-bottom:9px}
.card p{color:var(--ink2);font-size:15px;line-height:1.55}
.card .ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:rgba(26,191,110,.1);color:var(--green-d);margin-bottom:18px}
.card .ic svg{width:22px;height:22px}
.sec.dark .card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1);backdrop-filter:blur(6px)}
.sec.dark .card h3{color:#fff}.sec.dark .card p{color:rgba(255,255,255,.72)}
.sec.dark .card .ic{background:rgba(25,198,161,.14);color:var(--teal)}

/* ---------- Door cards ---------- */
.doors{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.door{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .24s,box-shadow .24s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.door:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.door .thumb{height:170px;overflow:hidden;border-bottom:1px solid var(--line);position:relative}
.door .thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s}
.door:hover .thumb img{transform:scale(1.04)}
.door .body{padding:24px;display:flex;flex-direction:column;flex:1}
.door .tag{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.door h3{font-size:22px;font-weight:600;margin-bottom:9px}
.door p{color:var(--ink2);font-size:14.5px;flex:1;line-height:1.55}
.door .go{margin-top:20px;font-weight:600;color:var(--green-d);font-size:14.5px;display:inline-flex;gap:6px}
.door:hover .go .arrow{transform:translateX(3px)}
.door .bar{height:4px}
.door.ti .bar{background:var(--purple)}.door.au .bar{background:var(--green)}.door.co .bar{background:var(--teal)}

/* ---------- Stat ---------- */
.stat .n{font-family:var(--mono);font-size:clamp(32px,4.2vw,52px);font-weight:600;letter-spacing:-.04em;line-height:1;color:var(--green-d)}
.stat .n.tx{color:var(--ink)}.sec.dark .stat .n{color:var(--teal)}
.stat .l{color:var(--ink2);font-size:14px;margin-top:10px;line-height:1.5}
.sec.dark .stat .l{color:rgba(255,255,255,.62)}

/* ---------- Clean list ---------- */
ul.clean{list-style:none;display:flex;flex-direction:column;gap:14px}
ul.clean li{display:flex;gap:13px;align-items:flex-start;font-size:16px;line-height:1.5}
ul.clean li .mk{flex:0 0 auto;width:24px;height:24px;border-radius:8px;background:rgba(26,191,110,.13);color:var(--green-d);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;margin-top:1px}
.sec.dark ul.clean li{color:rgba(255,255,255,.86)}
.sec.dark ul.clean li .mk{background:rgba(25,198,161,.16);color:var(--teal)}

/* ---------- Table ---------- */
.tbl{width:100%;border-collapse:collapse;margin-top:10px;font-size:15px}
.tbl th,.tbl td{text-align:left;padding:15px 18px;border-bottom:1px solid var(--line)}
.tbl thead th{color:var(--ink3);font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.tbl td:first-child{font-weight:600}
.tbl tr.hl td{background:rgba(26,191,110,.05)}
.tbl .yes{color:var(--green-d);font-weight:700}.tbl .no{color:#c2553f}
.tbl.dark th,.tbl.dark td{border-color:rgba(255,255,255,.12)}

/* ---------- Pills ---------- */
.pill{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;border:1px solid var(--line2);font-size:14px;font-weight:500;background:#fff}
.pill.mint{border-color:rgba(26,191,110,.4);color:var(--green-d);background:rgba(26,191,110,.06)}
.pill.dark{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);color:#fff}

/* ---------- Device / browser frame (eleva screenshots) ---------- */
.frame{border-radius:14px;overflow:hidden;border:1px solid var(--line2);box-shadow:var(--shadow-lg);background:#fff}
.frame .bar{height:38px;background:#f0f3f0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:7px;padding:0 14px}
.frame .bar i{width:11px;height:11px;border-radius:50%;background:#cfd6cf;display:block}
.frame .bar i:nth-child(1){background:#e6837a}.frame .bar i:nth-child(2){background:#e8c267}.frame .bar i:nth-child(3){background:#8fd3a6}
.frame .bar .url{margin-left:12px;font-size:12px;color:var(--ink3);font-family:var(--mono);background:#fff;border:1px solid var(--line);border-radius:6px;padding:3px 12px}
.frame img{width:100%;display:block}

/* ---------- Cockpit / dark feature ---------- */
.cockpit{position:relative;background:var(--dark2);color:#fff;border-radius:22px;padding:48px;display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center;overflow:hidden}
.cockpit::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 100% at 100% 0,rgba(25,198,161,.16),transparent 60%)}
.cockpit>*{position:relative}
.cockpit .eyebrow{color:var(--teal)}
.cockpit h2{font-size:30px;font-weight:700;margin-top:14px;letter-spacing:-.03em}
.cockpit p{color:rgba(255,255,255,.74);margin-top:14px;font-size:16px}
.cockpit .mini{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.cockpit .mini .b{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:13px;padding:18px}
.cockpit .mini .b .n{font-family:var(--mono);font-size:24px;font-weight:600;color:var(--teal);letter-spacing:-.03em}
.cockpit .mini .b .l{font-size:12px;color:rgba(255,255,255,.56);margin-top:3px}

/* ---------- Footer ---------- */
footer{padding:56px 0 34px;background:var(--card);border-top:1px solid var(--line)}
.foot{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap}
.foot .brand img{height:30px;margin-bottom:14px}
.foot .tag{color:var(--ink2);font-size:14.5px;max-width:32ch;line-height:1.6}
.foot .meta{color:var(--ink3);font-size:13px;margin-top:12px;line-height:1.8}
.foot .cols{display:flex;gap:58px}
.foot .col h4{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px}
.foot .col a{display:block;color:var(--ink2);text-decoration:none;font-size:14.5px;margin-bottom:10px}
.foot .col a:hover{color:var(--green-d)}
.copyr{border-top:1px solid var(--line);margin-top:36px;padding-top:20px;color:var(--ink3);font-size:13px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ---------- Mock banner ---------- */
.mockbar{background:var(--dark);color:#bfe;font-size:12.5px;text-align:center;padding:10px 16px;letter-spacing:.01em}
.mockbar b{color:var(--teal)}.mockbar a{color:var(--teal);text-decoration:underline}

/* ---------- Reveal on load (staggered) ---------- */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.21s}.d4{animation-delay:.29s}.d5{animation-delay:.37s}.d6{animation-delay:.45s}
@media(prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1}}

/* ---------- Section divider w/ contour motif ---------- */
.contour{position:absolute;inset:0;pointer-events:none;opacity:.5;background-repeat:no-repeat;background-position:center;background-size:cover;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1200' height='400' fill='none' stroke='%231ABF6E' stroke-opacity='0.06' stroke-width='1.2'%3E%3Cpath d='M0 80 Q300 20 600 80 T1200 80'/%3E%3Cpath d='M0 140 Q300 80 600 140 T1200 140'/%3E%3Cpath d='M0 200 Q300 140 600 200 T1200 200'/%3E%3Cpath d='M0 260 Q300 200 600 260 T1200 260'/%3E%3Cpath d='M0 320 Q300 260 600 320 T1200 320'/%3E%3C/svg%3E")}

@media(max-width:880px){
  .g2,.g3,.g4,.doors{grid-template-columns:1fr}
  .cockpit{grid-template-columns:1fr;padding:32px}
  .hero .ov{background:linear-gradient(180deg,rgba(8,28,16,.74),rgba(7,20,11,.5) 60%,rgba(7,20,11,.66))}
  .sec{padding:56px 0}

  /* mobile: hide desktop nav + inline CTAs, show hamburger.
     Brand + toggle stay on the 70px top row; the dropdown (nav links + CTAs)
     wraps to a full-width block below — no absolute positioning, no overlap. */
  .nav{flex-wrap:wrap}
  .nav .brand{order:1}
  .nav-toggle{display:inline-flex;order:2;margin-left:auto}
  .nav nav{display:none}
  .nav .right{display:none}

  header.open .nav nav,
  header.open .nav .right{order:3;flex:1 0 100%}
  header.open .nav nav{
    display:flex;flex-direction:column;gap:0;
    margin-top:8px;padding-top:6px;border-top:1px solid var(--line)
  }
  header.open .nav nav a{padding:14px 2px;font-size:16px;border-bottom:1px solid var(--line)}
  header.open .nav nav a.on::after{display:none}
  header.open .nav .right{
    display:flex;flex-direction:column;align-items:stretch;gap:10px;
    margin-top:14px;padding-bottom:6px
  }
  header.open .nav .right .btn{width:100%;justify-content:center}
}
