/* ============================================================
   SpillHour v2.0 — Full Stylesheet
   PHP 7.4+ | WordPress 6.x compatible
   ============================================================ */

: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 40px rgba(123,47,255,0.22);
  --r:      14px;
  --nav-h:  58px;
}

/* LIGHT THEME */
[data-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.3);
  --t1:#180A3C; --t2:#4A3A6A; --t3:#8A7AAA;
}
[data-theme="light"] .sh-nav { background:rgba(240,238,255,0.96); }
[data-theme="light"] .sh-card,
[data-theme="light"] .sh-qa-card,
[data-theme="light"] .sh-widget { background:#fff; box-shadow:0 1px 8px rgba(123,47,255,0.08); }

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

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 600px 400px at 15% 10%,rgba(123,47,255,0.07),transparent 70%),
             radial-gradient(ellipse 400px 300px at 90% 85%,rgba(0,212,255,0.05),transparent 70%);
}

a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:'DM Sans',sans-serif; }
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; }

/* ===================== LOGO ===================== */
.sh-logo { display:flex; align-items:center; font-family:'Syne',sans-serif; font-size:21px; font-weight:800; letter-spacing:-0.8px; flex-shrink:0; }
.sh-logo-spill { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sh-logo-hour  { color:var(--t1); }
[data-theme="light"] .sh-logo-hour { color:#180A3C; }

/* ===================== STICKY NAV — FIXED POSITION ===================== */
.sh-nav {
  position:fixed;           /* FIXED — never moves */
  top:0; left:0; right:0;
  z-index:999;
  height:var(--nav-h);
  background:rgba(7,7,26,0.97);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 20px rgba(0,0,0,0.3);
}
.sh-nav-inner {
  max-width:1200px; margin:0 auto; height:100%;
  padding:0 16px; display:flex; align-items:center; gap:10px;
}

/* Push all content below fixed nav */
.sh-site-wrapper { padding-top:var(--nav-h); }

.sh-nav-search { flex:1; max-width:320px; position:relative; }
.sh-nav-search form { position:relative; }
.sh-search-icon { position:absolute; left:11px; top:50%; transform:translateY(-50%); color:var(--t3); z-index:1; display:flex; }
.sh-search-inp {
  width:100%; background:var(--bg2); border:1px solid var(--border);
  color:var(--t1); padding:8px 12px 8px 34px; 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); box-shadow:0 0 0 3px rgba(123,47,255,0.12); }
.sh-search-inp::placeholder { color:var(--t3); }

.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); transition:all .2s; white-space:nowrap; display:flex; align-items:center; gap:4px; }
.sh-nav-tab span { display:none; }
.sh-nav-tab:hover { color:var(--t1); background:var(--s1); }
.sh-nav-tab.active { background:var(--grad); color:#fff; }

.sh-nav-right { margin-left:auto; display:flex; align-items:center; gap:8px; }

/* ===================== 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;
}
.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; transition:opacity .2s; }
.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-theme-opt { padding:5px 8px; border-radius:7px; font-size:12px; cursor:pointer; border:none; background:transparent; color:var(--t3); transition:all .2s; }
.sh-theme-opt:hover { color:var(--t1); }
.sh-theme-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:36px; height:36px; border-radius:9px; display:flex; align-items:center; justify-content:center; position:relative; transition:border-color .2s; }
.sh-notif-btn:hover { border-color:var(--p2); }
.sh-notif-badge { position:absolute; top:-5px; right:-5px; background:var(--red); color:#fff; border-radius:20px; font-size:9px; font-weight:800; padding:1px 5px; min-width:16px; text-align:center; }
.sh-notif-dropdown { display:none; position:absolute; right:0; top:calc(100% + 8px); width:300px; background:var(--bg2); border:1px solid var(--bord2); border-radius:14px; box-shadow:var(--glow); z-index:400; overflow:hidden; }
.sh-notif-wrap.open .sh-notif-dropdown { display:block; animation:fadeUp .2s ease; }
.sh-notif-head { display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid var(--border); font-size:13px; }
.sh-notif-mark-read { font-size:11px; color:var(--p2); background:transparent; border:none; cursor:pointer; }
.sh-notif-item { display:flex; gap:9px; padding:11px 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-icon { font-size:17px; flex-shrink:0; margin-top:1px; }
.sh-notif-text { flex:1; font-size:12.5px; color:var(--t2); line-height:1.45; }
.sh-notif-time { font-size:11px; color:var(--t3); margin-top:2px; }
.sh-notif-empty { padding:20px; 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:5px 10px 5px 5px; border-radius:10px; font-size:13px; font-weight:600; transition:border-color .2s; }
.sh-user-btn:hover { border-color:var(--p2); }
.sh-ava-sm { width:26px; height:26px; border-radius:7px; font-size:11px; }
.sh-user-name { max-width:80px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sh-dropdown { display:none; position:absolute; right:0; top:calc(100% + 8px); min-width:190px; background:var(--bg2); border:1px solid var(--bord2); border-radius:12px; padding:5px; box-shadow:var(--glow); z-index:400; }
.sh-user-menu.open .sh-dropdown { display:block; animation:fadeUp .2s ease; }
.sh-dropdown a { display:flex; align-items:center; gap:8px; padding:9px 12px; border-radius:8px; font-size:13px; color:var(--t2); transition:all .15s; }
.sh-dropdown a:hover { background:var(--s1); color:var(--t1); }
.sh-dropdown-divider { height:1px; background:var(--border); margin:4px 8px; }

/* ===================== HAMBURGER ===================== */
.sh-hamburger { display:none; flex-direction:column; gap:5px; background:transparent; border:1px solid var(--border); padding:7px 8px; border-radius:8px; }
.sh-hamburger span { width:18px; height:2px; background:var(--t2); border-radius:2px; transition:all .25s; display:block; }
.sh-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.sh-hamburger.open span:nth-child(2) { opacity:0; }
.sh-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.sh-mobile-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:150; }
.sh-mobile-overlay.open { display:block; }

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

