/* ========================================================
   Academia Lendár[IA] — Home v3.1
   Dark + light sections · more nuance · Apple-esque
   ======================================================== */

:root {
  --bg: #070709;
  --bg-deep: #000000;
  --bg-soft: #0d0d11;
  --bg-elev: #111115;
  --surface: rgba(255,255,255,0.02);
  --surface-2: rgba(255,255,255,0.04);
  --border: rgba(255,255,255,0.07);
  --border-strong: rgba(255,255,255,0.14);
  --text: #EDEBE6;
  --text-mid: rgba(237,235,230,0.68);
  --text-dim: rgba(237,235,230,0.42);
  --text-faint: rgba(237,235,230,0.22);

  /* Light section tokens (cream, Apple-like) */
  --cream: #F3EEE6;
  --cream-deep: #E8E1D3;
  --cream-ink: #1A1712;
  --cream-ink-mid: rgba(26,23,18,0.66);
  --cream-ink-dim: rgba(26,23,18,0.42);
  --cream-border: rgba(26,23,18,0.08);
  --cream-border-strong: rgba(26,23,18,0.16);

  --gold: #C9B298;
  --gold-bright: #E4D8CA;
  --gold-warm: #D4A574;
  --gold-deep: #8D7556;
  --gold-ink: #5a4a34;
  --gold-05: rgba(201,178,152,0.05);
  --gold-10: rgba(201,178,152,0.10);
  --gold-15: rgba(201,178,152,0.15);
  --gold-20: rgba(201,178,152,0.20);
  --gold-30: rgba(201,178,152,0.30);
  --gold-40: rgba(201,178,152,0.40);

  --ff-display: 'Instrument Serif', 'Times New Roman', serif;
  --ff-sans: 'Inter Tight', -apple-system, BlinkMacSystemFont, sans-serif;
  --ff-mono: 'JetBrains Mono', 'SF Mono', Consolas, monospace;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);

  --maxw: 1280px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg);-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-sans);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none;
}
body.no-cursor{cursor:default}
img,svg,video,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:none;cursor:none;color:inherit}
input,textarea{font:inherit;color:inherit}
.bracket{color:var(--gold);font-weight:inherit}
em.serif, .serif{font-family:var(--ff-display);font-style:italic;font-weight:400;letter-spacing:-0.01em}
::selection{background:var(--gold-30);color:var(--gold-bright)}

.grain{
  position:fixed;inset:0;pointer-events:none;z-index:200;opacity:0.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.9'/></svg>");
}
body.no-grain .grain{display:none}

/* Cursor */
.cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:300;mix-blend-mode:difference}
.cursor-dot{position:absolute;width:6px;height:6px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);transition:transform 0.15s ease}
.cursor-ring{position:absolute;width:28px;height:28px;border:1px solid rgba(255,255,255,0.55);border-radius:50%;transform:translate(-50%,-50%);transition:width 0.3s var(--ease),height 0.3s var(--ease),border-color 0.3s}
.cursor.cursor-hover .cursor-ring{width:50px;height:50px;border-color:var(--gold)}
.cursor.cursor-hover .cursor-dot{transform:translate(-50%,-50%) scale(0.5)}
body.no-cursor .cursor{display:none}
@media(max-width:900px){.cursor{display:none}body{cursor:default}button,a{cursor:pointer}}

/* Tweaks */
.tweaks-panel{
  position:fixed;bottom:24px;right:24px;z-index:250;
  background:rgba(10,10,13,0.85);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);
  border:1px solid var(--border-strong);border-radius:16px;
  padding:16px 18px;width:260px;font-family:var(--ff-mono);font-size:11px;
  transform:translateY(calc(100% + 32px));transition:transform 0.5s var(--ease-out-expo);
  box-shadow:0 20px 60px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03) inset;
}
.tweaks-panel.open{transform:translateY(0)}
.tweaks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.tweaks-title{color:var(--gold);letter-spacing:0.12em;text-transform:uppercase;font-weight:600}
.tweaks-close{color:var(--text-dim);font-size:20px;line-height:1;padding:0 4px}
.tweaks-close:hover{color:var(--text)}
.tweaks-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;color:var(--text-mid)}
.tweaks-switch{position:relative;display:inline-block;width:32px;height:18px;cursor:none}
.tweaks-switch input{opacity:0;width:0;height:0}
.tweaks-switch span{position:absolute;inset:0;background:rgba(255,255,255,0.08);border-radius:10px;transition:0.3s;border:1px solid var(--border)}
.tweaks-switch span::before{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;background:var(--text-dim);border-radius:50%;transition:0.3s}
.tweaks-switch input:checked+span{background:var(--gold-20);border-color:var(--gold-30)}
.tweaks-switch input:checked+span::before{transform:translateX(14px);background:var(--gold)}
.tweaks-note{font-size:9.5px;color:var(--text-dim);margin-top:10px;padding-top:10px;border-top:1px solid var(--border);letter-spacing:0.03em;font-family:var(--ff-sans);line-height:1.5}

/* ==================== NAV ==================== */
.nav{
  position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:100;width:min(calc(100% - 32px),var(--maxw));
  background:rgba(6,6,10,0.72);backdrop-filter:blur(24px) saturate(1.6);-webkit-backdrop-filter:blur(24px) saturate(1.6);
  border:1px solid var(--border-strong);border-radius:999px;
  box-shadow:0 10px 40px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.03) inset;
}
.nav-inner{height:56px;padding:0 8px 0 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-brand{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:500}
.nav-brand em{font-family:var(--ff-display);font-style:italic;font-weight:400;color:var(--gold-bright)}
.nav-mark{color:var(--gold);flex-shrink:0}
.nav-menu{display:flex;align-items:center;gap:28px}
.nav-link{font-size:13px;color:var(--text-mid);transition:color 0.2s;position:relative}
.nav-link:hover{color:var(--text)}
.nav-link::after{content:"";position:absolute;bottom:-6px;left:50%;width:0;height:1px;background:var(--gold);transition:width 0.3s var(--ease),left 0.3s var(--ease)}
.nav-link:hover::after{width:80%;left:10%}
.nav-actions{display:flex;align-items:center;gap:8px}
.nav-login{font-size:13px;color:var(--text-mid);padding:0 12px}
.nav-login:hover{color:var(--text)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 16px 10px 18px;border-radius:999px;font-size:12.5px;font-weight:500;color:var(--bg-deep);background:var(--gold);transition:all 0.3s var(--ease);box-shadow:0 4px 20px rgba(201,178,152,0.15);white-space:nowrap}
.nav-cta:hover{background:var(--gold-bright);transform:translateY(-1px);box-shadow:0 8px 30px rgba(201,178,152,0.25)}
@media(max-width:900px){.nav-menu,.nav-login{display:none}.nav-inner{padding:0 8px 0 20px;height:52px}}

/* ==================== HERO — LIMPO ==================== */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 55%, rgba(201,178,152,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 100% 80% at 50% 100%, rgba(212,165,116,0.05), transparent 70%),
    linear-gradient(180deg, #06060a 0%, #0a0810 50%, #050507 100%);
}

/* Aurora blobs — soft, apple-like ambient */
.hero-aurora{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.aurora{position:absolute;border-radius:50%;filter:blur(100px);opacity:0.5}
.aurora-1{top:-10%;left:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(201,178,152,0.3),transparent 70%);animation:auroraDrift 22s ease-in-out infinite}
.aurora-2{bottom:-20%;right:-10%;width:700px;height:700px;background:radial-gradient(circle,rgba(139,117,86,0.35),transparent 70%);animation:auroraDrift 28s ease-in-out infinite reverse}
.aurora-3{top:40%;left:50%;transform:translateX(-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(212,165,116,0.22),transparent 70%);animation:auroraDrift 18s ease-in-out infinite}
@keyframes auroraDrift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.1)}66%{transform:translate(-20px,20px) scale(0.95)}}
body.no-heavy .aurora{animation:none}

