/* =============================================================
   NihuPartners — styles.css
   Archetype: Mouse-Reactive Gradient (05) — dark, neon accent
   Skill: adrian-saenz-hostinger-premium-website
   ============================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0a0714;
  --bg-2:#110d1e;
  --bg-3:#1a1430;
  --card:rgba(255,255,255,.04);
  --ink:#f0ecfc;
  --ink-soft:#b8aed4;
  --ink-mute:#6b6285;
  --accent:#a78bfa;        /* violet */
  --accent-2:#38bdf8;      /* sky blue */
  --accent-3:#f472b6;      /* pink — missions */
  --accent-gold:#f59e0b;   /* gold — premium */
  --green:#22d3ee;
  --line:rgba(167,139,250,.12);
  --line-2:rgba(56,189,248,.1);
  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;
  --shadow:0 12px 40px rgba(0,0,0,.45);
  --shadow-glow:0 0 40px -10px rgba(167,139,250,.4);
  --nav-h:70px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.25,.46,.45,.94);
  /* Mouse gradient position */
  --mx:50%; --my:50%;
  /* Gradient-1, 2, 3 for hero */
  --g1:rgba(167,139,250,.7);
  --g2:rgba(56,189,248,.55);
  --g3:rgba(244,114,182,.4);
}

html{scroll-behavior:smooth;overflow-x:clip;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}
h1,h2,h3,h4{font-family:'Sora','Inter',sans-serif;line-height:1.1;letter-spacing:-.02em;font-weight:700}
input,select,textarea{font:inherit}
p{text-wrap:pretty}
::selection{background:var(--accent);color:#0a0714}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

.container{width:min(1180px,100% - 2.5rem);margin-inline:auto}

/* ---- Splash (skill A.9 double-safety) ---- */
.splash{
  position:fixed;inset:0;z-index:1000;display:grid;place-items:center;
  background:var(--bg);transition:opacity .8s var(--ease),clip-path 1.1s var(--ease);
  animation:splashSafety .01s 4.5s forwards
}
.splash.is-out{opacity:0;pointer-events:none;clip-path:inset(0 0 100% 0)}
@keyframes splashSafety{to{opacity:0;pointer-events:none;clip-path:inset(0 0 100% 0)}}
.splash-inner{display:flex;flex-direction:column;align-items:center;gap:1rem}
.splash-logo{width:56px;height:56px;animation:splashPulse 1.5s var(--ease-soft) infinite}
@keyframes splashPulse{0%,100%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.08) rotate(3deg)}}
.splash-name{font-family:'Sora',sans-serif;font-weight:800;font-size:1.2rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.splash-bar{width:120px;height:2px;background:var(--line);border-radius:99px;overflow:hidden}
.splash-bar::after{content:"";display:block;height:100%;width:0;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  animation:splashLoad 1.6s var(--ease) forwards}
@keyframes splashLoad{to{width:100%}}

/* ---- Nav ---- */
.nav{
  position:fixed;top:0;inset-inline:0;z-index:90;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .4s var(--ease),border-color .4s,backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(10,7,20,.85);backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);border-bottom-color:var(--line);
}
.nav-inner{width:min(1180px,100% - 2.5rem);margin-inline:auto;display:flex;align-items:center;gap:1.5rem}
.nav-brand{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.nav-brand-logo{width:36px;height:36px}
.nav-brand-name{font-family:'Sora',sans-serif;font-weight:800;font-size:1.15rem;letter-spacing:-.025em;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.nav-links{display:flex;align-items:center;gap:.2rem;margin-left:1rem}
.nav-link{
  position:relative;padding:.48rem .9rem;border-radius:10px;
  font-size:.9rem;font-weight:500;color:var(--ink-soft);transition:.18s;
}
.nav-link::after{
  content:"";position:absolute;left:.9rem;right:.9rem;bottom:.2rem;height:1.5px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transform:scaleX(0);transform-origin:right;transition:transform .42s var(--ease-soft);border-radius:2px;
}
.nav-link:hover{color:var(--ink);background:rgba(167,139,250,.08)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1);transform-origin:left}
.nav-link.active{color:var(--accent)}
.nav-actions{display:flex;align-items:center;gap:.6rem;margin-left:auto;flex-shrink:0}
.btn-nav{
  padding:.52rem 1.2rem;border-radius:var(--radius-pill);font-weight:600;font-size:.875rem;
  border:1px solid var(--line);color:var(--ink-soft);transition:.2s var(--ease);
}
.btn-nav:hover{border-color:var(--accent);color:var(--accent)}
.btn-nav-cta{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0a0714;
  border-color:transparent;font-weight:700;
  box-shadow:0 8px 24px -8px rgba(167,139,250,.5);
}
.btn-nav-cta:hover{transform:translateY(-2px);box-shadow:0 14px 32px -10px rgba(167,139,250,.65)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:9px;border-radius:10px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.8rem 1.65rem;border-radius:var(--radius-pill);font-weight:700;font-size:.94rem;
  transition:all .22s var(--ease);white-space:nowrap;border:1px solid transparent;
}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0a0714;
  box-shadow:0 10px 28px -8px rgba(167,139,250,.55);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px -10px rgba(167,139,250,.7)}
