/* ============================================================
   TonTV · Node Sale 2026 — Landing & Dashboard
   Design language extracted from official IR / Node Sale decks:
   white neumorphic surfaces · ink black · Netflix red · dark hero
   No external CSS framework. Fully offline-capable.
   ============================================================ */

/* ---------- Fonts (graceful fallback to system Korean) ---------- */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css');

/* ---------- Design tokens ---------- */
:root{
  --red:        #E8112D;   /* brand / Netflix red */
  --red-2:      #ff2740;
  --red-deep:   #B00710;
  --red-glow:   rgba(232,17,45,.55);

  --ink:        #121316;   /* near-black text / dark sections */
  --ink-2:      #1b1d22;
  --ink-3:      #24262c;

  --paper:      #eceef2;   /* light neumorphic page bg */
  --paper-2:    #e6e9ee;
  --card:       #f4f6f9;
  --card-hi:    #ffffff;

  --text:       #16181d;
  --text-soft:  #565c66;
  --muted:      #8a909b;
  --line:       #dfe3ea;

  --gold:       #f5c451;

  /* neumorphism shadows on light bg */
  --nm-lite:    #ffffff;
  --nm-dark:    #c8cdd6;
  --shadow-up:  -7px -7px 18px var(--nm-lite), 8px 8px 20px var(--nm-dark);
  --shadow-in:  inset -5px -5px 12px var(--nm-lite), inset 6px 6px 14px var(--nm-dark);
  --shadow-sm:  -4px -4px 10px var(--nm-lite), 5px 5px 12px var(--nm-dark);

  --radius:     22px;
  --radius-sm:  14px;
  --maxw:       1200px;
  --ease:       cubic-bezier(.22,.61,.36,1);

  --font: "Pretendard","Pretendard Variable",-apple-system,BlinkMacSystemFont,
          "Apple SD Gothic Neo","Malgun Gothic","Noto Sans KR",system-ui,sans-serif;
  /* Distinctive display face for Latin glyphs & numerals — Korean falls back to Pretendard */
  --font-display: "Clash Display","Pretendard",var(--font);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--paper);
  color:var(--text);
  line-height:1.55;
  letter-spacing:-.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
