
:root{
  --bg:#0b120e;
  --bg-2:#0f1a14;
  --paper:#ffffff;
  --paper-2:#f4f8f6;
  --ink:#0d1411;
  --ink-soft:#41504a;
  --mute:#6b7a73;
  --green:#16a34a;
  --green-2:#1d9e75;
  --green-deep:#0f6e56;
  --green-glow:rgba(29,158,117,.18);
  --amber:#c9791a;
  --line:rgba(13,20,17,.10);
  --line-soft:rgba(13,20,17,.06);
  --line-dark:rgba(255,255,255,.12);
  --radius:16px;
  --radius-sm:10px;
  --maxw:1080px;
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"Space Mono","Inter",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.12;letter-spacing:-.02em}
a{color:inherit}
img,svg{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green-2);font-weight:700;margin-bottom:14px;display:inline-block;
}
.section{padding:clamp(64px,9vw,120px) 0}
.section--paper2{background:var(--paper-2)}
.lead{font-size:clamp(17px,2.1vw,20px);color:var(--ink-soft);max-width:62ch}

/* ---------- progress bar ---------- */
.progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--green),var(--green-2));width:0;z-index:200;transition:width .1s linear}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(10px);background:rgba(11,18,14,.72);border-bottom:1px solid var(--line-dark);transition:transform .35s ease}
.nav.hide{transform:translateY(-100%)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-family:var(--display);font-weight:700;letter-spacing:.02em}
.brand .ring{width:26px;height:26px;border:2px solid var(--green-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--green-2)}
.brand-logo{width:30px;height:30px;border-radius:7px;object-fit:cover;background:#fff;padding:2px}
.nav-links{display:flex;gap:26px}
.nav-links a{color:rgba(255,255,255,.72);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{background:var(--green);color:#06140d!important;padding:8px 16px;border-radius:999px;font-weight:600;font-size:13px;text-decoration:none;transition:background .2s}
.nav-cta:hover{background:var(--green-2)}
@media(max-width:760px){.nav-links{display:none}}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--bg);color:#fff;padding:130px 0 90px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(700px 380px at 78% 18%,var(--green-glow),transparent 70%);pointer-events:none}
.hero-grid{position:absolute;inset:0;opacity:.05;background-image:linear-gradient(var(--green-2) 1px,transparent 1px),linear-gradient(90deg,var(--green-2) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at 70% 25%,#000,transparent 75%)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.25fr .75fr;gap:40px;align-items:center}
.hero h1{font-size:clamp(34px,5.4vw,58px);color:#fff;margin:8px 0 22px}
.hero h1 .hl{color:var(--green-2)}
.hero .lead{color:rgba(255,255,255,.74);max-width:54ch}
.status{display:inline-flex;align-items:center;gap:9px;background:rgba(29,158,117,.12);border:1px solid rgba(29,158,117,.35);color:#7fe3c4;padding:7px 15px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:26px}
.dot{width:9px;height:9px;border-radius:50%;background:#22d39a;box-shadow:0 0 0 0 rgba(34,211,154,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,211,154,.55)}70%{box-shadow:0 0 0 12px rgba(34,211,154,0)}100%{box-shadow:0 0 0 0 rgba(34,211,154,0)}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:999px;font-weight:600;font-size:15px;text-decoration:none;transition:transform .15s ease,background .2s,border-color .2s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--green);color:#06140d}
.btn-primary:hover{background:var(--green-2);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.25);color:#fff}
.btn-ghost:hover{border-color:#fff;transform:translateY(-2px)}
/* ring signature */
.ring-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:260px}
.ring-art svg{width:min(320px,80%);height:auto;filter:drop-shadow(0 0 30px var(--green-glow))}
.logo-halo{position:relative;width:min(320px,82%);aspect-ratio:1;display:flex;align-items:center;justify-content:center;animation:floaty 6s ease-in-out infinite}
/* selo redondo com a logo */
.hero-logo{width:84%;height:84%;object-fit:cover;border-radius:50%;background:#fff;box-shadow:0 16px 44px -12px rgba(0,0,0,.55),0 0 0 6px rgba(255,255,255,.04)}
/* anel girando em volta */
.logo-halo::before{content:"";position:absolute;inset:0;border-radius:50%;border:2px dashed rgba(29,158,117,.6);border-top-color:#22d39a;border-right-color:#22d39a;animation:spin 14s linear infinite}
.logo-halo::after{content:"";position:absolute;inset:5%;border-radius:50%;border:1px solid rgba(29,158,117,.25);animation:spin 22s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.ring-rot{transform-origin:center;animation:spin 26s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ring-chip{position:absolute;font-family:var(--mono);font-size:11px;letter-spacing:.06em;background:rgba(11,18,14,.8);border:1px solid var(--line-dark);color:#9fe7cf;padding:5px 10px;border-radius:8px}
.ring-chip.c1{top:8%;left:-2%}
.ring-chip.c2{bottom:14%;right:-4%}
.ring-chip.c3{bottom:-2%;left:18%}
@media(max-width:860px){
  .hero .wrap{grid-template-columns:1fr}
  .ring-art{min-height:200px;order:-1}
  .ring-chip{display:none}
}

/* ---------- hero stats ---------- */
.hero-stats{position:relative;border-top:1px solid var(--line-dark);margin-top:64px;padding-top:30px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.hstat .n{font-family:var(--display);font-size:clamp(22px,3vw,30px);font-weight:700;color:#fff}
.hstat .l{font-size:13px;color:rgba(255,255,255,.6);margin-top:2px}
.hstat .n .u{color:var(--green-2)}
@media(max-width:680px){.hero-stats{grid-template-columns:repeat(2,1fr);gap:24px 16px}}

/* ---------- generic section head ---------- */
.shead{max-width:64ch;margin-bottom:46px}
.shead h2{font-size:clamp(26px,3.8vw,40px);margin:6px 0 16px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- cards ---------- */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g2,.g3,.g4{grid-template-columns:1fr}}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.section--paper2 .card{background:#fff}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px -18px rgba(13,20,17,.22);border-color:var(--line)}
.card .ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--green-glow);color:var(--green-deep);font-size:22px;margin-bottom:16px}
.card h3{font-size:19px;margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:15px}
.pain .ico{background:rgba(201,121,26,.12);color:#9c5d10}

/* ---------- flow (ciclo) ---------- */
.flow{display:flex;align-items:stretch;gap:0;flex-wrap:wrap;counter-reset:s}
.flow-step{flex:1 1 160px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 18px;position:relative;margin:8px}
.flow-step .k{font-family:var(--mono);font-size:12px;color:var(--green-2);font-weight:700}
.flow-step h4{font-size:16px;margin:8px 0 4px}
.flow-step p{font-size:13.5px;color:var(--mute)}
.flow-arrow{align-self:center;color:var(--green-2);font-size:20px;flex:0 0 auto}
@media(max-width:760px){.flow-arrow{transform:rotate(90deg)}}

/* ---------- checklist (a prova) ---------- */
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 26px}
@media(max-width:640px){.checks{grid-template-columns:1fr}}
.check{display:flex;gap:13px;align-items:flex-start;padding:6px 0}
.check .tick{flex:0 0 auto;width:24px;height:24px;border-radius:7px;background:var(--green);color:#06140d;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;margin-top:2px}
.check b{font-weight:600}
.check span{display:block;font-size:13.5px;color:var(--mute)}

/* ---------- chart panel ---------- */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.panel h3{font-size:18px;margin-bottom:4px}
.panel .sub{font-size:13.5px;color:var(--mute);margin-bottom:20px}
.chart-box{position:relative;width:100%;height:300px}
.legend{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:14px;font-size:13px;color:var(--mute)}
.legend span{display:flex;align-items:center;gap:7px}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block}
.note{font-size:12.5px;color:var(--mute);margin-top:14px;font-style:italic}

/* ---------- market ---------- */
.sectors{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.tag{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 17px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;transition:border-color .2s,transform .2s}
.tag:hover{border-color:var(--green-2);transform:translateY(-2px)}
.tag i{color:var(--green-2)}

/* ---------- roadmap ---------- */
.road{display:flex;flex-direction:column;gap:14px}
.road-item{display:flex;gap:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.road-item .bar{flex:0 0 6px}
.road-item .body{padding:20px 22px}
.road-item .num{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;font-family:var(--display);font-weight:700;font-size:14px;margin-bottom:6px}
.road-item h4{font-size:18px;margin-bottom:6px}
.road-item p{font-size:14.5px;color:var(--ink-soft)}
.road-item .badge{font-size:12px;font-weight:600;color:var(--green-deep);background:var(--green-glow);padding:2px 10px;border-radius:999px;margin-left:8px}

/* ---------- thesis ---------- */
.thesis{background:var(--bg);color:#fff;text-align:center;position:relative;overflow:hidden}
.thesis::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% 0%,var(--green-glow),transparent 70%)}
.thesis .wrap{position:relative}
.thesis blockquote{font-family:var(--display);font-weight:600;font-size:clamp(24px,4vw,40px);line-height:1.25;letter-spacing:-.02em;max-width:20ch;margin:0 auto;color:#fff}
.thesis blockquote .hl{color:var(--green-2)}

/* ---------- honesty ---------- */
.honesty .card{border-left:4px solid var(--amber);border-radius:0 var(--radius) var(--radius) 0}
.honesty .ico{background:rgba(201,121,26,.12);color:#9c5d10}

/* ---------- CTA ---------- */
.cta{background:var(--bg-2);color:#fff;text-align:center}
.cta h2{font-size:clamp(26px,4vw,40px);color:#fff;margin-bottom:14px}
.cta p{color:rgba(255,255,255,.7);max-width:50ch;margin:0 auto 28px}
.contacts{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:8px}
.contact{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.05);border:1px solid var(--line-dark);border-radius:12px;padding:14px 20px;color:#fff;text-decoration:none;font-size:14.5px;transition:border-color .2s,background .2s}
.contact:hover{border-color:var(--green-2);background:rgba(29,158,117,.1)}
.contact i{color:var(--green-2);font-size:18px}

/* ---------- footer ---------- */
.foot{background:var(--bg);color:rgba(255,255,255,.5);padding:34px 0;border-top:1px solid var(--line-dark);font-size:13px}
.foot .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;align-items:center}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ==========================================================
   LINGUAGEM XMTI: 3D no hero + vidro SÓ nos cartões
   (checks, stats e painéis mantêm o desenho original)
   ========================================================== */
.hero-grid { perspective: 750px; }
.ring-art {
  transform-style: preserve-3d;
  transition: transform 0.15s ease-out;
  animation: flutuarApres 7s ease-in-out infinite;
  filter: drop-shadow(0 0 22px rgba(29, 158, 117, 0.35));
}
.ring-chip { transform: translateZ(60px); }
.hero-logo, .logo-halo { transform: translateZ(40px); }
@keyframes flutuarApres {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-12px); }
}

/* Vidro apenas nos cartões (preserva raio e padding originais) */
.card, .pain {
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.card:hover, .pain:hover {
  transform: translateY(-6px);
  border-color: #1d9e75;
  box-shadow: 0 14px 34px -18px rgba(13, 20, 17, 0.25),
              0 0 22px rgba(29, 158, 117, 0.18);
}

@media (prefers-reduced-motion: reduce) {
  .ring-art { animation: none; transition: none; }
}

/* ===== Marca oficial: Moonstone (a fonte do logo) ===== */
@font-face {
  font-family: 'Moonstone';
  src: url('../fonts/moonstone.woff') format('woff'),
       url('../fonts/moonstone.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
.brand {
  font-family: 'Moonstone', var(--display), sans-serif;
  font-weight: normal;
  font-size: 26px;
  letter-spacing: 0.02em;
  line-height: 0.9;
  display: inline-flex;
  align-items: baseline;
  text-decoration: none;
}
.brand .bxm { color: #5FE08A; }
.brand .bti { color: #F2F6F3; }

/* Botões falam a tipografia da casa (mesma família dos títulos) */
.btn, .nav-cta { font-family: var(--display); font-weight: 600; }