.btn-outline{border-color:var(--line);color:var(--ink-soft)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-gold{background:linear-gradient(135deg,var(--accent-gold),#fcd34d);color:#0a0714;
  box-shadow:0 10px 28px -8px rgba(245,158,11,.45)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 36px -8px rgba(245,158,11,.6)}
.btn-ghost{background:rgba(255,255,255,.05);border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover{background:rgba(167,139,250,.08);border-color:var(--accent);color:var(--accent)}
.btn-sm{padding:.52rem 1rem;font-size:.84rem}
.btn-lg{padding:1rem 2.2rem;font-size:1rem}
.btn-block{width:100%;display:flex}
/* Magnetic wrapper */
.has-magnetic{position:relative;isolation:isolate}
.magnetic-inner{display:inline-flex;align-items:center;justify-content:center;gap:inherit;will-change:transform;transition:transform .7s var(--ease-soft)}

/* ---- Toast ---- */
.toast{position:fixed;bottom:1.4rem;left:50%;transform:translateX(-50%) translateY(20px);z-index:999;
  background:var(--bg-3);border:1px solid var(--line);padding:.7rem 1.3rem;border-radius:var(--radius-pill);
  font-size:.9rem;font-weight:500;opacity:0;pointer-events:none;transition:.3s;box-shadow:var(--shadow)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:rgba(34,211,238,.3);color:var(--green)}
.toast.err{border-color:rgba(244,114,182,.3);color:var(--accent-3)}

/* ---- Mouse-reactive hero (skill 4.5) ---- */
.hero{
  min-height:100svh;display:flex;align-items:center;
  padding-block:calc(var(--nav-h) + 3rem) 4rem;
  position:relative;overflow:hidden;isolation:isolate;
}
.hero-gradient{
  position:absolute;inset:-20%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle 700px at var(--mx) var(--my),var(--g1) 0%,transparent 55%),
    radial-gradient(circle 600px at calc(var(--mx) + 18%) calc(var(--my) - 15%),var(--g2) 0%,transparent 50%),
    radial-gradient(circle 500px at calc(var(--mx) - 20%) calc(var(--my) + 20%),var(--g3) 0%,transparent 50%),
    var(--bg);
  filter:blur(48px) saturate(160%);
}
/* Grain overlay for depth (skill 5.5) */
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>") 200px 200px;
}
.hero-inner{width:min(1180px,100% - 2.5rem);margin-inline:auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.hero-kicker{display:inline-flex;align-items:center;gap:.55rem;font-size:.78rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.hero-kicker::before{content:"";width:28px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
.hero h1{font-size:clamp(2.8rem,5.5vw,4.5rem);margin-bottom:1.1rem}
.hero h1 em{font-style:normal;background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:1.1rem;color:var(--ink-soft);max-width:48ch;margin-bottom:2rem;line-height:1.7}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-numbers{display:flex;gap:2rem;margin-top:2.5rem;flex-wrap:wrap}
.hero-num{display:flex;flex-direction:column}
.hero-num-val{font-family:'Sora',sans-serif;font-weight:800;font-size:1.8rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.hero-num-lbl{font-size:.8rem;color:var(--ink-mute);margin-top:.25rem}

/* Hero right — platform grid */
.platforms-mini{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.platform-mini{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.25rem 1rem;display:flex;flex-direction:column;gap:.7rem;
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;position:relative;overflow:hidden;
}
.platform-mini::before{
  content:"";position:absolute;inset:0;z-index:0;border-radius:inherit;
  background:var(--plat-bg,rgba(167,139,250,.05));opacity:0;transition:opacity .3s;
}
.platform-mini:hover{transform:translateY(-5px);box-shadow:var(--shadow-glow);border-color:var(--accent)}
.platform-mini:hover::before{opacity:1}
.pm-logo{width:42px;height:42px;object-fit:contain;border-radius:10px;position:relative;z-index:1}
.pm-name{font-weight:700;font-size:.9rem;position:relative;z-index:1}
.pm-cat{font-size:.72rem;color:var(--ink-mute);position:relative;z-index:1}
.pm-perk{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:700;
  padding:.22rem .6rem;border-radius:99px;background:rgba(167,139,250,.12);color:var(--accent);position:relative;z-index:1}

/* ---- How-it-works ---- */
.section{padding-block:5rem}
.section-soft{background:var(--bg-2)}
.section-head{text-align:center;margin-bottom:3.5rem}
.kicker{display:inline-block;font-size:.76rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:.65rem}
.section-title{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:.7rem}
.section-desc{color:var(--ink-soft);max-width:56ch;margin-inline:auto;font-size:.97rem}

.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.step{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.75rem 1.4rem;position:relative;transition:transform .3s var(--ease),border-color .3s;
}
.step:hover{transform:translateY(-6px);border-color:var(--accent)}
.step::before{content:"";position:absolute;top:0;left:1.4rem;right:1.4rem;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));opacity:0;transition:opacity .3s}
.step:hover::before{opacity:1}
.step-num{width:2.6rem;height:2.6rem;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#0a0714;font-family:'Sora',sans-serif;font-weight:800;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.step-title{font-size:1rem;margin-bottom:.5rem}
.step-desc{font-size:.86rem;color:var(--ink-soft);line-height:1.6}

/* ---- Platforms section ---- */
.platforms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.platform-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem;display:flex;gap:1.5rem;align-items:flex-start;
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
}
.platform-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:var(--shadow-glow)}
.plc-logo{width:60px;height:60px;object-fit:contain;border-radius:14px;flex-shrink:0;
  padding:8px;background:var(--bg-3);border:1px solid var(--line)}
.plc-body{display:flex;flex-direction:column;gap:.4rem}
.plc-name{font-size:1.1rem;font-weight:700}
.plc-tagline{font-size:.8rem;color:var(--accent);font-weight:600}
.plc-desc{font-size:.875rem;color:var(--ink-soft);line-height:1.6}
.plc-perk{display:inline-flex;align-items:center;gap:.35rem;margin-top:.4rem;font-size:.78rem;font-weight:700;
  padding:.28rem .7rem;border-radius:99px;background:rgba(56,189,248,.1);color:var(--accent-2)}

/* ---- Tiers ---- */
.tiers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.tier-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.5rem 1.1rem;text-align:center;display:flex;flex-direction:column;gap:.5rem;
  transition:transform .3s var(--ease),box-shadow .3s;
}
.tier-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px -18px rgba(167,139,250,.45)}
.tier-ico{font-size:2.2rem}
.tier-name{font-family:'Sora',sans-serif;font-weight:800;font-size:.98rem}
.tier-min{font-size:.72rem;color:var(--accent);font-weight:700}
.tier-pct{font-family:'Sora',sans-serif;font-weight:800;font-size:2rem;line-height:1;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.tier-pct-lbl{font-size:.72rem;color:var(--ink-mute)}
.tier-perks{text-align:left;display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}
.tier-perks li{font-size:.76rem;color:var(--ink-soft);padding-left:1rem;position:relative}
.tier-perks li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}

/* ---- Missions ---- */
.missions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.mission-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.5rem;display:flex;flex-direction:column;gap:.65rem;
  transition:transform .3s var(--ease),border-color .3s;
}
.mission-card:hover{transform:translateY(-4px);border-color:var(--accent-3)}
.mission-reward{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;
  border-radius:99px;background:rgba(244,114,182,.1);color:var(--accent-3);font-weight:800;font-size:.84rem}