/* ===================== SIDEBARS ===================== */
.sh-sidebar-left {
  position:sticky; top:calc(var(--nav-h) + 16px);
  align-self:start; max-height:calc(100vh - var(--nav-h) - 32px);
  overflow-y:auto; display:flex; flex-direction:column; gap:2px;
  scrollbar-width:none;
}
.sh-sidebar-left::-webkit-scrollbar { display:none; }

.sl-label { font-size:10px; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; color:var(--t3); padding:10px 10px 4px; }
.sl-item { display:flex; align-items:center; gap:8px; padding:9px 10px; border-radius:10px; font-size:13px; font-weight:500; color:var(--t2); transition:all .15s; }
.sl-item:hover { background:var(--bg2); color:var(--t1); }
.sl-item.active { background:rgba(123,47,255,0.18); color:var(--p2); font-weight:600; }
.sl-item .ico { font-size:15px; width:20px; text-align:center; flex-shrink:0; }
.sl-badge { margin-left:auto; font-size:10px; font-weight:700; padding:2px 7px; border-radius:20px; background:var(--s1); color:var(--t3); }
.sl-item.active .sl-badge { background:rgba(123,47,255,0.3); color:var(--p2); }
.sl-divider { height:1px; background:var(--border); margin:5px 10px; }

.sh-sidebar-right { position:sticky; top:calc(var(--nav-h) + 16px); align-self:start; max-height:calc(100vh - var(--nav-h) - 32px); overflow-y:auto; display:flex; flex-direction:column; gap:12px; scrollbar-width:none; }
.sh-sidebar-right::-webkit-scrollbar { display:none; }

