:root{
  --bg:#ffffff;
  --surface:#f7f8fc;
  --surface-2:#eef1f8;
  --ink:#0a1024;
  --ink-2:#2a3354;
  --muted:#6b7593;
  --line:#e7eaf3;
  --line-2:#d8deeb;

  --brand:#3b46e6;
  --brand-2:#7c4bff;
  --brand-soft:#eef0ff;
  --red:#e53935;
  --gold:#e2920c;
  --gold-soft:#fff4dd;
  --pos:#15a66a;
  --neg:#e0413e;

  --shadow-sm:0 1px 2px rgba(16,24,40,.05),0 1px 3px rgba(16,24,40,.06);
  --shadow-md:0 6px 18px rgba(16,24,40,.08);
  --shadow-lg:0 22px 60px -12px rgba(20,28,60,.25);
  --radius:16px;
  --radius-sm:12px;
  --maxw:1240px;

  --display:"Sora",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;line-height:1.6;font-size:16px;font-weight:500;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.15;margin:0;font-weight:800;letter-spacing:-.02em}
.mono{font-family:var(--mono)}
.muted{color:var(--muted)}
.small{font-size:13px}
.pos{color:var(--pos)}
.neg{color:var(--neg)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ============ HEADER ============ */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:18px;height:72px}

.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.03em}
.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 60%,var(--gold) 100%);color:#fff;display:grid;place-items:center;font-weight:800;font-size:17px;box-shadow:0 8px 22px -6px rgba(75,91,215,.55)}
.brand-text{background:linear-gradient(95deg,var(--brand) 0%,var(--brand-2) 45%,var(--gold) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800}

.hdr-chips{display:flex;gap:9px;margin-left:6px}
.hdr-chip{position:relative;display:inline-flex;align-items:center;gap:8px;padding:9px 14px 9px 12px;border-radius:12px;background:#fff;border:1px solid var(--line-2);font-family:var(--mono);font-size:12.5px;font-weight:800;white-space:nowrap;transition:.18s;overflow:hidden;color:var(--ink)}
.hdr-chip:before{content:"";position:absolute;left:0;top:0;width:3px;bottom:0;background:linear-gradient(180deg,var(--red),#ff8a87)}
.hdr-chip:hover{border-color:var(--brand);box-shadow:0 4px 14px -4px rgba(20,28,60,.18);transform:translateY(-1px)}
.hdr-chip .coin-ic,.hdr-chip .coin-ic-text{width:22px;height:22px;font-size:10px;flex-shrink:0}
.hdr-chip .sym{font-weight:800;color:var(--ink);letter-spacing:.02em}
.hdr-chip .px{font-weight:800;color:var(--ink)}
.hdr-chip .pct{font-weight:800;padding:1px 5px;border-radius:5px;font-size:11.5px;letter-spacing:0}
.hdr-chip .pct.pos{background:#e6f6ee;color:var(--pos)}
.hdr-chip .pct.neg{background:#fdecec;color:var(--neg)}

.hdr-spacer{flex:1}

.main-nav{display:flex;align-items:center;gap:4px}
.nav-link{display:inline-flex;align-items:center;gap:5px;padding:9px 13px;border-radius:10px;font-weight:700;font-size:14.5px;background:none;border:0;cursor:pointer;font-family:var(--body);color:var(--ink)}
.nav-link .red{color:var(--red);font-weight:800}
.nav-link:hover{background:var(--brand-soft);color:var(--brand)}
.nav-link:hover .red{color:var(--brand)}

.nav-dropdown{position:relative}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s}
.nav-dropdown:hover .dropdown-menu,.nav-dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;padding:10px 12px;border-radius:9px;font-size:14px;font-weight:600;color:var(--ink-2)}
.dropdown-menu a:hover{background:var(--brand-soft);color:var(--brand)}
.dropdown-menu a .red{color:var(--red);font-weight:800}
.dropdown-menu a:hover .red{color:var(--brand)}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.hamburger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.2s}
.hamburger.active span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:1050px){ .hdr-chips{display:none} }

.site-main{padding:36px 24px 72px}

/* ============ HOMEPAGE INTRO ============ */
.intro-card{background:linear-gradient(150deg,#fafbff 0%,#f0f3ff 50%,#fbf5ee 100%);border:1px solid var(--line);border-radius:24px;padding:46px 38px;position:relative;overflow:hidden}
.intro-card:before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(124,75,255,.18),transparent 70%)}
.intro-card:after{content:"";position:absolute;left:-60px;bottom:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(226,146,12,.14),transparent 70%)}
.intro-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);background:#fff;border:1px solid var(--line);padding:7px 13px;border-radius:999px;position:relative;z-index:2;margin-bottom:20px}
.intro-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--pos);box-shadow:0 0 0 4px rgba(21,166,106,.2);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(21,166,106,0)}}
.intro-card h1{font-size:44px;font-weight:800;line-height:1.08;max-width:820px;position:relative;z-index:2}
.intro-card h1 .grad{background:linear-gradient(100deg,var(--brand),var(--brand-2),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.intro-card p{font-size:17px;color:var(--ink-2);max-width:680px;margin:18px 0 0;position:relative;z-index:2;line-height:1.65;font-weight:500}

/* ============ TRACKER TICKER (center, slow scroll) ============ */
.tracker-wrap{margin:34px 0 0;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%)}
.tracker-strip{display:flex;gap:14px;width:max-content;animation:slide 60s linear infinite;padding:8px 0}
.tracker-strip:hover{animation-play-state:paused}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tk-card{display:inline-flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:11px 18px;box-shadow:var(--shadow-sm);min-width:240px;transition:.15s}
.tk-card:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:var(--shadow-md)}
.tk-card .coin-ic,.tk-card .coin-ic-text{width:30px;height:30px}
.tk-name{font-weight:700;font-size:13.5px;color:var(--muted)}
.tk-sym{font-weight:800;font-size:14px}
.tk-price{font-family:var(--mono);font-size:14px;font-weight:700;margin-left:auto}
.tk-chg{font-family:var(--mono);font-size:12.5px;font-weight:700}