/* Full-hero neural network background */
.hero-neural{
  position:absolute;inset:0;z-index:2;pointer-events:none;
}
.hero-graph{position:absolute;inset:0;width:100%;height:100%;opacity:0.7}
body.no-heavy .hero-graph{opacity:0.35}

/* Infinity 3D canvas — Three.js fullscreen */
.hero-infinity-wrap{
  position:absolute;inset:0;z-index:3;
  pointer-events:none;
  opacity:0;
  animation:inf3dFadeIn 1.2s ease-out 0.3s forwards;
}
.hero-infinity-wrap canvas{
  display:block;width:100%;height:100%;
}
@keyframes inf3dFadeIn{
  to{opacity:1}
}
body.no-heavy .hero-infinity-wrap{display:none}

.hero-vignette{position:absolute;inset:0;z-index:3;pointer-events:none;background:radial-gradient(ellipse 55% 55% at center,rgba(6,6,10,0.85) 0%,rgba(6,6,10,0.45) 35%,transparent 65%),radial-gradient(ellipse at center,transparent 0%,transparent 50%,rgba(0,0,0,0.65) 100%)}

.hero-inner{position:relative;z-index:20;max-width:960px;text-align:center;padding:100px 24px 80px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 16px;border-radius:999px;
  background:rgba(12,12,16,0.6);border:1px solid var(--gold-20);
  font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.12em;color:var(--gold);
  margin-bottom:40px;text-transform:uppercase;
  backdrop-filter:blur(10px);
}
.eyebrow-ping{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:livePulse 1.8s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:0.4}}

.hero-title{
  font-family:var(--ff-sans);
  font-size:clamp(2.5rem,7.2vw,6.2rem);
  font-weight:500;letter-spacing:-0.045em;line-height:0.98;
  color:var(--text);margin-bottom:36px;
}
.hero-title .line{display:block;opacity:0;transform:translateY(30px);animation:titleRise 1s var(--ease-out-expo) forwards}
.hero-title .line:nth-child(1){animation-delay:0.3s}
.hero-title .line:nth-child(2){animation-delay:0.5s}
.hero-title .line:nth-child(3){animation-delay:0.7s}
.hero-title .line-accent{background:linear-gradient(105deg,var(--gold-bright) 0%,var(--gold) 45%,var(--gold-warm) 75%,var(--gold-deep) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero-title .gold-accent{
  color: var(--gold-bright);
}
@keyframes titleRise{to{opacity:1;transform:translateY(0)}}

.hero-sub{font-size:clamp(1rem,1.45vw,1.15rem);color:var(--text-mid);line-height:1.65;max-width:560px;margin:0 auto 44px;opacity:0;animation:fadeIn 1s ease 1s forwards;font-weight:300}
@keyframes fadeIn{to{opacity:1}}

.hero-ctas{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-bottom:72px;opacity:0;animation:fadeIn 1s ease 1.2s forwards}
.btn{display:inline-flex;align-items:center;gap:10px;height:50px;padding:0 26px;border-radius:999px;font-size:14px;font-weight:500;transition:all 0.3s var(--ease);position:relative;overflow:hidden}
.btn-primary{background:var(--gold);color:var(--bg-deep);box-shadow:0 0 0 1px rgba(255,255,255,0.15) inset,0 10px 40px rgba(201,178,152,0.25)}
.btn-primary:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 0 0 1px rgba(255,255,255,0.2) inset,0 16px 50px rgba(201,178,152,0.4)}
.btn-primary::after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.4),transparent);transition:left 0.8s}
.btn-primary:hover::after{left:150%}
.btn-ghost{background:rgba(255,255,255,0.04);color:var(--text);border:1px solid var(--border-strong);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(255,255,255,0.08);border-color:var(--gold-30);color:var(--gold-bright)}

.hero-stats{display:flex;justify-content:center;align-items:center;gap:40px;opacity:0;animation:fadeIn 1s ease 1.4s forwards;flex-wrap:wrap}
.hs{display:flex;flex-direction:column;align-items:center;gap:4px}
.hs-val{font-family:var(--ff-mono);font-size:22px;font-weight:600;color:var(--text);letter-spacing:-0.02em}
.hs-lbl{font-family:var(--ff-mono);font-size:9.5px;letter-spacing:0.15em;color:var(--text-dim);text-transform:uppercase}
.hs-sep{width:1px;height:28px;background:var(--border-strong)}
@media(max-width:680px){.hs-sep{display:none}.hero-stats{gap:22px 34px}.hs-val{font-size:18px}}

.hero-scrollhint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:15;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--ff-mono);font-size:9.5px;letter-spacing:0.3em;color:var(--text-faint);opacity:0;animation:fadeIn 1s ease 2s forwards}
.sh-line{width:1px;height:40px;background:linear-gradient(180deg,var(--text-faint),transparent);position:relative;overflow:hidden}
.sh-line::after{content:"";position:absolute;top:-40px;left:0;width:100%;height:40px;background:linear-gradient(180deg,transparent,var(--gold));animation:scrollDown 2s ease-in-out infinite}
@keyframes scrollDown{0%{top:-40px}100%{top:100%}}

/* ==================== TRUST ==================== */
.trust{padding:64px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#050507;overflow:hidden}
.trust-label{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:32px;padding:0 24px;font-family:var(--ff-mono);font-size:10px;letter-spacing:0.15em;color:var(--text-dim);text-transform:uppercase;text-align:center}
.trust-dash{width:40px;height:1px;background:var(--border-strong)}
.trust-ticker{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent);mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent)}
.trust-track{display:flex;align-items:center;gap:48px;width:max-content;animation:trustRoll 50s linear infinite}
.trust-track:hover{animation-play-state:paused}
.trust-item{font-family:var(--ff-sans);font-weight:600;font-size:18px;letter-spacing:0.02em;color:var(--text-dim);transition:color 0.3s;white-space:nowrap;flex-shrink:0}
.trust-item:hover{color:var(--text)}
.trust-dot{width:4px;height:4px;border-radius:50%;background:var(--gold-30);flex-shrink:0}
@keyframes trustRoll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==================== LIGHT SECTIONS (Apple-esque cream) ==================== */
.light-section{
  background:
    radial-gradient(ellipse 70% 50% at 20% 0%, rgba(201,178,152,0.18), transparent 60%),
    radial-gradient(ellipse 70% 50% at 80% 100%, rgba(212,165,116,0.14), transparent 60%),
    linear-gradient(180deg, var(--cream) 0%, var(--cream-deep) 100%);
  color:var(--cream-ink);
  position:relative;
  border-top:1px solid rgba(26,23,18,0.08);
  border-bottom:1px solid rgba(26,23,18,0.08);
}
.light-section::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(26,23,18,0.06) 1px, transparent 0);
  background-size:32px 32px;
  opacity:0.5;
  -webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 85%);
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 85%);
}
.light-section > *{position:relative;z-index:1}

