/* ================================================================
   SpillHour v3.0 — Complete Stylesheet
   Mobile-first | Dark/Light | Sticky nav | All features
   ================================================================ */

:root {
  --p:      #7B2FFF;
  --p2:     #9B59FF;
  --cyan:   #00D4FF;
  --amber:  #FFB800;
  --green:  #00E5A0;
  --red:    #FF4757;
  --bg0:    #07071A;
  --bg1:    #0E0E28;
  --bg2:    #151530;
  --bg3:    #1C1C3A;
  --s1:     #242448;
  --s2:     #2E2E58;
  --border: rgba(123,47,255,0.18);
  --bord2:  rgba(123,47,255,0.32);
  --t1:     #F2EEFF;
  --t2:     #B0A8D0;
  --t3:     #6A6490;
  --grad:   linear-gradient(135deg,#7B2FFF 0%,#00D4FF 100%);
  --glow:   0 0 32px rgba(123,47,255,0.22);
  --r:      12px;
  --nav-h:  58px;
}

/* LIGHT THEME */
.sh-theme-light {
  --bg0:#F0EEFF; --bg1:#E8E4FF; --bg2:#FFFFFF; --bg3:#F5F3FF;
  --s1:#EDE8FF; --s2:#E0D9FF;
  --border:rgba(123,47,255,0.15); --bord2:rgba(123,47,255,0.28);
  --t1:#180A3C; --t2:#4A3A6A; --t3:#8A7AAA;
}
.sh-theme-light .sh-nav { background:rgba(240,238,255,0.97); }
.sh-theme-light .sh-card,
.sh-theme-light .sh-qa-card,
.sh-theme-light .sh-widget,
.sh-theme-light .sh-single-post,
.sh-theme-light .sh-comments-section { background:#fff; box-shadow:0 1px 8px rgba(123,47,255,0.07); }

/* RESET */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'DM Sans',sans-serif;
  background:var(--bg0);
  color:var(--t1);
  min-height:100vh;
  overflow-x:hidden;
  line-height:1.5;
}
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 500px 350px at 15% 5%, rgba(123,47,255,0.07), transparent 70%),
    radial-gradient(ellipse 350px 250px at 88% 88%, rgba(0,212,255,0.05), transparent 70%);
}
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:inherit; }
img { max-width:100%; height:auto; display:block; }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:var(--bg1); }
::-webkit-scrollbar-thumb { background:var(--s2); border-radius:20px; }

