/* ── RESET ─────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#060E1C;color:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ── TOKENS ─────────────────────────────────── */
:root{
  --ink:#0A1628;--ink-deep:#060E1C;--ink-card:#0D1F3C;--ink-card2:#0F2244;
  --lab:#00C49A;--lab-dim:rgba(0,196,154,.1);--lab-mid:rgba(0,196,154,.2);
  --lab-glow:rgba(0,196,154,.07);
  --white:#fff;--gray-d:#4A5568;--gray-m:#94A3B8;--gray-l:#CBD5E1;
}

/* ── KEYFRAMES ───────────────────────────────── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 20px rgba(0,196,154,.15)}50%{box-shadow:0 0 60px rgba(0,196,154,.45),0 0 0 8px rgba(0,196,154,.06)}}
@keyframes border-glow{0%,100%{border-color:rgba(0,196,154,.2)}50%{border-color:rgba(0,196,154,.7)}}
@keyframes shimmer{0%{transform:translateX(-120%) skewX(-15deg)}100%{transform:translateX(220%) skewX(-15deg)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes glow-breathe{0%,100%{opacity:.35;transform:scale(1)}50%{opacity:.65;transform:scale(1.08)}}
@keyframes word-in{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes slide-in-hero{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes live-dot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(2.2);opacity:.25}}
@keyframes spin-slow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes fade-in{from{opacity:0}to{opacity:1}}

/* ── INTRO KEYFRAMES ─────────────────────────── */
@keyframes tli-slash{
  0%{opacity:0;transform:scale(0) rotate(-20deg)}
  65%{transform:scale(1.18) rotate(4deg)}
  100%{opacity:1;transform:scale(1) rotate(0deg)}
}
@keyframes tli-left{from{opacity:0;transform:translateX(-48px)}to{opacity:1;transform:translateX(0)}}
@keyframes tli-right{from{opacity:0;transform:translateX(48px)}to{opacity:1;transform:translateX(0)}}
@keyframes tli-line-draw{from{width:0;opacity:0}to{width:260px;opacity:1}}
@keyframes tli-tag-in{from{opacity:0;transform:translateY(8px)}to{opacity:.65;transform:translateY(0)}}
@keyframes tli-slash-glow{0%,100%{text-shadow:0 0 24px rgba(0,196,154,.7)}50%{text-shadow:0 0 60px rgba(0,196,154,1),0 0 120px rgba(0,196,154,.5)}}
@keyframes tli-particle{0%{transform:translateY(0) scale(1);opacity:.6}100%{transform:translateY(-80px) scale(0);opacity:0}}
@keyframes tli-exit{
  0%{opacity:1;transform:scale(1)}
  30%{opacity:1;transform:scale(1.015)}
  100%{opacity:0;transform:scale(1.04);visibility:hidden}
}
@keyframes tli-bg-shimmer{
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}

/* ── SCROLL ANIMATIONS ───────────────────────── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .8s ease,transform .8s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .8s ease,transform .8s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.94);transition:opacity .6s ease,transform .6s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}
.stagger-4{transition-delay:.4s}.stagger-5{transition-delay:.5s}.stagger-6{transition-delay:.6s}

/* ── HERO WORD ANIMATE ───────────────────────── */
.hero-word{display:inline-block;opacity:0;animation:word-in .6s cubic-bezier(.22,1,.36,1) forwards}
.hero-sub-animate,.hero-body-animate,.hero-ctas-animate,.hero-note-animate{opacity:0;animation:slide-in-hero .5s ease forwards}

/* ── FLOATING ─────────────────────────────── */
.float-1{animation:float 4s ease-in-out infinite}
.float-2{animation:float2 5.5s ease-in-out infinite}
.glow-orb{animation:glow-breathe 6s ease-in-out infinite}

/* ── SCROLL PROGRESS BAR ─────────────────── */
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--lab),#00ffc8);z-index:200;
  transition:width .05s linear;box-shadow:0 0 10px rgba(0,196,154,.6)}

/* ── 3D TILT ─────────────────────────────── */
.tilt-card{transform-style:preserve-3d;transition:box-shadow .3s}
.tilt-card:hover{box-shadow:0 24px 60px rgba(0,196,154,.15)}

/* ── BUTTONS ─────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:15px;font-weight:700;
  padding:15px 32px;border-radius:7px;border:none;cursor:pointer;text-decoration:none;
  transition:all .25s;white-space:nowrap}
.btn-primary{background:var(--lab);color:#060E1C;position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:0;left:0;width:60%;height:100%;
  background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.18) 50%,transparent 80%);
  animation:shimmer 3s ease-in-out 2s infinite}
.btn-primary:hover{background:#00DFB0;transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,196,154,.3)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.18)}
.btn-outline:hover{border-color:var(--lab);color:var(--lab)}
.btn-lg{font-size:17px;padding:18px 40px;border-radius:8px}
.btn-full{width:100%;justify-content:center}

/* ── LAYOUT ─────────────────────────────── */
.container{max-width:1240px;margin:0 auto;padding:0 60px}
section{position:relative;overflow:hidden}
.h2{font-size:clamp(32px,3.5vw,52px);font-weight:900;letter-spacing:-1.5px;line-height:1.1}
.body{font-size:16px;color:var(--gray-m);line-height:1.75}
.glow-orb{position:absolute;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(0,196,154,.18) 0%,transparent 70%)}
.section-label{display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;letter-spacing:3px;color:var(--lab);text-transform:uppercase;margin-bottom:18px}
.section-label::before{content:'//';font-weight:900}
.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.icon svg{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ── NAVBAR ─────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;height:72px;
  background:rgba(6,14,28,.85);backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(0,196,154,.1);transition:background .3s,border-color .3s}