.mission-title{font-weight:700;font-size:.98rem}
.mission-desc{font-size:.84rem;color:var(--ink-soft);line-height:1.55;flex:1}
.mission-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;
  color:var(--ink-mute);border:1px solid var(--line);border-radius:99px;padding:.2rem .65rem}

/* ---- Reveal ---- */
[data-reveal]{opacity:0;transform:translateY(22px);
  transition:opacity .75s var(--ease-soft),transform .75s var(--ease-soft);
  transition-delay:calc(var(--i,0)*60ms)}
[data-reveal].is-revealed{opacity:1;transform:none}

/* ---- Forms (login/register) ---- */
.auth-page{min-height:100svh;display:flex;align-items:center;justify-content:center;
  padding:calc(var(--nav-h) + 2rem) 1.5rem 2rem;position:relative;overflow:hidden}
.auth-gradient{position:absolute;inset:-20%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle 600px at 25% 40%,rgba(167,139,250,.35) 0%,transparent 55%),
    radial-gradient(circle 500px at 75% 60%,rgba(56,189,248,.25) 0%,transparent 50%),
    var(--bg);
  filter:blur(60px)}
.auth-box{
  width:100%;max-width:440px;background:rgba(17,13,30,.85);
  border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2.5rem;box-shadow:0 24px 64px rgba(0,0,0,.5);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.auth-logo{width:48px;height:48px;margin:0 auto .9rem}
.auth-title{font-size:1.5rem;text-align:center;margin-bottom:.3rem}
.auth-sub{text-align:center;font-size:.9rem;color:var(--ink-mute);margin-bottom:1.8rem}
.auth-tabs{display:flex;background:var(--bg-3);border-radius:99px;padding:3px;gap:3px;margin-bottom:1.5rem}
.auth-tab{flex:1;padding:.55rem;border-radius:99px;font-size:.875rem;font-weight:700;color:var(--ink-mute);transition:.18s}
.auth-tab.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0a0714}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.9rem}
.field label{font-size:.8rem;font-weight:600;color:var(--ink-soft);letter-spacing:.04em}
.input{padding:.72rem 1rem;background:var(--bg-3);border:1px solid var(--line);border-radius:12px;
  color:var(--ink);font-size:.9rem;transition:.18s;width:100%}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(167,139,250,.15)}