/* ===================== WIDGETS ===================== */
.sh-widget { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:15px; }
.sh-widget-head { font-family:'Syne',sans-serif; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:var(--t3); margin-bottom:12px; display:flex; align-items:center; gap:5px; }
.sh-grad-text { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sh-widget-empty { font-size:13px; color:var(--t3); padding:4px 0; }

/* ===================== HERO ===================== */
.sh-hero { background:linear-gradient(135deg,rgba(123,47,255,0.14),rgba(0,212,255,0.07)); border:1px solid var(--bord2); border-radius:18px; padding:20px 22px; margin-bottom:16px; display:flex; align-items:center; gap:16px; position:relative; overflow:hidden; }
.sh-hero::after { content:''; position:absolute; right:-30px; top:-30px; width:180px; height:180px; 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:20px; font-weight:800; margin-bottom:5px; line-height:1.25; }
.sh-hero-txt p { font-size:13px; color:var(--t2); line-height:1.55; max-width:360px; }
.sh-hero-actions { margin-left:auto; display:flex; gap:8px; flex-shrink:0; flex-wrap:wrap; }

/* ===================== COMPOSE ===================== */
.sh-compose { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:11px 13px; display:flex; align-items:center; gap:9px; margin-bottom:13px; transition:border-color .2s; cursor:text; }
.sh-compose:focus-within { border-color:var(--p2); }
.sh-ava { width:34px; height:34px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:800; flex-shrink:0; font-family:'Syne',sans-serif; color:#fff; }
.sh-ava-grad { background:var(--grad); }
.sh-compose-inp { flex:1; background:transparent; border:none; color:var(--t1); font-size:13.5px; font-family:'DM Sans',sans-serif; outline:none; }
.sh-compose-inp::placeholder { color:var(--t3); }

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

/* ===================== SECTION LABEL ===================== */
.sh-sec-label { display:flex; align-items:center; gap:10px; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--t3); margin-bottom:11px; }
.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:15px; margin-bottom:9px; transition:border-color .2s,box-shadow .2s,transform .15s; animation:fadeUp .35s ease both; }
.sh-card:hover { border-color:var(--p2); box-shadow:var(--glow); transform:translateY(-2px); }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