nav .container{height:100%;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-size:16px;font-weight:900;letter-spacing:3px;color:#fff;text-decoration:none}
.nav-logo .slash{color:var(--lab)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--gray-m);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:#fff}

/* ── HERO ─────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:72px;
  background:linear-gradient(135deg,#04080F 0%,#060E1C 45%,#071A2E 100%)}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
  padding-top:60px;padding-bottom:80px}
.hero-label{display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,196,154,.08);border:1px solid rgba(0,196,154,.2);
  border-radius:100px;padding:7px 16px;
  font-size:11px;font-weight:700;letter-spacing:3px;color:var(--lab);
  text-transform:uppercase;margin-bottom:28px}
.hero-label::before{content:'//';font-weight:900}
.hero-h1{font-size:clamp(48px,5.5vw,76px);font-weight:900;letter-spacing:-3px;
  line-height:1.02;margin-bottom:20px}
.line-accent{color:var(--lab)}
.hero-sub{font-size:20px;font-weight:700;color:var(--lab);letter-spacing:.5px;margin-bottom:20px}
.hero-sub .sep{opacity:.5;margin:0 4px}
.hero-body{font-size:17px;color:var(--gray-m);line-height:1.7;margin-bottom:36px;max-width:460px}
.hero-ctas{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.hero-note{font-size:13px;color:var(--gray-d)}

/* platform mockup */
.platform-card{background:var(--ink-card);border:1px solid rgba(0,196,154,.12);
  border-radius:20px;overflow:hidden;box-shadow:0 48px 96px rgba(0,0,0,.5),0 0 60px rgba(0,196,154,.06)}
.platform-topbar{background:rgba(10,22,40,.9);padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.05)}
.platform-logo{font-size:12px;font-weight:900;letter-spacing:2px;color:#fff}
.platform-tabs{display:flex;gap:18px}
.platform-tabs span{font-size:12px;color:var(--gray-d);cursor:pointer;transition:color .2s}
.platform-tabs span.active{color:var(--lab);border-bottom:2px solid var(--lab);padding-bottom:2px}
.instructor-strip{display:flex;align-items:center;gap:0;padding:12px 20px;
  border-bottom:1px solid rgba(255,255,255,.04)}
.instructor-strip-label{font-size:12px;color:var(--gray-d);margin-right:8px}
.instr-avatar{width:28px;height:28px;border-radius:50%;
  background:var(--ink-card2);border:2px solid var(--ink-card);
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.instr-avatar-img{width:100%;height:100%;background:linear-gradient(135deg,#1a3a5c,#0d2233)}
.instr-avatar-img.r1{background:linear-gradient(135deg,#00C49A33,#0d2233)}
.instr-avatar-img.r2{background:linear-gradient(135deg,#6366f133,#1e1040)}
.instr-avatar-img.r3{background:linear-gradient(135deg,#f59e0b33,#2a1800)}
.instr-initials{position:absolute;font-size:9px;font-weight:800;color:#fff}
.now-playing{display:flex;align-items:center;gap:6px;margin-left:auto;
  font-size:11px;color:var(--lab);font-weight:600}
.play-dot{width:7px;height:7px;border-radius:50%;background:var(--lab);
  animation:live-dot 1.5s ease-in-out infinite}
.platform-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.04)}
.mini-trail{background:var(--ink-card);padding:16px;position:relative}
.mt-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;margin-bottom:10px;color:var(--lab)}
.mt1 .mt-icon{background:rgba(0,196,154,.1)}
.mt2 .mt-icon{background:rgba(99,102,241,.1);color:#818cf8}
.mt3 .mt-icon{background:rgba(245,158,11,.1);color:#fbbf24}
.mt4 .mt-icon{background:rgba(239,68,68,.1);color:#f87171}
.mt-code{font-size:9px;font-weight:700;letter-spacing:2px;color:var(--gray-d);margin-bottom:3px}
.mt-name{font-size:13px;font-weight:700;color:#fff;margin-bottom:8px}
.mt-tag{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 8px;border-radius:4px;display:inline-block}
.mt1 .mt-tag{background:rgba(0,196,154,.12);color:var(--lab)}
.mt2 .mt-tag{background:rgba(99,102,241,.12);color:#818cf8}
.mt3 .mt-tag{background:rgba(245,158,11,.12);color:#fbbf24}
.mt4 .mt-tag{background:rgba(239,68,68,.12);color:#f87171}
.mt-progress{height:3px;background:rgba(255,255,255,.06);border-radius:2px;margin-top:12px}
.mt-progress-fill{height:100%;border-radius:2px;background:var(--lab);
  transition:width 1s ease;width:0}
.mt1 .mt-progress-fill{width:68%;background:var(--lab)}
.mt2 .mt-progress-fill{width:45%;background:#818cf8}
.mt3 .mt-progress-fill{width:82%;background:#fbbf24}
.mt4 .mt-progress-fill{width:31%;background:#f87171}
.platform-footer{padding:12px 20px;display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.04)}
.pf-label{font-size:11px;color:var(--gray-d);display:flex;align-items:center;gap:6px}
.new-badge{font-size:9px;font-weight:800;letter-spacing:2px;background:rgba(0,196,154,.15);
  color:var(--lab);border:1px solid rgba(0,196,154,.25);padding:3px 8px;border-radius:4px}

/* ── BENEFITS BAR ─────────────────────── */
.benefits{background:var(--ink);padding:24px 0;border-top:1px solid rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.04)}
.benefits .container{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.benefit{display:flex;align-items:center;gap:16px;padding:16px 28px;
  border-right:1px solid rgba(255,255,255,.06)}
.benefit:last-child{border-right:none}
.benefit-icon-box{width:40px;height:40px;border-radius:10px;
  background:var(--lab-dim);border:1px solid rgba(0,196,154,.15);
  display:flex;align-items:center;justify-content:center;color:var(--lab);flex-shrink:0}
.benefit-icon-box svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.benefit-text{display:flex;flex-direction:column;gap:2px}
.benefit-text strong{font-size:14px;font-weight:700;color:#fff}
.benefit-text span{font-size:12px;color:var(--gray-d)}

/* ── MANIFESTO ────────────────────────── */
.manifesto{background:var(--ink-deep);padding:120px 0}
.manifesto .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.man-lines{margin-top:40px;display:flex;flex-direction:column;gap:0}
.man-line{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:16px;line-height:1.55}
.man-line.taught{color:var(--gray-d);font-style:italic}
.man-line.truth{color:#fff;font-weight:600;display:flex;gap:12px;align-items:flex-start}
.slash-marker{color:var(--lab);font-weight:900;font-size:18px;flex-shrink:0;margin-top:1px}

.renan-card{background:var(--ink-card);border:1px solid rgba(0,196,154,.1);border-radius:20px;overflow:hidden}
.renan-photo{height:300px;position:relative;
  background:linear-gradient(145deg,#0C2840 0%,#071a28 50%,#040C18 100%);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.renan-photo-placeholder{width:80px;height:80px;border-radius:50%;
  background:rgba(0,196,154,.08);border:2px dashed rgba(0,196,154,.25);
  display:flex;align-items:center;justify-content:center;color:rgba(0,196,154,.4)}
.renan-photo-placeholder svg{width:36px;height:36px}
.renan-photo-hint{font-size:11px;color:rgba(0,196,154,.35);letter-spacing:2px;text-transform:uppercase}
.renan-info{padding:24px 28px 28px}
.renan-name{font-size:20px;font-weight:900;margin-bottom:3px}
.renan-role{font-size:13px;color:var(--lab);letter-spacing:.5px;margin-bottom:14px}
.renan-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:20px}
.rtag{font-size:11px;font-weight:600;color:var(--gray-m);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:4px;padding:4px 10px}
.renan-quote{font-size:14px;color:var(--gray-l);font-style:italic;line-height:1.65;
  border-left:2px solid var(--lab);padding-left:16px}

/* ── DIFERENCIAÇÃO ────────────────────── */
.diff{background:var(--ink);padding:120px 0}
.diff-header{margin-bottom:64px}
.diff-table{width:100%;border-collapse:collapse;border-radius:12px;overflow:hidden}
.diff-table th,.diff-table td{padding:16px 24px;text-align:left;font-size:14px}
.diff-table thead th{background:rgba(255,255,255,.03);font-size:11px;
  font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gray-m);padding:14px 24px}
.diff-table .col-bad{color:rgba(239,68,68,.7)}
.diff-table .col-good{color:var(--lab)}
.diff-table tbody tr{border-bottom:1px solid rgba(255,255,255,.04)}
.diff-table tbody tr:hover{background:rgba(255,255,255,.02)}
.diff-table td:first-child{color:var(--gray-l);font-weight:500}
.diff-table .yes,.diff-table .no{text-align:center}
.icon-yes,.icon-no{display:inline-flex;width:22px;height:22px;border-radius:50%;
  align-items:center;justify-content:center}
.icon-yes{background:rgba(0,196,154,.15)}
.icon-yes svg{stroke:var(--lab);width:13px;height:13px;fill:none;stroke-width:2.5}
.icon-no{background:rgba(239,68,68,.1)}
.icon-no svg{stroke:rgba(239,68,68,.7);width:13px;height:13px;fill:none;stroke-width:2.5}

/* ── TRILHAS ──────────────────────────── */
.trilhas{background:var(--ink-deep);padding:120px 0}
.trilhas-hdr{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px}
.trails-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.trail-card{border-radius:16px;overflow:hidden;background:var(--ink-card);
  border:1px solid rgba(255,255,255,.06);transition:transform .25s,border-color .25s;cursor:pointer}
.trail-card:hover{transform:translateY(-6px);border-color:rgba(0,196,154,.2)}
.trail-card-img{height:160px;position:relative;display:flex;align-items:center;justify-content:center}
.trail-card-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center}
.trail-card-icon svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:1.8}
.tc1{background:linear-gradient(135deg,#0a2218,#040c0a)}
.tc1 .trail-card-icon{background:rgba(0,196,154,.15);color:var(--lab)}
.tc2{background:linear-gradient(135deg,#120a28,#080410)}
.tc2 .trail-card-icon{background:rgba(99,102,241,.15);color:#818cf8}
.tc3{background:linear-gradient(135deg,#1a1208,#0c0804)}
.tc3 .trail-card-icon{background:rgba(245,158,11,.15);color:#fbbf24}
.tc4{background:linear-gradient(135deg,#1a0a0a,#0c0404)}
.tc4 .trail-card-icon{background:rgba(239,68,68,.15);color:#f87171}
.tc5{background:linear-gradient(135deg,#0a1228,#040810)}
.tc5 .trail-card-icon{background:rgba(59,130,246,.15);color:#60a5fa}
.tc6{background:linear-gradient(135deg,#1a1020,#080410)}
.tc6 .trail-card-icon{background:rgba(168,85,247,.15);color:#c084fc}
.trail-card-body{padding:20px 24px 24px}
.trail-card-code{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--gray-d);margin-bottom:4px}
.trail-card-name{font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.trail-card-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;padding:3px 9px;border-radius:4px;margin-bottom:12px}
.trail-card-desc{font-size:13px;color:var(--gray-m);line-height:1.6;margin-bottom:16px}
.trail-card-status{display:flex;align-items:center;justify-content:space-between;
  font-size:12px;color:var(--gray-d)}
.status-dot{display:flex;align-items:center;gap:6px}
.status-dot::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gray-d)}
.status-dot.active::before{background:var(--lab)}

/* ── PRICING ──────────────────────────── */
.pricing{background:var(--ink);padding:120px 0;text-align:center}
.pricing-hdr{margin-bottom:64px}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:860px;margin:0 auto}
.plan{background:var(--ink-card);border:1px solid rgba(255,255,255,.08);
  border-radius:20px;padding:40px;text-align:left}
.plan-featured{border-color:rgba(0,196,154,.3);animation:border-glow 2.5s ease-in-out infinite;
  box-shadow:0 0 40px rgba(0,196,154,.08)}
.plan-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:2px;
  background:var(--lab);color:#060E1C;padding:4px 12px;border-radius:100px;margin-bottom:20px}
.plan-name{font-size:11px;font-weight:700;letter-spacing:3px;color:var(--gray-m);
  text-transform:uppercase;margin-bottom:8px}
.plan-tagline{font-size:16px;font-weight:700;color:#fff;margin-bottom:24px}
.plan-price{margin-bottom:4px}
.plan-val{font-size:52px;font-weight:900;letter-spacing:-2px;color:#fff}
.plan-featured .plan-val{color:var(--lab)}
.plan-period{font-size:16px;color:var(--gray-m)}
.plan-billing{font-size:12px;color:var(--gray-d);margin-bottom:28px}
.plan-div{height:1px;background:rgba(255,255,255,.06);margin-bottom:28px}
.plan-feats{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:36px}
.plan-feats li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--gray-l)}
.plan-feats li.disabled{color:var(--gray-d)}
.plan-feats li::before{content:'';width:16px;height:16px;border-radius:50%;flex-shrink:0;
  background:rgba(0,196,154,.1);border:1px solid rgba(0,196,154,.25)}
.plan-feats li.disabled::before{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08)}
.plan-feats li:not(.disabled)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpolyline points='3 8 6.5 11.5 13 5' stroke='%2300C49A' stroke-width='1.8' stroke-linecap='round' fill='none'/%3E%3C/svg%3E")}
.plan-btn{display:block;width:100%;padding:16px;border-radius:10px;font-size:15px;
  font-weight:700;text-align:center;cursor:pointer;border:none;transition:all .25s;text-decoration:none}
.plan-btn-outline{background:transparent;color:var(--lab);border:1.5px solid rgba(0,196,154,.3)}
.plan-btn-outline:hover{background:var(--lab-dim)}
.plan-btn-solid{background:var(--lab);color:#060E1C}
.plan-btn-solid:hover{background:#00DFB0;transform:translateY(-2px)}
.pricing-note{margin-top:28px;font-size:13px;color:var(--gray-d);display:flex;align-items:center;
  justify-content:center;gap:16px}

/* ── INSTRUTORES ──────────────────────── */
.instrutores{background:var(--ink);padding:120px 0}
.instrutores-hdr{text-align:center;margin-bottom:72px}
.instrutores-hdr .h2{font-size:clamp(36px,3.8vw,56px);font-weight:900;letter-spacing:-1.8px;line-height:1.08;margin-bottom:16px}
.instrutores-hdr .sub{font-size:17px;color:var(--gray-m);max-width:560px;margin:0 auto}
.instrutores-layout{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.instr-lead{background:var(--ink-card);border:1px solid rgba(0,196,154,.14);
  border-radius:20px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.4);transition:transform .3s}
.instr-lead:hover{transform:translateY(-4px)}
.instr-lead-photo{height:320px;position:relative;overflow:hidden;
  background:linear-gradient(145deg,#0C2840 0%,#071a28 50%,#040C18 100%);
  display:flex;align-items:center;justify-content:center}
.instr-lead-initials{width:80px;height:80px;border-radius:50%;
  background:rgba(0,196,154,.08);border:2px solid rgba(0,196,154,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:900;color:rgba(0,196,154,.75)}
.instr-lead-trail{position:absolute;top:18px;left:18px;
  background:rgba(0,196,154,.12);border:1px solid rgba(0,196,154,.25);
  border-radius:6px;padding:4px 10px;font-size:10px;font-weight:700;
  letter-spacing:2px;color:var(--lab);text-transform:uppercase}
.instr-lead-body{padding:24px 28px 28px}
.instr-lead-name{font-size:21px;font-weight:900;color:#fff;margin-bottom:3px}
.instr-lead-role{font-size:13px;color:var(--lab);letter-spacing:.5px;margin-bottom:14px}
.instr-lead-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.instr-tag{font-size:11px;font-weight:600;color:var(--gray-m);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:4px;padding:4px 10px}
.instr-lead-quote{font-size:13.5px;color:var(--gray-l);font-style:italic;
  line-height:1.65;border-left:2px solid var(--lab);padding-left:14px}
.instrutores-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.instr-card{background:var(--ink-card2);border:1px solid rgba(255,255,255,.06);
  border-radius:16px;overflow:hidden;transition:transform .25s,border-color .25s}
.instr-card:hover{transform:translateY(-4px);border-color:rgba(0,196,154,.2)}
.instr-card-photo{height:150px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center}
.instr-card-initials{width:48px;height:48px;border-radius:50%;
  background:rgba(0,196,154,.08);border:1.5px solid rgba(0,196,154,.28);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:900;color:rgba(0,196,154,.75)}
.instr-card-trail{position:absolute;top:9px;left:9px;
  font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:2px 7px;border-radius:4px;color:#fff;opacity:.85}
.instr-card-body{padding:14px 18px 18px}
.instr-card-name{font-size:14px;font-weight:800;color:#fff;margin-bottom:2px}
.instr-card-role{font-size:11px;color:var(--gray-m);margin-bottom:8px}
.instr-card-desc{font-size:11.5px;color:var(--gray-d);line-height:1.55}

/* ── DEPOIMENTOS ──────────────────────── */
.depoimentos{background:#060E1C;padding:120px 0}
.dep-hdr{margin-bottom:60px}
.dep-hdr .h2{font-size:clamp(36px,3.5vw,52px);font-weight:900;letter-spacing:-1.5px}
.dep-marquee-wrap{overflow:hidden;width:100%;cursor:grab}
.dep-marquee-wrap:active{cursor:grabbing}
.dep-marquee-track{display:flex;gap:24px;width:max-content;animation:marquee 40s linear infinite}
.dep-marquee-track:hover{animation-play-state:paused}
.dep-card{flex:0 0 360px;border-radius:16px;overflow:hidden;
  border:1px solid rgba(255,255,255,.06);background:var(--ink-card)}
.dep-thumb{height:200px;position:relative;overflow:hidden}
.dep-thumb-bg{position:absolute;inset:0}
.dep-thumb-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,31,60,.95) 0%,transparent 60%)}
.dep-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(0,196,154,.9);display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 8px rgba(0,196,154,.15);transition:transform .2s}
.dep-play:hover{transform:translate(-50%,-50%) scale(1.1)}
.dep-play svg{width:18px;height:18px;margin-left:3px}
.dep-quote-label{position:absolute;bottom:12px;left:16px;right:16px;
  font-size:13px;font-weight:700;color:#fff;line-height:1.4}
.dep-body{padding:20px 24px 24px}
.dep-stars{color:#fbbf24;font-size:14px;letter-spacing:2px;margin-bottom:10px}
.dep-text{font-size:14px;color:var(--gray-l);line-height:1.65;margin-bottom:16px;font-style:italic}
.dep-author{display:flex;align-items:center;gap:12px}
.dep-avatar{width:36px;height:36px;border-radius:50%;
  background:var(--lab-dim);border:2px solid rgba(0,196,154,.25);flex-shrink:0;
  display:flex;align-items:center;justify-content:center}
.dep-avatar-inner{font-size:12px;font-weight:800;color:var(--lab)}
.dep-name{font-size:13px;font-weight:700;color:#fff}
.dep-meta{font-size:11px;color:var(--gray-d)}

/* ── FAQ ──────────────────────────────── */
.faq{background:var(--ink);padding:120px 0}
.faq .container{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}
.faq-l .h2{font-size:clamp(32px,3vw,48px);font-weight:900;letter-spacing:-1.5px;margin-bottom:16px}
.faq-list{display:flex;flex-direction:column;gap:4px}
.faq-item{background:var(--ink-card2);border:1px solid rgba(255,255,255,.06);
  border-radius:12px;overflow:hidden}
.faq-item summary{padding:20px 24px;font-size:15px;font-weight:600;color:#fff;
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-icon{width:24px;height:24px;border-radius:50%;background:var(--lab-dim);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}
.faq-icon svg{width:14px;height:14px;stroke:var(--lab);fill:none;stroke-width:2.5}
.faq-item[open] .faq-icon{transform:rotate(45deg)}
.faq-answer{padding:0 24px 20px;font-size:14px;color:var(--gray-m);line-height:1.7}

/* ── CTA FINAL ────────────────────────── */
.cta-final{background:var(--ink-deep);padding:160px 0;text-align:center;position:relative;overflow:hidden}
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,196,154,.12) 0%,transparent 70%)}
.cta-final .container{position:relative;z-index:1}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.cta-note{display:flex;gap:32px;justify-content:center;font-size:13px;color:var(--gray-d)}
.cta-note span::before{content:'✦ ';color:var(--lab);font-size:10px}

/* ── FOOTER ───────────────────────────── */
footer{background:rgba(4,8,15,1);padding:80px 0 40px;border-top:1px solid rgba(255,255,255,.04)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-brand p{font-size:13px;color:var(--gray-d);line-height:1.7;margin-top:16px;max-width:260px}
.footer-social{display:flex;gap:12px;margin-top:20px}
.social-link{width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;transition:all .2s;text-decoration:none;color:var(--gray-m)}
.social-link:hover{background:var(--lab-dim);border-color:rgba(0,196,154,.3);color:var(--lab)}
.social-link svg{width:16px;height:16px}
footer h4{font-size:11px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--gray-d);margin-bottom:20px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-links a{font-size:14px;color:var(--gray-m);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:12px;color:var(--gray-d)}
.footer-bottom .slash{color:var(--lab);font-size:12px;font-weight:700}

/* ── FORMS ────────────────────────────── */
.capture-form{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.capture-form input{flex:1;min-width:240px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:14px 18px;
  color:#fff;font-size:15px;font-family:inherit;transition:border-color .2s}
.capture-form input::placeholder{color:var(--gray-d)}
.capture-form input:focus{outline:none;border-color:rgba(0,196,154,.4)}
.form-msg{font-size:13px;margin-top:10px;min-height:20px;transition:opacity .3s}
.form-msg.success{color:var(--lab)}
.form-msg.error{color:#f87171}

/* ── PÁGINA OBRIGADO ──────────────────── */
.page-obrigado{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--ink-deep);text-align:center;padding:40px}
.obrigado-card{max-width:520px;padding:64px 48px;background:var(--ink-card);
  border:1px solid rgba(0,196,154,.15);border-radius:24px;animation:fade-in .6s ease}
.obrigado-icon{font-size:48px;margin-bottom:24px}
.obrigado-card h1{font-size:36px;font-weight:900;letter-spacing:-1px;margin-bottom:12px}
.obrigado-card p{font-size:16px;color:var(--gray-m);line-height:1.7;margin-bottom:32px}

/* ── ADMIN ────────────────────────────── */
.page-admin{min-height:100vh;background:var(--ink-deep);padding:100px 0 60px}
.admin-header{margin-bottom:40px}
.admin-header h1{font-size:28px;font-weight:900;margin-bottom:6px}
.admin-header p{font-size:14px;color:var(--gray-m)}
.admin-tabs{display:flex;gap:8px;margin-bottom:32px}
.admin-tab{padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;
  cursor:pointer;border:1px solid rgba(255,255,255,.08);background:transparent;color:var(--gray-m);transition:all .2s}
.admin-tab.active{background:var(--lab-dim);border-color:rgba(0,196,154,.3);color:var(--lab)}
.admin-table-wrap{background:var(--ink-card);border:1px solid rgba(255,255,255,.06);
  border-radius:16px;overflow:hidden}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{padding:14px 20px;text-align:left;font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--gray-d);
  background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.06)}
.admin-table td{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.04);
  color:var(--gray-l)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:rgba(255,255,255,.02)}
.admin-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:1px}
.badge-pro{background:rgba(0,196,154,.1);color:var(--lab);border:1px solid rgba(0,196,154,.2)}
.badge-premium{background:rgba(168,85,247,.1);color:#c084fc;border:1px solid rgba(168,85,247,.2)}
.admin-empty{text-align:center;padding:48px;color:var(--gray-d);font-size:14px}
.admin-login{max-width:400px;margin:0 auto;padding:40px;background:var(--ink-card);
  border:1px solid rgba(255,255,255,.08);border-radius:16px}
.admin-login h2{font-size:20px;font-weight:800;margin-bottom:20px}
.admin-login input{width:100%;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:12px 16px;
  color:#fff;font-size:14px;font-family:inherit;margin-bottom:14px}
.admin-login input:focus{outline:none;border-color:rgba(0,196,154,.4)}
.admin-stat{background:var(--ink-card);border:1px solid rgba(255,255,255,.06);
  border-radius:12px;padding:24px;margin-bottom:24px;display:inline-flex;
  align-items:center;gap:16px;margin-right:16px}
.admin-stat-val{font-size:36px;font-weight:900;color:var(--lab)}
.admin-stat-label{font-size:12px;color:var(--gray-d);margin-top:4px}

/* ══════════════════════════════════════════════════
   TS APP — component styles (matches renderXxx output)
   ══════════════════════════════════════════════════ */

/* ── Shared helpers ─────────────────────────────── */
.hidden{display:none!important}
.btn-lab{background:var(--lab);color:#060E1C;position:relative;overflow:hidden}
.btn-lab::after{content:'';position:absolute;top:0;left:0;width:60%;height:100%;
  background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.18) 50%,transparent 80%);
  animation:shimmer 3s ease-in-out 2s infinite}
.btn-lab:hover{background:#00DFB0;transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,196,154,.3)}
.btn-sm{font-size:13px;padding:9px 20px}
.shimmer-btn{position:relative;overflow:hidden}
.shimmer-btn::after{content:'';position:absolute;top:0;left:0;width:60%;height:100%;
  background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.18) 50%,transparent 80%);
  animation:shimmer 3s ease-in-out 2s infinite}
.section-title{font-size:clamp(32px,3.5vw,52px);font-weight:900;letter-spacing:-1.5px;line-height:1.1;margin-bottom:16px;color:#fff}
.section-sub{font-size:17px;color:var(--gray-m);max-width:600px;margin-bottom:56px;line-height:1.7}

/* ── Navbar ─────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(6,14,28,.85);backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(0,196,154,.1);transition:background .3s}
.navbar.scrolled{background:rgba(4,8,15,.95)}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 60px;height:72px;
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{font-size:16px;font-weight:900;letter-spacing:3px;color:#fff;text-decoration:none}
.nav-logo span{color:var(--lab)}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--gray-m);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{white-space:nowrap}
.nav-actions{display:flex;align-items:center;gap:10px}
.btn-nav-login{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;border-radius:7px;
  border:1.5px solid rgba(255,255,255,.13);
  background:transparent;
  color:var(--gray-m);
  font-size:13px;font-weight:600;
  text-decoration:none;white-space:nowrap;
  transition:all .22s;
}
.btn-nav-login:hover{border-color:rgba(0,196,154,.35);color:#fff;background:rgba(0,196,154,.05)}
.btn-nav-login svg{stroke:currentColor;flex-shrink:0}
.btn-nav-loggedin{border-color:rgba(0,196,154,.3);color:#00C49A}
.btn-nav-loggedin:hover{border-color:#00C49A;background:rgba(0,196,154,.08);color:#00C49A}
.nav-avatar-mini{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:#00C49A;color:#0A1628;
  font-size:10px;font-weight:700;flex-shrink:0;
}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:16px 24px 20px;
  background:rgba(4,8,15,.97);border-top:1px solid rgba(255,255,255,.06)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--gray-m);text-decoration:none;
  padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.mobile-menu a:hover{color:#fff}
@media(max-width:900px){
  .nav-links,.nav-actions{display:none}
  .burger{display:flex}
}

/* ── Hero (TS version) ──────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:72px;
  background:linear-gradient(135deg,#04080F 0%,#060E1C 45%,#071A2E 100%);
  position:relative;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
  padding-top:60px;padding-bottom:80px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,196,154,.08);border:1px solid rgba(0,196,154,.2);
  border-radius:100px;padding:7px 16px;
  font-size:11px;font-weight:700;letter-spacing:3px;color:var(--lab);
  text-transform:uppercase;margin-bottom:28px;animation:fade-in .5s ease}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--lab);
  animation:live-dot 1.5s ease-in-out infinite}
.hero-title{font-size:clamp(42px,5vw,72px);font-weight:900;letter-spacing:-2.5px;
  line-height:1.04;margin-bottom:20px;color:#fff}
.hero-sub{font-size:17px;color:var(--gray-m);line-height:1.7;margin-bottom:32px;max-width:460px}
.hero-form{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.hero-form input{flex:1;min-width:220px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:14px 18px;
  color:#fff;font-size:15px;font-family:inherit;transition:border-color .2s}
.hero-form input::placeholder{color:var(--gray-d)}
.hero-form input:focus{outline:none;border-color:rgba(0,196,154,.4)}
.hero-hint{font-size:12px;color:var(--gray-d);margin-bottom:28px}
.hero-social-proof{display:flex;align-items:center;gap:14px}
.proof-avatars{display:flex}
.proof-av{width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;color:#fff;
  margin-left:-8px;border:2px solid #060E1C}
.proof-av:first-child{margin-left:0}
.hero-social-proof p{font-size:13px;color:var(--gray-m)}
.hero-social-proof strong{color:#fff}
.hero-right{display:flex;flex-direction:column}

/* Platform card (TS hero version) */
.platform-card{background:var(--ink-card);border:1px solid rgba(0,196,154,.12);
  border-radius:20px;padding:20px;box-shadow:0 32px 80px rgba(0,0,0,.5),0 0 40px rgba(0,196,154,.05)}
.card-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.card-icon{font-size:20px}
.card-title{font-size:13px;font-weight:700;color:var(--gray-m)}
.card-progress{margin-bottom:16px}
.progress-label{display:flex;justify-content:space-between;font-size:12px;color:var(--gray-d);margin-bottom:6px}
.progress-pct{color:var(--lab);font-weight:700}
.progress-bar-wrap{height:4px;background:rgba(255,255,255,.08);border-radius:4px;overflow:hidden}
.progress-bar-fill{height:100%;background:var(--lab);border-radius:4px;transition:width 1s ease}
.card-lesson{display:flex;align-items:center;gap:12px}
.lesson-thumb{width:52px;height:52px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,#0a2218,#040c0a)}
.lesson-info{flex:1;min-width:0}
.lesson-title{font-size:13px;font-weight:700;color:#fff;margin-bottom:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lesson-meta{font-size:11px;color:var(--gray-d)}
.platform-streak{display:flex;align-items:center;gap:12px;
  background:rgba(246,173,85,.06);border:1px solid rgba(246,173,85,.15);
  border-radius:12px;padding:12px 16px}
.streak-label{font-size:11px;color:var(--gray-d);margin-bottom:2px}
.streak-count{font-size:14px;font-weight:800;color:#F6AD55}

@media(max-width:860px){.hero-inner{grid-template-columns:1fr}.hero-right{display:none}}

/* ── Benefits bar (TS version) ──────────────────── */
.benefits-bar{background:var(--ink);padding:24px 0;
  border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.benefits-inner{max-width:1240px;margin:0 auto;padding:0 60px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.benefit-item{display:flex;align-items:center;gap:14px;padding:16px 24px;
  border-right:1px solid rgba(255,255,255,.06);font-size:14px;font-weight:600;color:#fff}
.benefit-item:nth-child(3n){border-right:none}
.benefit-icon{font-size:20px}
@media(max-width:860px){.benefits-inner{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.benefits-inner{grid-template-columns:1fr}.benefit-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}}

/* ── Manifesto (TS version) ─────────────────────── */
.manifesto-section{background:var(--ink-deep);padding:120px 0}
.manifesto-inner{max-width:900px}
.manifesto-label{display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;letter-spacing:3px;color:var(--lab);text-transform:uppercase;margin-bottom:28px}
.manifesto-lines{display:flex;flex-direction:column;gap:32px;margin-bottom:56px}
.manifesto-line{font-size:clamp(18px,2vw,22px);color:var(--gray-l);line-height:1.65}
.manifesto-line strong{color:#fff}
.manifesto-line em{color:var(--lab);font-style:normal;font-weight:700}
.manifesto-conclusion{margin-bottom:64px}
.manifesto-conclusion p{font-size:18px;color:var(--gray-m);line-height:1.7;max-width:700px}
.manifesto-conclusion p+p{margin-top:12px}
.manifesto-tagline{font-size:22px!important;font-weight:900!important;color:#fff!important;letter-spacing:-.5px}
.manifesto-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.mstat{background:var(--ink-card);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:24px}
.mstat-num{display:block;font-size:40px;font-weight:900;color:var(--lab);letter-spacing:-2px;margin-bottom:4px;font-variant-numeric:tabular-nums}
.mstat-label{font-size:12px;color:var(--gray-d);letter-spacing:.5px}
@media(max-width:700px){.manifesto-stats{grid-template-columns:1fr 1fr}}

/* ── Diff section (TS version) ──────────────────── */
.diff-section{background:var(--ink);padding:120px 0}
.diff-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid rgba(255,255,255,.06)}
.diff-table{width:100%;border-collapse:collapse;font-size:14px}
.diff-table th{padding:14px 24px;font-size:11px;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--gray-d);background:rgba(255,255,255,.03);text-align:left}
.diff-table td{padding:14px 24px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--gray-l)}
.diff-table tr:last-child td{border-bottom:none}
.diff-table tr:hover td{background:rgba(255,255,255,.02)}
.tll-col{color:var(--lab)!important;font-weight:700}
.tll-val{color:var(--lab)!important}
.others-col{color:rgba(248,113,113,.75)}

/* ── Trails (TS version) ─────────────────────────── */
.trails-section{background:var(--ink-deep);padding:120px 0}
.trail-card{border-radius:16px;background:var(--ink-card);
  border:1px solid rgba(255,255,255,.06);padding:24px;
  transition:transform .25s,border-color .25s;cursor:pointer}
.trail-card:hover{transform:translateY(-6px);border-color:rgba(0,196,154,.2)}
.trail-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}
.trail-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:22px;flex-shrink:0}
.trail-badge{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 9px;border-radius:4px;background:rgba(255,255,255,.07);color:var(--gray-m)}
.badge-hot{background:rgba(246,173,85,.15);color:#F6AD55}
.badge-new{background:rgba(0,196,154,.12);color:var(--lab)}
.trail-code{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--gray-d);margin-bottom:4px}
.trail-name{font-size:18px;font-weight:800;color:#fff;margin-bottom:8px}
.trail-desc{font-size:13px;color:var(--gray-m);line-height:1.6;margin-bottom:16px}
.trail-meta{display:flex;gap:16px;font-size:12px;color:var(--gray-d);margin-bottom:14px}
.trail-bar{height:3px;border-radius:4px;overflow:hidden}
.trail-bar-fill{height:100%;border-radius:4px;transition:width 1.2s ease}

/* ── Pricing (TS version) ────────────────────────── */
.pricing-section{background:var(--ink);padding:120px 0;text-align:center}
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:860px;margin:0 auto 32px}
.pricing-card{background:var(--ink-card);border:1px solid rgba(255,255,255,.08);
  border-radius:20px;padding:40px;text-align:left;position:relative}
.pricing-card-highlight{border-color:rgba(0,196,154,.3);
  animation:border-glow 2.5s ease-in-out infinite;box-shadow:0 0 40px rgba(0,196,154,.08)}
.pricing-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:2px;
  background:var(--lab);color:#060E1C;padding:4px 12px;border-radius:100px;margin-bottom:16px}
.pricing-plan{font-size:11px;font-weight:700;letter-spacing:3px;color:var(--gray-m);
  text-transform:uppercase;margin-bottom:8px}
.pricing-price{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}
.price-currency{font-size:22px;font-weight:700;color:var(--gray-m)}
.price-value{font-size:56px;font-weight:900;letter-spacing:-2px;color:#fff}
.pricing-card-highlight .price-value{color:var(--lab)}
.price-period{font-size:16px;color:var(--gray-m)}
.pricing-tagline{font-size:14px;color:var(--gray-m);margin-bottom:28px;margin-top:4px}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.pricing-features li{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;color:var(--gray-l);line-height:1.45}
.pricing-features .feat-no{color:var(--gray-d);text-decoration:line-through;opacity:.6}
.pricing-form{display:flex;flex-direction:column;gap:10px}
.pricing-form input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:8px;padding:12px 16px;color:#fff;font-size:14px;font-family:inherit}
.pricing-form input:focus{outline:none;border-color:rgba(0,196,154,.4)}
.pricing-form .btn{width:100%;justify-content:center}
.pricing-note{font-size:13px;color:var(--gray-d)}
@media(max-width:700px){.pricing-grid{grid-template-columns:1fr}}

/* ── Instrutores (TS version) ────────────────────── */
.instrutores-section{background:var(--ink-deep);padding:120px 0}
.instrutores-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.instr-lead{background:var(--ink-card);border:1px solid rgba(0,196,154,.14);
  border-radius:20px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.4)}
.instr-photo-wrap{height:260px;background:linear-gradient(145deg,#0C2840 0%,#071a28 50%,#040C18 100%);
  display:flex;align-items:center;justify-content:center}
.instr-photo-placeholder{width:72px;height:72px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:900;color:#fff;
  background:rgba(0,196,154,.1);border:2px solid rgba(0,196,154,.3)}
.instr-photo-lead{width:90px;height:90px;font-size:28px}
.instr-initials{}
.instr-info{padding:24px 28px 28px}
.instr-trail-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.trail-chip{font-size:10px;font-weight:700;letter-spacing:1.5px;
  padding:3px 9px;border-radius:4px}
.instr-name{font-size:18px;font-weight:900;color:#fff;margin-bottom:3px}
.instr-role{font-size:12px;color:var(--lab);letter-spacing:.5px;margin-bottom:14px}
.instr-bio{font-size:13.5px;color:var(--gray-m);line-height:1.7;margin-bottom:16px}
.instr-bio-short{font-size:12px;color:var(--gray-m);line-height:1.6;margin-bottom:0}
.instr-tags{display:flex;flex-wrap:wrap;gap:7px}
.instr-tags span{font-size:11px;font-weight:600;color:var(--gray-m);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:4px;padding:4px 10px}
.instr-specialists{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.instr-card{background:var(--ink-card2);border:1px solid rgba(255,255,255,.06);
  border-radius:16px;padding:20px;transition:transform .25s,border-color .25s}
.instr-card:hover{transform:translateY(-4px);border-color:rgba(0,196,154,.2)}
@media(max-width:900px){.instrutores-grid{grid-template-columns:1fr}}
@media(max-width:600px){.instr-specialists{grid-template-columns:1fr}}

/* ── Depoimentos (TS version) ────────────────────── */
.dep-section{background:#060E1C;padding:120px 0;overflow:hidden}
.dep-marquee-wrap{overflow:hidden;width:100%;cursor:grab;padding:24px 0}
.dep-marquee-wrap:active{cursor:grabbing}
.dep-marquee-track{display:flex;gap:24px;width:max-content;animation:marquee 50s linear infinite}
.dep-marquee-track:hover{animation-play-state:paused}
.dep-card{flex:0 0 360px;background:var(--ink-card);border:1px solid rgba(255,255,255,.06);
  border-radius:16px;padding:28px}
.dep-text{font-size:14px;color:var(--gray-l);line-height:1.65;margin-bottom:20px;font-style:italic}
.dep-author{display:flex;align-items:center;gap:12px}
.dep-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
.dep-name{font-size:13px;font-weight:700;color:#fff}
.dep-role{font-size:11px;color:var(--gray-d)}

/* ── FAQ (TS version) ────────────────────────────── */
.faq-section{background:var(--ink);padding:120px 0}
.faq-inner{max-width:760px}
.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.faq-item{background:var(--ink-card2);border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden}
.faq-q{padding:20px 24px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:16px;user-select:none}
.faq-chevron{color:var(--lab);font-size:20px;font-weight:300;transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-chevron{transform:rotate(90deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 24px 20px;font-size:14px;color:var(--gray-m);line-height:1.7}

/* ── CTA (TS version) ────────────────────────────── */
.cta-section{background:var(--ink-deep);padding:140px 0;text-align:center;position:relative;overflow:hidden}
.cta-orb{position:absolute;border-radius:50%;pointer-events:none}
.cta-orb-1{width:600px;height:600px;top:50%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(0,196,154,.1) 0%,transparent 70%)}
.cta-orb-2{width:300px;height:300px;top:20%;right:10%;
  background:radial-gradient(circle,rgba(99,102,241,.07) 0%,transparent 70%)}
.cta-inner{position:relative;z-index:1}
.cta-label{display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;letter-spacing:3px;color:var(--lab);text-transform:uppercase;margin-bottom:24px}
.cta-title{font-size:clamp(40px,5vw,72px);font-weight:900;letter-spacing:-2.5px;
  line-height:1.05;color:#fff;margin-bottom:20px}
.cta-sub{font-size:18px;color:var(--gray-m);max-width:540px;margin:0 auto 48px;line-height:1.65}
.cta-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.cta-form input{min-width:220px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:15px 20px;
  color:#fff;font-size:15px;font-family:inherit;flex:0 1 260px}
.cta-form input::placeholder{color:var(--gray-d)}
.cta-form input:focus{outline:none;border-color:rgba(0,196,154,.4)}
.cta-hint{font-size:13px;color:var(--gray-d)}
.btn-lg{font-size:17px;padding:18px 40px}

/* ── Footer (TS version) ─────────────────────────── */
.footer{background:rgba(4,8,15,1);padding:80px 0 0;border-top:1px solid rgba(255,255,255,.04)}
.footer-inner{display:grid;grid-template-columns:1.4fr 2fr;gap:80px;padding-bottom:60px}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{font-size:16px;font-weight:900;letter-spacing:3px;color:#fff}
.footer-logo span{color:var(--lab)}
.footer-tagline{font-size:13px;color:var(--gray-d);line-height:1.6;max-width:240px}
.footer-social{display:flex;gap:10px;margin-top:4px}
.footer-social a{width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-m);text-decoration:none;transition:all .2s}
.footer-social a:hover{background:var(--lab-dim);border-color:rgba(0,196,154,.3);color:var(--lab)}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.footer-col{display:flex;flex-direction:column;gap:12px}
.footer-col h4{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gray-d)}
.footer-col a{font-size:13px;color:var(--gray-m);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.04);padding:28px 0}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between}
.footer-bottom p,.footer-bottom-right{font-size:12px;color:var(--gray-d)}
@media(max-width:860px){
  .footer-inner{grid-template-columns:1fr}
  .footer-links{grid-template-columns:1fr 1fr}
}

/* ── Forms shared ─────────────────────────────────── */
.form-error{font-size:13px;color:#f87171;margin-top:8px}
.form-success{display:flex;align-items:center;gap:12px;padding:16px;
  background:rgba(0,196,154,.08);border:1px solid rgba(0,196,154,.2);border-radius:8px}
.form-success-icon{width:32px;height:32px;border-radius:50%;background:var(--lab);
  color:#060E1C;display:flex;align-items:center;justify-content:center;font-weight:900;flex-shrink:0}

/* ── Obrigado page ────────────────────────────────── */
.obrigado-page{min-height:100vh;display:flex;flex-direction:column;
  background:var(--ink-deep);padding-top:72px}
.obrigado-inner{max-width:680px;margin:auto;padding:80px 0;text-align:center}
.obrigado-icon{width:80px;height:80px;border-radius:50%;background:rgba(0,196,154,.12);
  border:2px solid rgba(0,196,154,.3);display:flex;align-items:center;justify-content:center;
  font-size:32px;margin:0 auto 32px;color:var(--lab);font-weight:900}
.obrigado-title{font-size:clamp(36px,4vw,56px);font-weight:900;letter-spacing:-2px;
  color:#fff;margin-bottom:16px;line-height:1.05}
.obrigado-sub{font-size:17px;color:var(--gray-m);line-height:1.7;
  max-width:520px;margin:0 auto 48px}
.obrigado-steps{display:flex;flex-direction:column;gap:16px;margin-bottom:48px;text-align:left}
.ob-step{display:flex;align-items:flex-start;gap:20px;
  background:var(--ink-card);border:1px solid rgba(255,255,255,.06);
  border-radius:12px;padding:20px 24px}
.ob-step-num{font-size:11px;font-weight:800;letter-spacing:2px;color:var(--lab);
  background:rgba(0,196,154,.1);border:1px solid rgba(0,196,154,.2);
  border-radius:6px;padding:4px 10px;flex-shrink:0;margin-top:2px}
.ob-step strong{display:block;font-size:15px;font-weight:700;color:#fff;margin-bottom:4px}
.ob-step p{font-size:13px;color:var(--gray-m);line-height:1.55;margin:0}
.obrigado-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ── Admin (TS version) ───────────────────────────── */
.admin-login-wrap{min-height:100vh;display:flex;align-items:center;
  justify-content:center;background:var(--ink-deep);padding:24px}
.admin-login-card{width:100%;max-width:400px;background:var(--ink-card);
  border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:48px 40px;text-align:center}
.admin-logo{font-size:14px;font-weight:900;letter-spacing:3px;color:#fff;margin-bottom:24px}
.admin-logo span{color:var(--lab)}
.admin-login-title{font-size:22px;font-weight:800;margin-bottom:28px}
.admin-login-form{display:flex;flex-direction:column;gap:12px}
.admin-login-form input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:8px;padding:13px 16px;color:#fff;font-size:14px;font-family:inherit}
.admin-login-form input:focus{outline:none;border-color:rgba(0,196,154,.4)}
.admin-login-error{font-size:13px;color:#f87171;margin-top:4px}
.admin-wrap{min-height:100vh;background:var(--ink-deep)}
.admin-header{background:rgba(6,14,28,.95);border-bottom:1px solid rgba(255,255,255,.06);
  padding:16px 48px;display:flex;align-items:center;justify-content:space-between}
.admin-body{max-width:1240px;margin:0 auto;padding:48px 48px 80px}
.admin-tab-panel{margin-top:4px}
.admin-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.admin-panel-header h2{font-size:20px;font-weight:800}
.admin-loading{text-align:center;padding:48px;color:var(--gray-d)}
.admin-error{color:#f87171;padding:20px}
.admin-count{font-size:13px;color:var(--gray-d);padding:12px 20px;
  border-bottom:1px solid rgba(255,255,255,.04)}
.plan-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:1px}
.plan-pro{background:rgba(0,196,154,.1);color:var(--lab);border:1px solid rgba(0,196,154,.2)}
.plan-premium{background:rgba(168,85,247,.1);color:#c084fc;border:1px solid rgba(168,85,247,.2)}
.msg-cell{max-width:300px;font-size:12px;color:var(--gray-m);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Responsive container ─────────────────────────── */
@media(max-width:860px){
  .container,.nav-inner{padding-left:24px;padding-right:24px}
}
@media(max-width:560px){
  .manifesto-stats{grid-template-columns:1fr 1fr}
  .cta-form{flex-direction:column}
  .cta-form input{min-width:100%;flex:none}
  .pricing-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════
   LOGO INTRO SPLASH
═══════════════════════════════════════════════════ */
body.tll-intro-active{overflow:hidden}

#tll-intro{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:#04080F;
  animation:tli-exit .7s cubic-bezier(.4,0,.2,1) 2.5s forwards;
}

/* scanline subtle overlay */
#tll-intro::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,196,154,.012) 2px,rgba(0,196,154,.012) 4px);
  pointer-events:none;
}

/* ambient glow behind logo */
#tll-intro::after{
  content:'';position:absolute;
  width:500px;height:200px;
  background:radial-gradient(ellipse,rgba(0,196,154,.12) 0%,transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);
  pointer-events:none;
}

.tli-content{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}

/* Logo row */
.tli-logo{
  display:flex;align-items:center;
  font-family:'Inter',sans-serif;
  font-size:clamp(30px,6vw,58px);
  font-weight:900;
  letter-spacing:10px;
  line-height:1;
}
.tli-the{
  color:#fff;
  opacity:0;
  animation:tli-left .55s cubic-bezier(.22,1,.36,1) .25s forwards;
}
.tli-slash{
  color:#00C49A;
  margin:0 6px;
  opacity:0;
  animation:
    tli-slash .5s cubic-bezier(.22,1,.36,1) 0s forwards,
    tli-slash-glow 2s ease-in-out .8s infinite;
}
.tli-lab{
  color:#fff;
  opacity:0;
  animation:tli-right .55s cubic-bezier(.22,1,.36,1) .5s forwards;
}

/* Underline */
.tli-line{
  height:1px;
  width:0;
  background:linear-gradient(90deg,transparent,#00C49A 40%,#00C49A 60%,transparent);
  box-shadow:0 0 16px rgba(0,196,154,.6);
  animation:tli-line-draw .55s ease .82s forwards;
}

/* Tagline */
.tli-tagline{
  font-size:10px;
  letter-spacing:5px;
  text-transform:uppercase;
  color:#94A3B8;
  opacity:0;
  animation:tli-tag-in .45s ease 1.1s forwards;
}

/* Floating particles */
.tli-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.tli-p{
  position:absolute;
  width:3px;height:3px;
  border-radius:50%;
  background:#00C49A;
  opacity:0;
  animation:tli-particle 1.6s ease-out infinite;
}
.tli-p1{left:48%;top:52%;animation-delay:.9s}
.tli-p2{left:44%;top:55%;animation-delay:1.1s;width:2px;height:2px;opacity:.4}
.tli-p3{left:52%;top:50%;animation-delay:1.0s;width:2px;height:2px}
.tli-p4{left:46%;top:54%;animation-delay:1.25s;opacity:.3}
.tli-p5{left:50%;top:53%;animation-delay:1.35s;width:2px;height:2px;opacity:.5}

/* ═══════════════════════════════════════════════════
   HERO FORM — dois botões lado a lado
═══════════════════════════════════════════════════ */
.hero-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.hero-form-btns{display:flex;gap:10px;flex-wrap:wrap}
.btn-client-login{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 22px;border-radius:8px;
  border:1.5px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.03);
  color:var(--gray-m);
  font-size:14px;font-weight:600;font-family:'Inter',sans-serif;
  text-decoration:none;white-space:nowrap;
  transition:all .25s;cursor:pointer;
}
.btn-client-login:hover{
  border-color:rgba(0,196,154,.35);
  color:#fff;
  background:rgba(0,196,154,.05);
}
.btn-client-login svg{flex-shrink:0;stroke:currentColor}

@media(max-width:600px){
  .hero-form-btns{flex-direction:column}
  .hero-form-btns .btn,.hero-form-btns .btn-client-login{width:100%;justify-content:center}
  .tli-logo{letter-spacing:6px}
  .tli-tagline{letter-spacing:3px}
}