/* ============ SECTIONS ============ */
.section{margin:64px 0 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:24px}
.eyebrow{font-family:var(--mono);font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.eyebrow .red{color:var(--red)}
.section-head h2{font-size:32px;font-weight:800}
.section-head h2 .red{color:var(--red)}
.section-head .see-all{font-size:14px;font-weight:700;color:var(--brand);white-space:nowrap;display:inline-flex;align-items:center;gap:5px;padding:9px 15px;border-radius:10px;background:var(--brand-soft)}
.section-head .see-all:hover{background:var(--brand);color:#fff}

/* layout with sidebar (section 1 + article pages) */
.with-side{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start}
.sidebar{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}

/* ============ COIN ICONS (clean circles) ============ */
.coin-ic,.coin-ic-text{width:48px;height:48px;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 8px rgba(16,24,40,.12);object-fit:cover;background:#fff;display:inline-block}
.coin-ic.sm,.coin-ic-text.sm{width:30px;height:30px}
.coin-ic.lg,.coin-ic-text.lg{width:72px;height:72px}
.coin-ic-text{display:inline-grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-family:var(--display);font-weight:800;font-size:15px;letter-spacing:-.02em}
.coin-ic-text.sm{font-size:11px}
.coin-ic-text.lg{font-size:24px}

/* ============ SECTION 1: Listing Soon Cards (with exchange tick rows) ============ */
.ls-grid{display:grid;grid-template-columns:1fr;gap:16px}
.ls-card{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm);transition:.18s}
.ls-card:hover{transform:translateY(-2px);border-color:var(--brand-2);box-shadow:var(--shadow-md)}
.ls-meta .name{font-weight:800;font-size:17px;letter-spacing:-.01em}
.ls-meta .sub{font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-top:2px}
.ls-meta .price{font-family:var(--mono);font-weight:700;font-size:14.5px;margin-top:6px}
.ls-exch{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ls-tick{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;background:var(--surface);border:1px solid var(--line-2);padding:4px 9px;border-radius:8px;color:var(--ink-2)}
.ls-tick .check{color:var(--pos);font-weight:900}
.ls-target{text-align:right}
.ls-target .lab{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700}
.ls-target .val{font-family:var(--display);font-weight:800;font-size:16px;color:var(--red);margin-top:3px}
.ls-target .when{font-size:12px;color:var(--ink-2);font-weight:600;margin-top:2px}

/* ============ SECTION 2 / 3: Upcoming cards (animated label) ============ */

@keyframes upPulse{0%,100%{transform:scale(1);box-shadow:0 3px 10px -2px rgba(226,146,12,.55)}50%{transform:scale(1.06);box-shadow:0 5px 16px -2px rgba(226,146,12,.75)}}

/* ============ SECTION 4: Blog flat cards (no thumb) ============ */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.bp-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px 20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;transition:.18s}
.bp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand)}
.bp-cat{font-family:var(--mono);font-size:11.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--brand)}
.bp-cat .red{color:var(--red)}
.bp-card h3{font-size:20px;font-weight:800;line-height:1.3}
.bp-card:hover h3{color:var(--brand)}
.bp-ex{color:var(--muted);font-size:14.5px;flex:1;font-weight:500}
.bp-meta{font-size:12.5px;color:var(--muted);font-weight:600}
.bp-read{align-self:flex-start;margin-top:6px;display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;background:var(--brand);color:#fff;font-weight:700;font-size:13.5px}
.bp-read:hover{background:#2d37c4}

/* ============ SIDEBAR ============ */
.side-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 19px;box-shadow:var(--shadow-sm)}
.side-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:7px}
.side-title .red{color:var(--red)}
.mover{display:grid;grid-template-columns:32px 1fr auto auto;align-items:center;gap:10px;padding:9px 7px;border-radius:9px}
.mover:hover{background:var(--surface)}
.mover-name{font-weight:700;font-size:13.5px}
.mover-price{font-family:var(--mono);font-size:12.5px;font-weight:600}
.mover-chg{font-family:var(--mono);font-size:12px;font-weight:700;min-width:58px;text-align:right}
.pop-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:13px}
.pop-list li a{font-weight:700;font-size:14px;line-height:1.4}
.pop-list li a:hover{color:var(--brand)}
.pop-list .small{display:block;margin-top:3px;color:var(--muted);font-weight:500}