ul{list-style:none}
::selection{background:var(--red);color:#fff}

/* ---------- Display typography (Latin + numerals) ---------- */
.brand,
.hero h1,.hero-eyebrow,
.sec-head h2,.eyebrow,
.stat .big,.pillar h3 .px,
.node-price .v,.formula .f,
.buy-stats .v,.tier .apy,
.road .rp .pill,
.metric .v,.accrue .big,.wallet-bal .xt,.mn-stat .v,
.total-box .amt,.donut .cc .v,
.chip .v,.hero-chips .chip b,
.noderow .nx,.stkrow .a,.tsel .a{
  font-family:var(--font-display);
  font-feature-settings:"ss01","tnum";
  letter-spacing:-.015em;
}
.stat .big,.node-price .v,.buy-stats .v,.tier .apy,
.metric .v,.accrue .big,.total-box .amt{font-weight:700}

/* ---------- Icon system (single coherent line-icon family) ---------- */
.icon{width:1em;height:1em;display:inline-block;flex:none;fill:none;stroke:currentColor;
  stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;vertical-align:-.125em}
.icon.fill{fill:currentColor;stroke:none}
.stat .ic{color:var(--red)}
.pillar .ic,.feat .ic{color:#fff}
.flow .step .ic{color:var(--red)}
.ref .card .ic{color:var(--red)} .ref .card.me .ic{color:#fff}
.metric .mh .e{color:var(--red-2);font-size:16px;display:inline-flex;align-items:center}
.dash-card .ch h3 .em{color:var(--red-2);display:inline-flex;align-items:center;font-size:18px}
.noderow .nidx{color:var(--red-2);font-size:18px}
.phone .ps-side .ic{color:#fff;font-size:17px}
.wbtn .icon{width:17px;height:17px}
.toast .ic .icon{width:14px;height:14px;color:#fff}
.poster .genre .icon{width:13px;height:13px;color:#ff9aa6;vertical-align:-.18em}
.poster .meta .icon{width:12px;height:12px;vertical-align:-.1em}
.rail-head .hint .icon{width:13px;height:13px;color:var(--muted);vertical-align:-.18em}
.btn .icon,.nav .btn .icon{width:1.05em;height:1.05em;vertical-align:-.16em}
.sdot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block;flex:none}
.rg{display:inline-flex;align-items:center;font-size:10px;font-weight:800;letter-spacing:.05em;
  color:#dfe2e8;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  border-radius:5px;padding:3px 6px;margin-left:5px}

/* ---------- Cinematic film-still scenes (poster + phone mockups) ---------- */
.poster .art{background:#0a0506}
.poster .art::before,.poster .art::after{content:none}
.poster .poster-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.scene{position:absolute;inset:0;width:100%;height:100%;display:block}
.ps-scene{position:absolute;inset:0;z-index:0}
.ps-video{overflow:hidden}
.ps-scene .scene{width:100%;height:100%}
.ps-scene .ps-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.ps-video::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.15),transparent 30%,rgba(0,0,0,.55))}
.ps-play,.ps-ad,.ps-mine,.ps-side,.ps-bottom{z-index:3}

/* ---------- Poster wall tiles (real film stills) ---------- */
.poster-wall i{position:relative;overflow:hidden}
.poster-wall i .scene{border-radius:8px}

/* ---------- Premium poster polish ---------- */
.poster .meta{display:flex;align-items:center;gap:0;flex-wrap:wrap;line-height:1}
.poster .meta .msep{opacity:.35;margin:0 6px}
.poster{will-change:transform}
.poster::after{content:"";position:absolute;inset:0;z-index:5;border-radius:16px;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);transition:box-shadow .35s var(--ease)}
.poster:hover::after{box-shadow:inset 0 0 0 1.5px rgba(232,17,45,.65),0 0 22px -2px rgba(232,17,45,.35)}
.poster:focus-visible{outline:none}
.poster:focus-visible::after{box-shadow:inset 0 0 0 2px var(--red),0 0 0 3px rgba(232,17,45,.3)}

/* ---------- Active nav link (multi-page) ---------- */
.nav-links a{position:relative}
.nav-links a.active{color:#fff;font-weight:700}
.nav.scrolled .nav-links a.active{color:var(--red)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;border-radius:2px;background:var(--red)}

/* ---------- Compact page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:132px 0 58px;border-bottom:1px solid rgba(255,255,255,.06)}
.page-hero .pbar{position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--red),var(--red-deep))}
.page-hero .glow{position:absolute;width:520px;height:520px;right:-140px;top:-180px;border-radius:50%;background:radial-gradient(circle,rgba(232,17,45,.34),transparent 62%);filter:blur(12px)}
.page-hero .grid{position:absolute;inset:0;opacity:.05;background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(circle at 70% 0,#000,transparent 70%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .crumb{font-size:12.5px;color:#8a909b;margin-bottom:15px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.page-hero .crumb a{color:#8a909b;transition:color .2s}.page-hero .crumb a:hover{color:#fff}
.page-hero .crumb .sep{opacity:.4}
.page-hero .eyebrow{color:var(--red-2)}
.page-hero h1{font-size:clamp(30px,4.6vw,52px);font-weight:900;letter-spacing:-.03em;line-height:1.1}
.page-hero h1 .r{color:var(--red-2)}
.page-hero p{margin-top:15px;color:#a9adb6;font-size:clamp(15px,1.7vw,18px);max-width:660px;line-height:1.6}
.page-hero .ph-actions{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Section "see all" link + page CTA band ---------- */
.see-all{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14.5px;color:var(--red);transition:gap .2s}
.see-all:hover{gap:11px}
.see-all .icon{width:16px;height:16px}
.sec-head.row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;max-width:none}
.cta-band{background:linear-gradient(160deg,var(--ink),#000);color:#fff;border-radius:26px;padding:46px 40px;text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--red),var(--red-deep))}
.cta-band h2{font-size:clamp(24px,3.2vw,36px);font-weight:900;letter-spacing:-.02em;position:relative}
.cta-band p{margin:12px auto 26px;color:#a9adb6;max-width:560px;position:relative}
.cta-band .ph-actions{justify-content:center;position:relative}

/* ---------- Scroll progress ---------- */
.scroll-prog{position:fixed;top:0;left:0;right:0;height:3px;z-index:95;pointer-events:none}
.scroll-prog i{display:block;height:100%;width:100%;transform:scaleX(0);transform-origin:0 50%;
  background:linear-gradient(90deg,var(--red-deep),var(--red),#ff5a6e);box-shadow:0 0 10px rgba(232,17,45,.55)}

/* ---------- Film-grain atmosphere overlay ---------- */
.grain-overlay{
  position:fixed;inset:0;z-index:70;pointer-events:none;opacity:.5;
  mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.18'/%3E%3C/svg%3E");
}

/* ---------- Hero staggered load-in ---------- */
@keyframes heroIn{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes heroPhone{from{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:none}}
.hero-eyebrow{animation:heroIn .8s var(--ease) both}
.hero h1{animation:heroIn .8s var(--ease) .1s both}
.hero .lead{animation:heroIn .8s var(--ease) .22s both}
.hero-chips{animation:heroIn .8s var(--ease) .34s both}
.hero-actions{animation:heroIn .8s var(--ease) .46s both}
.hero-live{animation:heroIn .8s var(--ease) .58s both}
.phone-stage{animation:heroPhone 1s var(--ease) .3s both}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
section{position:relative}
section[id]{scroll-margin-top:84px}
.sec{padding:96px 0}
.sec-pad{padding:88px 0}

/* ---------- Section header (red bar) ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);margin-bottom:14px;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--red)}
.sec-head{margin-bottom:46px;max-width:820px}
.sec-head h2{
  font-size:clamp(26px,3.6vw,40px);font-weight:800;line-height:1.22;letter-spacing:-.02em;
  padding-left:18px;border-left:5px solid var(--red);
}
.sec-head h2 .r{color:var(--red)}
.sec-head p{margin-top:14px;padding-left:18px;color:var(--text-soft);font-size:clamp(15px,1.6vw,17px)}
.center{text-align:center}
.center .sec-head{margin-left:auto;margin-right:auto}
.center .sec-head h2{border-left:none;padding-left:0}
.center .sec-head h2::after{content:"";display:block;width:54px;height:4px;background:var(--red);border-radius:3px;margin:16px auto 0}
.center .sec-head p{padding-left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 26px;border-radius:999px;font-weight:700;font-size:15px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  white-space:nowrap;
}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 26px -8px var(--red-glow)}
.btn-red:hover{background:var(--red-2);transform:translateY(-2px);box-shadow:0 16px 34px -8px var(--red-glow)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.28)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-3);transform:translateY(-2px)}
.btn-soft{background:var(--card);color:var(--text);box-shadow:var(--shadow-sm)}
.btn-soft:hover{transform:translateY(-2px);box-shadow:var(--shadow-up)}
.btn-lg{padding:17px 34px;font-size:16.5px}
.btn-block{width:100%}
.btn:active{transform:translateY(0) scale(.98)}

/* ---------- Chips ---------- */
.chip{
  display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:999px;
  font-size:13.5px;font-weight:600;
}
.chip-dark{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#e9eaee;backdrop-filter:blur(6px)}
.chip-dark b{color:#fff}
.chip-dark .v{color:var(--red-2);font-weight:800}
.chip-soft{background:var(--card);box-shadow:var(--shadow-sm);color:var(--text)}
.chip-soft .v{color:var(--red);font-weight:800}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  transition:background .3s,box-shadow .3s,backdrop-filter .3s;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav.scrolled{background:rgba(255,255,255,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{width:34px;height:34px;flex:none;filter:drop-shadow(0 6px 15px rgba(232,17,45,.4));transition:transform .35s var(--ease)}
.brand:hover .brand-mark{transform:rotate(-6deg) scale(1.06)}
.brand-word{font-family:var(--font-display);font-weight:700;font-size:23px;letter-spacing:-.035em;line-height:1}
.brand-word .logo{color:#fff;transition:color .3s}
.nav.scrolled .brand-word .logo{color:var(--ink)}
.brand-word .tv{color:var(--red)}
.brand-div{width:1px;height:17px;background:rgba(255,255,255,.22);transition:.3s}
.nav.scrolled .brand-div{background:var(--line)}
.brand .tag{font-size:9.5px;font-weight:800;letter-spacing:.2em;color:rgba(255,255,255,.62);transition:.3s}
.nav.scrolled .brand .tag{color:var(--muted)}
.brand-footer{margin-bottom:20px}
.brand-footer .brand-word{font-size:25px}
.brand-footer .brand-word .logo{color:#fff}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:14.5px;font-weight:600;color:rgba(255,255,255,.82);transition:color .2s}
.nav.scrolled .nav-links a{color:var(--text-soft)}
.nav-links a:hover{color:var(--red-2)}
.nav.scrolled .nav-links a:hover{color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav .btn{padding:11px 20px;font-size:14px}
.nav-ghost-sm{color:#fff;font-weight:700;font-size:14px;transition:.3s}
.nav.scrolled .nav-ghost-sm{color:var(--ink)}
.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:22px;height:2px;background:#fff;transition:.3s}
.nav.scrolled .burger span{background:var(--ink)}

/* =========================================================
   HERO (dark, cinematic)
   ========================================================= */
.hero{
  position:relative;background:var(--ink);color:#fff;overflow:hidden;
  padding:150px 0 90px;
}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg .glow{position:absolute;border-radius:50%;filter:blur(10px);opacity:.9}
.hero-bg .g1{width:620px;height:620px;right:-160px;top:-160px;
  background:radial-gradient(circle,rgba(232,17,45,.42),transparent 62%)}
.hero-bg .g2{width:520px;height:520px;left:-180px;bottom:-200px;
  background:radial-gradient(circle,rgba(120,8,20,.55),transparent 64%)}
.hero-bg .topbar{position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--red),var(--red-deep));z-index:3}
/* Raycast / Unicorn Studio animated background */
.us-bg{position:absolute;inset:0;z-index:0;overflow:hidden;background:#0c0d10}
.us-bg>div,.us-bg canvas{width:100%!important;height:100%!important;display:block}
.us-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(13,14,17,.88),rgba(13,14,17,.5) 50%,rgba(13,14,17,.16)),
             linear-gradient(180deg,rgba(13,14,17,.12),rgba(13,14,17,.78))}
.hero-bg .grid{position:absolute;inset:0;opacity:.05;
  background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%)}
/* faint poster wall */
.poster-wall{position:absolute;inset:0;display:grid;grid-template-columns:repeat(8,1fr);gap:14px;
  padding:20px;opacity:.10;transform:rotate(-8deg) scale(1.4);filter:saturate(.7)}
.poster-wall i{border-radius:8px;aspect-ratio:2/3;display:block}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:9px;padding:7px 14px;border-radius:999px;
  background:rgba(232,17,45,.13);border:1px solid rgba(232,17,45,.35);
  font-size:12px;font-weight:700;letter-spacing:.12em;color:#ff8a98;margin-bottom:22px;
}
.eb-dot{width:7px;height:7px;border-radius:50%;background:var(--red-2);flex:none;
  box-shadow:0 0 8px rgba(255,39,64,.9);animation:breathe 1.8s ease-in-out infinite}
.hero h1{
  font-size:clamp(34px,5.2vw,62px);font-weight:900;line-height:1.08;letter-spacing:-.035em;
}
.hero h1 .r{color:var(--red-2)}
.hero h1 .u{position:relative;white-space:nowrap}
.hero h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.12em;background:var(--red);border-radius:3px}
.hero .lead{margin-top:22px;font-size:clamp(15px,1.8vw,18.5px);color:#c4c7cf;max-width:540px;line-height:1.62}
.hero .lead b{color:#fff;font-weight:700}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-live{display:flex;align-items:center;gap:18px;margin-top:30px;flex-wrap:wrap;
  font-size:13.5px;color:#aeb2bb}
.hero-live .dotlive{width:9px;height:9px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:pulse 1.8s infinite}
.hero-live b{color:#fff;font-weight:800;font-variant-numeric:tabular-nums}

/* ---------- Phone mockup ---------- */
.phone-stage{display:flex;justify-content:center;align-items:center;position:relative}
.phone-stage::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,17,45,.35),transparent 64%);filter:blur(20px)}
.phone{
  position:relative;width:268px;border-radius:40px;background:#000;
  padding:11px;box-shadow:0 40px 90px -20px rgba(0,0,0,.8),0 0 0 2px #2a2c31, inset 0 0 0 1px #3a3c42;
  animation:floaty 6s ease-in-out infinite;
}
.phone .notch{position:absolute;top:18px;left:50%;transform:translateX(-50%);width:90px;height:22px;background:#000;border-radius:0 0 14px 14px;z-index:5}
.phone-screen{position:relative;border-radius:30px;overflow:hidden;aspect-ratio:9/19;
  background:linear-gradient(180deg,#171717,#000)}
.ps-top{position:absolute;top:0;left:0;right:0;z-index:4;display:flex;justify-content:space-between;align-items:center;padding:16px 14px 10px}
.ps-coin{display:inline-flex;align-items:center;gap:6px;background:rgba(0,0,0,.55);border:1px solid rgba(245,196,81,.5);
  color:#fff;font-weight:800;font-size:12px;padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px)}
.ps-coin .c{width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffe08a,#f5c451);display:inline-block}
.ps-tg{font-size:11px;color:rgba(255,255,255,.7);font-weight:600}
.ps-video{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(120% 80% at 70% 20%,rgba(232,17,45,.30),transparent 55%),
    radial-gradient(90% 70% at 20% 80%,rgba(80,0,12,.7),transparent 60%),
    linear-gradient(160deg,#2a0a10,#0a0a0c 70%)}
.ps-video::after{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0 2px,transparent 2px 4px)}
.ps-play{position:relative;width:62px;height:62px;border-radius:50%;background:var(--red);
  display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 10px rgba(232,17,45,.18),0 12px 30px rgba(232,17,45,.5);animation:breathe 2.6s ease-in-out infinite}
.ps-play::before{content:"";border-left:18px solid #fff;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:4px}
.ps-ad{position:absolute;top:54px;left:14px;background:var(--red);color:#fff;font-size:10px;font-weight:800;padding:4px 9px;border-radius:7px;letter-spacing:.04em;display:flex;gap:5px;align-items:center}
.ps-ad .pp{width:0;height:0;border-left:6px solid #fff;border-top:4px solid transparent;border-bottom:4px solid transparent}
.ps-mine{position:absolute;left:50%;bottom:96px;transform:translateX(-50%);white-space:nowrap;
  background:var(--red);color:#fff;font-size:12px;font-weight:800;padding:7px 15px;border-radius:999px;
  box-shadow:0 8px 22px rgba(232,17,45,.5);animation:nudge 3s ease-in-out infinite}
.ps-bottom{position:absolute;left:0;right:0;bottom:0;padding:16px 16px 20px;
  background:linear-gradient(0deg,rgba(0,0,0,.92),transparent);z-index:4}
.ps-bottom .t{font-weight:800;font-size:15px;color:#fff}
.ps-bottom .s{font-size:11.5px;color:rgba(255,255,255,.62);margin-top:4px}
.ps-progress{height:3px;border-radius:3px;background:rgba(255,255,255,.2);margin-top:12px;overflow:hidden}
.ps-progress i{display:block;height:100%;width:38%;background:var(--red);border-radius:3px;animation:seek 8s linear infinite}
.ps-side{position:absolute;right:12px;bottom:120px;display:flex;flex-direction:column;gap:16px;z-index:4}
.ps-side b{display:flex;flex-direction:column;align-items:center;gap:3px;color:#fff;font-size:10px;font-weight:700;opacity:.92}
.ps-side .ic{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:17px;backdrop-filter:blur(4px)}

/* =========================================================
   TRUST BAR
   ========================================================= */
.trust{background:var(--ink-2);color:#cfd2d8;padding:18px 0;border-top:1px solid rgba(255,255,255,.06)}
.trust-inner{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;align-items:center;font-size:13.5px}
.trust-inner b{color:#fff;font-weight:700}
.trust-inner .dot{width:4px;height:4px;border-radius:50%;background:var(--red)}
.trust-inner .it{display:flex;align-items:center;gap:9px}

/* =========================================================
   STAT CARDS (neumorphic)
   ========================================================= */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.stat{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:34px 28px;text-align:center;transition:transform .3s var(--ease)}
.stat:hover{transform:translateY(-5px)}
.stat .ic{width:56px;height:56px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;
  background:var(--card);box-shadow:var(--shadow-in);font-size:24px}
.stat .big{font-size:clamp(28px,3.4vw,40px);font-weight:900;color:var(--red);letter-spacing:-.02em;line-height:1}
.stat .lbl{margin-top:12px;font-size:14.5px;color:var(--text-soft);font-weight:600;line-height:1.45}
.src-note{margin-top:26px;font-size:12.5px;color:var(--muted);font-style:italic}

/* =========================================================
   PILLARS
   ========================================================= */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pillar{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:30px 24px;transition:transform .3s var(--ease)}
.pillar:hover{transform:translateY(-5px)}
.pillar .ic{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,var(--red),var(--red-deep));color:#fff;font-size:24px;box-shadow:0 10px 22px -8px var(--red-glow);margin-bottom:18px}
.pillar h3{font-size:18px;font-weight:800;margin-bottom:8px}
.pillar h3 .px{color:var(--red);font-size:13px;font-weight:800;display:block;margin-bottom:2px}
.pillar p{font-size:14px;color:var(--text-soft);line-height:1.55}

/* =========================================================
   COMPARISON TABLE
   ========================================================= */
.cmp{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);overflow:hidden}
.cmp table{width:100%;border-collapse:collapse}
.cmp th,.cmp td{padding:16px 20px;text-align:center;font-size:14.5px}
.cmp thead th{background:var(--ink);color:#fff;font-weight:800;font-size:15px}
.cmp thead th.us{background:var(--red)}
.cmp tbody tr:not(:last-child){border-bottom:1px solid var(--line)}
.cmp td.k{text-align:left;font-weight:700;color:var(--text)}
.cmp td.us{background:rgba(232,17,45,.05);color:var(--red);font-weight:800}
.cmp td.them{color:var(--muted)}

/* =========================================================
   POSTERS (Netflix-style short-drama mockups)
   ========================================================= */
.poster-rail{position:relative}
.rail-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px}
.rail-head .lbl{display:flex;align-items:center;gap:10px;font-weight:800;font-size:19px}
.rail-head .lbl .tag{background:var(--red);color:#fff;font-size:11px;font-weight:800;padding:4px 9px;border-radius:6px;letter-spacing:.05em}
.rail-head .hint{font-size:13px;color:var(--muted)}
.rail{display:flex;gap:18px;overflow-x:auto;padding:14px 4px 22px;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--red) transparent}
.rail::-webkit-scrollbar{height:8px}
.rail::-webkit-scrollbar-thumb{background:var(--red);border-radius:9px}
.rail::-webkit-scrollbar-track{background:var(--line);border-radius:9px}

.poster{
  position:relative;flex:0 0 auto;width:208px;aspect-ratio:2/3;border-radius:16px;overflow:hidden;
  scroll-snap-align:start;cursor:pointer;color:#fff;
  box-shadow:0 16px 34px -14px rgba(0,0,0,.5);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  isolation:isolate;
}
.poster.rank{width:248px}
.poster:hover{transform:translateY(-8px) scale(1.03);box-shadow:0 26px 50px -16px rgba(0,0,0,.6)}
.poster .art{position:absolute;inset:0;z-index:0}
.poster .art::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 30% 18%,rgba(255,255,255,.16),transparent 50%),
            radial-gradient(90% 70% at 80% 90%,rgba(0,0,0,.55),transparent 60%)}
.poster .art::after{content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;
  background:repeating-linear-gradient(115deg,rgba(255,255,255,.05) 0 8px,transparent 8px 18px)}
.poster .grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.05) 30%,rgba(0,0,0,.82))}
.poster .silh{position:absolute;left:50%;bottom:0;width:70%;height:62%;transform:translateX(-50%);z-index:1;
  background:radial-gradient(60% 80% at 50% 100%,rgba(0,0,0,.55),transparent 70%)}
.poster .top{position:absolute;top:10px;left:10px;right:10px;z-index:3;display:flex;justify-content:space-between;align-items:flex-start}
.poster .ep{background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(4px);
  font-size:10.5px;font-weight:800;padding:4px 8px;border-radius:6px}
.poster .free{background:#fff;color:var(--ink);font-size:10px;font-weight:900;padding:4px 8px;border-radius:6px}
.poster .body{position:absolute;left:14px;right:14px;bottom:14px;z-index:3}
.poster .genre{display:inline-flex;gap:6px;font-size:10.5px;font-weight:700;color:#ffd2d8;margin-bottom:6px}
.poster .ttl{font-size:18px;font-weight:900;line-height:1.18;letter-spacing:-.02em;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.poster .meta{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:11px;color:rgba(255,255,255,.78);font-weight:600}
.poster .earn{position:absolute;left:14px;bottom:14px;z-index:4;display:none}
.poster .xbadge{display:inline-flex;align-items:center;gap:5px;background:var(--red);color:#fff;font-size:10.5px;font-weight:800;padding:5px 10px;border-radius:999px;box-shadow:0 6px 16px rgba(232,17,45,.5)}
.poster .num{position:absolute;left:-6px;bottom:-18px;z-index:2;font-size:150px;font-weight:900;line-height:.7;
  color:transparent;-webkit-text-stroke:3px rgba(255,255,255,.9);text-stroke:3px rgba(255,255,255,.9);
  font-family:Arial,sans-serif;text-shadow:0 4px 20px rgba(0,0,0,.4)}
.poster.rank .body{left:78px}
.poster .playover{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.poster:hover .playover{opacity:1}
.poster .playbtn{width:52px;height:52px;border-radius:50%;background:rgba(232,17,45,.92);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.poster .playbtn::before{content:"";border-left:15px solid #fff;border-top:9px solid transparent;border-bottom:9px solid transparent;margin-left:4px}

/* poster art palettes */
.art-a{background:linear-gradient(155deg,#5a0a18,#1a0307)}
.art-b{background:linear-gradient(155deg,#3a0a2a,#0c0410)}
.art-c{background:linear-gradient(155deg,#7a1020,#220308)}
.art-d{background:linear-gradient(155deg,#6b4a0a,#1c1303)}
.art-e{background:linear-gradient(155deg,#2a1060,#0a0518)}
.art-f{background:linear-gradient(155deg,#0a3a44,#03161a)}
.art-g{background:linear-gradient(155deg,#1a2a6b,#04081c)}
.art-h{background:linear-gradient(155deg,#7a0f3a,#22040f)}
.art-i{background:linear-gradient(155deg,#0d5a3a,#03160f)}
.art-j{background:linear-gradient(155deg,#4a0a55,#150418)}

/* =========================================================
   NODE — definition section
   ========================================================= */
.node-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:28px;align-items:stretch}
.node-price{background:linear-gradient(160deg,var(--ink),#000);color:#fff;border-radius:var(--radius);
  padding:42px 34px;text-align:center;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.node-price::before{content:"";position:absolute;width:300px;height:300px;right:-120px;top:-120px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,17,45,.4),transparent 62%)}
.node-price .k{position:relative;font-size:17px;font-weight:700;color:#cfd2d8}
.node-price .v{position:relative;font-size:clamp(48px,7vw,76px);font-weight:900;color:var(--red-2);line-height:1;margin:8px 0 4px;letter-spacing:-.03em}
.node-price .div{width:54px;height:3px;background:rgba(255,255,255,.25);border-radius:3px;margin:18px auto}
.node-price .sub{position:relative;font-size:14.5px;color:#fff;font-weight:700}
.node-price .note{position:relative;font-size:12.5px;color:#9aa0ab;margin-top:8px;line-height:1.5}
.node-feats{display:flex;flex-direction:column;gap:16px}
.feat{display:flex;gap:18px;align-items:flex-start;background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:22px 24px;transition:transform .3s}
.feat:hover{transform:translateX(5px)}
.feat .ic{flex:0 0 auto;width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,var(--red),var(--red-deep));color:#fff;font-size:21px;box-shadow:0 8px 18px -7px var(--red-glow)}
.feat h4{font-size:16.5px;font-weight:800;margin-bottom:3px}
.feat p{font-size:14px;color:var(--text-soft);line-height:1.5}

/* formula box */
.formula{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:30px 34px;text-align:center;margin-bottom:30px}
.formula .f{font-size:clamp(17px,2.4vw,26px);font-weight:800;letter-spacing:-.01em}
.formula .f .r{color:var(--red)}
.formula .cap{margin-top:10px;font-size:13.5px;color:var(--muted)}

/* =========================================================
   REVENUE TABLE + CHART
   ========================================================= */
.rev-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:26px;align-items:stretch}
.rev-table{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);overflow:hidden}
.rev-table table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
.rev-table th,.rev-table td{padding:13px 14px;text-align:center;font-size:13.5px;white-space:nowrap}
.rev-table thead th{background:var(--ink);color:#fff;font-weight:800;font-size:12.5px}
.rev-table tbody tr:not(:last-child){border-bottom:1px solid var(--line)}
.rev-table td.sub{font-weight:800;color:var(--text)}
.rev-table td.hi{color:var(--red);font-weight:800;background:rgba(232,17,45,.05)}
.rev-table tr.peak td{background:rgba(18,19,22,.04);font-weight:700}
.rev-table tr.peak td.full{color:var(--red);font-weight:800}
.chart{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:26px 24px;display:flex;flex-direction:column}
.chart h4{font-size:15px;font-weight:800;text-align:center;margin-bottom:6px}
.chart .cap{font-size:12px;color:var(--muted);text-align:center;margin-bottom:20px}
.bars{display:flex;align-items:flex-end;justify-content:space-around;gap:12px;flex:1;min-height:200px}
.bars .col{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}
.bars .bar{width:70%;max-width:46px;background:linear-gradient(180deg,var(--red-2),var(--red));border-radius:7px 7px 0 0;
  position:relative;min-height:8px;transition:height 1.1s var(--ease);box-shadow:0 6px 14px -6px var(--red-glow)}
.bars .bar .val{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:12px;font-weight:800;color:var(--text)}
.bars .xl{font-size:12px;color:var(--text-soft);font-weight:700}

/* =========================================================
   SETTLEMENT FLOW
   ========================================================= */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative}
.flow .step{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:28px 22px;text-align:center;position:relative}
.flow .step .n{position:absolute;top:14px;left:16px;font-size:13px;font-weight:900;color:var(--red)}
.flow .step .ic{width:62px;height:62px;border-radius:50%;margin:6px auto 16px;display:flex;align-items:center;justify-content:center;
  background:var(--card);box-shadow:var(--shadow-in);font-size:26px}
.flow .step h4{font-size:16px;font-weight:800;margin-bottom:6px}
.flow .step p{font-size:13px;color:var(--text-soft);line-height:1.45}
.flow .arr{position:absolute;top:50%;right:-14px;transform:translateY(-50%);color:var(--red);font-size:22px;z-index:2;font-weight:900}
.flow .step:last-child .arr{display:none}
.note-bar{margin-top:24px;background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
  padding:18px 24px;display:flex;flex-wrap:wrap;gap:8px 24px;align-items:center;font-size:13.5px;color:var(--text-soft)}
.note-bar .r{color:var(--red);font-weight:800}

/* =========================================================
   STAKING TIERS
   ========================================================= */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.tier{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:30px 22px;text-align:center;transition:transform .3s var(--ease);position:relative;overflow:hidden}
.tier:hover{transform:translateY(-6px)}
.tier .lock{width:56px;height:56px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;
  background:var(--card);box-shadow:var(--shadow-in);font-size:24px;color:var(--red)}
.tier .lk{font-size:14.5px;font-weight:700;color:var(--text-soft)}
.tier .apy{font-size:clamp(30px,4vw,44px);font-weight:900;color:var(--red);line-height:1;margin-top:8px}
.tier .apy small{font-size:16px}
.tier.best{background:linear-gradient(160deg,var(--ink),#000)}
.tier.best .lk{color:#cfd2d8}
.tier.best .lock{background:var(--ink-2);box-shadow:inset -4px -4px 10px #26282e,inset 5px 5px 12px #050608;color:var(--red-2)}
.tier.best .apy{color:var(--red-2)}
.tier.best .badge{position:absolute;top:0;right:0;background:var(--red);color:#fff;font-size:10px;font-weight:800;padding:5px 12px;border-radius:0 0 0 12px}
.tier-note{margin-top:22px;background:rgba(232,17,45,.05);border:1px solid rgba(232,17,45,.16);border-radius:var(--radius-sm);
  padding:14px 20px;font-size:12.5px;color:var(--text-soft);line-height:1.55}

/* =========================================================
   REFERRAL
   ========================================================= */
.ref{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.ref .card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:30px 36px;text-align:center;min-width:200px}
.ref .card.me{background:linear-gradient(150deg,var(--red),var(--red-deep));color:#fff;box-shadow:0 18px 40px -14px var(--red-glow)}
.ref .card .ic{width:54px;height:54px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:24px;
  background:var(--card);box-shadow:var(--shadow-in)}
.ref .card.me .ic{background:rgba(0,0,0,.25);box-shadow:none}
.ref .card .t{font-size:20px;font-weight:900}
.ref .card .s{font-size:13px;margin-top:4px;opacity:.8}
.ref .arr{color:var(--red);font-size:28px;font-weight:900}
.ref-note{margin-top:26px;text-align:center;font-size:14.5px;color:var(--text-soft);max-width:760px;margin-left:auto;margin-right:auto}
.ref-note b{color:var(--text)} .ref-note .r{color:var(--red);font-weight:800}
.ref-note small{display:block;margin-top:8px;color:var(--muted);font-size:12.5px}

/* =========================================================
   ROADMAP
   ========================================================= */
.road{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:10px}
.road::before{content:"";position:absolute;top:84px;left:6%;right:6%;height:3px;background:var(--line)}
.road .rp{text-align:center;position:relative;z-index:2}
.road .rp .pill{background:var(--card);border-radius:16px;box-shadow:var(--shadow-up);padding:18px 10px;font-weight:900;font-size:clamp(16px,2vw,22px);color:var(--red)}
.road .rp .dot{width:20px;height:20px;border-radius:50%;background:var(--red);margin:18px auto 14px;box-shadow:0 0 0 5px rgba(232,17,45,.16)}
.road .rp.last .dot{width:26px;height:26px;background:var(--red);box-shadow:0 0 0 6px rgba(232,17,45,.22),0 0 0 0 rgba(232,17,45,.5);animation:pulse 2s infinite}
.road .rp h4{font-size:15px;font-weight:800;margin-bottom:5px}
.road .rp p{font-size:12.5px;color:var(--text-soft);line-height:1.4}

/* =========================================================
   PURCHASE CTA strip
   ========================================================= */
.buy{background:linear-gradient(160deg,var(--ink),#000);color:#fff;border-radius:28px;padding:54px 44px;position:relative;overflow:hidden}
.buy::before{content:"";position:absolute;width:420px;height:420px;right:-140px;bottom:-180px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,17,45,.4),transparent 62%)}
.buy::after{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--red),var(--red-deep))}
.buy-stats{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center;margin-bottom:38px}
.buy-stats .s .v{font-size:clamp(34px,5vw,52px);font-weight:900;color:var(--red-2);line-height:1}
.buy-stats .s .l{font-size:14px;color:#cfd2d8;margin-top:8px;font-weight:600}
.buy-steps{position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin-bottom:36px}
.buy-steps .bs{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  padding:12px 20px;border-radius:999px;font-weight:700;font-size:14.5px}
.buy-steps .bs .n{width:24px;height:24px;border-radius:50%;background:var(--red);color:#fff;font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center}
.buy-steps .sep{color:var(--red);font-size:18px}
.buy-cta{position:relative;text-align:center}
.buy-org{position:relative;margin-top:30px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:13.5px;color:#aeb3bd;line-height:1.7}
.buy-org b{color:#fff;font-weight:700}

/* =========================================================
   DASHBOARD
   ========================================================= */
.dash{background:linear-gradient(180deg,#101113,#17181b);color:#fff;padding:90px 0}
.dash .eyebrow{color:var(--red-2)}
.dash .sec-head h2{color:#fff}
.dash .sec-head p{color:#a9adb6}
.dash-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:30px}
.dash-top .who{display:flex;align-items:center;gap:14px}
.dash-top .who .av{width:46px;height:46px;border-radius:14px;background:linear-gradient(145deg,var(--red),var(--red-deep));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px}
.dash-top .who .nm{font-weight:800;font-size:16px}
.dash-top .who .id{font-size:12.5px;color:#9aa0ab}
.live-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.4);color:#5ee08a;
  font-size:12.5px;font-weight:800;padding:7px 14px;border-radius:999px;letter-spacing:.04em}
.live-badge .d{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse 1.6s infinite}

.dash-card{background:#1d1f24;border:1px solid #2a2d34;border-radius:20px;padding:24px}
.dash-card .ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.dash-card .ch h3{font-size:16px;font-weight:800;display:flex;align-items:center;gap:9px}
.dash-card .ch h3 .em{font-size:18px}
.dash-card .ch .tagx{font-size:11px;color:#8a909b;font-weight:700}

/* live platform metric tiles */
.metrics{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:22px}
.metric{background:#1d1f24;border:1px solid #2a2d34;border-radius:18px;padding:20px 18px;position:relative;overflow:hidden;transition:border-color .3s}
.metric:hover{border-color:#3a3d45}
.metric .mh{display:flex;align-items:center;gap:8px;font-size:12.5px;color:#9aa0ab;font-weight:600;margin-bottom:12px}
.metric .mh .e{font-size:15px}
.metric .v{font-size:clamp(20px,2.2vw,27px);font-weight:900;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}
.metric .v.r{color:var(--red-2)}
.metric .sub{font-size:11.5px;color:#6f757f;margin-top:8px;display:flex;align-items:center;gap:6px}
.metric .up{color:#5ee08a;font-weight:800}
.metric .livedot{width:7px;height:7px;border-radius:50%;background:#ef4444;animation:pulse 1.4s infinite;display:inline-block}
.metric .spark{position:absolute;right:0;bottom:0;left:0;height:34px;opacity:.5}

/* main grids */
.dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-bottom:20px}
.dash-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}

/* my node revenue panel */
.mynode-top{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px}
.mn-stat{background:#16181c;border:1px solid #2a2d34;border-radius:14px;padding:16px}
.mn-stat .l{font-size:12px;color:#9aa0ab;margin-bottom:7px}
.mn-stat .v{font-size:22px;font-weight:900;font-variant-numeric:tabular-nums}
.mn-stat .v .u{font-size:13px;color:#9aa0ab;font-weight:700}
.accrue{background:linear-gradient(135deg,rgba(232,17,45,.16),rgba(232,17,45,.04));border:1px solid rgba(232,17,45,.32);
  border-radius:16px;padding:22px;text-align:center;position:relative;overflow:hidden}
.accrue .l{font-size:13px;color:#e9b3bb;font-weight:700;margin-bottom:6px;display:flex;align-items:center;justify-content:center;gap:8px}
.accrue .big{font-size:clamp(30px,4.5vw,46px);font-weight:900;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}
.accrue .big .c{color:var(--red-2)}
.accrue .xeq{font-size:13.5px;color:#cdd1d8;margin-top:8px;font-weight:600}
.accrue .xeq b{color:var(--red-2)}
.accrue .prog{margin-top:18px;text-align:left}
.accrue .prog .pl{display:flex;justify-content:space-between;font-size:11.5px;color:#9aa0ab;margin-bottom:7px}
.accrue .prbar{height:8px;border-radius:6px;background:#2a2d34;overflow:hidden}
.accrue .prbar i{display:block;height:100%;background:linear-gradient(90deg,var(--red),var(--red-2));border-radius:6px;transition:width .6s}

/* wallet / XONT */
.wallet-bal{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;
  background:#16181c;border:1px solid #2a2d34;border-radius:16px;padding:20px;margin-bottom:16px}
.wallet-bal .l{font-size:12.5px;color:#9aa0ab;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.wallet-bal .xt{font-size:32px;font-weight:900;font-variant-numeric:tabular-nums;line-height:1}
.wallet-bal .xt .s{font-size:15px;color:var(--red-2);font-weight:800;margin-left:6px}
.wallet-bal .usd{font-size:13px;color:#7f858f;margin-top:6px}
.wallet-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.wbtn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:12px;font-weight:700;font-size:14px;transition:.25s}
.wbtn.send{background:var(--red);color:#fff}
.wbtn.send:hover{background:var(--red-2)}
.wbtn.stake{background:#26282e;color:#fff;border:1px solid #34373f}
.wbtn.stake:hover{background:#30333a}

/* per-node XONT list */
.nodelist{display:flex;flex-direction:column;gap:10px;max-height:230px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:#3a3d45 transparent}
.nodelist::-webkit-scrollbar{width:6px}
.nodelist::-webkit-scrollbar-thumb{background:#3a3d45;border-radius:6px}
.noderow{display:flex;align-items:center;justify-content:space-between;background:#16181c;border:1px solid #2a2d34;border-radius:12px;padding:13px 16px}
.noderow .li{display:flex;align-items:center;gap:12px}
.noderow .nidx{width:36px;height:36px;border-radius:10px;background:linear-gradient(145deg,#26282e,#16181c);display:flex;align-items:center;justify-content:center;font-size:16px}
.noderow .ni{font-size:13.5px;font-weight:800}
.noderow .ns{font-size:11.5px;color:#7f858f}
.noderow .nr{text-align:right}
.noderow .nx{font-size:14.5px;font-weight:900;font-variant-numeric:tabular-nums}
.noderow .nx .u{color:var(--red-2);font-size:11px}
.noderow .mining{font-size:10.5px;color:#5ee08a;font-weight:700;display:flex;align-items:center;gap:5px;justify-content:flex-end;margin-top:3px}

/* forms (stake / transfer) */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;color:#9aa0ab;font-weight:600;margin-bottom:8px}
.inp{width:100%;background:#16181c;border:1px solid #2a2d34;border-radius:12px;padding:14px 16px;color:#fff;font-size:15px;transition:border-color .2s}
.inp:focus{outline:none;border-color:var(--red)}
.inp::placeholder{color:#5a5f68}
.inp-amt{display:flex;align-items:center;background:#16181c;border:1px solid #2a2d34;border-radius:12px;padding:0 14px;transition:border-color .2s}
.inp-amt:focus-within{border-color:var(--red)}
.inp-amt input{flex:1;background:none;border:none;padding:14px 4px;color:#fff;font-size:18px;font-weight:800;font-variant-numeric:tabular-nums}
.inp-amt input:focus{outline:none}
.inp-amt .unit{font-weight:800;color:var(--red-2);font-size:14px}
.inp-amt .max{font-size:11px;font-weight:800;color:#fff;background:var(--red);border-radius:7px;padding:5px 9px;margin-left:8px}
.inp-amt .max:hover{background:var(--red-2)}
.balhint{font-size:11.5px;color:#7f858f;margin-top:8px;display:flex;justify-content:space-between}
.balhint b{color:#cdd1d8}

/* tier selector chips */
.tiersel{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:6px}
.tsel{background:#16181c;border:1px solid #2a2d34;border-radius:12px;padding:12px 8px;text-align:center;transition:.2s;cursor:pointer}
.tsel:hover{border-color:#44474f}
.tsel.on{border-color:var(--red);background:rgba(232,17,45,.1)}
.tsel .m{font-size:12px;color:#9aa0ab;font-weight:700}
.tsel .a{font-size:18px;font-weight:900;color:var(--red-2);margin-top:3px}
.tsel.on .m{color:#fff}

.est{display:flex;justify-content:space-between;align-items:center;background:#16181c;border:1px dashed #34373f;border-radius:12px;padding:13px 16px;margin:14px 0 16px;font-size:13px}
.est .l{color:#9aa0ab}
.est .v{font-weight:900;color:var(--red-2);font-variant-numeric:tabular-nums}

.active-stakes{margin-top:18px;border-top:1px solid #2a2d34;padding-top:16px}
.active-stakes .t{font-size:12.5px;color:#9aa0ab;font-weight:700;margin-bottom:10px}
.stkrow{display:flex;align-items:center;justify-content:space-between;background:#16181c;border:1px solid #2a2d34;border-radius:12px;padding:12px 15px;margin-bottom:9px}
.stkrow .a{font-size:14.5px;font-weight:800;font-variant-numeric:tabular-nums}
.stkrow .b{font-size:11px;color:#7f858f;margin-top:2px}
.stkrow .reward{text-align:right}
.stkrow .reward .rv{color:#5ee08a;font-weight:800;font-size:13.5px;font-variant-numeric:tabular-nums}
.stkrow .reward .rl{font-size:10.5px;color:#7f858f}

.dash-note{margin-top:24px;text-align:center;font-size:12.5px;color:#7f858f}
.dash-note .r{color:var(--red-2);font-weight:700}

/* ad-revenue live breakdown */
.adrev{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
.adrev .legend{display:flex;flex-direction:column;gap:14px}
.adrev .lr{display:flex;align-items:center;justify-content:space-between}
.adrev .lr .ll{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#cdd1d8;font-weight:600}
.adrev .lr .sw{width:12px;height:12px;border-radius:4px}
.adrev .lr .lv{font-weight:900;font-variant-numeric:tabular-nums}
.donut{width:170px;height:170px;border-radius:50%;margin:0 auto;position:relative;
  background:conic-gradient(var(--red) 0 62%,#f5c451 62% 86%,#3a82f6 86% 100%)}
.donut::before{content:"";position:absolute;inset:26px;border-radius:50%;background:#1d1f24}
.donut .cc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut .cc .l{font-size:11px;color:#9aa0ab}
.donut .cc .v{font-size:19px;font-weight:900;font-variant-numeric:tabular-nums}

/* =========================================================
   RISK / DISCLAIMER
   ========================================================= */
.risk{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-up);padding:38px 40px}
.risk ul{display:flex;flex-direction:column;gap:16px}
.risk li{display:flex;gap:14px;align-items:flex-start;font-size:14.5px;color:var(--text-soft);line-height:1.55}
.risk li .b{flex:0 0 auto;width:16px;height:16px;border-radius:4px;background:var(--red);margin-top:4px}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--ink);color:#cfd2d8;padding:64px 0 40px}
.footer-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer .brand .logo{color:#fff}
.footer-lead{max-width:380px}
.footer-lead .play{width:64px;height:64px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 10px rgba(232,17,45,.16);margin-bottom:20px}
.footer-lead .play::before{content:"";border-left:20px solid #fff;border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:5px}
.footer-lead h3{font-size:22px;font-weight:900;color:#fff;line-height:1.3}
.footer-lead h3 .u{border-bottom:4px solid var(--red);padding-bottom:2px}
.footer-lead p{margin-top:14px;font-size:14px;color:#9aa0ab}
.footer-cols{display:flex;gap:60px;flex-wrap:wrap}
.fcol h5{font-size:13px;font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:.02em}
.fcol a,.fcol p{display:block;font-size:13.5px;color:#9aa0ab;margin-bottom:10px;transition:color .2s}
.fcol a:hover{color:var(--red-2)}
.footer-bottom{padding-top:26px;font-size:12px;color:#73787f;line-height:1.7}
.footer-bottom .org{color:#cfd2d8;font-weight:600;margin-bottom:8px}
.footer-bottom .org b{color:#fff}

/* =========================================================
   MODAL (deposit)
   ========================================================= */
.modal-back{position:fixed;inset:0;z-index:200;background:rgba(8,9,11,.72);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-back.open{opacity:1;pointer-events:auto}
.modal{background:#fff;border-radius:26px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;
  transform:translateY(24px) scale(.97);transition:transform .35s var(--ease);box-shadow:0 40px 100px -20px rgba(0,0,0,.6)}
.modal-back.open .modal{transform:none}
.modal-head{position:relative;background:linear-gradient(160deg,var(--ink),#000);color:#fff;padding:26px 28px;border-radius:26px 26px 0 0}
.modal-head .topbar{position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--red),var(--red-deep));border-radius:26px 26px 0 0}
.modal-head h3{font-size:20px;font-weight:900}
.modal-head p{font-size:13px;color:#9aa0ab;margin-top:5px}
.modal-x{position:absolute;top:20px;right:20px;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;transition:.2s}
.modal-x:hover{background:rgba(255,255,255,.2)}
.modal-body{padding:26px 28px 30px}

.mlabel{font-size:12.5px;font-weight:700;color:var(--text-soft);margin-bottom:10px}
.qty-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:14px}
.qchip{background:var(--card);box-shadow:var(--shadow-sm);border-radius:12px;padding:13px 6px;text-align:center;font-weight:800;transition:.2s;border:2px solid transparent}
.qchip:hover{transform:translateY(-2px)}
.qchip.on{border-color:var(--red);color:var(--red);box-shadow:var(--shadow-in)}
.qchip .q{font-size:18px}
.qchip .qs{font-size:10.5px;color:var(--muted);font-weight:700;margin-top:2px}
.qcustom{display:flex;align-items:center;gap:10px;background:var(--card);border-radius:12px;box-shadow:var(--shadow-in);padding:4px 6px 4px 16px;margin-bottom:20px}
.qcustom label{font-size:13px;color:var(--text-soft);font-weight:700;white-space:nowrap}
.qcustom input{flex:1;background:none;border:none;text-align:right;font-size:18px;font-weight:800;color:var(--text);padding:12px 8px}
.qcustom input:focus{outline:none}
.qcustom .u{font-size:13px;color:var(--muted);font-weight:700}

.total-box{background:linear-gradient(160deg,var(--ink),#000);border-radius:16px;padding:20px 22px;color:#fff;display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.total-box .l{font-size:13px;color:#9aa0ab}
.total-box .l b{display:block;color:#fff;font-size:15px;font-weight:800;margin-top:3px}
.total-box .amt{font-size:30px;font-weight:900;color:var(--red-2);font-variant-numeric:tabular-nums}
.total-box .amt .u{font-size:15px;color:#fff;margin-left:4px}

.net-badge{display:flex;align-items:center;gap:12px;background:rgba(38,161,123,.08);border:1px solid rgba(38,161,123,.3);
  border-radius:14px;padding:14px 16px;margin-bottom:20px}
.net-badge .ic{width:40px;height:40px;border-radius:50%;background:#26a17b;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px}
.net-badge .nt b{font-size:14.5px;font-weight:800;color:var(--text)}
.net-badge .nt span{display:block;font-size:12px;color:var(--text-soft);margin-top:2px}
.net-badge .tron{margin-left:auto;font-size:11px;font-weight:800;color:#fff;background:#ef0027;border-radius:7px;padding:5px 10px}

.qr-zone{display:flex;gap:20px;align-items:center;background:var(--card);border-radius:16px;box-shadow:var(--shadow-in);padding:18px;margin-bottom:18px}
.qr-zone .qr{flex:0 0 auto;width:128px;height:128px;background:#fff;border-radius:12px;padding:8px;box-shadow:0 4px 14px rgba(0,0,0,.1)}
.qr-zone .qr img{width:100%;height:100%;image-rendering:pixelated}
.qr-zone .qi{flex:1}
.qr-zone .qi .l{font-size:12px;color:var(--text-soft);font-weight:700;margin-bottom:6px}
.qr-zone .qi .scan{font-size:13.5px;color:var(--text);line-height:1.5}
.qr-zone .qi .scan b{color:var(--red)}

.addr-row{margin-bottom:14px}
.addr-row .l{font-size:12px;color:var(--text-soft);font-weight:700;margin-bottom:8px}
.copy-field{display:flex;align-items:center;gap:10px;background:var(--card);border-radius:12px;box-shadow:var(--shadow-in);padding:12px 14px}
.copy-field .val{flex:1;font-size:13px;font-weight:700;color:var(--text);word-break:break-all;font-family:ui-monospace,Menlo,monospace}
.copy-field .cp{flex:0 0 auto;background:var(--ink);color:#fff;font-size:12px;font-weight:800;padding:9px 14px;border-radius:9px;transition:.2s}
.copy-field .cp:hover{background:var(--red)}
.copy-field .cp.done{background:#22c55e}

.warn{display:flex;gap:10px;background:rgba(232,17,45,.06);border:1px solid rgba(232,17,45,.2);border-radius:12px;
  padding:13px 15px;margin-bottom:14px;font-size:12.5px;color:var(--text-soft);line-height:1.55}
.warn .i{flex:0 0 auto;color:var(--red);font-weight:900}
.warn b{color:var(--red)}
.demo-note{font-size:11.5px;color:var(--muted);text-align:center;margin-top:14px;line-height:1.5}

/* modal success */
.msuccess{text-align:center;padding:14px 0}
.msuccess .check{width:80px;height:80px;border-radius:50%;background:rgba(34,197,94,.12);border:2px solid #22c55e;
  display:flex;align-items:center;justify-content:center;margin:0 auto 22px;font-size:38px;color:#22c55e;animation:pop .4s var(--ease)}
.msuccess h3{font-size:22px;font-weight:900;margin-bottom:10px}
.msuccess p{font-size:14px;color:var(--text-soft);line-height:1.6;max-width:340px;margin:0 auto 8px}
.msuccess .rec{background:var(--card);box-shadow:var(--shadow-in);border-radius:14px;padding:18px;margin:22px 0;text-align:left}
.msuccess .rec .rr{display:flex;justify-content:space-between;font-size:13.5px;padding:6px 0}
.msuccess .rec .rr .k{color:var(--text-soft)}
.msuccess .rec .rr .v{font-weight:800}
.msuccess .rec .rr .v.r{color:var(--red)}

/* =========================================================
   TOAST
   ========================================================= */
.toast-wrap{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{background:var(--ink);color:#fff;padding:14px 22px;border-radius:14px;font-size:14px;font-weight:600;
  box-shadow:0 16px 40px -10px rgba(0,0,0,.5);display:flex;align-items:center;gap:10px;
  transform:translateY(20px);opacity:0;transition:.35s var(--ease);max-width:90vw}
.toast.show{transform:none;opacity:1}
.toast .ic{width:22px;height:22px;border-radius:50%;background:#22c55e;display:flex;align-items:center;justify-content:center;font-size:13px;flex:0 0 auto}
.toast.err .ic{background:var(--red)}

/* =========================================================
   FLOATING MOBILE CTA
   ========================================================= */
.float-cta{position:fixed;bottom:18px;left:18px;right:18px;z-index:80;display:none}
.float-cta .btn{width:100%;box-shadow:0 16px 40px -10px var(--red-glow)}

/* =========================================================
   ANIMATIONS
   ========================================================= */
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 12px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes nudge{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-5px)}}
@keyframes seek{0%{width:0}100%{width:100%}}
@keyframes pop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
/* Reveal-on-scroll: content is visible by default; only hidden once JS is
   confirmed (.has-js), so it can NEVER stay invisible if scripting fails. */
.reveal{opacity:1}
.has-js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.has-js .reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .phone-stage{order:-1}
  .grid-4,.pillars,.tiers,.flow{grid-template-columns:repeat(2,1fr)}
  .metrics{grid-template-columns:repeat(3,1fr)}
  .node-grid,.rev-grid,.dash-grid,.dash-grid-2{grid-template-columns:1fr}
  .flow .arr{display:none}
  .road{grid-template-columns:repeat(5,1fr);gap:8px}
  .road::before{display:none}
}
@media(max-width:760px){
  .sec{padding:64px 0}
  .nav-links{display:none}
  .nav .nav-ghost-sm{display:none}
  .burger{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;
    align-items:flex-start;gap:0;background:#fff;box-shadow:0 12px 30px -10px rgba(0,0,0,.25);padding:8px 0;border-top:1px solid var(--line)}
  .nav.open .nav-links a{width:100%;padding:14px 24px;color:var(--text);font-size:15.5px}
  .nav.open .nav-links a:active{background:var(--paper)}
  .grid-3,.grid-2,.grid-4,.pillars,.tiers,.flow,.buy-stats{grid-template-columns:1fr}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .cmp{overflow-x:auto}.cmp table{min-width:520px}
  .rev-table{overflow-x:auto}.rev-table table{min-width:560px}
  .road{grid-template-columns:1fr;gap:14px}
  .ref{flex-direction:column}.ref .arr{transform:rotate(90deg)}
  .float-cta{display:block}
  .adrev{grid-template-columns:1fr}
  .mynode-top{grid-template-columns:1fr}
  .buy{padding:40px 24px}
  .modal-body{padding:22px}
  .qr-zone{flex-direction:column;text-align:center}
}
@media(max-width:520px){
  .brand-div,.brand .tag{display:none}
  .brand-mark{width:30px;height:30px}
  .brand-word{font-size:21px}
  .nav .btn{padding:9px 14px;font-size:13px}
  .page-hero{padding:104px 0 44px}
  .wrap{padding:0 18px}
  .sec-head.row{flex-direction:column;align-items:flex-start;gap:10px}
  .cta-band{padding:36px 22px}
}

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