/* TYPOGRAPHY */
h1,h2,h3 { font-family:'Syne',sans-serif; }
.sh-grad-text {
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ===================== LOGO ===================== */
.sh-logo { font-family:'Syne',sans-serif; font-size:20px; font-weight:800; letter-spacing:-0.8px; flex-shrink:0; display:flex; align-items:center; }
.sh-logo-s { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ===================== STICKY NAV — FIXED ALWAYS ===================== */
.sh-nav {
  position:fixed !important;  /* NEVER moves */
  top:0; left:0; right:0;
  height:var(--nav-h);
  z-index:999;
  background:rgba(7,7,26,0.97);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transform:none !important;  /* override any JS that tries to hide it */
}
.sh-nav-inner {
  max-width:1200px; margin:0 auto; height:100%;
  padding:0 16px; display:flex; align-items:center; gap:10px;
}
/* Push content below fixed nav */
.sh-body-pad { padding-top:var(--nav-h); }

/* SEARCH */
.sh-nav-search { flex:1; max-width:300px; position:relative; }
.sh-search-icon { position:absolute; left:10px; top:50%; transform:translateY(-50%); color:var(--t3); pointer-events:none; font-size:13px; }
.sh-search-inp {
  width:100%; background:var(--bg2); border:1px solid var(--border);
  color:var(--t1); padding:8px 12px 8px 32px; border-radius:10px;
  font-size:13px; font-family:'DM Sans',sans-serif; outline:none;
  transition:border-color .2s;
}
.sh-search-inp:focus { border-color:var(--p2); }
.sh-search-inp::placeholder { color:var(--t3); }

/* NAV TABS */
.sh-nav-tabs { display:flex; gap:2px; background:var(--bg2); border:1px solid var(--border); border-radius:11px; padding:3px; flex-shrink:0; }
.sh-nav-tab { padding:6px 14px; border-radius:8px; font-size:13px; font-weight:600; color:var(--t3); white-space:nowrap; transition:all .2s; }
.sh-nav-tab:hover:not(.active) { color:var(--t1); background:var(--s1); }
.sh-nav-tab.active { background:var(--grad); color:#fff; }

/* NAV RIGHT */
.sh-nav-right { margin-left:auto; display:flex; align-items:center; gap:7px; }

/* BUTTONS */
.sh-btn-ghost { background:transparent; border:1px solid var(--bord2); color:var(--t2); padding:7px 14px; border-radius:9px; font-size:13px; font-weight:500; transition:all .2s; white-space:nowrap; }
.sh-btn-ghost:hover { border-color:var(--p2); color:var(--t1); }
.sh-btn-primary { background:var(--grad); border:none; color:#fff; padding:7px 16px; border-radius:9px; font-size:13px; font-weight:700; transition:opacity .2s,transform .15s; white-space:nowrap; display:inline-block; text-align:center; }
.sh-btn-primary:hover { opacity:.88; transform:scale(1.02); }
.sh-btn-primary:active { transform:scale(.97); }
.sh-btn-ask { background:linear-gradient(135deg,var(--cyan),var(--p2)); border:none; color:#fff; padding:7px 16px; border-radius:9px; font-size:13px; font-weight:700; white-space:nowrap; }
.sh-btn-ask:hover { opacity:.88; }

/* THEME TOGGLE */
.sh-theme-toggle { display:flex; gap:2px; background:var(--bg2); border:1px solid var(--border); border-radius:9px; padding:2px; }
.sh-t-opt { width:28px; height:28px; border-radius:7px; font-size:12px; border:none; background:transparent; color:var(--t3); display:flex; align-items:center; justify-content:center; transition:all .2s; }
.sh-t-opt:hover { color:var(--t1); }
.sh-t-opt.active { background:var(--grad); }

/* NOTIFICATIONS */
.sh-notif-wrap { position:relative; }
.sh-notif-btn { background:var(--bg2); border:1px solid var(--border); color:var(--t2); width:34px; height:34px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:16px; position:relative; transition:border-color .2s; }
.sh-notif-btn:hover { border-color:var(--p2); }
.sh-notif-badge { position:absolute; top:-4px; right:-4px; background:var(--red); color:#fff; border-radius:20px; font-size:9px; font-weight:800; padding:1px 5px; min-width:15px; text-align:center; }
.sh-notif-drop { display:none; position:absolute; right:0; top:calc(100% + 8px); width:290px; background:var(--bg2); border:1px solid var(--bord2); border-radius:12px; box-shadow:var(--glow); z-index:500; overflow:hidden; }
.sh-notif-wrap.open .sh-notif-drop { display:block; animation:shFadeUp .2s ease; }
.sh-notif-head { display:flex; align-items:center; justify-content:space-between; padding:11px 14px; border-bottom:1px solid var(--border); font-size:13px; font-weight:700; }
.sh-notif-mark { font-size:11px; color:var(--p2); background:transparent; border:none; cursor:pointer; }
.sh-notif-item { display:flex; gap:9px; padding:10px 14px; border-bottom:1px solid rgba(255,255,255,0.04); transition:background .15s; }
.sh-notif-item:hover { background:var(--bg3); }
.sh-notif-item.unread { background:rgba(123,47,255,0.07); }
.sh-notif-ico { font-size:16px; flex-shrink:0; }
.sh-notif-txt { flex:1; font-size:12px; color:var(--t2); line-height:1.45; }
.sh-notif-time { font-size:10px; color:var(--t3); margin-top:2px; }
.sh-notif-empty { padding:18px; text-align:center; color:var(--t3); font-size:13px; }

/* USER MENU */
.sh-user-menu { position:relative; }
.sh-user-btn { display:flex; align-items:center; gap:6px; background:var(--bg2); border:1px solid var(--border); color:var(--t1); padding:4px 10px 4px 4px; border-radius:9px; font-size:13px; font-weight:600; transition:border-color .2s; }
.sh-user-btn:hover { border-color:var(--p2); }
.sh-uname { max-width:80px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sh-udrop { display:none; position:absolute; right:0; top:calc(100% + 8px); min-width:180px; background:var(--bg2); border:1px solid var(--bord2); border-radius:11px; padding:4px; box-shadow:var(--glow); z-index:500; }
.sh-user-menu.open .sh-udrop { display:block; animation:shFadeUp .2s ease; }
.sh-udrop a { display:flex; align-items:center; gap:8px; padding:8px 12px; border-radius:7px; font-size:13px; color:var(--t2); transition:all .15s; }
.sh-udrop a:hover { background:var(--s1); color:var(--t1); }
.sh-udrop-div { height:1px; background:var(--border); margin:3px 8px; }

/* HAMBURGER */
.sh-ham { display:none; flex-direction:column; gap:5px; background:transparent; border:1px solid var(--border); padding:6px 8px; border-radius:8px; }
.sh-ham span { width:18px; height:2px; background:var(--t2); border-radius:2px; transition:all .25s; display:block; }
.sh-ham.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.sh-ham.open span:nth-child(2) { opacity:0; }
.sh-ham.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.sh-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:150; }
.sh-overlay.open { display:block; }

/* BADGES */
.sh-v-badge { display:inline-flex; align-items:center; justify-content:center; width:14px; height:14px; background:var(--p); border-radius:50%; font-size:8px; color:#fff; font-weight:900; vertical-align:middle; margin-left:2px; flex-shrink:0; }
.sh-p-badge { display:inline-flex; align-items:center; justify-content:center; width:14px; height:14px; background:var(--amber); border-radius:50%; font-size:8px; color:#000; font-weight:900; vertical-align:middle; margin-left:2px; flex-shrink:0; }

/* ===================== LAYOUT ===================== */
.sh-layout {
  display:grid;
  grid-template-columns:210px 1fr 262px;
  gap:16px;
  max-width:1200px; margin:0 auto;
  padding:18px 14px 60px;
  position:relative; z-index:1;
}

/* LEFT SIDEBAR */
.sh-sidebar-l {
  position:sticky; top:calc(var(--nav-h) + 14px);
  align-self:start; max-height:calc(100vh - var(--nav-h) - 28px);
  overflow-y:auto; display:flex; flex-direction:column; gap:2px;
  scrollbar-width:none;
}
.sh-sidebar-l::-webkit-scrollbar { display:none; }
.sh-sl-label { font-size:10px; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; color:var(--t3); padding:9px 10px 3px; }
.sh-sl-item { display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius:9px; font-size:13px; font-weight:500; color:var(--t2); transition:all .15s; text-decoration:none; border:none; background:transparent; width:100%; text-align:left; cursor:pointer; }
.sh-sl-item:hover { background:var(--bg2); color:var(--t1); }
.sh-sl-item.active { background:rgba(123,47,255,0.18); color:var(--p2); font-weight:600; }
.sh-sl-ico { font-size:14px; width:18px; text-align:center; flex-shrink:0; }
.sh-sl-badge { margin-left:auto; font-size:10px; font-weight:700; padding:2px 6px; border-radius:20px; background:var(--s1); color:var(--t3); }
.sh-sl-item.active .sh-sl-badge { background:rgba(123,47,255,0.3); color:var(--p2); }
.sh-sl-div { height:1px; background:var(--border); margin:4px 10px; }

/* RIGHT SIDEBAR */
.sh-sidebar-r { position:sticky; top:calc(var(--nav-h) + 14px); align-self:start; max-height:calc(100vh - var(--nav-h) - 28px); overflow-y:auto; display:flex; flex-direction:column; gap:12px; scrollbar-width:none; }
.sh-sidebar-r::-webkit-scrollbar { display:none; }

/* WIDGETS */
.sh-widget { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:14px; }
.sh-whead { font-family:'Syne',sans-serif; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:var(--t3); margin-bottom:11px; display:flex; align-items:center; gap:5px; }

/* ===================== HERO ===================== */
.sh-hero { background:linear-gradient(135deg,rgba(123,47,255,0.13),rgba(0,212,255,0.07)); border:1px solid var(--bord2); border-radius:16px; padding:18px 20px; margin-bottom:14px; display:flex; align-items:center; gap:14px; position:relative; overflow:hidden; }
.sh-hero::after { content:''; position:absolute; right:-30px; top:-30px; width:160px; height:160px; border-radius:50%; background:radial-gradient(circle,rgba(0,212,255,0.07),transparent 70%); pointer-events:none; }
.sh-hero-txt h1 { font-family:'Syne',sans-serif; font-size:19px; font-weight:800; margin-bottom:5px; line-height:1.25; }
.sh-hero-txt p { font-size:13px; color:var(--t2); line-height:1.55; }
.sh-hero-actions { margin-left:auto; display:flex; gap:7px; flex-shrink:0; flex-wrap:wrap; }

/* COMPOSE */
.sh-compose { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:10px 12px; display:flex; align-items:center; gap:8px; margin-bottom:12px; cursor:pointer; transition:border-color .2s; }
.sh-compose:hover { border-color:var(--p2); }
.sh-compose-inp { flex:1; background:transparent; border:none; color:var(--t3); font-size:13px; font-family:'DM Sans',sans-serif; outline:none; pointer-events:none; }
.sh-ava { width:32px; height:32px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; flex-shrink:0; color:#fff; font-family:'Syne',sans-serif; }
.sh-ava-g { background:var(--grad); }

/* SORT TABS */
.sh-sort-tabs { display:flex; gap:2px; margin-bottom:12px; background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:3px; overflow-x:auto; scrollbar-width:none; }
.sh-sort-tabs::-webkit-scrollbar { display:none; }
.sh-sort-tab { flex:1; text-align:center; padding:6px 4px; border-radius:8px; font-size:12px; font-weight:600; color:var(--t3); transition:all .2s; white-space:nowrap; flex-shrink:0; text-decoration:none; display:block; }
.sh-sort-tab.active { background:var(--s2); color:var(--t1); }
.sh-sort-tab:hover:not(.active) { color:var(--t2); }

/* SEC LABEL */
.sh-sec-label { display:flex; align-items:center; gap:8px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--t3); margin-bottom:10px; }
.sh-sec-label::after { content:''; flex:1; height:1px; background:var(--border); }

/* ===================== POST CARD ===================== */
.sh-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:14px; margin-bottom:8px; animation:shFadeUp .3s ease both; transition:border-color .2s,box-shadow .2s,transform .15s; }
.sh-card:hover { border-color:var(--p2); box-shadow:var(--glow); transform:translateY(-1px); }
.sh-card.sh-hidden { display:none; }
@keyframes shFadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

.sh-card-meta { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.sh-card-meta .sh-ava { width:28px; height:28px; border-radius:8px; font-size:11px; }
.sh-meta-info { flex:1; }
.sh-meta-user { font-size:12px; font-weight:700; color:var(--t1); display:flex; align-items:center; gap:3px; flex-wrap:wrap; }
.sh-meta-user a:hover { color:var(--p2); }
.sh-meta-comm { font-size:11px; color:var(--p2); font-weight:500; }
.sh-meta-comm a:hover { text-decoration:underline; }
.sh-meta-time { font-size:11px; color:var(--t3); flex-shrink:0; }
.sh-card-title { font-family:'Syne',sans-serif; font-size:15px; font-weight:700; line-height:1.35; margin-bottom:7px; }
.sh-card-title a:hover { color:var(--p2); }
.sh-card-body { font-size:13px; color:var(--t2); line-height:1.6; margin-bottom:8px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sh-card-tags { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:9px; }
.sh-tag { background:rgba(123,47,255,0.12); color:var(--p2); border:1px solid rgba(123,47,255,0.2); padding:2px 8px; border-radius:20px; font-size:11px; font-weight:600; }
.sh-tag.c { background:rgba(0,212,255,0.09); color:var(--cyan); border-color:rgba(0,212,255,0.18); }
.sh-tag.g { background:rgba(0,229,160,0.09); color:var(--green); border-color:rgba(0,229,160,0.18); }

/* CARD FOOTER */
.sh-card-foot { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.sh-votes { display:flex; align-items:center; gap:1px; background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:2px; }
.sh-vbtn { width:24px; height:24px; border:none; background:transparent; color:var(--t3); font-size:10px; border-radius:6px; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.sh-vbtn:hover { background:rgba(123,47,255,0.18); color:var(--p2); }
.sh-vbtn.voted-up { background:rgba(123,47,255,0.22); color:var(--p2); }
.sh-vbtn.voted-down { background:rgba(255,71,87,0.18); color:var(--red); }
.sh-vscore { font-size:12px; font-weight:800; color:var(--t1); padding:0 5px; font-family:'Syne',sans-serif; }
.sh-act-btn { display:flex; align-items:center; gap:4px; border:1px solid var(--border); background:var(--bg3); color:var(--t3); font-size:11px; padding:4px 8px; border-radius:7px; transition:all .15s; white-space:nowrap; }
.sh-act-btn:hover { color:var(--t1); border-color:var(--p2); }
.sh-ai-btn { display:flex; align-items:center; gap:3px; margin-left:auto; background:linear-gradient(90deg,rgba(123,47,255,0.14),rgba(0,212,255,0.09)); border:1px solid rgba(0,212,255,0.2); color:var(--cyan); font-size:10px; font-weight:700; padding:3px 8px; border-radius:20px; white-space:nowrap; }
.sh-anon-tag { background:rgba(0,229,160,0.09); border:1px solid rgba(0,229,160,0.18); color:var(--green); font-size:10px; font-weight:700; padding:2px 8px; border-radius:20px; }
.sh-ans-badge { background:rgba(0,229,160,0.1); color:var(--green); border:1px solid rgba(0,229,160,0.2); font-size:10px; font-weight:700; padding:2px 8px; border-radius:20px; margin-left:auto; }
.sh-pend-badge { background:rgba(255,184,0,0.1); color:var(--amber); border:1px solid rgba(255,184,0,0.2); font-size:10px; font-weight:700; padding:2px 8px; border-radius:20px; margin-left:auto; }
.sh-report-btn { font-size:11px; color:var(--t3); background:transparent; border:none; padding:3px 6px; border-radius:6px; }
.sh-report-btn:hover { color:var(--red); }
.sh-wa-btn { background:rgba(37,211,102,0.1) !important; color:#25D366 !important; border-color:rgba(37,211,102,0.2) !important; }

/* ===================== MEDIA IN CARDS ===================== */
.sh-post-img { width:100%; border-radius:10px; max-height:360px; object-fit:cover; margin-bottom:9px; }
.sh-post-gif { width:100%; border-radius:10px; max-height:280px; object-fit:contain; background:var(--bg3); margin-bottom:9px; }
.sh-embed-wrap { position:relative; width:100%; padding-bottom:56.25%; border-radius:10px; overflow:hidden; background:var(--bg3); margin-bottom:9px; }
.sh-embed-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.sh-embed-link-wrap { display:flex; align-items:center; justify-content:center; min-height:60px; border:1px solid var(--border); border-radius:10px; }
.sh-embed-ext-link { font-size:13px; font-weight:700; color:var(--p2); padding:14px; display:block; width:100%; text-align:center; }
.sh-embed-ext-link:hover { color:var(--cyan); }

/* QUOTE EMBED */
.sh-quote-embed { display:block; background:var(--bg3); border:1px solid var(--border); border-left:3px solid var(--p2); border-radius:9px; padding:10px 12px; margin-bottom:9px; }
.sh-quote-embed:hover { border-color:var(--p2); }
.sh-quote-title { font-size:13px; font-weight:700; color:var(--t1); margin-bottom:3px; }
.sh-quote-body { font-size:11px; color:var(--t2); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ===================== Q&A CARD ===================== */
.sh-qa-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:14px; margin-bottom:8px; cursor:pointer; animation:shFadeUp .3s ease both; transition:border-color .2s,box-shadow .2s,transform .15s; }
.sh-qa-card:hover { border-color:var(--cyan); box-shadow:0 0 28px rgba(0,212,255,0.12); transform:translateY(-1px); }
.sh-qa-q { font-family:'Syne',sans-serif; font-size:15px; font-weight:700; line-height:1.35; margin-bottom:9px; }
.sh-qa-qmark { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-weight:800; margin-right:4px; }
.sh-qa-ans-box { background:var(--bg3); border-radius:9px; padding:9px 12px; margin-bottom:8px; border-left:3px solid var(--cyan); }
.sh-qa-ans-lbl { font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.9px; color:var(--cyan); margin-bottom:3px; }
.sh-qa-ans-txt { font-size:12px; color:var(--t2); line-height:1.55; }
.sh-qa-foot { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.sh-qa-stat { font-size:11px; color:var(--t3); }

/* ===================== BLOG CARD ===================== */
.sh-blog-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; margin-bottom:8px; display:flex; animation:shFadeUp .3s ease both; transition:border-color .2s,transform .15s; }
.sh-blog-card:hover { border-color:var(--p2); transform:translateY(-1px); box-shadow:var(--glow); }
.sh-blog-thumb { width:140px; min-height:105px; flex-shrink:0; overflow:hidden; }
.sh-blog-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.sh-blog-card:hover .sh-blog-thumb img { transform:scale(1.04); }
.sh-blog-content { padding:12px; flex:1; display:flex; flex-direction:column; }
.sh-blog-title { font-family:'Syne',sans-serif; font-size:14px; font-weight:700; margin-bottom:5px; line-height:1.35; }
.sh-blog-title a:hover { color:var(--p2); }
.sh-blog-excerpt { font-size:12px; color:var(--t2); line-height:1.5; flex:1; margin-bottom:8px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sh-blog-foot { display:flex; align-items:center; gap:6px; }
.sh-read-more { font-size:12px; font-weight:700; color:var(--p2); margin-left:auto; }
.sh-read-more:hover { color:var(--cyan); }
.sh-read-time { font-size:11px; color:var(--t3); }

/* ===================== BRANDED NATIVE ADS ===================== */
.sh-ad-unit { background:var(--bg2); border:1px solid var(--border); border-left:3px solid var(--p); border-radius:var(--r); padding:13px 14px; margin:7px 0; position:relative; animation:shFadeUp .3s ease both; }
.sh-ad-label { position:absolute; top:9px; right:11px; font-size:8px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--t3); background:var(--bg3); padding:2px 7px; border-radius:20px; border:1px solid var(--border); }
.sh-ad-house { display:flex; align-items:flex-start; gap:11px; padding-right:50px; }
.sh-ad-house-icon { font-size:26px; flex-shrink:0; margin-top:2px; }
.sh-ad-title { font-family:'Syne',sans-serif; font-size:14px; font-weight:700; color:var(--t1); margin-bottom:4px; }
.sh-ad-body { font-size:12px; color:var(--t2); line-height:1.5; margin-bottom:7px; }
.sh-ad-cta { font-size:12px; font-weight:700; color:var(--p2); }
.sh-ad-cta:hover { color:var(--cyan); }
.sh-ad-footer { display:flex; align-items:center; justify-content:space-between; margin-top:9px; padding-top:7px; border-top:1px solid var(--border); font-size:10px; color:var(--t3); }
.sh-ad-footer a { color:var(--t3); }
.sh-ad-footer a:hover { color:var(--p2); }

/* ===================== TREND RADAR ===================== */
.sh-trend-row { display:flex; align-items:center; gap:8px; padding:6px 0; border-bottom:1px solid rgba(255,255,255,0.04); transition:color .15s; text-decoration:none; }
.sh-trend-row:last-child { border-bottom:none; }
.sh-trend-row:hover .sh-trend-name { color:var(--p2); }
.sh-trend-n { font-size:10px; font-weight:800; color:var(--t3); width:14px; flex-shrink:0; }
.sh-trend-d { flex:1; }
.sh-trend-name { font-size:12px; font-weight:700; color:var(--t1); transition:color .15s; }
.sh-trend-cnt { font-size:10px; color:var(--t3); }
.sh-theat { font-size:9px; font-weight:700; padding:2px 7px; border-radius:20px; }
.sh-theat.hot    { background:rgba(255,71,87,0.12); color:var(--red); }
.sh-theat.rising { background:rgba(255,184,0,0.1); color:var(--amber); }
.sh-theat.new    { background:rgba(0,229,160,0.09); color:var(--green); }

/* SPILL SCORE */
.sh-ss-head { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.sh-ss-ava { width:40px; height:40px; border-radius:11px; font-size:16px; }
.sh-ss-name { font-size:13px; font-weight:700; }
.sh-ss-handle { font-size:11px; color:var(--t3); }
.sh-ss-bar-row { display:flex; justify-content:space-between; font-size:11px; margin-bottom:3px; }
.sh-ss-bar-row span:last-child { color:var(--p2); font-weight:700; }
.sh-ss-track { background:var(--bg3); border-radius:20px; height:4px; margin-bottom:8px; overflow:hidden; }
.sh-ss-fill { height:100%; border-radius:20px; background:var(--grad); transition:width .6s ease; }
.sh-ss-badges { display:flex; gap:4px; flex-wrap:wrap; }
.sh-ss-badge { background:var(--bg3); border:1px solid var(--border); border-radius:6px; padding:3px 7px; font-size:11px; color:var(--t2); }

/* ===================== LEADERBOARD ===================== */
.sh-leaderboard-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:16px; padding:18px; }
.sh-lb-tabs { display:flex; gap:2px; background:var(--bg3); border-radius:9px; padding:3px; margin-bottom:16px; }
.sh-lb-tab { flex:1; text-align:center; padding:7px; border-radius:7px; font-size:12px; font-weight:700; border:none; background:transparent; color:var(--t3); transition:all .2s; }
.sh-lb-tab.active { background:var(--grad); color:#fff; }
.sh-lb-row { display:flex; align-items:center; gap:11px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.04); }
.sh-lb-row:last-child { border-bottom:none; }
.sh-lb-rank { font-family:'Syne',sans-serif; font-size:16px; font-weight:800; width:28px; text-align:center; flex-shrink:0; }
.sh-lb-ava { width:36px; height:36px; border-radius:10px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:800; color:#fff; font-family:'Syne',sans-serif; overflow:hidden; }
.sh-lb-info { flex:1; min-width:0; }
.sh-lb-name { font-size:13px; font-weight:700; color:var(--t1); display:flex; align-items:center; gap:4px; flex-wrap:wrap; }
.sh-lb-name a { color:var(--t1); }
.sh-lb-name a:hover { color:var(--p2); }
.sh-lb-level { font-size:11px; color:var(--t3); margin-top:1px; }
.sh-lb-badges { display:flex; gap:2px; margin-top:3px; font-size:13px; }
.sh-lb-score { text-align:right; flex-shrink:0; }
.sh-lb-sv { font-family:'Syne',sans-serif; font-size:15px; font-weight:800; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sh-lb-sl { font-size:10px; color:var(--t3); text-transform:uppercase; letter-spacing:.8px; }

/* ===================== MODALS ===================== */
.sh-modal { display:none; position:fixed; inset:0; z-index:600; background:rgba(7,7,26,0.88); backdrop-filter:blur(8px); align-items:center; justify-content:center; padding:14px; }
.sh-modal.open { display:flex; }
.sh-modal-box { background:var(--bg2); border:1px solid var(--bord2); border-radius:16px; padding:20px; max-width:520px; width:100%; box-shadow:var(--glow); animation:shFadeUp .28s ease; max-height:90vh; overflow-y:auto; }
.sh-modal-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:15px; }
.sh-modal-head h2 { font-family:'Syne',sans-serif; font-size:17px; font-weight:800; }
.sh-modal-close { background:var(--bg3); border:1px solid var(--border); color:var(--t3); width:28px; height:28px; border-radius:7px; font-size:13px; display:flex; align-items:center; justify-content:center; }
.sh-modal-close:hover { color:var(--t1); border-color:var(--p2); }
/* FORM ELEMENTS */
.sh-form-title { width:100%; background:var(--bg3); border:1px solid var(--border); color:var(--t1); padding:10px 12px; border-radius:9px; font-size:15px; font-weight:600; font-family:'Syne',sans-serif; outline:none; transition:border-color .2s; margin-bottom:8px; }
.sh-form-title:focus { border-color:var(--p2); }
.sh-form-title::placeholder { color:var(--t3); font-family:'DM Sans',sans-serif; font-weight:400; font-size:13px; }
.sh-form-body { width:100%; background:var(--bg3); border:1px solid var(--border); color:var(--t1); padding:10px 12px; border-radius:9px; font-size:13px; font-family:'DM Sans',sans-serif; outline:none; resize:vertical; transition:border-color .2s; margin-bottom:8px; }
.sh-form-body:focus { border-color:var(--p2); }
.sh-form-body::placeholder { color:var(--t3); }
.sh-form-select { width:100%; background:var(--bg3); border:1px solid var(--border); color:var(--t2); padding:9px 11px; border-radius:9px; font-size:13px; font-family:'DM Sans',sans-serif; outline:none; margin-bottom:8px; }
.sh-media-toolbar { display:flex; gap:5px; flex-wrap:wrap; padding:7px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:9px; }
.sh-mbtn { display:flex; align-items:center; gap:4px; background:var(--bg3); border:1px solid var(--border); color:var(--t2); padding:5px 10px; border-radius:7px; font-size:11px; font-weight:600; transition:all .2s; }
.sh-mbtn:hover,.sh-mbtn.active { border-color:var(--p2); color:var(--t1); }
.sh-anon-chk { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--t2); margin-left:auto; }
.sh-anon-chk input { accent-color:var(--p); }
.sh-media-panel { margin-top:8px; animation:shFadeUp .2s ease; }
.sh-char-count { font-size:10px; color:var(--t3); text-align:right; margin:-5px 0 7px; }
.sh-form-submit { width:100%; padding:11px; font-size:14px; margin-top:4px; }

/* AI SUMMARY MODAL */
.sh-sum-modal { display:none; position:fixed; inset:0; z-index:700; background:rgba(7,7,26,0.9); backdrop-filter:blur(10px); align-items:center; justify-content:center; padding:14px; }
.sh-sum-modal.open { display:flex; }
.sh-sum-box { background:var(--bg2); border:1px solid var(--bord2); border-radius:16px; padding:24px; max-width:400px; width:100%; box-shadow:var(--glow); animation:shFadeUp .28s ease; }
.sh-sum-box h3 { font-family:'Syne',sans-serif; font-size:15px; font-weight:800; margin-bottom:13px; }
.sh-sum-pt { display:flex; gap:9px; margin-bottom:9px; font-size:13px; color:var(--t2); line-height:1.5; }
.sh-sum-dot { width:6px; height:6px; border-radius:50%; background:var(--grad); flex-shrink:0; margin-top:6px; }
.sh-sum-close { margin-top:15px; width:100%; background:var(--grad); border:none; color:#fff; padding:10px; border-radius:9px; font-size:13px; font-weight:700; font-family:'DM Sans',sans-serif; }

/* TOGGLE SWITCH */
.sh-toggle { width:36px; height:20px; border-radius:20px; background:var(--p); position:relative; cursor:pointer; flex-shrink:0; transition:background .2s; }
.sh-toggle::after { content:''; position:absolute; width:16px; height:16px; background:#fff; border-radius:50%; top:2px; right:2px; transition:all .2s; }
.sh-toggle.off { background:var(--s2); }
.sh-toggle.off::after { right:unset; left:2px; }

/* ===================== SINGLE POST ===================== */
.sh-single-post { background:var(--bg2); border:1px solid var(--border); border-radius:16px; padding:20px; margin-bottom:16px; }
.sh-single-title { font-family:'Syne',sans-serif; font-size:22px; font-weight:800; line-height:1.28; margin-bottom:13px; }
.sh-single-body { font-size:15px; color:var(--t2); line-height:1.78; margin-bottom:13px; }
.sh-single-body p { margin-bottom:11px; }
.sh-single-body h2,.sh-single-body h3 { color:var(--t1); margin:20px 0 9px; }
.sh-single-body a { color:var(--p2); text-decoration:underline; }
.sh-single-body ul,.sh-single-body ol { padding-left:20px; margin-bottom:11px; }
.sh-single-body li { margin-bottom:5px; }
.sh-single-acts { display:flex; align-items:center; gap:6px; flex-wrap:wrap; padding-top:13px; border-top:1px solid var(--border); }
.sh-comments-section { background:var(--bg2); border:1px solid var(--border); border-radius:16px; padding:16px; }
.sh-comment { background:var(--bg3); border-radius:10px; padding:12px; margin-bottom:8px; border:1px solid rgba(255,255,255,0.04); }
.sh-comment.top-answer { border-color:rgba(0,212,255,0.22); }
.sh-comment-meta { display:flex; align-items:center; gap:7px; margin-bottom:8px; flex-wrap:wrap; }
.sh-comment-author { font-size:12px; font-weight:700; color:var(--t1); }
.sh-comment-body { font-size:13px; color:var(--t2); line-height:1.6; }
.sh-reply-inp { flex:1; background:transparent; border:none; color:var(--t1); font-size:13px; font-family:'DM Sans',sans-serif; outline:none; resize:none; min-height:34px; }
.sh-breadcrumb { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--t3); margin-bottom:13px; flex-wrap:wrap; }
.sh-breadcrumb a { color:var(--t3); }
.sh-breadcrumb a:hover { color:var(--p2); }

/* PROFILE */
.sh-profile-header { background:var(--bg2); border:1px solid var(--border); border-radius:16px; overflow:hidden; margin-bottom:14px; }
.sh-profile-cover { height:72px; background:linear-gradient(135deg,rgba(123,47,255,0.4),rgba(0,212,255,0.22)); }
.sh-profile-info { display:flex; align-items:flex-start; gap:13px; padding:0 16px 16px; flex-wrap:wrap; }
.sh-profile-ava { width:64px; height:64px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:26px; font-weight:800; color:#fff; margin-top:-26px; border:3px solid var(--bg2); flex-shrink:0; font-family:'Syne',sans-serif; overflow:hidden; }
.sh-profile-name { font-family:'Syne',sans-serif; font-size:18px; font-weight:800; margin-bottom:3px; display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.sh-profile-handle { font-size:12px; color:var(--t3); margin-bottom:7px; }
.sh-profile-stats { display:flex; gap:16px; }
.sh-pstat { font-size:12px; color:var(--t3); display:flex; flex-direction:column; gap:1px; }
.sh-pstat span { font-size:15px; font-weight:800; color:var(--t1); font-family:'Syne',sans-serif; }

/* EMPTY STATE */
.sh-empty { text-align:center; padding:48px 20px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); }
.sh-empty-ico { font-size:42px; margin-bottom:13px; }
.sh-empty h3 { font-family:'Syne',sans-serif; font-size:18px; margin-bottom:6px; }
.sh-empty p { color:var(--t2); font-size:13px; margin-bottom:16px; }

/* PAGINATION */
.sh-pagination { margin-top:20px; display:flex; justify-content:center; }
.sh-pagination .page-numbers { display:flex; gap:4px; list-style:none; flex-wrap:wrap; justify-content:center; }
.sh-pagination .page-numbers li a,
.sh-pagination .page-numbers li span { padding:7px 12px; border-radius:8px; font-size:13px; font-weight:600; background:var(--bg2); border:1px solid var(--border); color:var(--t2); display:block; transition:all .2s; }
.sh-pagination .page-numbers li a:hover { border-color:var(--p2); color:var(--t1); }
.sh-pagination .page-numbers li span.current { background:var(--grad); color:#fff; border-color:transparent; }

/* FOOTER */
.sh-footer { background:var(--bg1); border-top:1px solid var(--border); margin-top:40px; position:relative; z-index:1; }
.sh-footer-inner { max-width:1200px; margin:0 auto; padding:36px 16px 24px; display:grid; grid-template-columns:1fr 2fr; gap:36px; }
.sh-footer-brand p { font-size:13px; color:var(--t2); line-height:1.6; margin-top:8px; max-width:250px; }
.sh-footer-socials { display:flex; gap:11px; margin-top:13px; }
.sh-footer-socials a { font-size:17px; transition:transform .2s; }
.sh-footer-socials a:hover { transform:scale(1.2); }
.sh-footer-links { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.sh-footer-col h4 { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--t3); margin-bottom:10px; }
.sh-footer-col a { display:block; font-size:13px; color:var(--t2); padding:3px 0; transition:color .15s; }
.sh-footer-col a:hover { color:var(--p2); }
.sh-footer-bottom { border-top:1px solid var(--border); padding:13px 16px; text-align:center; font-size:12px; color:var(--t3); }

/* TOAST */
#sh-toast { position:fixed; bottom:22px; left:50%; transform:translateX(-50%) translateY(60px); background:var(--bg2); border:1px solid var(--bord2); color:var(--t1); padding:11px 20px; border-radius:11px; font-size:13px; font-weight:600; z-index:9999; transition:transform .3s,opacity .3s; opacity:0; pointer-events:none; box-shadow:var(--glow); white-space:nowrap; max-width:90vw; text-align:center; }
#sh-toast.show { transform:translateX(-50%) translateY(0); opacity:1; }

/* ANIMATIONS */
@keyframes shFadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

/* ===================== RESPONSIVE ===================== */
@media (max-width:1100px) {
  .sh-layout { grid-template-columns:190px 1fr 245px; gap:12px; }
}
@media (max-width:860px) {
  .sh-layout { grid-template-columns:1fr; }
  .sh-sidebar-l {
    position:fixed; left:-248px; top:var(--nav-h); bottom:0; width:248px;
    background:var(--bg1); border-right:1px solid var(--border);
    z-index:160; padding:12px 8px; transition:left .28s ease;
    max-height:calc(100vh - var(--nav-h)); overflow-y:auto;
  }
  .sh-sidebar-l.open { left:0; }
  .sh-sidebar-r { position:static; max-height:none; }
  .sh-ham { display:flex; }
  .sh-nav-search { max-width:180px; }
  .sh-nav-tabs { display:none; }
  .sh-theme-toggle { display:none; }
  .sh-footer-inner { grid-template-columns:1fr; gap:24px; }
  .sh-footer-links { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px) {
  .sh-layout { padding:10px 8px 40px; }
  .sh-hero { flex-direction:column; gap:11px; padding:14px; }
  .sh-hero-actions { margin-left:0; }
  .sh-nav-right .sh-btn-ghost { display:none; }
  .sh-single-title { font-size:18px; }
  .sh-card-title { font-size:14px; }
  .sh-blog-card { flex-direction:column; }
  .sh-blog-thumb { width:100%; height:140px; }
  .sh-embed-wrap { padding-bottom:58%; }
  .sh-notif-drop { width:calc(100vw - 20px); right:-50px; }
  .sh-modal-box { padding:16px; }
  .sh-footer-links { grid-template-columns:1fr; }
  .sh-post-img { max-height:240px; }
  /* Hide less critical elements on tiny screens */
  .sh-ai-btn { display:none; }
}
@media (max-width:380px) {
  .sh-nav-search { display:none; }
  .sh-nav-tabs { display:none; }
}

/* ===================== FEED EMBED / CLICK TO PLAY ===================== */
.sh-feed-embed:hover .sh-play-btn { background:rgba(123,47,255,1) !important; transform:translate(-50%,-50%) scale(1.1) !important; }
.sh-feed-embed iframe { position:absolute; inset:0; width:100%; height:100%; border:none; border-radius:10px; }
.sh-post-embed-wrap { position:relative; width:100%; padding-bottom:56.25%; border-radius:10px; overflow:hidden; background:#000; margin-bottom:14px; }
.sh-post-embed-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