/* ============ FOOTER ============ */
.site-footer{margin-top:80px;background:linear-gradient(180deg,#fafbff,#f1f4fc);border-top:1px solid var(--line);position:relative}
.site-footer:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),var(--brand-2),var(--gold))}
.footer-top{padding:54px 24px 36px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;max-width:var(--maxw);margin:0 auto}
.footer-brand .brand{margin-bottom:14px}
.footer-about{font-size:14px;color:var(--muted);line-height:1.65;font-weight:500;margin:0 0 14px}
.footer-disclaimer{font-size:12.5px;color:#7a5a12;background:var(--gold-soft);border:1px solid #f0d49a;border-radius:10px;padding:10px 13px;font-weight:500;margin:0}
.footer-col h4{font-size:13.5px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);margin-bottom:14px}
.footer-col h4 .red{color:var(--red)}
.footer-col a{display:block;font-size:14px;color:var(--ink-2);font-weight:600;padding:5px 0}
.footer-col a:hover{color:var(--brand)}
.footer-bottom{border-top:1px solid var(--line);padding:18px 24px;font-size:13px;color:var(--muted);text-align:center;font-weight:500}
.footer-bottom strong{color:var(--ink);font-weight:800}

/* ============ ADS ============ */
.ad-slot{margin:18px auto;text-align:center;display:flex;justify-content:center;align-items:center;overflow:hidden;max-width:100%}
.ad-slot:empty{display:none}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .with-side{grid-template-columns:1fr}
  .sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .sidebar .side-card{flex:1;min-width:280px}
  
  .footer-top{grid-template-columns:1fr 1fr;gap:30px}
  .footer-brand{grid-column:1 / -1}
}
@media(max-width:680px){
  .hamburger{display:flex;margin-left:auto}
  .main-nav{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);padding:14px 20px 20px;gap:2px;transform:translateY(-130%);transition:.26s;max-height:calc(100vh - 72px);overflow:auto}
  .main-nav.open{transform:translateY(0)}
  .nav-link{padding:13px 12px;font-size:15.5px;justify-content:space-between}
  .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--brand-soft);border-radius:0;margin:2px 0 6px 12px;padding:0 0 0 10px;display:none}
  .nav-dropdown.open .dropdown-menu{display:block}
  .intro-card{padding:32px 24px}
  .intro-card h1{font-size:30px}
  .intro-card p{font-size:15.5px}
  .blog-grid{grid-template-columns:1fr}
  
  .section-head h2{font-size:24px}
  .ls-card{grid-template-columns:auto 1fr;grid-template-rows:auto auto}
  .ls-target{grid-column:1 / -1;text-align:left;border-top:1px solid var(--line);padding-top:10px;margin-top:4px}
  .footer-top{grid-template-columns:1fr;padding:42px 24px 28px}
}