/* ==================== MANIFESTO (light) ==================== */
.manifesto{padding:140px 24px;overflow:hidden}
.manifesto-inner{max-width:980px;margin:0 auto;text-align:center}
.mf-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:rgba(26,23,18,0.06);border:1px solid var(--cream-border-strong);font-family:var(--ff-mono);font-size:10px;letter-spacing:0.18em;color:var(--gold-ink);text-transform:uppercase;margin-bottom:40px}
.mf-tag-dot{width:5px;height:5px;border-radius:50%;background:var(--gold-deep);box-shadow:0 0 8px var(--gold-deep)}
.karaoke{
  font-family:var(--ff-sans);
  font-size:clamp(1.5rem,3.5vw,2.7rem);
  font-weight:400;letter-spacing:-0.025em;line-height:1.35;
  color:var(--cream-ink);text-wrap:pretty;
}
.karaoke .karaoke-word{opacity:0.18;transition:opacity 0.4s var(--ease);display:inline-block}
.karaoke .karaoke-word.lit{opacity:1}
.karaoke strong{color:var(--gold-deep);font-weight:500}
.karaoke em{font-family:var(--ff-display);font-style:italic;font-weight:400;color:var(--gold-deep)}
.mf-sig{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:48px;font-family:var(--ff-mono);font-size:11px;letter-spacing:0.1em;color:var(--cream-ink-mid)}
.mf-sig-line{width:48px;height:1px;background:rgba(26,23,18,0.3)}

/* ==================== SECTION HEADS ==================== */
.section-head{max-width:900px;margin:0 auto 80px;padding:0 24px;text-align:center}
.section-head-split{max-width:var(--maxw);margin:0 auto 72px;padding:0 32px;display:grid;grid-template-columns:1fr;gap:28px;text-align:left}
@media(min-width:900px){.section-head-split{grid-template-columns:1.4fr 1fr;align-items:end;gap:48px;margin-bottom:96px}}
.sh-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.2em;text-transform:uppercase;margin-bottom:24px;color:var(--gold)}
.light-section .sh-eyebrow{color:var(--gold-deep)}
.sh-dash{width:28px;height:1px;background:currentColor}
.sh-title{font-size:clamp(1.9rem,4.5vw,3.6rem);font-weight:500;letter-spacing:-0.035em;line-height:1.05;margin-bottom:16px;text-wrap:balance}
.sh-title em{color:var(--gold-bright)}
.light-section .sh-title{color:var(--cream-ink)}
.light-section .sh-title em{color:var(--gold-deep)}
.sh-sub{color:var(--text-mid);font-size:clamp(1rem,1.3vw,1.1rem);max-width:560px;margin:0 auto;line-height:1.6;font-weight:300}
.light-section .sh-sub{color:var(--cream-ink-mid)}
.sh-aside{color:var(--text-mid);font-size:15px;line-height:1.6;padding-left:24px;border-left:1px solid var(--border-strong);font-weight:300}
@media(max-width:899px){.sh-aside{padding-left:0;border-left:none;padding-top:12px}}

/* Reveal */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.9s var(--ease-out-expo),transform 0.9s var(--ease-out-expo)}
.reveal.active{opacity:1;transform:translateY(0)}

/* ==================== BENTO ==================== */
.why{padding:140px 0 120px;background:linear-gradient(180deg, #080809 0%, #0a0a0e 100%)}
.bento{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.b-big{grid-column:span 6}
.b-mid{grid-column:span 3}
@media(min-width:900px){
  .b-big:nth-of-type(1){grid-column:span 4}
  .b-big:nth-of-type(4){grid-column:span 4}
  .b-mid:nth-of-type(2){grid-column:span 2}
  .b-mid:nth-of-type(3){grid-column:span 2}
}
.b-card{
  position:relative;overflow:hidden;padding:32px;border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.005));
  border:1px solid var(--border);
  min-height:380px;display:flex;flex-direction:column;
  transform-style:preserve-3d;transition:border-color 0.4s,box-shadow 0.4s,transform 0.1s;
}
.b-card:hover{border-color:var(--gold-30);box-shadow:0 20px 60px -20px rgba(201,178,152,0.18),0 0 0 1px rgba(201,178,152,0.08) inset}
.b-spot{position:absolute;inset:-100px;background:radial-gradient(circle at var(--sx,50%) var(--sy,50%),rgba(201,178,152,0.14),transparent 50%);opacity:0;transition:opacity 0.4s;pointer-events:none}
.b-card:hover .b-spot{opacity:1}
.b-header{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.b-idx{font-family:var(--ff-mono);font-size:10px;color:var(--gold);letter-spacing:0.1em;padding:4px 8px;border:1px solid var(--gold-20);border-radius:4px}
.b-title{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.15em;color:var(--text-dim);text-transform:uppercase}
.b-visual{flex:1;display:flex;align-items:center;justify-content:center;margin:8px 0 24px;min-height:120px;position:relative}
.b-visual-network svg{width:100%;max-width:420px;height:auto}
.net-nodes circle{animation:nodePulse 3s ease-in-out infinite}
.net-nodes circle:nth-child(7){animation-delay:-2.4s;filter:drop-shadow(0 0 6px #E4D8CA)}
@keyframes nodePulse{0%,100%{opacity:0.6}50%{opacity:1}}
.net-pulse{stroke-dasharray:8 200;stroke-dashoffset:0;animation:pulseLine 3s linear infinite}
.np-1{animation-delay:0s}.np-2{animation-delay:-0.7s}.np-3{animation-delay:-1.4s}.np-4{animation-delay:-2.1s}
@keyframes pulseLine{0%{stroke-dashoffset:0;opacity:1}100%{stroke-dashoffset:-208;opacity:0.3}}
body.no-heavy .net-pulse,body.no-heavy .net-nodes circle{animation:none}

.b-visual-orbit{width:180px;height:180px;margin:0 auto;position:relative}
.orbit-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:var(--gold-bright);border-radius:50%;box-shadow:0 0 16px var(--gold),0 0 32px var(--gold-30)}
.orbit-ring{position:absolute;top:50%;left:50%;border:1px dashed var(--gold-20);border-radius:50%;transform:translate(-50%,-50%)}
.orbit-r1{width:70px;height:70px;animation:orbitSpin 6s linear infinite}
.orbit-r2{width:120px;height:120px;animation:orbitSpin 10s linear infinite reverse}
.orbit-r3{width:170px;height:170px;animation:orbitSpin 16s linear infinite}
.orbit-planet{position:absolute;top:-4px;left:50%;transform:translateX(-50%);width:8px;height:8px;background:var(--gold);border-radius:50%;box-shadow:0 0 10px var(--gold)}
.orbit-r2 .orbit-planet{background:var(--gold-bright);width:6px;height:6px}
.orbit-r3 .orbit-planet{width:5px;height:5px;background:var(--gold-warm)}
@keyframes orbitSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
body.no-heavy .orbit-ring{animation:none}

.b-visual-globe svg{width:100%;max-width:320px;height:auto}
.globe-dot{animation:globeDot 2.5s ease-in-out infinite}
.gd-1{animation-delay:0s}.gd-2{animation-delay:-0.3s}.gd-3{animation-delay:-0.6s}.gd-4{animation-delay:-0.9s}
.gd-5{animation-delay:-1.2s}.gd-6{animation-delay:-1.5s}.gd-7{animation-delay:-1.8s}.gd-8{animation-delay:-2.1s}
@keyframes globeDot{0%,100%{opacity:0.5;r:2}50%{opacity:1;r:3.5}}
body.no-heavy .globe-dot{animation:none}

.b-big-nums{display:flex;flex-direction:column;gap:16px;margin:24px 0;padding:24px 20px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(201,178,152,0.02),rgba(201,178,152,0))}
.bn-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:0 4px}
.bn-val{font-family:var(--ff-mono);font-size:28px;font-weight:600;color:var(--gold-bright);letter-spacing:-0.02em}
.bn-lbl{font-size:12px;color:var(--text-dim);font-family:var(--ff-mono);letter-spacing:0.05em}
.bn-sep{height:1px;background:var(--border)}
.b-body h3{font-size:22px;font-weight:500;letter-spacing:-0.025em;color:var(--text);margin-bottom:10px;line-height:1.2}
.b-body p{font-size:14.5px;color:var(--text-mid);line-height:1.65;font-weight:300}
.b-body strong{color:var(--text);font-weight:500}
.b-link{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font-size:13px;color:var(--gold);transition:gap 0.3s}
.b-link:hover{gap:12px;color:var(--gold-bright)}

/* ==================== PROGRAMS ==================== */
.programs{padding:140px 0 120px;background:#050507;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.prog-stack{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:flex;flex-direction:column;gap:0}
.prog{position:relative;display:grid;grid-template-columns:120px 1fr auto;gap:40px;align-items:center;padding:40px 0;border-top:1px solid var(--border);transition:all 0.4s var(--ease)}
.prog:last-child{border-bottom:1px solid var(--border)}
.prog::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--gold-05) 50%,transparent 100%);opacity:0;transition:opacity 0.4s;pointer-events:none}
.prog:hover::before{opacity:1}
.prog:hover{padding-left:24px}
.prog-num{display:flex;flex-direction:column;gap:12px;align-self:start;padding:8px 0 0 12px}
.prog-num-val{font-family:var(--ff-mono);font-size:16px;color:var(--text-dim);letter-spacing:0.1em}
.prog-num-line{height:1px;width:40px;background:var(--gold-30);transition:width 0.5s var(--ease)}
.prog:hover .prog-num-line{width:80px;background:var(--gold)}
.prog:hover .prog-num-val{color:var(--gold)}
.prog-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.prog-tag{font-family:var(--ff-mono);font-size:9.5px;font-weight:600;letter-spacing:0.15em;padding:4px 10px;border-radius:4px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-mid);text-transform:uppercase}
.prog-tag-live{background:var(--gold-10);border-color:var(--gold-30);color:var(--gold)}
.prog-tag-gold{background:var(--gold);border-color:var(--gold);color:var(--bg-deep)}
.prog-title{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:500;letter-spacing:-0.03em;color:var(--text);line-height:1.1;margin-bottom:14px;transition:color 0.3s}
.prog:hover .prog-title{color:var(--gold-bright)}
.prog-desc{font-size:15px;color:var(--text-mid);line-height:1.6;font-weight:300;max-width:680px;margin-bottom:18px}
.prog-desc strong{color:var(--text);font-weight:500}
.prog-bullets{display:flex;flex-wrap:wrap;gap:8px}
.prog-bullets span{font-size:11.5px;padding:5px 11px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--text-mid);font-family:var(--ff-mono)}
.prog-cta{display:flex;align-items:center;gap:12px;font-size:13.5px;color:var(--text);white-space:nowrap;align-self:start;padding-top:8px}
.prog-arrow{width:40px;height:40px;border-radius:50%;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;color:var(--gold);transition:all 0.3s var(--ease)}
.prog:hover .prog-arrow{background:var(--gold);color:var(--bg-deep);border-color:var(--gold);transform:translateX(6px) rotate(-5deg)}
.prog-premium{background:linear-gradient(90deg,var(--gold-05),transparent)}
@media(max-width:900px){
  .prog{grid-template-columns:60px 1fr;gap:20px;padding:32px 0}
  .prog-cta{grid-column:1 / -1;justify-content:space-between;padding:16px 0 0;border-top:1px dashed var(--border)}
  .prog:hover{padding-left:0}
}