.input::placeholder{color:var(--ink-mute)}
.input-code{font-family:'JetBrains Mono','Fira Mono',monospace;font-size:1.1rem;font-weight:700;
  letter-spacing:.12em;text-align:center;color:var(--accent);background:rgba(167,139,250,.07)}

/* ---- Dashboard ---- */
.dash-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;min-height:100svh;padding-top:var(--nav-h)}
.dash-sidebar{
  background:var(--bg-2);border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:0;position:sticky;top:var(--nav-h);align-self:start;
  height:calc(100svh - var(--nav-h));overflow-y:auto;
}
.dash-profile{padding:2rem 1.4rem 1.5rem;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:.5rem}
.dash-avatar{width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#0a0714;margin-bottom:.3rem}
.dash-name{font-weight:700;font-size:1.1rem}
.dash-email{font-size:.78rem;color:var(--ink-mute)}
.dash-tier-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:99px;
  font-size:.78rem;font-weight:700;background:rgba(167,139,250,.12);color:var(--accent);margin-top:.2rem}
.dash-code-wrap{margin-top:.6rem;background:var(--bg-3);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem}
.dash-code-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mute);margin-bottom:.3rem}
.dash-code{font-family:'JetBrains Mono','Fira Mono',monospace;font-size:1.05rem;font-weight:800;color:var(--accent);letter-spacing:.08em}
.dash-code-copy{font-size:.72rem;color:var(--ink-mute);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.dash-code-copy:hover{color:var(--accent)}
.dash-nav{padding:.75rem;flex:1}
.dash-nav-link{display:flex;align-items:center;gap:.7rem;padding:.7rem .9rem;border-radius:11px;
  font-size:.9rem;font-weight:600;color:var(--ink-soft);transition:.18s;cursor:pointer;width:100%;text-align:left}
.dash-nav-link:hover{background:rgba(167,139,250,.07);color:var(--ink)}
.dash-nav-link.active{background:rgba(167,139,250,.12);color:var(--accent)}
.dash-nav-ico{font-size:1.1rem}
.dash-nav-badge{margin-left:auto;font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:99px;
  background:var(--accent);color:#0a0714}
.dash-main{padding:1.8rem;overflow-y:auto}
.dash-panel{display:none}
.dash-panel.active{display:block;animation:panelFade .3s var(--ease)}
@keyframes panelFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.dash-title{font-size:1.4rem;margin-bottom:1.5rem}

.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.stat-card{
  background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.2rem 1.3rem;
}
.stat-val{font-family:'Sora',sans-serif;font-weight:800;font-size:1.65rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat-lbl{font-size:.78rem;color:var(--ink-mute);margin-top:.3rem}

/* Period tabs */
.period-tabs{display:flex;gap:.4rem;margin-bottom:1.2rem}
.period-tab{padding:.45rem .9rem;border-radius:99px;font-size:.84rem;font-weight:600;color:var(--ink-mute);
  border:1px solid transparent;transition:.18s;cursor:pointer}
.period-tab:hover{color:var(--ink)}
.period-tab.active{background:rgba(167,139,250,.12);color:var(--accent);border-color:var(--line)}

/* Analytics chart (CSS-only bar chart) */
.chart-wrap{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.4rem;margin-bottom:1.5rem}
.chart-title{font-size:.85rem;font-weight:600;color:var(--ink-soft);margin-bottom:1rem}
.chart-bars{display:flex;align-items:flex-end;gap:4px;height:120px;overflow:hidden}
.chart-bar{flex:1;border-radius:4px 4px 0 0;min-height:4px;
  background:linear-gradient(to top,var(--accent),var(--accent-2));opacity:.75;transition:opacity .2s}
.chart-bar:hover{opacity:1}
.chart-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.65rem;color:var(--ink-mute)}

/* Platform breakdown table */
.platform-table{width:100%;border-collapse:collapse}
.platform-table th,.platform-table td{padding:.7rem .8rem;border-bottom:1px solid var(--line);font-size:.875rem;text-align:left}
.platform-table th{font-size:.73rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-mute)}
.plat-logo-sm{width:28px;height:28px;object-fit:contain;border-radius:6px}
.platform-table td.val{font-family:'Sora',sans-serif;font-weight:700;color:var(--accent)}

/* Missions in dashboard */
.mission-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--bg-3);
  border:1px solid var(--line);border-radius:var(--radius);margin-bottom:.7rem}