/* red animated ring around coin icon for upcoming cards */
.coin-ring-red{position:relative;display:inline-block;padding:3px;border-radius:50%;line-height:0}
.coin-ring-red:before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,var(--red),transparent 35%,transparent 65%,var(--red));
  animation:ringSpin 2.5s linear infinite;
  -webkit-mask:radial-gradient(circle, transparent 60%, #000 62%);
          mask:radial-gradient(circle, transparent 60%, #000 62%);
}
.coin-ring-red .coin-ic,.coin-ring-red .coin-ic-text{border:2px solid #fff;position:relative;z-index:2;display:block}
@keyframes ringSpin{to{transform:rotate(360deg)}}

/* ============ ARTICLE PAGE ============ */
.crumb{font-size:13px;color:var(--muted);margin:8px 0 18px;font-weight:600}
.crumb a:hover{color:var(--brand)}
.article-head{margin-bottom:22px}
.article-head h1{font-size:36px;font-weight:800;line-height:1.18;margin:8px 0 14px}
.article-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:14px;font-weight:600}
.article-meta .coin-ic,.article-meta .coin-ic-text{width:28px;height:28px;font-size:11px}
.meta-sep{color:var(--line-2)}

.curr-exch{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px 15px;display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:24px}
.ce-lab{font-size:12.5px;font-weight:800;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;margin-right:4px}

.prose{font-size:17px;line-height:1.78;color:var(--ink-2);font-weight:500}
.prose h2{font-weight:800;color:var(--ink);padding-left:14px;border-left:4px solid var(--brand);font-size:25px;margin:36px 0 14px}
.prose h3{font-weight:700;color:var(--brand-2);font-size:19.5px;margin:26px 0 10px}
.prose p{margin:0 0 17px}
.prose strong{color:var(--ink);font-weight:700}
.prose ul{margin:0 0 18px;padding-left:22px}
.prose ul li::marker{color:var(--brand)}
.prose li{margin:6px 0}
.prose a{color:var(--brand);font-weight:700}
.prose .news-block{background:linear-gradient(150deg,#fff,#fafbff);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:28px 0}
.prose .news-block h2{border:0;padding:0;font-size:20px;margin:0 0 12px}
.news-list{list-style:none;padding:0;margin:0}
.news-list li{padding:9px 0;border-top:1px dashed var(--line);font-size:14.5px;font-weight:600}
.news-list li:first-child{border-top:0}
.news-list .news-src{font-size:12px;color:var(--muted);font-weight:600;margin-left:6px}

.disclaim{background:var(--gold-soft);border:1px solid #f0d49a;border-radius:12px;padding:13px 16px;font-size:13.5px;color:#7a5a12;font-weight:500;margin:24px 0}

.comments{margin:34px 0}
.comments h3{font-size:18px;font-weight:800;margin-bottom:14px}
.cmt-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.cmt-form input,.cmt-form textarea{padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:14.5px;font-family:var(--body);background:#fff}
.cmt-form input:focus,.cmt-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.cmt-form textarea{min-height:90px;resize:vertical}
.cmt-list{display:flex;flex-direction:column;gap:10px}
.cmt{background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:14px 16px}
.cmt-head{margin-bottom:6px;font-size:14px}
.cmt p{margin:0;font-size:14.5px;color:var(--ink-2)}

/* sub-category pills */
.subcat-row{display:flex;flex-wrap:wrap;gap:8px;margin:-6px 0 22px}
.subcat-row a{padding:8px 14px;border-radius:999px;background:var(--surface);border:1px solid var(--line-2);font-size:13px;font-weight:700;color:var(--ink-2)}
.subcat-row a:hover,.subcat-row a.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ====== News cards (replace old list) ====== */
.prose .news-block{background:linear-gradient(155deg,#fff,#fafbff);border:1px solid var(--line);border-radius:16px;padding:22px 22px 20px;margin:30px 0}
.prose .news-block h2{border:0;padding:0;font-size:21px;margin:0 0 16px;display:flex;align-items:center;gap:10px}
.news-tag{display:inline-block;background:linear-gradient(135deg,var(--red),#ff6e6b);color:#fff;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;padding:4px 10px;border-radius:7px;font-family:var(--display)}
.news-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.news-card{display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;transition:.2s}
.news-card:hover{border-color:var(--brand);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.news-num{width:30px;height:30px;border-radius:50%;background:var(--brand-soft);color:var(--brand);font-family:var(--display);font-weight:800;font-size:14px;display:grid;place-items:center;flex-shrink:0}
.news-body{display:flex;flex-direction:column;gap:5px;min-width:0}
.news-headline{font-weight:700;font-size:14px;line-height:1.4;color:var(--ink);text-decoration:none}
a.news-headline:hover{color:var(--brand)}
@media(max-width:680px){ .news-cards{grid-template-columns:1fr} }

/* ====== Symbol pill (next to coin name on cards) ====== */
.sym-pill{display:inline-block;background:var(--surface);border:1px solid var(--line-2);color:var(--ink-2);font-family:var(--mono);font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;letter-spacing:.04em;margin-left:4px;vertical-align:middle}

/* ====== Reaction "voted" state ====== */


/* ================================================== */
/* ============ UPCOMING CARDS (premium) ============ */
/* ================================================== */
.up-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.up-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px 22px 22px;box-shadow:0 2px 6px rgba(16,24,40,.04);transition:.25s cubic-bezier(.2,.8,.2,1);overflow:hidden;display:flex;flex-direction:column}
.up-card:before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,#3b46e6 0%,#7c4bff 50%,#e2920c 100%)}
.up-card:after{content:"";position:absolute;right:-50px;bottom:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(124,75,255,.06),transparent 70%);pointer-events:none;transition:.4s}
.up-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -20px rgba(20,28,60,.22);border-color:var(--brand-2)}
.up-card:hover:after{transform:scale(1.4)}
.up-top{display:flex;align-items:center;gap:14px;margin-bottom:16px;position:relative;z-index:2}
.up-name{font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.up-sym{font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--muted);letter-spacing:.04em;margin-top:2px}
.up-desc{font-size:14px;color:var(--ink-2);line-height:1.55;font-weight:500;margin:4px 0 16px;flex:1;position:relative;z-index:2}
.up-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px;position:relative;z-index:2}
.up-net-chip{display:inline-flex;align-items:center;gap:5px;background:var(--brand-soft);color:var(--brand);font-size:11.5px;font-weight:800;padding:5px 11px;border-radius:999px;letter-spacing:.02em}
.up-net-chip:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand)}
.up-cta{margin-top:auto;display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:800;color:var(--brand);letter-spacing:.01em;position:relative;z-index:2;transition:.2s}
.up-card:hover .up-cta{gap:10px}
.up-label{position:absolute;right:14px;top:14px;background:linear-gradient(135deg,#e2920c,#f3a93a);color:#fff;font-family:var(--display);font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;padding:5px 10px;border-radius:6px;box-shadow:0 3px 10px -2px rgba(226,146,12,.55);animation:upPulse 2.4s ease-in-out infinite;z-index:3}
@keyframes upPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}

@media(max-width:980px){ .up-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .up-grid{grid-template-columns:1fr} }

/* ============================================ */
/* ============ ARTICLE INFO BOXES ============ */
/* ============================================ */
.info-boxes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 26px;align-items:stretch}
.ib{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 1px 3px rgba(16,24,40,.04);transition:.2s;display:flex;flex-direction:column;justify-content:flex-start;min-height:100%}
.ib:hover{transform:translateY(-2px);box-shadow:0 12px 30px -12px rgba(20,28,60,.16);border-color:var(--brand-2)}
.ib-icon-wrap{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--brand-soft),#fff);display:grid;place-items:center;font-size:18px;margin-bottom:12px;border:1px solid var(--line)}
.ib-icon-wrap.red{background:linear-gradient(135deg,#ffe9e8,#fff);border-color:#f7c5c3}
.ib-icon-wrap.gold{background:linear-gradient(135deg,#fff4dd,#fff);border-color:#f0d49a}
.ib-icon-wrap.purple{background:linear-gradient(135deg,#f1ecff,#fff);border-color:#dccff5}
.ib-icon-wrap.green{background:linear-gradient(135deg,#e6f6ee,#fff);border-color:#b8e6cd}
.ib-lab{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:800;margin-bottom:6px}
.ib-val{font-family:var(--display);font-weight:800;font-size:16px;color:var(--ink);line-height:1.3;letter-spacing:-.005em;word-wrap:break-word}
.ib-val.red{color:var(--red)}
.ib-sub{font-size:12px;color:var(--muted);margin-top:4px;font-weight:600}

/* Visit button: pill shaped with red animated border line that follows the shape */
.visit-btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  padding:12px 28px;border-radius:999px;background:#fff;color:var(--red);
  font-family:var(--display);font-weight:800;font-size:13px;
  text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;
  border:2px solid var(--red);
  transition:transform .2s,background .2s,color .2s;
  z-index:1;
}
.visit-btn::before{
  content:"";position:absolute;inset:-4px;border-radius:999px;
  background:conic-gradient(from 0deg,var(--red) 0deg,rgba(229,57,53,0) 80deg,rgba(229,57,53,0) 280deg,var(--red) 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  padding:3px;
  animation:visitRingSpin 2.5s linear infinite;
  pointer-events:none;z-index:-1;
}
@keyframes visitRingSpin{ to{ transform:rotate(360deg) } }
.visit-btn:hover{transform:scale(1.06);background:var(--red);color:#fff}
.ib-site{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}

@media(max-width:900px){ .info-boxes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 26px;align-items:stretch} }
@media(max-width:480px){ .info-boxes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 26px;align-items:stretch} }

/* =================================== */
/* ============ REACTIONS ============ */
/* =================================== */
.reactions{margin:32px 0 14px;text-align:center}
.reactions h3{font-size:17px;margin-bottom:14px;font-weight:800}
.react-row{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}
.rbtn{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:11px 20px;font-weight:700;font-size:14.5px;cursor:pointer;font-family:var(--body);transition:.2s;color:var(--ink)}
.rbtn:hover{border-color:var(--brand);background:var(--brand-soft);color:var(--brand);transform:translateY(-2px)}
.rbtn.voted{background:var(--brand-soft);border-color:var(--brand);color:var(--brand);cursor:default;transform:none}
.rbtn .rb-emoji{font-size:18px;line-height:1}
.rbtn .rb-count{font-family:var(--mono);font-weight:800;min-width:14px;text-align:left}

/* ================================ */
/* ============ NEWS ============== */
/* ================================ */
.prose .news-block{background:linear-gradient(155deg,#fff,#fafbff);border:1px solid var(--line);border-radius:16px;padding:24px;margin:32px 0}
.prose .news-block h2{border:0;padding:0;font-size:21px;margin:0 0 18px;display:flex;align-items:center;gap:10px}
.news-tag{display:inline-block;background:linear-gradient(135deg,var(--red),#ff6e6b);color:#fff;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:800;padding:4px 11px;border-radius:7px;font-family:var(--display)}
.news-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.news-card{display:flex;gap:13px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;transition:.2s}
.news-card:hover{border-color:var(--brand-2);box-shadow:0 6px 18px -6px rgba(20,28,60,.12);transform:translateY(-2px)}
.news-num{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-family:var(--display);font-weight:800;font-size:14px;display:grid;place-items:center}
.news-body{display:flex;flex-direction:column;gap:6px;min-width:0}
.news-headline{font-family:var(--display);font-weight:800;font-size:15px;line-height:1.4;color:var(--ink)}
.news-summary{font-size:13.5px;color:var(--ink-2);line-height:1.55;font-weight:500}

@media(max-width:680px){ .news-cards{grid-template-columns:1fr} }

/* ========================================== */
/* ============ SYMBOL PILL ================= */
/* ========================================== */
.sym-pill{display:inline-block;background:var(--surface);border:1px solid var(--line-2);color:var(--ink-2);font-family:var(--mono);font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;letter-spacing:.04em;margin-left:5px;vertical-align:1px}