/* ==================== PROVAS (light) — Video carousel + Photo wall ==================== */
.proofs{padding:140px 0 120px}

/* -- Video carousel -- */
.ti-video-wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px 48px}
.ti-vtag{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;border-radius:999px;background:rgba(201,178,152,0.1);border:1px solid var(--cream-border-strong);font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.12em;color:var(--gold-ink);text-transform:uppercase;margin-bottom:28px}
.ti-vtag-dot{width:6px;height:6px;border-radius:50%;background:var(--gold-ink);box-shadow:0 0 8px rgba(141,117,86,0.6);animation:livePulse 2s ease-in-out infinite}

.ti-video{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px}
@media(max-width:720px){.ti-video{grid-template-columns:1fr;gap:14px}}
.ti-vbtn{
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,0.6);
  border:1px solid var(--cream-border-strong);
  color:var(--cream-ink);
  display:flex;align-items:center;justify-content:center;
  transition:all 0.3s var(--ease);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 4px 20px -8px rgba(26,23,18,0.15);
  flex-shrink:0;z-index:5;
}
.ti-vbtn:hover{background:var(--gold-ink);color:#fff;border-color:var(--gold-ink);transform:scale(1.05);box-shadow:0 10px 30px -10px rgba(141,117,86,0.5)}
.ti-vbtn:disabled{opacity:0.35;pointer-events:none}
@media(max-width:720px){
  .ti-vbtn{width:42px;height:42px}
  .ti-vbtn-prev{grid-row:2;grid-column:1;justify-self:start}
  .ti-vbtn-next{grid-row:2;grid-column:1;justify-self:end;margin-top:-52px}
}

.ti-vstage{overflow:hidden;border-radius:24px}
.ti-vtrack{display:flex;transition:transform 0.75s cubic-bezier(.2,.85,.25,1);will-change:transform}
.ti-vslide{flex:0 0 100%;padding:0 4px}

.ti-vcard{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0;
  border-radius:24px;overflow:hidden;
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(26,23,18,0.08);
  box-shadow:0 2px 4px rgba(26,23,18,0.04),0 30px 80px -30px rgba(26,23,18,0.2);
}
@media(max-width:880px){.ti-vcard{grid-template-columns:1fr}}

.ti-vmedia{
  position:relative;min-height:340px;
  background:linear-gradient(135deg,var(--ti-g1,#C9B298) 0%,var(--ti-g2,#6B4A35) 100%);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;
}
.ti-vmedia::before{
  content:attr(data-initials);
  font-family:var(--ff-display);font-style:italic;
  font-size:10rem;color:rgba(255,255,255,0.25);
  line-height:1;letter-spacing:-0.05em;
  text-shadow:0 8px 40px rgba(0,0,0,0.3);
  transition:transform 0.6s var(--ease);
}
.ti-vmedia::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,0.3), transparent 50%),
    radial-gradient(circle at 70% 80%, rgba(0,0,0,0.2), transparent 60%);
  mix-blend-mode:overlay;
}
.ti-vmedia:hover::before{transform:scale(1.06)}
.ti-vplay{
  position:absolute;z-index:3;
  width:76px;height:76px;border-radius:50%;
  background:rgba(255,255,255,0.95);color:var(--cream-ink);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 40px rgba(0,0,0,0.3),0 0 0 0 rgba(255,255,255,0.4);
  transition:all 0.3s var(--ease);
  animation:playPulse 2.4s ease-out infinite;
}
.ti-vmedia:hover .ti-vplay{transform:scale(1.1);background:#fff}
@keyframes playPulse{
  0%{box-shadow:0 10px 40px rgba(0,0,0,0.3),0 0 0 0 rgba(255,255,255,0.5)}
  100%{box-shadow:0 10px 40px rgba(0,0,0,0.3),0 0 0 24px rgba(255,255,255,0)}
}
.ti-vduration{
  position:absolute;z-index:3;bottom:16px;right:16px;
  padding:4px 10px;border-radius:6px;
  background:rgba(0,0,0,0.6);color:#fff;
  font-family:var(--ff-mono);font-size:11px;letter-spacing:0.04em;
  backdrop-filter:blur(8px);
}

.ti-vbody{padding:44px 40px;display:flex;flex-direction:column;gap:20px;justify-content:center;color:var(--cream-ink)}
@media(max-width:880px){.ti-vbody{padding:32px}}
.ti-quote{width:32px;height:26px;color:var(--gold-deep);opacity:0.45}
.ti-vtext{font-family:var(--ff-display);font-style:italic;font-size:clamp(1.3rem,2vw,1.6rem);line-height:1.35;color:var(--cream-ink);letter-spacing:-0.015em;font-weight:400}
.ti-vtext strong{font-style:normal;font-family:var(--ff-sans);font-weight:600;color:var(--gold-ink)}
.ti-vauthor{display:flex;flex-direction:column;gap:4px;padding-top:16px;border-top:1px solid var(--cream-border)}
.ti-vname{font-size:15px;font-weight:600;color:var(--cream-ink);letter-spacing:-0.01em}
.ti-vrole{font-family:var(--ff-mono);font-size:11px;color:var(--cream-ink-dim);letter-spacing:0.04em}

.ti-vdots{grid-column:1 / -1;display:flex;justify-content:center;gap:8px;margin-top:24px}
.ti-vdot{width:24px;height:6px;border-radius:3px;background:var(--cream-border-strong);transition:all 0.3s var(--ease);cursor:pointer}
.ti-vdot.active{background:var(--gold-ink);width:36px}
.ti-vdot:hover:not(.active){background:var(--cream-ink-dim)}

/* -- Photo wall (multi-column marquee) -- */
.ti-wall-wrap{max-width:1440px;margin:0 auto;padding:40px 32px 0}
.ti-wall{
  position:relative;
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  height:520px;overflow:hidden;border-radius:24px;
  -webkit-mask-image:linear-gradient(180deg,transparent,black 12%,black 88%,transparent);
  mask-image:linear-gradient(180deg,transparent,black 12%,black 88%,transparent);
}
@media(min-width:1080px){.ti-wall{grid-template-columns:1fr 1fr 1fr;gap:24px}}
.ti-wcol{position:relative;overflow:hidden}
.ti-wcol-hide{display:none}
@media(min-width:1080px){.ti-wcol-hide{display:block}}

.ti-wtrack{display:flex;flex-direction:column;gap:20px;animation:wallUp 90s linear infinite}
.ti-wcol[data-dir="down"] .ti-wtrack{animation:wallDown 95s linear infinite}
.ti-wcol:nth-child(2) .ti-wtrack{animation-duration:105s}
.ti-wcol:nth-child(3) .ti-wtrack{animation-duration:85s}
@keyframes wallUp{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}
@keyframes wallDown{0%{transform:translateY(-50%)}100%{transform:translateY(0)}}
body.no-heavy .ti-wtrack{animation:none}

.ti-wcard{
  display:grid;grid-template-columns:72px 1fr;gap:16px;align-items:flex-start;
  padding:20px;border-radius:18px;
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(26,23,18,0.06);
  box-shadow:0 1px 3px rgba(26,23,18,0.03),0 16px 40px -24px rgba(26,23,18,0.14);
  transition:transform 0.35s var(--ease),box-shadow 0.35s var(--ease);
}
.ti-wcard:hover{transform:translateY(-3px);box-shadow:0 2px 6px rgba(26,23,18,0.06),0 24px 50px -20px rgba(26,23,18,0.2)}
.ti-wphoto{
  width:72px;height:72px;border-radius:14px;
  background:linear-gradient(135deg,var(--ti-g1,#C9B298) 0%,var(--ti-g2,#6B4A35) 100%);
  position:relative;overflow:hidden;flex-shrink:0;
}
.ti-wphoto::before{
  content:attr(data-initials);
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-style:italic;font-size:32px;
  color:rgba(255,255,255,0.6);letter-spacing:-0.03em;
}
.ti-wphoto::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.35), transparent 50%);
}
.ti-wtext{font-size:13.5px;line-height:1.5;color:var(--cream-ink);margin:2px 0 10px;letter-spacing:-0.005em}
.ti-wtext strong{color:var(--gold-ink);font-weight:600}
.ti-wmeta{display:flex;flex-direction:column;gap:2px;font-size:12px}
.ti-wmeta strong{color:var(--cream-ink);font-weight:600;font-size:12.5px}
.ti-wmeta span{font-family:var(--ff-mono);font-size:10px;color:var(--cream-ink-dim);letter-spacing:0.04em}