.mission-row-ico{font-size:1.8rem;flex-shrink:0}
.mission-row-body{flex:1}
.mission-row-title{font-weight:700;font-size:.95rem;margin-bottom:.2rem}
.mission-row-desc{font-size:.83rem;color:var(--ink-soft)}
.mission-row-reward{margin-top:.4rem;font-weight:800;font-size:.84rem;
  background:linear-gradient(90deg,var(--accent-gold),#fcd34d);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.coming-soon-badge{font-size:.68rem;font-weight:700;padding:.2rem .55rem;border-radius:99px;
  background:rgba(255,255,255,.06);color:var(--ink-mute);border:1px solid var(--line)}

/* Ranking coming soon */
.ranking-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1rem;padding:4rem 2rem;text-align:center}
.ranking-soon-ico{font-size:4rem}
.ranking-preview{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1rem;
  width:100%;max-width:480px;opacity:.4;pointer-events:none}
.rank-row{display:flex;align-items:center;gap.8rem;padding:.5rem .8rem;border-radius:10px;margin-bottom:.4rem;
  background:rgba(167,139,250,.04)}

/* ---- CTA band ---- */
.cta-band{padding:1px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--accent),var(--accent-2),var(--accent-3))}
.cta-inner{background:var(--bg-2);border-radius:calc(var(--radius-lg) - 1px);
  padding:3.5rem;text-align:center;position:relative;overflow:hidden}
.cta-inner::before{content:"";position:absolute;inset:-40%;z-index:0;pointer-events:none;
  background:radial-gradient(circle 400px at 50% 50%,rgba(167,139,250,.12),transparent 65%)}
.cta-inner h2{font-size:clamp(1.8rem,3vw,2.5rem);position:relative;z-index:1}
.cta-inner p{color:var(--ink-soft);margin:.7rem auto 1.8rem;max-width:52ch;position:relative;z-index:1}
.cta-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ---- Footer ---- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding-block:3rem 1.5rem}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem}
.footer-brand img{width:36px;height:36px;margin-bottom:.6rem}
.footer-brand p{font-size:.88rem;color:var(--ink-mute);margin-top:.5rem;max-width:28ch}
.footer h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);margin-bottom:.85rem}
.footer a{display:block;font-size:.88rem;color:var(--ink-soft);padding:.22rem 0;transition:.15s}
.footer a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem;
  margin-top:2rem;padding-top:1.2rem;border-top:1px solid var(--line);font-size:.8rem;color:var(--ink-mute)}