.sh-card-meta { display:flex; align-items:center; gap:8px; margin-bottom:9px; }
.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:12.5px; font-weight:700; color:var(--t1); }
.sh-meta-user a:hover { color:var(--p2); }
.sh-meta-com { font-size:11px; color:var(--p2); font-weight:500; }
.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.38; margin-bottom:7px; }
.sh-card-title a:hover { color:var(--p2); }
.sh-card-body { font-size:13px; color:var(--t2); line-height:1.65; margin-bottom:9px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sh-card-tags { display:flex; gap:5px; flex-wrap:wrap; margin-bottom:10px; }
.sh-tag { background:rgba(123,47,255,0.12); color:var(--p2); border:1px solid rgba(123,47,255,0.2); padding:2px 9px; border-radius:20px; font-size:11px; font-weight:600; transition:background .15s; }
.sh-tag:hover { background:rgba(123,47,255,0.22); }
.sh-tag.cyan  { background:rgba(0,212,255,0.09); color:var(--cyan); border-color:rgba(0,212,255,0.18); }
.sh-tag.green { background:rgba(0,229,160,0.09); color:var(--green); border-color:rgba(0,229,160,0.18); }

.sh-card-footer { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.sh-vote-wrap { display:flex; align-items:center; gap:1px; background:var(--bg3); border:1px solid var(--border); border-radius:9px; padding:2px; }
.sh-vote-btn { width:26px; height:26px; border:none; background:transparent; color:var(--t3); font-size:11px; border-radius:7px; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.sh-vote-btn:hover { background:rgba(123,47,255,0.18); color:var(--p2); }
.sh-vote-btn.up.voted { background:rgba(123,47,255,0.22); color:var(--p2); }
.sh-vote-btn.down.voted { background:rgba(255,71,87,0.18); color:var(--red); }
.sh-vote-count { font-size:12px; font-weight:800; color:var(--t1); padding:0 6px; 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:12px; padding:4px 9px; border-radius:8px; transition:all .15s; }
.sh-act-btn:hover { color:var(--t1); border-color:var(--p2); }
.sh-ai-pill { display:flex; align-items:center; gap:3px; margin-left:auto; background:linear-gradient(90deg,rgba(123,47,255,0.15),rgba(0,212,255,0.1)); border:1px solid rgba(0,212,255,0.22); color:var(--cyan); font-size:11px; font-weight:700; padding:3px 9px; border-radius:20px; transition:all .2s; }
.sh-ai-pill:hover { background:linear-gradient(90deg,rgba(123,47,255,0.28),rgba(0,212,255,0.2)); }
.sh-anon-indicator { display:flex; align-items:center; gap:4px; background:rgba(0,229,160,0.09); border:1px solid rgba(0,229,160,0.18); color:var(--green); font-size:11px; font-weight:700; padding:2px 9px; border-radius:20px; }
.sh-report-btn { font-size:11px; color:var(--t3); background:transparent; border:none; padding:4px 7px; border-radius:6px; transition:color .15s; }
.sh-report-btn:hover { color:var(--red); }
.sh-share-wa { background:rgba(37,211,102,0.1)!important; color:#25D366!important; border-color:rgba(37,211,102,0.22)!important; }
.sh-share-wa:hover { background:rgba(37,211,102,0.2)!important; }

/* ===================== Q&A CARD ===================== */
.sh-qa-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:15px; margin-bottom:9px; cursor:pointer; transition:border-color .2s,box-shadow .2s,transform .15s; animation:fadeUp .35s ease both; }
.sh-qa-card:hover { border-color:var(--cyan); box-shadow:0 0 32px rgba(0,212,255,0.12); transform:translateY(-2px); }
.sh-qa-q { font-family:'Syne',sans-serif; font-size:15px; font-weight:700; line-height:1.38; margin-bottom:9px; }
.sh-qa-q-mark { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-weight:800; margin-right:4px; }
.sh-qa-answer-box { background:var(--bg3); border-radius:10px; padding:10px 13px; margin-bottom:9px; border-left:3px solid var(--cyan); }
.sh-qa-ans-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.9px; color:var(--cyan); margin-bottom:4px; }
.sh-qa-ans-text { font-size:13px; color:var(--t2); line-height:1.6; }
.sh-qa-footer { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.sh-qa-stat { font-size:12px; color:var(--t3); }
.sh-badge-answered { margin-left:auto; background:rgba(0,229,160,0.1); color:var(--green); border:1px solid rgba(0,229,160,0.22); font-size:11px; font-weight:700; padding:2px 10px; border-radius:20px; }
.sh-badge-pending { margin-left:auto; background:rgba(255,184,0,0.1); color:var(--amber); border:1px solid rgba(255,184,0,0.22); font-size:11px; font-weight:700; padding:2px 10px; border-radius:20px; }

/* ===================== BLOG CARD ===================== */
.sh-blog-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; margin-bottom:9px; display:flex; transition:border-color .2s,transform .15s; animation:fadeUp .35s ease both; }
.sh-blog-card:hover { border-color:var(--p2); transform:translateY(-2px); box-shadow:var(--glow); }
.sh-blog-thumb { width:150px; min-height:110px; 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.05); }
.sh-blog-content { padding:14px; 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.55; flex:1; margin-bottom:9px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sh-blog-footer { display:flex; align-items:center; gap:7px; }
.sh-read-more { font-size:12px; font-weight:700; color:var(--p2); margin-left:auto; transition:color .15s; }
.sh-read-more:hover { color:var(--cyan); }
.sh-read-time { font-size:11px; color:var(--t3); }

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

/* ===================== SPILL SCORE WIDGET ===================== */
.sh-ss-head { display:flex; align-items:center; gap:10px; margin-bottom:13px; }
.sh-ss-ava { width:42px; height:42px; border-radius:12px; font-size:17px; }
.sh-ss-name { font-size:14px; font-weight:700; }
.sh-ss-handle { font-size:11.5px; color:var(--t3); }
.sh-ss-bar-row { display:flex; justify-content:space-between; font-size:12px; margin-bottom:4px; }
.sh-ss-bar-row span:last-child { color:var(--p2); font-weight:700; }
.sh-ss-track { background:var(--bg3); border-radius:20px; height:5px; 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:5px; flex-wrap:wrap; }
.sh-ss-badge { background:var(--bg3); border:1px solid var(--border); border-radius:7px; padding:3px 8px; font-size:11px; color:var(--t2); }

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

/* ===================== BRANDED NATIVE ADS ===================== */
/* Ads look like premium SpillHour content — not jarring banners */
.sh-ad-unit {
  background:var(--bg2);
  border:1px solid var(--border);
  border-left:3px solid var(--p);
  border-radius:var(--r);
  padding:14px 16px;
  margin:8px 0;
  position:relative;
  animation:fadeUp .35s ease both;
}
.sh-ad-label {
  position:absolute; top:10px; right:12px;
  font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  color:var(--t3); background:var(--bg3); padding:2px 8px; border-radius:20px;
  border:1px solid var(--border);
}
.sh-ad-inner { padding-right:60px; }
.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:10px; }
.sh-ad-cta   { display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:700; color:var(--p2); transition:color .15s; }
.sh-ad-cta:hover { color:var(--cyan); }
.sh-ad-placeholder { display:flex; align-items:center; justify-content:space-between; padding:4px 0; }
.sh-ad-placeholder span { font-size:13px; color:var(--t2); font-weight:600; }
.sh-ad-placeholder a { font-size:12px; color:var(--p2); font-weight:700; transition:color .15s; }
.sh-ad-placeholder a:hover { color:var(--cyan); }
/* AdSense wrapper keeps native feel */
.sh-ad-adsense .adsbygoogle { border-radius:10px; overflow:hidden; }

/* ===================== LEADERBOARD ===================== */
.sh-leaderboard-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:18px; padding:20px; }
.sh-lb-tabs { display:flex; gap:3px; background:var(--bg3); border-radius:10px; padding:3px; margin-bottom:18px; }
.sh-lb-tab { flex:1; text-align:center; padding:7px; border-radius:8px; font-size:12px; font-weight:700; cursor:pointer; border:none; background:transparent; color:var(--t3); transition:all .2s; font-family:'DM Sans',sans-serif; }
.sh-lb-tab.active { background:var(--grad); color:#fff; }
.sh-lb-row { display:flex; align-items:center; gap:12px; padding:11px 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:30px; text-align:center; flex-shrink:0; }
.sh-lb-rank-1 { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sh-lb-rank-2 { color:#C0C0C0; }
.sh-lb-rank-3 { color:#CD7F32; }
.sh-lb-ava { width:38px; height:38px; border-radius:11px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:800; color:#fff; font-family:'Syne',sans-serif; }
.sh-lb-info { flex:1; }
.sh-lb-name { font-size:13.5px; font-weight:700; color:var(--t1); display:flex; align-items:center; gap:5px; }
.sh-lb-level { font-size:11px; color:var(--t3); }
.sh-lb-score { text-align:right; flex-shrink:0; }
.sh-lb-score-val { 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-score-lbl { font-size:10px; color:var(--t3); text-transform:uppercase; letter-spacing:.8px; }
.sh-lb-badges { display:flex; gap:3px; flex-wrap:wrap; margin-top:3px; }
.sh-lb-badge { font-size:13px; }

/* ===================== AI SEEDS CARD ===================== */
.sh-ai-seed-card { background:linear-gradient(135deg,rgba(123,47,255,0.1),rgba(0,212,255,0.07)); border:1px solid rgba(123,47,255,0.28); border-radius:var(--r); padding:14px; margin-bottom:9px; animation:fadeUp .35s ease both; }
.sh-ai-seed-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--p2); margin-bottom:8px; display:flex; align-items:center; gap:5px; }
.sh-ai-seed-q { font-family:'Syne',sans-serif; font-size:14.5px; font-weight:700; color:var(--t1); margin-bottom:9px; line-height:1.38; }

/* ===================== MODALS ===================== */
.sh-modal { display:none; position:fixed; inset:0; z-index:500; background:rgba(7,7,26,0.88); backdrop-filter:blur(8px); align-items:center; justify-content:center; padding:16px; }
.sh-modal.open { display:flex; }
.sh-modal-box { background:var(--bg2); border:1px solid var(--bord2); border-radius:20px; padding:22px; max-width:520px; width:100%; box-shadow:var(--glow); animation:fadeUp .3s ease; max-height:90vh; overflow-y:auto; }
.sh-modal-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.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:30px; height:30px; border-radius:8px; font-size:14px; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.sh-modal-close:hover { color:var(--t1); border-color:var(--p2); }

/* FORM ELEMENTS */
.sh-form-title { background:var(--bg3); border:1px solid var(--border); color:var(--t1); padding:11px 13px; border-radius:10px; font-size:15px; font-weight:600; font-family:'Syne',sans-serif; outline:none; transition:border-color .2s; width:100%; margin-bottom:9px; }
.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 { background:var(--bg3); border:1px solid var(--border); color:var(--t1); padding:11px 13px; border-radius:10px; font-size:13px; font-family:'DM Sans',sans-serif; outline:none; resize:vertical; transition:border-color .2s; width:100%; margin-bottom:9px; }
.sh-form-body:focus { border-color:var(--p2); }
.sh-form-body::placeholder { color:var(--t3); }
.sh-form-select { background:var(--bg3); border:1px solid var(--border); color:var(--t2); padding:9px 12px; border-radius:9px; font-size:13px; font-family:'DM Sans',sans-serif; outline:none; width:100%; margin-bottom:9px; }
.sh-form-row { display:flex; gap:8px; margin-bottom:9px; }
.sh-form-row .sh-form-select { flex:1; margin-bottom:0; }
.sh-anon-check { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--t2); cursor:pointer; padding:8px 0; }
.sh-anon-check input { accent-color:var(--p); width:15px; height:15px; }
.sh-media-toolbar { display:flex; gap:5px; flex-wrap:wrap; padding:8px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:10px; }
.sh-media-btn { display:flex; align-items:center; gap:4px; background:var(--bg3); border:1px solid var(--border); color:var(--t2); padding:6px 11px; border-radius:8px; font-size:12px; font-weight:600; transition:all .2s; }
.sh-media-btn:hover { border-color:var(--p2); color:var(--t1); }
.sh-media-btn.active { background:rgba(123,47,255,0.18); border-color:var(--p2); color:var(--p2); }
.sh-form-submit { width:100%; padding:12px; font-size:14px; margin-top:4px; }
.sh-char-count { font-size:11px; color:var(--t3); text-align:right; margin:-6px 0 8px; }

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

/* ===================== SINGLE POST ===================== */
.sh-single-post { background:var(--bg2); border:1px solid var(--border); border-radius:18px; padding:22px; margin-bottom:18px; }
.sh-single-title { font-family:'Syne',sans-serif; font-size:22px; font-weight:800; line-height:1.28; margin-bottom:14px; }
.sh-single-body { font-size:15px; color:var(--t2); line-height:1.8; margin-bottom:14px; }
.sh-single-body p { margin-bottom:12px; }
.sh-single-actions { display:flex; align-items:center; gap:7px; flex-wrap:wrap; padding-top:14px; border-top:1px solid var(--border); }
.sh-comments-section { background:var(--bg2); border:1px solid var(--border); border-radius:18px; padding:18px; }
.sh-comment { background:var(--bg3); border-radius:12px; padding:13px; margin-bottom:9px; border:1px solid rgba(255,255,255,0.04); }
.sh-comment-top { border-color:rgba(0,212,255,0.22); }
.sh-comment-meta { display:flex; align-items:center; gap:8px; margin-bottom:9px; flex-wrap:wrap; }
.sh-comment-author { font-size:12.5px; font-weight:700; color:var(--t1); }
.sh-comment-body { font-size:13.5px; color:var(--t2); line-height:1.65; }
.sh-comment-footer { display:flex; gap:8px; margin-top:9px; padding-top:8px; border-top:1px solid rgba(255,255,255,0.04); }
.sh-reply-inp { flex:1; background:transparent; border:none; color:var(--t1); font-size:13px; font-family:'DM Sans',sans-serif; outline:none; resize:vertical; min-height:36px; }

/* ===================== EMPTY STATE ===================== */
.sh-empty-state { text-align:center; padding:50px 20px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); }
.sh-empty-icon { font-size:44px; margin-bottom:14px; }
.sh-empty-state h3 { font-family:'Syne',sans-serif; font-size:18px; margin-bottom:7px; }
.sh-empty-state p { color:var(--t2); margin-bottom:18px; font-size:13.5px; }

/* ===================== PAGINATION ===================== */
.sh-pagination { margin-top:22px; 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:8px 13px; border-radius:9px; font-size:13px; font-weight:600; background:var(--bg2); border:1px solid var(--border); color:var(--t2); transition:all .2s; display:block; }
.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; }

/* ===================== EMBED / MEDIA ===================== */
.sh-post-media { margin:11px 0; border-radius:12px; overflow:hidden; }
.sh-post-img { width:100%; border-radius:12px; max-height:380px; object-fit:cover; }
.sh-post-gif { width:100%; border-radius:12px; max-height:280px; object-fit:contain; background:var(--bg3); }
.sh-embed-wrap { position:relative; width:100%; padding-bottom:56.25%; border-radius:12px; overflow:hidden; background:var(--bg3); margin:8px 0; }
.sh-embed-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.sh-embed-responsive { position:relative; padding-bottom:56.25%; border-radius:12px; overflow:hidden; }
.sh-embed-responsive iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.sh-embed-link { display:flex; align-items:center; justify-content:center; padding:18px; color:var(--p2); font-weight:600; font-size:14px; position:absolute; inset:0; }

/* ===================== BREADCRUMB ===================== */
.sh-breadcrumb { display:flex; align-items:center; gap:7px; font-size:12px; color:var(--t3); margin-bottom:14px; flex-wrap:wrap; }
.sh-breadcrumb a { color:var(--t3); transition:color .15s; }
.sh-breadcrumb a:hover { color:var(--p2); }

/* ===================== QUOTE EMBED ===================== */
.sh-quote-embed { display:block; background:var(--bg3); border:1px solid var(--border); border-left:3px solid var(--p2); border-radius:10px; padding:11px 13px; margin-bottom:11px; transition:border-color .2s; }
.sh-quote-embed:hover { border-color:var(--p2); }
.sh-quote-meta { display:flex; align-items:center; gap:6px; margin-bottom:5px; flex-wrap:wrap; }
.sh-quote-author { font-size:12px; font-weight:700; color:var(--t1); }
.sh-quote-title { font-size:13px; font-weight:700; color:var(--t1); margin-bottom:3px; }
.sh-quote-body { font-size:12px; color:var(--t2); line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ===================== PROFILE ===================== */
.sh-profile-header { background:var(--bg2); border:1px solid var(--border); border-radius:18px; overflow:hidden; margin-bottom:16px; }
.sh-profile-cover { height:75px; 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:14px; padding:0 18px 18px; flex-wrap:wrap; }
.sh-profile-ava { width:66px; height:66px; border-radius:15px; display:flex; align-items:center; justify-content:center; font-size:26px; font-weight:800; color:#fff; margin-top:-28px; border:3px solid var(--bg2); flex-shrink:0; font-family:'Syne',sans-serif; }
.sh-profile-name { font-family:'Syne',sans-serif; font-size:19px; font-weight:800; margin-bottom:3px; }
.sh-profile-handle { font-size:12px; color:var(--t3); margin-bottom:7px; }
.sh-profile-stats { display:flex; gap:18px; }
.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; }

/* ===================== 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:40px 16px 28px; display:grid; grid-template-columns:1fr 2fr; gap:40px; }
.sh-footer-brand p { font-size:13px; color:var(--t2); line-height:1.6; margin-top:9px; max-width:260px; }
.sh-footer-socials { display:flex; gap:12px; margin-top:14px; }
.sh-footer-socials a { font-size:18px; transition:transform .2s; }
.sh-footer-socials a:hover { transform:scale(1.2); }
.sh-footer-links { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.sh-footer-col h4 { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--t3); margin-bottom:11px; }
.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:14px 16px; text-align:center; font-size:12px; color:var(--t3); }

/* ===================== ANIMATIONS ===================== */
@keyframes fadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulse  { 0%,100%{opacity:1} 50%{opacity:.6} }
.sh-loading { animation:pulse 1.5s ease infinite; }

/* ===================== RESPONSIVE ===================== */
@media (max-width:1100px) {
  .sh-layout { grid-template-columns:190px 1fr 250px; gap:14px; }
}
@media (max-width:860px) {
  .sh-layout { grid-template-columns:1fr; }
  .sh-sidebar-left { position:fixed; left:-240px; top:var(--nav-h); bottom:0; width:240px; background:var(--bg1); border-right:1px solid var(--border); z-index:160; padding:14px 8px; transition:left .3s ease; overflow-y:auto; max-height:calc(100vh - var(--nav-h)); }
  .sh-sidebar-left.open { left:0; }
  .sh-sidebar-right { position:static; max-height:none; }
  .sh-hamburger { display:flex; }
  .sh-nav-search { max-width:200px; }
  .sh-nav-tab span { display:none; }
  .sh-theme-toggle { display:none; }
  .sh-footer-inner { grid-template-columns:1fr; gap:28px; }
  .sh-footer-links { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:560px) {
  .sh-hero { flex-direction:column; gap:12px; }
  .sh-hero-actions { margin-left:0; }
  .sh-nav-right .sh-btn-ghost { display:none; }
  .sh-notif-dropdown { width:calc(100vw - 24px); right:-50px; }
  .sh-blog-card { flex-direction:column; }
  .sh-blog-thumb { width:100%; height:150px; }
  .sh-embed-wrap { padding-bottom:60%; }
  .sh-single-title { font-size:18px; }
  .sh-ai-pill,.sh-card-tags { display:none; }
  .sh-footer-links { grid-template-columns:1fr; }
  .sh-leaderboard-wrap { padding:14px; }
  .sh-lb-badges { display:none; }
}