.ti-meta{max-width:var(--maxw);margin:72px auto 0;padding:40px 32px 0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid var(--cream-border-strong)}
@media(max-width:700px){.ti-meta{grid-template-columns:1fr;gap:24px}}
.ti-stat{display:flex;flex-direction:column;gap:6px;text-align:center}
.tis-num{font-family:var(--ff-sans);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:500;color:var(--cream-ink);letter-spacing:-0.03em;line-height:1}
.tis-num small{font-size:0.5em;color:var(--cream-ink-dim);font-weight:400;margin-left:2px}
.tis-lbl{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.12em;color:var(--cream-ink-dim);text-transform:uppercase}

/* ==================== FOUNDER ==================== */
.founder{padding:140px 0;background:linear-gradient(180deg,#070709 0%,#0a0a0e 50%,#070709 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.founder-inner{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:900px){.founder-inner{grid-template-columns:420px 1fr;gap:80px;align-items:start}}
.founder-portrait{position:sticky;top:100px}
.fp-frame{
  position:relative;aspect-ratio:3/4;border-radius:20px;overflow:hidden;
  border:1px solid var(--border-strong);
  background:linear-gradient(135deg,#1a1612,#0a0908);
  box-shadow:0 30px 80px -20px rgba(0,0,0,0.8),0 0 60px -30px rgba(201,178,152,0.3);
}
.fp-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.fp-fallback{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 40%,rgba(201,178,152,0.25),transparent 60%)}
.fp-placeholder{font-family:var(--ff-display);font-style:italic;font-size:160px;color:var(--gold-bright);line-height:1;opacity:0.6;text-shadow:0 10px 40px rgba(201,178,152,0.4)}
.fp-tint{position:absolute;inset:0;z-index:3;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.4) 100%);pointer-events:none}
.fp-corner{position:absolute;z-index:4;width:16px;height:16px;border:1px solid var(--gold);pointer-events:none}
.fp-corner-tl{top:12px;left:12px;border-right:none;border-bottom:none}
.fp-corner-tr{top:12px;right:12px;border-left:none;border-bottom:none}
.fp-corner-bl{bottom:12px;left:12px;border-right:none;border-top:none}
.fp-corner-br{bottom:12px;right:12px;border-left:none;border-top:none}
.fp-caption{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-top:16px;padding:0 4px;font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase}
.fp-c-val{color:var(--gold);font-weight:600}
.fp-c-lbl{color:var(--text-dim)}