/* ---- Family card ---- */
.family-card{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.2rem;display:flex;align-items:center;gap:1rem;margin-bottom:.7rem}
.family-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;color:#0a0714;flex-shrink:0}
.family-info{flex:1;min-width:0}
.family-name{font-weight:700;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.family-sub{font-size:.75rem;color:var(--ink-mute);margin-top:.1rem}
.family-earn{text-align:right;flex-shrink:0}
.family-earn-val{font-family:'Sora',sans-serif;font-weight:800;font-size:.98rem;color:var(--green)}
.family-earn-lbl{font-size:.7rem;color:var(--ink-mute)}

/* Passive income tip card */
.passive-tip{background:linear-gradient(135deg,rgba(167,139,250,.08),rgba(56,189,248,.06));border:1px solid rgba(167,139,250,.2);border-radius:var(--radius-lg);padding:1.2rem 1.3rem;display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem;cursor:pointer;transition:border-color .2s}
.passive-tip:hover{border-color:var(--accent)}
.passive-tip-ico{font-size:1.8rem;flex-shrink:0;line-height:1}
.passive-tip-body h4{font-size:.94rem;font-weight:700;margin-bottom:.2rem}
.passive-tip-body p{font-size:.82rem;color:var(--ink-soft);line-height:1.55}
.passive-tip-body span{font-size:.78rem;color:var(--accent);font-weight:600;margin-top:.4rem;display:inline-block}

/* Payment info banner */
.payment-banner{background:rgba(34,211,238,.06);border:1px solid rgba(34,211,238,.15);border-radius:var(--radius);padding:.85rem 1rem;font-size:.82rem;color:var(--ink-soft);line-height:1.55;margin-bottom:1.2rem}
.payment-banner strong{color:var(--green)}

/* ---- Mobile sidebar drawer ---- */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:79;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.sidebar-overlay.active{display:block}
.sidebar-mob-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--line);color:var(--ink-soft);transition:.18s;flex-shrink:0}
.sidebar-mob-btn:hover{border-color:var(--accent);color:var(--accent)}
.sidebar-mob-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}

/* ---- Responsive ---- */
@media(max-width:1100px){
  .tiers-grid{grid-template-columns:repeat(3,1fr)}
  .platforms-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr}
  .hero h1{font-size:clamp(2.2rem,6vw,3.5rem)}
  .platforms-mini{display:none}
  /* Dashboard: sidebar becomes fixed drawer */
  .dash-layout{grid-template-columns:1fr;padding-top:var(--nav-h)}
  .dash-sidebar{
    position:fixed;left:0;top:var(--nav-h);
    height:calc(100svh - var(--nav-h));width:280px;z-index:80;
    transform:translateX(-100%);transition:transform .3s cubic-bezier(.22,1,.36,1);
  }
  .dash-sidebar.is-open{transform:translateX(0)}
  .dash-main{padding:1.2rem}
  .sidebar-mob-btn{display:flex}
}
@media(max-width:720px){
  .stats-row{grid-template-columns:1fr 1fr}
  .missions-grid{grid-template-columns:1fr}
  .tiers-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
  .cta-inner{padding:2rem 1.5rem}
  .section{padding-block:3.5rem}
}
@media(max-width:540px){
  :root{--nav-h:62px}
  .nav-links{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(10,7,20,.98);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-direction:column;
    align-items:stretch;gap:0;padding:.5rem;border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .nav-toggle{display:flex}
  .nav-inner{gap:.8rem}
  .btn-nav{padding:.45rem .85rem;font-size:.82rem}
  .stats-row{grid-template-columns:1fr}
  .tiers-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-numbers{gap:1.2rem}
  .steps-grid{grid-template-columns:1fr}
  .dash-main{padding:.9rem}
  .auth-box{padding:1.8rem 1.2rem}
  .period-tabs{flex-wrap:wrap;gap:.3rem}
  .period-tab{font-size:.78rem;padding:.38rem .7rem}
  .platform-card{flex-direction:column}
  .plc-logo{width:48px;height:48px}
  .missions-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .splash-logo,.splash-bar::after{animation:none}
  .hero-gradient{background:linear-gradient(135deg,rgba(167,139,250,.2),rgba(56,189,248,.1),var(--bg))}
  .dash-sidebar{transition:none}
}