.founder-name{font-size:clamp(3rem,6vw,5rem);font-weight:500;letter-spacing:-0.045em;line-height:1;margin:20px 0 16px;color:var(--text)}
.founder-name em{color:var(--gold-bright)}
.founder-role{font-size:17px;color:var(--text-mid);line-height:1.5;margin-bottom:28px;font-weight:300;max-width:520px}
.founder-role strong{color:var(--text);font-weight:500}
.founder-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}
.founder-tags span{padding:7px 14px;border-radius:999px;font-size:12px;background:var(--surface);border:1px solid var(--border-strong);color:var(--text-mid);font-family:var(--ff-mono)}
.founder-stats{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin:0 0 40px;padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.fs-num{font-family:var(--ff-mono);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:600;color:var(--gold);letter-spacing:-0.03em;display:block;line-height:1}
.fs-num small{font-size:0.5em;color:var(--gold-bright);font-weight:500;margin-left:4px}
.fs-lbl{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.1em;color:var(--text-dim);text-transform:uppercase;display:block;margin-top:8px}
.founder-text{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.founder-text p{font-size:15px;color:var(--text-mid);line-height:1.7;font-weight:300}
.founder-text strong{color:var(--text);font-weight:500}
.founder-media{padding-top:24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.fm-label{font-family:var(--ff-mono);font-size:10px;letter-spacing:0.15em;color:var(--text-dim);text-transform:uppercase}
.fm-logos{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.fm-logos span{font-family:var(--ff-display);font-style:italic;font-size:20px;color:var(--text-dim);transition:color 0.2s}
.fm-logos span:hover{color:var(--text)}
@media(max-width:900px){.founder-portrait{position:relative;top:auto;max-width:340px;margin:0 auto}}

/* ==================== HUBS LENDÁRIOS ==================== */
.hubs{position:relative;padding:140px 0 120px;background:#050507;border-top:1px solid var(--border);overflow:hidden}
.hubs-sky{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:0.8}
.hubs-sky-svg{width:100%;height:100%}
.hubs-inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* Strip */
.hubs-strip{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:24px;align-items:center;
  margin:56px 0 80px;padding:36px 40px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(201,178,152,0.06),rgba(201,178,152,0.02));
  border:1px solid var(--gold-20);
  box-shadow:0 30px 80px -40px rgba(201,178,152,0.2),0 0 0 1px rgba(255,255,255,0.02) inset;
}
@media(max-width:900px){
  .hubs-strip{grid-template-columns:1fr 1fr;gap:24px;padding:28px 24px}
  .hubs-strip .hs-sep2{display:none}
}
.hs-stat{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.hs-big{font-family:var(--ff-mono);font-size:clamp(2.4rem,5vw,4rem);font-weight:600;color:var(--gold-bright);letter-spacing:-0.035em;line-height:0.95}
.hs-big small{font-size:0.4em;color:var(--gold);font-weight:500;margin-left:4px}
.hs-lbl2{font-family:var(--ff-mono);font-size:11px;letter-spacing:0.12em;color:var(--text-dim);text-transform:uppercase}
.hs-sep2{width:1px;height:44px;background:var(--gold-20)}

/* Split map + copy */
.hubs-split{display:grid;grid-template-columns:1fr;gap:60px;margin-bottom:80px;align-items:start}
@media(min-width:960px){.hubs-split{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:80px}}

.hubs-map{position:relative}
.hm-frame{
  position:relative;aspect-ratio:3/2;max-width:640px;margin:0 auto;
  border-radius:24px;overflow:hidden;
  background:radial-gradient(ellipse at center,rgba(201,178,152,0.08) 0%,transparent 70%),linear-gradient(180deg,#0a0a0e,#050507);
  border:1px solid var(--border-strong);
  box-shadow:0 30px 80px -30px rgba(0,0,0,0.8),0 0 60px -30px rgba(201,178,152,0.15) inset;
}
.hm-brazil{width:100%;height:100%;padding:24px}
.hm-pins g circle:first-child{animation:hmHalo 3s ease-in-out infinite}
.hm-pins g:nth-child(2) circle:first-child{animation-delay:-0.5s}
.hm-pins g:nth-child(3) circle:first-child{animation-delay:-1s}
.hm-pins g:nth-child(4) circle:first-child{animation-delay:-1.5s}
.hm-pins g:nth-child(5) circle:first-child{animation-delay:-2s}
.hm-pins g:nth-child(6) circle:first-child{animation-delay:-2.5s}
.hm-pins g:nth-child(7) circle:first-child{animation-delay:-0.8s}
@keyframes hmHalo{0%,100%{opacity:0.3;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}
body.no-heavy .hm-pins g circle:first-child{animation:none}

.hm-legend{
  position:absolute;bottom:16px;left:16px;right:16px;
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:10px 14px;border-radius:10px;
  background:rgba(10,10,14,0.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border-strong);
  font-family:var(--ff-mono);font-size:10px;letter-spacing:0.08em;color:var(--text-mid);text-transform:uppercase;
}
.hm-l-item{display:inline-flex;align-items:center;gap:8px}
.hm-l-dot{width:7px;height:7px;border-radius:50%}
.hm-l-dot.active{background:#E4D8CA;box-shadow:0 0 8px var(--gold)}
.hm-l-dot.seeking{border:1px dashed var(--gold);background:transparent}

/* Copy side */
.hubs-ctitle{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:500;letter-spacing:-0.03em;line-height:1.1;color:var(--text);margin-bottom:20px;text-wrap:balance}
.hubs-ctitle em{color:var(--gold-bright)}
.hubs-cdesc{font-size:15.5px;line-height:1.65;color:var(--text-mid);margin-bottom:32px;font-weight:300}
.hubs-cdesc strong{color:var(--text);font-weight:500}

.hubs-list{display:flex;flex-direction:column;gap:18px;margin-bottom:36px;padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.hubs-list li{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.hl-num{font-family:var(--ff-mono);font-size:11px;color:var(--gold);letter-spacing:0.1em;padding:4px 8px;border:1px solid var(--gold-20);border-radius:4px;margin-top:2px}
.hubs-list li strong{display:block;font-size:15px;color:var(--text);font-weight:500;margin-bottom:2px;letter-spacing:-0.01em}
.hubs-list li span{display:block;font-size:13.5px;color:var(--text-mid);line-height:1.55;font-weight:300}

.hubs-ctas{display:flex;flex-wrap:wrap;gap:10px}
.btn-sm{height:44px;padding:0 20px;font-size:13px}

/* Events */
.hubs-events{margin-bottom:64px}
.he-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.he-all{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-mono);font-size:11px;letter-spacing:0.1em;color:var(--gold);text-transform:uppercase;transition:gap 0.3s}
.he-all:hover{gap:10px;color:var(--gold-bright)}

.he-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.he-grid{grid-template-columns:1fr 1fr;gap:14px}}
@media(min-width:960px){.he-grid{grid-template-columns:repeat(4,1fr)}}

.he-card{
  display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  padding:20px;border-radius:16px;
  background:var(--surface);
  border:1px solid var(--border);
  transition:all 0.3s var(--ease);
}
.he-card:hover{border-color:var(--gold-30);transform:translateY(-3px);background:linear-gradient(180deg,rgba(201,178,152,0.04),var(--surface));box-shadow:0 20px 40px -20px rgba(201,178,152,0.15)}
.he-date{display:flex;flex-direction:column;align-items:center;padding:10px 14px;border-radius:10px;background:var(--gold-10);border:1px solid var(--gold-20);min-width:60px}
.he-day{font-family:var(--ff-sans);font-size:22px;font-weight:600;color:var(--gold-bright);letter-spacing:-0.02em;line-height:1}
.he-month{font-family:var(--ff-mono);font-size:10px;letter-spacing:0.1em;color:var(--gold);margin-top:2px}
.he-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.he-tag{font-family:var(--ff-mono);font-size:9px;letter-spacing:0.15em;color:var(--text-dim)}
.he-city{font-size:16px;font-weight:500;color:var(--text);letter-spacing:-0.015em}
.he-name{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.he-arrow{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;color:var(--text-mid);transition:all 0.3s var(--ease)}
.he-card:hover .he-arrow{background:var(--gold);color:var(--bg-deep);border-color:var(--gold);transform:translateX(4px)}

/* No hub in your city */
.hubs-empty{
  display:grid;grid-template-columns:1fr;gap:20px;align-items:center;
  padding:36px 40px;border-radius:20px;
  background:linear-gradient(90deg,rgba(201,178,152,0.08),rgba(201,178,152,0.02));
  border:1px dashed var(--gold-30);
}
@media(min-width:800px){.hubs-empty{grid-template-columns:auto 1fr auto;gap:40px;padding:32px 40px}}
.hue-left{display:flex;flex-direction:column;gap:4px}
.hue-eyebrow{font-family:var(--ff-mono);font-size:11px;letter-spacing:0.1em;color:var(--text-dim);text-transform:uppercase}
.hue-title{font-family:var(--ff-display);font-style:italic;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--gold-bright);letter-spacing:-0.02em;line-height:1}
.hue-desc{font-size:14px;color:var(--text-mid);line-height:1.55;font-weight:300;max-width:460px}
.hue-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:999px;background:var(--gold);color:var(--bg-deep);font-weight:600;font-size:13.5px;transition:all 0.3s var(--ease);white-space:nowrap}
.hue-cta:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 10px 30px -10px rgba(201,178,152,0.4)}

/* ==================== CTA ==================== */
.cta{position:relative;padding:140px 24px;overflow:hidden;background:var(--bg-deep)}
.cta-neural{position:absolute;inset:0;z-index:0;width:100%;height:100%;opacity:0.8;pointer-events:none}
body.no-heavy .cta-neural{opacity:0.4}
.cta-gradient{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(201,178,152,0.18), transparent 60%),
    radial-gradient(ellipse 40% 40% at 20% 30%, rgba(212,165,116,0.12), transparent 70%),
    radial-gradient(ellipse 40% 40% at 80% 70%, rgba(139,117,86,0.15), transparent 70%);
}
.cta-frame{
  position:relative;z-index:2;max-width:800px;margin:0 auto;
  padding:56px 48px;border-radius:24px;
  background:rgba(10,10,13,0.72);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);
  border:1px solid var(--gold-20);
  box-shadow:0 30px 100px rgba(0,0,0,0.5),0 0 60px -20px rgba(201,178,152,0.2),0 0 0 1px rgba(255,255,255,0.03) inset;
}
.cta-meta{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;border-radius:999px;background:var(--gold-05);border:1px solid var(--gold-30);font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.15em;color:var(--gold);text-transform:uppercase;margin-bottom:28px}
.cta-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);animation:livePulse 2s ease-in-out infinite}
.cta-title{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:500;letter-spacing:-0.035em;line-height:1.05;color:var(--text);margin-bottom:20px;text-wrap:balance}
.cta-title em{color:var(--gold-bright)}
.cta-sub{font-size:15.5px;color:var(--text-mid);line-height:1.65;margin-bottom:40px;max-width:560px;font-weight:300}
.cta-sub strong{color:var(--text);font-weight:500}
.cta-form{position:relative}
.cta-fields{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:20px;transition:opacity 0.4s}
@media(min-width:620px){.cta-fields{grid-template-columns:1fr 1fr}.cta-field:first-child{grid-column:span 2}}
.cta-field{display:flex;flex-direction:column;gap:6px}
.cta-field label{font-family:var(--ff-mono);font-size:10px;letter-spacing:0.15em;color:var(--text-dim);text-transform:uppercase}
.cta-field input{height:46px;padding:0 16px;border-radius:10px;background:rgba(255,255,255,0.04);border:1px solid var(--border-strong);color:var(--text);font-size:14px;transition:all 0.2s;outline:none}
.cta-field input::placeholder{color:var(--text-faint)}
.cta-field input:focus{border-color:var(--gold);background:rgba(255,255,255,0.06);box-shadow:0 0 0 3px var(--gold-10)}
.cta-submit{width:100%;height:52px;border-radius:12px;background:var(--gold);color:var(--bg-deep);font-weight:600;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:all 0.3s var(--ease);box-shadow:0 10px 40px -10px rgba(201,178,152,0.4)}
.cta-submit:hover:not(:disabled){background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 16px 50px -10px rgba(201,178,152,0.55)}
.cta-submit:disabled{opacity:0.5}
.cta-fine{text-align:center;margin-top:14px;font-family:var(--ff-mono);font-size:10px;color:var(--text-dim);letter-spacing:0.08em}
.cta-success{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:12px;background:rgba(10,10,13,0.95);border-radius:12px;opacity:0;pointer-events:none;transition:opacity 0.4s;font-size:15px;color:var(--gold-bright);padding:20px;text-align:center;flex-direction:column}
.cta-success.show{opacity:1}
.cta-success-icon{width:48px;height:48px;border-radius:50%;background:var(--gold);color:var(--bg-deep);display:flex;align-items:center;justify-content:center;animation:successPop 0.5s var(--ease-out-expo)}
@keyframes successPop{0%{transform:scale(0) rotate(-180deg)}100%{transform:scale(1) rotate(0)}}

/* ==================== FOOTER (unificado) ==================== */
.footer{background:var(--bg);padding:0}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:80px 32px 40px}
.footer-top{display:flex;flex-direction:column;gap:16px;padding-bottom:56px;border-bottom:1px solid var(--border);margin-bottom:56px;max-width:520px}
.footer-brand{display:inline-flex;align-items:center;gap:10px;font-size:16px;font-weight:500}
.footer-brand em{font-family:var(--ff-display);font-style:italic;font-weight:400;color:var(--gold-bright)}
.footer-tagline{color:var(--text-mid);line-height:1.6;font-size:14px;font-weight:300}
.footer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px 24px;margin-bottom:56px}
@media(min-width:720px){.footer-grid{grid-template-columns:repeat(4,1fr)}}
.footer-grid h4{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.15em;color:var(--gold);text-transform:uppercase;margin-bottom:16px;font-weight:600}
.footer-grid a{display:block;padding:6px 0;color:var(--text-mid);font-size:13.5px;transition:color 0.2s}
.footer-grid a:hover{color:var(--text)}
.footer-bottom{display:flex;flex-direction:column;gap:12px;padding-top:32px;border-top:1px solid var(--border);font-family:var(--ff-mono);font-size:10.5px;letter-spacing:0.08em;color:var(--text-dim);text-transform:uppercase}
@media(min-width:720px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}}
.footer-middle{color:var(--text-faint)}

/* ===== Video iframe inside ti-vmedia ===== */
.ti-vcard--video-only{
  grid-template-columns:1fr !important;
  max-width:960px;margin:0 auto;
  background:rgba(15,13,10,0.92);
  border:1px solid rgba(201,178,152,0.18);
  box-shadow:0 30px 80px -30px rgba(0,0,0,0.6);
}
.ti-vmedia--video{
  background:#000;cursor:default;min-height:0;
  aspect-ratio:16/9;width:100%;
}
.ti-vmedia--video::before,.ti-vmedia--video::after{display:none}
.ti-vmedia--video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:2}

/* ===== Image cards for testimonial wall (softer shadow) ===== */
.ti-wimg{
  border-radius:16px;overflow:hidden;
  background:rgba(255,255,255,0.4);
  border:1px solid rgba(26,23,18,0.04);
  box-shadow:0 8px 24px -16px rgba(26,23,18,0.1);
  transition:transform 0.3s var(--ease),box-shadow 0.3s var(--ease);
}
.ti-wimg:hover{transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(26,23,18,0.16)}
.ti-wimg img{display:block;width:100%;height:auto;border-radius:15px}

/* ===== Wall mask — suaviza fade nas bordas ===== */
.ti-wall{
  -webkit-mask-image:linear-gradient(180deg,transparent,black 6%,black 94%,transparent) !important;
  mask-image:linear-gradient(180deg,transparent,black 6%,black 94%,transparent) !important;
}

/* ===== Contraste tag eyebrow no light-section ===== */
.light-section .ti-vtag{
  background:rgba(141,117,86,0.08);
  border-color:rgba(107,74,53,0.25);
  color:var(--cream-ink);
}

/* ===== Contraste dots de paginação ===== */
.ti-vdot{background:rgba(107,74,53,0.25)}
.ti-vdot.active{background:var(--cream-ink);width:36px}
.ti-vdot:hover:not(.active){background:rgba(107,74,53,0.5)}

/* ===== Globe hubs (Hubs section) ===== */
.hm-globe{width:100%;height:100%;display:block}
.hg-pins{filter:drop-shadow(0 0 16px rgba(228,216,202,0.45))}
.hg-pins g circle:first-child{animation:hgHalo 3s ease-in-out infinite}
.hg-pins g:nth-child(2) circle:first-child{animation-delay:-0.4s}
.hg-pins g:nth-child(3) circle:first-child{animation-delay:-0.8s}
.hg-pins g:nth-child(4) circle:first-child{animation-delay:-1.2s}
.hg-pins g:nth-child(5) circle:first-child{animation-delay:-1.6s}
.hg-pins g:nth-child(6) circle:first-child{animation-delay:-2s}
.hg-pins g:nth-child(7) circle:first-child{animation-delay:-2.4s}
.hg-pins g:nth-child(8) circle:first-child{animation-delay:-0.6s}
.hg-pins g:nth-child(9) circle:first-child{animation-delay:-1s}
@keyframes hgHalo{0%,100%{opacity:0.3;transform:scale(1)}50%{opacity:1;transform:scale(1.35)}}
body.no-heavy .hg-pins g circle:first-child{animation:none}
.hg-labels text{filter:drop-shadow(0 0 4px rgba(0,0,0,0.7))}

/* ===== Logo no nav — img vez de svg ===== */
img.nav-mark{flex-shrink:0;object-fit:contain}

/* ===== Nav brand — mesma fonte, sem serif italic ===== */
.nav-brand em,.footer-brand em{font-family:inherit;font-style:normal;font-weight:inherit;color:inherit}
.nav-brand .bracket,.footer-brand .bracket{color:var(--gold)}

/* ===== Wall hover — pausa a animação pra conseguir ler ===== */
.ti-wall:hover .ti-wtrack,
.ti-wall:focus-within .ti-wtrack{animation-play-state:paused}

/* ===== 3D testimonial carousel (estilo v2 adaptado pra v4) ===== */
.testi-stage{
  position:relative;width:100%;max-width:1200px;margin:0 auto;
  min-height:520px;overflow:visible;perspective:1400px;
  padding:0 0 90px;
}
@media(max-width:880px){.testi-stage{min-height:auto;perspective:none;padding:0 12px 80px}}
.testi-glow{
  position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);
  width:55%;height:55%;background:radial-gradient(ellipse,rgba(201,178,152,0.1),transparent 70%);
  border-radius:50%;pointer-events:none;z-index:1;
}
.testi-card{
  position:absolute;top:45%;left:50%;width:640px;max-width:92vw;
  transition:all 0.55s cubic-bezier(0.4,0,0.2,1);cursor:pointer;
  will-change:transform,opacity;
}
.testi-card[data-pos="center"]{transform:translate(-50%,-50%) scale(1) rotate(0deg);z-index:30;opacity:1}
.testi-card[data-pos="left"]{transform:translate(-108%,-50%) scale(0.78) rotate(-6deg);z-index:10;opacity:0.4}
.testi-card[data-pos="left"]:hover{opacity:0.8;z-index:35}
.testi-card[data-pos="right"]{transform:translate(8%,-50%) scale(0.78) rotate(6deg);z-index:10;opacity:0.4}
.testi-card[data-pos="right"]:hover{opacity:0.8;z-index:35}
.testi-card[data-pos="hidden"]{transform:translate(-50%,-50%) scale(0.6) rotate(0deg);z-index:0;opacity:0;pointer-events:none}

.testi-card-outer{
  position:relative;display:flex;flex-direction:column;
  background:#0a0807;
  border:1px solid rgba(201,178,152,0.12);
  border-radius:20px;overflow:hidden;
  box-shadow:0 18px 40px -20px rgba(0,0,0,0.55);
}
.testi-card[data-pos="center"] .testi-card-outer{
  border-color:rgba(201,178,152,0.32);
  box-shadow:0 24px 60px -24px rgba(0,0,0,0.7),0 0 24px rgba(201,178,152,0.08);
}
.testi-card-shine{
  position:absolute;top:0;left:1.5rem;right:1.5rem;height:1px;z-index:30;
  background:linear-gradient(to right,transparent,rgba(255,255,255,0.18),transparent);opacity:0.5;
}
.testi-card[data-pos="center"] .testi-card-shine{
  background:linear-gradient(to right,transparent,var(--gold-bright),transparent);opacity:1;
  box-shadow:0 0 10px rgba(201,178,152,0.4);
}
.testi-card-inner{position:relative;background:#000;border-radius:19px;overflow:hidden}
.testi-card-grid{display:none}
.testi-card-body{position:relative;z-index:10;padding:0}
.testi-video{
  aspect-ratio:16/9;overflow:hidden;background:#000;
  width:100%;position:relative;
}
.testi-video iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}

.testi-nav{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  display:flex;gap:14px;z-index:40;
}
.testi-btn{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(to bottom,rgba(30,25,20,0.95),rgba(12,10,8,0.95));
  border:1px solid rgba(201,178,152,0.2);
  color:var(--gold-bright);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all 0.2s ease;
  box-shadow:0 4px 12px rgba(0,0,0,0.4);
}
.testi-btn:hover{color:#fff;border-color:rgba(201,178,152,0.5);transform:translateY(-1px)}
.testi-btn:active{transform:translateY(1px);box-shadow:0 2px 6px rgba(0,0,0,0.4)}

@media(max-width:880px){
  .testi-card{position:relative;top:auto;left:auto;width:100%;
    transform:none !important;opacity:1 !important;z-index:auto !important;
    margin-bottom:16px;pointer-events:auto !important;
    transition:none;
  }
  .testi-card[data-pos="hidden"]{display:none}
  .testi-nav{position:relative;bottom:auto;margin-top:8px;transform:none;left:auto;justify-content:center}
  .testi-glow{display:none}
}

/* ===== Performance — content-visibility on below-the-fold sections ===== */
/* Saves render work for offscreen content. Browser skips paint+layout until near viewport. */
.manifesto,
.why,
.programs,
.proofs,
.founder,
.hubs,
.cta,
.footer{content-visibility:auto;contain-intrinsic-size:0 800px}
