/* ============================================================================
   The GLP Lounge — "Nightshade" Design System v1
   A dark, app-like community UI. Floating cards, pill navigation,
   speech-bubble posts. Sora (display) · Karla (text) · JetBrains Mono (data)
   NOTE: legacy variable NAMES are kept defined — inline styles in the
   generated pages reference them. Values are Nightshade.
   ============================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Karla:ital,wght@0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
    /* surfaces */
    --bg:#0E0C13;--surface:#16131D;--surface-2:#1D1926;--surface-3:#262031;
    --line:rgba(255,255,255,.07);--line-2:rgba(255,255,255,.13);
    /* type colors */
    --text:#F2EDF7;--text-2:#C3BACF;--text-3:#8D8299;--text-4:#5F5570;
    /* brand */
    --accent:#D08956;--accent-dk:#B06A3F;--accent-deep:#94572F;--accent-lt:#E5B98C;
    --violet:#9087C9;--violet-dk:#6F66A8;
    --green-600:#5FB98F;--red-600:#C9685A;--amber-600:#D6B36A;
    /* tints (dark) */
    --coral-tint:rgba(208,137,86,.12);--violet-tint:rgba(144,135,201,.12);
    --green-100:rgba(95,185,143,.14);--red-100:rgba(201,104,90,.14);--amber-100:rgba(214,179,106,.14);
    --emerald-50:rgba(95,185,143,.1);--blue-100:rgba(144,135,201,.14);--blue-50:rgba(255,255,255,.035);
    /* legacy var names referenced by generated inline styles */
    --card:#16131D;--border:rgba(255,255,255,.07);--border-lt:rgba(255,255,255,.05);--border-dk:rgba(255,255,255,.16);
    --primary:#6F66A8;--primary-dk:#262031;--primary-lt:#9087C9;
    --teal-400:#D08956;--teal-500:#B06A3F;--teal-600:#94572F;
    --slate-900:#16131D;--slate-800:#1D1926;--slate-700:#332C42;--slate-600:#5F5570;--slate-500:#8D8299;
    --slate-400:#8D8299;--slate-300:#C3BACF;--slate-200:#DCD5E5;--slate-100:#EEE9F4;--slate-50:#1D1926;
    /* depth */
    --shadow-xs:0 1px 2px rgba(0,0,0,.3);
    --shadow-sm:0 2px 8px rgba(0,0,0,.35);
    --shadow:0 8px 24px -8px rgba(0,0,0,.5);
    --shadow-md:0 14px 40px -12px rgba(0,0,0,.6);
    --shadow-lg:0 30px 80px -20px rgba(0,0,0,.75);
    --glow:0 0 0 3px rgba(208,137,86,.18);
    --glow-card:0 8px 26px -14px rgba(208,137,86,.2);
    /* geometry & motion */
    --r:8px;--r-md:10px;--r-lg:12px;
    --ease:cubic-bezier(.2,.9,.25,1);
    /* type */
    --ff:'Karla',-apple-system,'Segoe UI',sans-serif;
    --ff-display:'Sora','Segoe UI',sans-serif;
    --ff-mono:'JetBrains Mono',Consolas,monospace;
}

/* ========= BASE ========= */
*{margin:0;padding:0;box-sizing:border-box}
@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
body{
    font-family:var(--ff);color:var(--text-2);line-height:1.6;font-size:14.5px;
    -webkit-font-smoothing:antialiased;
    background-color:var(--bg);
    background-image:
        radial-gradient(900px 480px at 12% -120px,rgba(208,137,86,.07),transparent 60%),
        radial-gradient(1000px 560px at 105% 12%,rgba(111,102,168,.08),transparent 62%),
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
    background-attachment:fixed;
}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent-lt)}
img{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 22px}
::selection{background:rgba(208,137,86,.9);color:#171009}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#332C42;border:3px solid var(--bg);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:#4A4258}
html{scrollbar-color:#332C42 var(--bg);scrollbar-width:thin}
.topbar{display:none}

/* ========= HEADER (app bar) ========= */
.hdr{background:rgba(14,12,19,.82);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--line);padding:13px 0;position:relative;z-index:120}
.hdr .container{display:flex;justify-content:space-between;align-items:center;gap:18px}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0}
.logo-mark{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;
    background:linear-gradient(135deg,#D89A66,#A05A36);color:#fff;font-family:var(--ff-display);font-weight:800;font-size:14px;
    box-shadow:0 4px 18px -2px rgba(208,137,86,.5);transition:transform .3s var(--ease)}
.logo:hover .logo-mark{transform:scale(1.07) rotate(3deg)}
.logo-mark svg{width:30px;height:30px}
.logo-type{display:flex;flex-direction:column}
.logo-type h1,.logo-type .logo-name{color:#fff;font-family:var(--ff-display);font-size:19px;font-weight:700;letter-spacing:-.3px;line-height:1.1;margin:0}
.logo-type h1 span,.logo-type .logo-name span{background:linear-gradient(90deg,#D08956,#E5B98C);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--accent)}
.logo-sub,.logo-type small{display:none}
.hdr-right{display:flex;gap:8px;align-items:center}
.hdr-search{position:relative}
.hdr-search input{background:var(--surface-2);border:1px solid var(--line);color:#fff;padding:9px 14px 9px 36px;border-radius:12px;font-size:13.5px;width:220px;transition:all .3s var(--ease);outline:none;font-family:var(--ff)}
.hdr-search input::placeholder{color:var(--text-4)}
.hdr-search input:focus{border-color:rgba(208,137,86,.6);width:290px;box-shadow:var(--glow);background:var(--surface)}
.hdr-search i{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text-4);font-size:13px}
.hdr-btn{padding:9px 16px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .22s var(--ease);display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-display)}
.hdr-btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--line-2)}
.hdr-btn-ghost:hover{color:#fff;border-color:rgba(208,137,86,.5);background:var(--coral-tint)}
.hdr-btn-fill{background:linear-gradient(135deg,#D89A66,#B06A3F);color:#1A130C;box-shadow:0 6px 20px -6px rgba(208,137,86,.55)}
.hdr-btn-fill:hover{transform:translateY(-1px);box-shadow:0 9px 24px -6px rgba(208,137,86,.7);filter:brightness(1.05)}

/* ========= PILL NAV ========= */
.nav{position:sticky;top:0;z-index:110;background:rgba(14,12,19,.78);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s;padding:9px 0}
.nav.is-stuck{border-bottom-color:var(--line);box-shadow:0 14px 34px -18px rgba(0,0,0,.8)}
.nav .container{display:flex;justify-content:center}
.nav-list{display:flex;list-style:none;gap:6px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px}
.nav-list li a{display:flex;align-items:center;gap:7px;padding:7px 16px;border-radius:999px;color:var(--text-3);font-family:var(--ff-display);font-size:12.5px;font-weight:600;transition:all .2s var(--ease);white-space:nowrap}
.nav-list li a i{font-size:12px;opacity:.7;transition:opacity .2s}
.nav-list li a:hover{color:#fff;background:rgba(255,255,255,.05)}
.nav-list li a:hover i{opacity:1}
.nav-list li a.on{background:linear-gradient(135deg,rgba(208,137,86,.2),rgba(224,99,74,.16));color:var(--accent-lt);box-shadow:inset 0 0 0 1px rgba(208,137,86,.35)}
.nav-list li a.on i{opacity:1}
.nav-list li a .badge{background:var(--red-600);color:#1A0D0D;font-family:var(--ff-mono);font-size:9px;padding:1px 6px;border-radius:8px;font-weight:700}
.nav-r{display:none}
.user-menu{display:flex;align-items:center;gap:8px;padding:0 4px}
.user-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:11px;cursor:pointer;border:2px solid var(--line-2);transition:all .2s}
.user-av:hover{border-color:var(--accent);transform:scale(1.06)}
.notif-b{background:none;border:none;color:var(--text-3);font-size:15px;cursor:pointer;position:relative;padding:6px;transition:color .15s}
.notif-b:hover{color:var(--accent)}
.notif-b .dot{position:absolute;top:3px;right:3px;width:7px;height:7px;background:var(--red-600);border-radius:50%;border:1.5px solid var(--surface)}

/* ========= BREADCRUMBS ========= */
.crumbs{padding:18px 0 4px;font-family:var(--ff-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-4)}
.crumbs a{color:var(--text-4)}.crumbs a:hover{color:var(--accent)}
.crumbs .sep{margin:0 8px;color:var(--text-4);opacity:.5;font-size:9px}

/* ========= LAYOUT ========= */
.layout{display:grid;grid-template-columns:1fr 300px;gap:28px;padding:24px 0 56px}
.layout-full{padding:24px 0 56px}

/* ========= CATEGORY SECTIONS (card grid, not table) ========= */
.cat{background:transparent;border:none;box-shadow:none;margin-bottom:34px;overflow:visible}
.cat-h{border-radius:12px;padding:11px 18px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none;position:relative;margin-bottom:14px;overflow:hidden}
.cat-h::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,12,19,0) 30%,rgba(14,12,19,.45));pointer-events:none}
.cat-h h2{color:#fff;font-family:var(--ff-display);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;display:flex;align-items:center;gap:10px;position:relative;z-index:1}
.cat-h h2 i{font-size:13px;opacity:.85}
.cat-h .chv{color:rgba(255,255,255,.55);font-size:10px;transition:transform .25s var(--ease);position:relative;z-index:1}
.cat-h.shut .chv{transform:rotate(-90deg)}
.cat>div:not(.cat-h){display:grid;grid-template-columns:1fr 1fr;gap:12px}
.f-row{display:grid;grid-template-columns:46px 1fr auto;grid-auto-rows:auto;align-items:center;column-gap:14px;padding:16px 18px 14px;background:var(--surface);border:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:var(--r-lg);cursor:pointer;transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;position:relative}
.f-row:hover{transform:translateY(-3px);border-color:rgba(208,137,86,.4);box-shadow:var(--glow-card);background:var(--surface)}
.f-row:last-child{border-bottom:1px solid var(--line)}
.f-ico{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;grid-row:1/3;flex-shrink:0;transition:transform .25s var(--ease)}
.f-ico.on{background:linear-gradient(135deg,#857BC0,#5C5494);box-shadow:0 6px 16px -6px rgba(111,102,168,.6)}
.f-ico.off{background:var(--surface-3)}
.f-row:hover .f-ico{transform:scale(1.08) rotate(-3deg)}
.f-info{grid-column:2/4;padding:0}
.f-info h3{font-family:var(--ff-display);font-size:14.5px;font-weight:700;line-height:1.3}
.f-info h3 a{color:#fff}.f-info h3 a:hover,.f-row:hover .f-info h3 a{color:var(--accent-lt)}
.f-info p{color:var(--text-3);font-size:12.5px;line-height:1.5;margin-top:3px}
.f-info .subs{margin-top:6px;display:flex;flex-wrap:wrap;gap:4px}
.f-info .sub{font-family:var(--ff-mono);font-size:9px;color:var(--violet);background:var(--violet-tint);padding:2px 8px;border-radius:6px;font-weight:500}
.f-stat{text-align:left;display:inline-flex;align-items:baseline;gap:5px;grid-row:3;margin-top:12px}
.f-stat:nth-of-type(3){grid-column:2}
.f-stat:nth-of-type(4){grid-column:3;justify-self:start}
.f-stat .n{font-family:var(--ff-mono);font-weight:600;color:var(--text-2);display:inline;font-size:12.5px;font-variant-numeric:tabular-nums}
.f-stat .l{font-family:var(--ff-mono);color:var(--text-4);font-size:9px;text-transform:uppercase;letter-spacing:.1em}
.f-last{display:flex;align-items:center;gap:10px;font-size:11.5px;grid-column:1/4;border-top:1px solid var(--line);margin-top:13px;padding-top:11px}
.av-s{width:30px;height:30px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:10.5px}
.f-last-info{min-width:0}
.f-last-info .ttl{color:var(--text-2);font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;max-width:100%}
.f-last-info .mt{color:var(--text-4);font-family:var(--ff-mono);font-size:9.5px}.f-last-info .mt a{color:var(--text-3)}

/* ========= THREAD FEED (floating cards) ========= */
.tl-h{background:transparent;border:none;box-shadow:none;border-radius:0;padding:4px 2px 16px;display:flex;justify-content:space-between;align-items:center}
.tl-h h2,.tl-h h1{font-family:var(--ff-display);font-size:21px;font-weight:800;letter-spacing:-.4px;color:#fff;display:flex;align-items:center;gap:11px;margin:0}
.tl-h h2 i,.tl-h h1 i{color:var(--accent);font-size:17px}
.filters{display:flex;gap:6px}
.fb{padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--text-3);transition:all .2s var(--ease);font-family:var(--ff-display)}
.fb:hover{color:#fff;border-color:var(--line-2);background:var(--surface)}
.fb.on{background:linear-gradient(135deg,#D89A66,#B06A3F);color:#1A130C;border-color:transparent;font-weight:700}
.btn{padding:10px 19px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .22s var(--ease);display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-display)}
.btn-teal{background:linear-gradient(135deg,#D89A66,#B06A3F);color:#1A130C;box-shadow:0 6px 20px -6px rgba(208,137,86,.5)}
.btn-teal:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn-blue{background:linear-gradient(135deg,#857BC0,#5C5494);color:#fff;box-shadow:0 6px 20px -6px rgba(111,102,168,.5)}
.btn-blue:hover{transform:translateY(-1px);filter:brightness(1.07)}
.btn-ghost{background:var(--surface);color:var(--text-2);border:1px solid var(--line)}.btn-ghost:hover{border-color:var(--line-2);color:#fff}

.t-row{display:grid;grid-template-columns:42px 1fr 64px 64px 190px;align-items:center;padding:14px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:10px;cursor:pointer;transition:transform .22s var(--ease),border-color .22s,box-shadow .22s}
.t-row:hover{transform:translateY(-2px);border-color:rgba(208,137,86,.4);box-shadow:var(--glow-card);background:var(--surface)}
.t-row:last-child{border-bottom:1px solid var(--line);border-radius:var(--r-md)}
.t-row.pin{border-color:rgba(214,179,106,.4);background:linear-gradient(135deg,rgba(214,179,106,.06),var(--surface) 50%)}
.t-row.locked{opacity:.5;filter:saturate(.5)}
.t-av{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.t-av img{border-radius:12px!important}
.t-info{padding:0 14px}
.t-ttl{font-family:var(--ff-display);font-size:14px;font-weight:600;line-height:1.4;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.t-ttl a{color:#fff}.t-ttl a:hover,.t-row:hover .t-ttl a{color:var(--accent-lt)}
.pfx{font-family:var(--ff-mono);font-size:8.5px;padding:3px 8px;border-radius:7px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}
.pfx-pin{background:var(--amber-100);color:var(--amber-600)}
.pfx-hot{background:var(--red-100);color:var(--red-600)}
.pfx-new{background:var(--green-100);color:var(--green-600)}
.pfx-poll{background:var(--violet-tint);color:var(--violet)}
.pfx-guide{background:rgba(122,167,217,.14);color:#7AA7D9}
.pfx-warn{background:var(--amber-100);color:var(--amber-600)}
.pfx-review{background:rgba(201,123,164,.14);color:#C97BA4}
.pfx-solved{background:var(--green-100);color:var(--green-600)}
.pfx-study{background:var(--violet-tint);color:var(--violet)}
.t-meta{font-family:var(--ff-mono);font-size:10px;color:var(--text-4);margin-top:4px}.t-meta a{color:var(--text-3)}
.t-stat{text-align:center}
.t-stat .n{font-family:var(--ff-mono);font-weight:600;font-size:13px;display:block;color:var(--text-2);font-variant-numeric:tabular-nums}
.t-stat .l{font-family:var(--ff-mono);font-size:8.5px;color:var(--text-4);text-transform:uppercase;letter-spacing:.12em}
.t-last{display:flex;align-items:center;gap:9px}
.m-av{width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:10px;flex-shrink:0}
.m-av img{border-radius:9px!important}
.tl-i{font-size:11px}.tl-i .tm{color:var(--text-4);font-family:var(--ff-mono);font-size:9.5px}.tl-i a{color:var(--text-3);font-weight:600}

/* ========= THREAD VIEW — speech-bubble posts ========= */
.tv-h{background:linear-gradient(135deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 28px;margin-bottom:22px;position:relative;overflow:hidden;box-shadow:none}
.tv-h::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#D89A66,#B06A3F)}
.tv-h h1{font-family:var(--ff-display);font-size:22px;font-weight:800;line-height:1.35;letter-spacing:-.4px;margin-bottom:10px;color:#fff}
.tv-meta{display:flex;gap:16px;font-family:var(--ff-mono);font-size:10.5px;color:var(--text-3);flex-wrap:wrap}
.tv-meta i{margin-right:5px;color:var(--accent);opacity:.9}
.post{background:transparent;border:none;box-shadow:none;border-radius:0;margin-bottom:22px;overflow:visible}
.post:hover{box-shadow:none}
.post-g{display:block;min-height:0}
.p-auth{display:flex;align-items:center;gap:11px;background:transparent;border:none;border-right:none;padding:0 0 9px 2px;text-align:left}
.p-av{width:42px;height:42px;border-radius:10px;margin:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;box-shadow:0 4px 14px -4px rgba(0,0,0,.6);flex-shrink:0}
.p-av img{border-radius:12px!important}
.p-name{font-family:var(--ff-display);font-weight:700;font-size:13.5px;margin:0;display:inline}
.p-name a{color:#fff}.p-name a:hover{color:var(--accent-lt)}
.p-role{font-family:var(--ff-mono);font-size:8.5px;padding:3px 9px;border-radius:7px;display:inline-block;margin:0 0 0 4px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;vertical-align:1px;border:none}
.r-admin{background:var(--red-100);color:var(--red-600)}
.r-mod{background:rgba(122,167,217,.14);color:#7AA7D9}
.r-mem{background:rgba(255,255,255,.06);color:var(--text-3)}
.r-vip{background:var(--amber-100);color:var(--amber-600)}
.r-sr{background:var(--violet-tint);color:var(--violet)}
.r-new{background:var(--green-100);color:var(--green-600)}
.p-stats{display:none}
.p-online{display:inline-flex;align-items:center;gap:5px;font-family:var(--ff-mono);font-size:9px;letter-spacing:.05em;color:var(--green-600);margin:0 0 0 8px;font-weight:500}
.p-online .dot{width:6px;height:6px;border-radius:50%;background:var(--green-600);box-shadow:0 0 8px rgba(95,185,143,.6)}
.p-wrap{padding:18px 24px;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:12px;margin-left:0;position:relative}
.p-wrap::before{display:none}
.p-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:15px;font-family:var(--ff-mono);font-size:10.5px;color:var(--text-4)}
.p-head a{font-family:var(--ff-mono);color:var(--violet);background:var(--violet-tint);padding:2px 9px;border-radius:7px;transition:all .15s}
.p-head a:hover{background:var(--violet);color:#1A1430}
.p-body{flex:1;font-size:14.5px;line-height:1.75;color:var(--text-2)}
.p-body p{margin-bottom:13px}
.p-body strong{color:#fff}
.p-body blockquote{background:var(--surface-2);border-left:3px solid var(--violet);padding:13px 17px;margin:13px 0;border-radius:4px 12px 12px 4px;color:var(--text-3);font-size:13.5px}
.p-body .qa{font-family:var(--ff-mono);font-weight:600;color:var(--violet);margin-bottom:4px;font-size:10px;text-transform:uppercase;letter-spacing:.1em}
.p-body ul,.p-body ol{margin:8px 0 13px 22px;font-size:14px}.p-body li{margin-bottom:5px}
.p-body .ref{margin-top:17px;padding-top:13px;border-top:1px solid var(--line);font-size:12px;color:var(--text-3);line-height:1.9}
.p-body .ref strong{color:var(--text-2);font-size:12.5px}
.p-body .fn{font-size:10px;vertical-align:super;color:var(--violet);font-weight:600;cursor:help}
.p-body .sig{margin-top:17px;padding-top:12px;border-top:1px dashed var(--line-2);font-size:12px;color:var(--text-4);font-style:italic}
.p-body code{background:var(--surface-3);padding:2px 7px;border-radius:6px;font-family:var(--ff-mono);font-size:12px;color:var(--accent-lt)}
.p-body .data-table{width:100%;border-collapse:collapse;margin:14px 0;font-size:13px}
.p-body .data-table th{background:var(--surface-3);color:var(--text);padding:9px 12px;text-align:left;font-family:var(--ff-mono);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--line-2)}
.p-body .data-table td{padding:8px 12px;border:1px solid var(--line);font-variant-numeric:tabular-nums}
.p-body .data-table tr:nth-child(even) td{background:rgba(255,255,255,.02)}
.p-foot{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--line);margin-top:16px}
.rxns{display:flex;gap:6px;align-items:center}
.rx{padding:5px 13px;border-radius:999px;font-size:11px;cursor:pointer;border:1px solid var(--line);background:var(--surface-2);color:var(--text-3);transition:all .2s var(--ease);display:flex;align-items:center;gap:5px;font-variant-numeric:tabular-nums}
.rx:hover{border-color:rgba(208,137,86,.5);color:var(--accent-lt);transform:translateY(-1px);background:var(--surface-2)}
.rx.on{border-color:rgba(208,137,86,.5);color:var(--accent);background:var(--coral-tint)}
.pacts{display:flex;gap:3px}
.pa{padding:5px 11px;border:none;background:transparent;color:var(--text-4);font-size:11.5px;cursor:pointer;border-radius:9px;transition:all .15s;font-family:var(--ff)}
.pa:hover{background:rgba(255,255,255,.05);color:var(--accent-lt)}

/* ========= EDITOR ========= */
.editor{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;margin-bottom:22px;box-shadow:none}
.editor h3{font-family:var(--ff-display);font-size:16px;font-weight:700;color:#fff;margin-bottom:13px;display:flex;align-items:center;gap:9px}
.tb{display:flex;gap:2px;padding:7px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px 12px 0 0;border-bottom:none;flex-wrap:wrap}
.tbb{width:32px;height:30px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-3);border-radius:8px;cursor:pointer;font-size:13px;transition:all .14s}
.tbb:hover{background:var(--surface-3);color:#fff}
.ts{width:1px;background:var(--line-2);margin:4px 5px}
textarea.ta{width:100%;min-height:130px;padding:14px;border:1px solid var(--line);border-radius:0 0 12px 12px;font-family:var(--ff);font-size:13.5px;line-height:1.65;resize:vertical;outline:none;transition:all .2s;background:var(--surface-2);color:var(--text)}
textarea.ta:focus{border-color:rgba(208,137,86,.5);box-shadow:var(--glow)}
.ed-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.ed-opts{display:flex;gap:14px;font-size:12px;color:var(--text-3)}
.ed-opts label{cursor:pointer;display:flex;align-items:center;gap:4px}

/* ========= SIDEBAR ========= */
.sw{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:16px;box-shadow:none}
.sw-h{padding:13px 17px;font-family:var(--ff-display);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--text-2);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:9px;background:transparent}
.sw-h i{font-size:12px;color:var(--accent)}
.sw-b{padding:14px 17px}
.st-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.st-box{text-align:center;padding:13px 8px;background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--line);transition:all .25s var(--ease)}
.st-box:hover{transform:translateY(-2px);border-color:rgba(208,137,86,.35);box-shadow:none}
.st-box .sn{font-family:var(--ff-display);font-size:19px;font-weight:800;display:block;line-height:1.25;background:linear-gradient(90deg,#D89A66,#E5B98C);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--accent)}
.st-box .sl{font-family:var(--ff-mono);font-size:8.5px;color:var(--text-4);text-transform:uppercase;letter-spacing:.14em}
.on-list{display:flex;flex-wrap:wrap;gap:5px}
.on-tag{font-size:11px;padding:4px 10px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;color:var(--text-3);display:flex;align-items:center;gap:5px;cursor:pointer;transition:all .18s var(--ease)}
.on-tag:hover{border-color:rgba(95,185,143,.4);color:var(--green-600);transform:translateY(-1px);background:var(--surface-2)}
.on-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--green-600);box-shadow:0 0 6px rgba(95,185,143,.5)}
.ri{padding:9px 0;border-bottom:1px solid var(--line)}.ri:last-child{border-bottom:none}
.ri a{font-size:12.5px;font-weight:600;color:var(--text-2);display:block;margin-bottom:2px;line-height:1.45}.ri a:hover{color:var(--accent-lt)}
.ri .rm{font-family:var(--ff-mono);font-size:9.5px;color:var(--text-4)}
.tags{display:flex;flex-wrap:wrap;gap:5px}
.tag{font-family:var(--ff-mono);font-size:10px;padding:4px 11px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;color:var(--text-3);transition:all .18s var(--ease);cursor:pointer}
.tag:hover{border-color:rgba(144,135,201,.5);color:var(--violet);transform:translateY(-1px);background:var(--surface-2)}

/* ========= ADS ========= */
.ad{border-radius:var(--r-lg);padding:18px 22px;margin-bottom:22px;display:flex;align-items:center;gap:16px;position:relative;overflow:hidden;
    background:linear-gradient(135deg,var(--surface-2),var(--surface-3));
    border:1px solid var(--line-2);transition:all .3s var(--ease)}
.ad:hover{border-color:rgba(144,135,201,.5);transform:translateY(-2px);box-shadow:0 14px 40px -14px rgba(111,102,168,.4)}
.ad::after{content:'SPONSORED';position:absolute;top:9px;right:14px;font-family:var(--ff-mono);font-size:7.5px;color:var(--text-4);letter-spacing:.3em;font-weight:500}
.ad-ico{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;color:#fff;box-shadow:0 6px 16px -6px rgba(0,0,0,.6)}
.ad-body h4{color:#fff;font-family:var(--ff-display);font-size:13.5px;font-weight:700;margin-bottom:3px}
.ad-body p{color:var(--text-3);font-size:11.5px;line-height:1.5}
.ad-body .ad-cta{display:inline-block;margin-top:9px;padding:6px 16px;background:linear-gradient(135deg,#857BC0,#5C5494);color:#fff;border-radius:999px;font-size:11px;font-weight:700;font-family:var(--ff-display);transition:all .2s;box-shadow:none}
.ad-body .ad-cta:hover{transform:translateY(-1px);filter:brightness(1.1)}
@keyframes ad-shimmer{0%{background-position:230% 0,0 0}100%{background-position:-130% 0,0 0}}
.ad-animated{background:
    linear-gradient(105deg,transparent 42%,rgba(144,135,201,.08) 50%,transparent 58%),
    linear-gradient(135deg,var(--surface-2),var(--surface-3));
    background-size:240% 100%,auto;animation:ad-shimmer 6s ease-in-out 2}
@keyframes ad-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.03);opacity:.93}}
.ad-cta-pulse{animation:ad-pulse 2.5s ease-in-out 3}
.ad-side{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:16px;transition:all .3s var(--ease);box-shadow:none}
.ad-side:hover{border-color:rgba(144,135,201,.5);transform:translateY(-2px);box-shadow:none}
.ad-side .ad-lbl{font-family:var(--ff-mono);font-size:7.5px;color:var(--text-4);text-align:right;padding:5px 12px;letter-spacing:.28em;text-transform:uppercase}
.ad-side .ad-inner{padding:16px;text-align:center}
.ad-side .ad-inner h4{font-family:var(--ff-display);font-size:14px;font-weight:700;margin-bottom:4px}
.ad-side .ad-inner p{font-size:11.5px;color:inherit;opacity:.85;margin-bottom:10px;line-height:1.5}

/* ========= PAGINATION ========= */
.pgn{display:flex;align-items:center;gap:6px;justify-content:center;margin:26px 0}
.pg{padding:8px 13px;min-width:36px;text-align:center;border:1px solid var(--line);background:var(--surface);border-radius:11px;font-family:var(--ff-mono);font-size:12px;cursor:pointer;color:var(--text-3);transition:all .2s var(--ease);text-decoration:none}
.pg:hover{border-color:rgba(208,137,86,.5);color:var(--accent-lt);transform:translateY(-1px);box-shadow:none}
.pg.on{background:linear-gradient(135deg,#D89A66,#B06A3F);color:#1A130C;border-color:transparent;font-weight:700;box-shadow:none}

/* ========= MODALS ========= */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(5,4,8,.7);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.modal-bg.open{display:flex}
.modal{background:var(--surface-2);border-radius:14px;width:440px;max-width:94vw;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line-2)}
.modal-top{padding:19px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-top h3{font-family:var(--ff-display);font-size:17px;font-weight:700;color:#fff}
.modal-x{width:32px;height:32px;border:none;background:var(--surface-3);border-radius:50%;cursor:pointer;font-size:15px;color:var(--text-3);display:flex;align-items:center;justify-content:center;transition:all .25s var(--ease)}
.modal-x:hover{background:#332C42;color:#fff;transform:rotate(90deg)}
.modal-inner{padding:24px}
.fg{margin-bottom:15px}
.fg label{display:block;font-size:12.5px;font-weight:700;margin-bottom:6px;color:var(--text-2)}
.fi{width:100%;padding:11px 14px;border:1px solid var(--line-2);border-radius:12px;font-size:14px;font-family:var(--ff);outline:none;transition:all .2s;background:var(--surface);color:var(--text)}
.fi:focus{border-color:rgba(208,137,86,.55);box-shadow:var(--glow)}
.fg select.fi{background:var(--surface)}
.fg .err{color:var(--red-600);font-size:11px;margin-top:4px;display:none}
.btn-full{width:100%;justify-content:center;padding:12px;font-size:13.5px}

/* ========= PROFILE ========= */
.prof-banner{background:linear-gradient(120deg,var(--surface-2) 0%,#2E2138 60%,#3D2333 100%);border:1px solid var(--line-2);border-radius:14px;padding:32px;color:#fff;display:flex;align-items:center;gap:22px;margin-bottom:22px;box-shadow:none;position:relative;overflow:hidden}
.prof-banner::before{content:'';position:absolute;inset:0;pointer-events:none;
    background:radial-gradient(420px 200px at 88% -20%,rgba(208,137,86,.18) 0%,transparent 60%)}
.prof-av{width:84px;height:84px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;color:#fff;border:2px solid rgba(208,137,86,.5);box-shadow:0 0 30px rgba(208,137,86,.25);flex-shrink:0;position:relative}
.prof-av img{border-radius:24px!important}
.prof-info{position:relative}
.prof-info h2,.prof-info h1{font-family:var(--ff-display);font-size:24px;margin-bottom:5px;font-weight:800;letter-spacing:-.4px}
.prof-info .ptag{display:inline-block;padding:3px 12px;border-radius:999px;font-family:var(--ff-mono);font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--coral-tint);border:1px solid rgba(208,137,86,.35);color:var(--accent-lt);margin-bottom:8px}
.prof-stats{display:flex;gap:24px;margin-top:9px}
.ps-i{text-align:center}
.ps-i .pn{font-family:var(--ff-display);font-size:20px;font-weight:800;display:block;line-height:1.2}
.ps-i .pl{font-family:var(--ff-mono);font-size:8.5px;opacity:.6;text-transform:uppercase;letter-spacing:.16em}

/* ========= STATIC PAGES ========= */
.page-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:40px 44px;margin-bottom:22px;box-shadow:none}
.page-card h1{font-family:var(--ff-display);font-size:27px;font-weight:800;letter-spacing:-.5px;margin-bottom:10px;color:#fff}
.page-card h1::after{content:'';display:block;width:52px;height:4px;border-radius:3px;margin-top:13px;background:linear-gradient(90deg,#D89A66,#B06A3F)}
.page-card .updated{font-family:var(--ff-mono);font-size:10.5px;color:var(--text-4);margin-bottom:22px;letter-spacing:.04em}
.page-card h2{font-family:var(--ff-display);font-size:18px;font-weight:700;letter-spacing:-.2px;margin:28px 0 11px;color:#fff;padding-bottom:8px;border-bottom:1px solid var(--line)}
.page-card h3{font-family:var(--ff-display);font-size:14.5px;font-weight:700;margin:18px 0 8px;color:var(--text)}
.page-card p{font-size:14.5px;line-height:1.85;margin-bottom:13px;color:var(--text-2)}
.page-card ul,.page-card ol{margin:8px 0 15px 22px;color:var(--text-2);font-size:14.5px;line-height:1.85}
.page-card li{margin-bottom:5px}
.page-card strong{color:#fff}
.page-card .highlight{background:var(--violet-tint);border-left:3px solid var(--violet);padding:15px 19px;border-radius:4px 12px 12px 4px;margin:15px 0;font-size:13.5px;color:var(--text-2)}
.page-card .warning{background:var(--amber-100);border-left:3px solid var(--amber-600);padding:15px 19px;border-radius:4px 12px 12px 4px;margin:15px 0;font-size:13.5px;color:var(--text-2)}
.page-card table{width:100%;border-collapse:collapse;margin:15px 0;font-size:13px}
.page-card table th{background:var(--surface-3);color:var(--text);padding:10px 14px;text-align:left;font-family:var(--ff-mono);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--line-2)}
.page-card table td{padding:9px 14px;border:1px solid var(--line);font-variant-numeric:tabular-nums}
.page-card table tr:nth-child(even) td{background:rgba(255,255,255,.02)}
.page-card .ref-list{margin-top:20px;padding-top:15px;border-top:1px solid var(--line);font-size:12px;color:var(--text-3);line-height:2}
.page-card .contact-box{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:19px;margin:15px 0}

/* Dosing calc */
.calc-box{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:24px;margin:20px 0}
.calc-box label{display:block;font-size:12.5px;font-weight:700;margin-bottom:6px;color:var(--text-2)}
.calc-box input,.calc-box select{padding:11px 14px;border:1px solid var(--line-2);border-radius:11px;font-size:13.5px;font-family:var(--ff);outline:none;margin-bottom:13px;width:100%;background:var(--surface);color:var(--text);transition:all .2s}
.calc-box input:focus,.calc-box select:focus{border-color:rgba(208,137,86,.55);box-shadow:var(--glow)}
.calc-result{background:var(--coral-tint);border:1px solid rgba(208,137,86,.4);border-radius:14px;padding:17px;margin-top:15px;font-size:14px}
.calc-result strong{color:var(--accent-lt)}

/* FAQ */
.faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:10px;overflow:hidden;background:var(--surface);transition:border-color .25s;box-shadow:none}
.faq-item:hover{border-color:var(--line-2);box-shadow:none}
.faq-q{padding:15px 19px;font-family:var(--ff-display);font-weight:600;font-size:13.5px;color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:transparent;transition:background .18s}
.faq-q:hover{background:rgba(255,255,255,.03)}
.faq-q i{color:var(--text-4);font-size:12px;transition:transform .25s var(--ease)}
.faq-a{padding:0 19px;max-height:0;overflow:hidden;transition:max-height .35s var(--ease),padding .35s var(--ease);font-size:13.5px;color:var(--text-2);line-height:1.8}
.faq-item.open{border-color:rgba(208,137,86,.4)}
.faq-item.open .faq-a{max-height:600px;padding:0 19px 16px}
.faq-item.open .faq-q i{transform:rotate(180deg);color:var(--accent)}

/* ========= FOOTER (minimal, centered) ========= */
.footer{padding:46px 0 26px;margin-top:56px;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(208,137,86,.04));text-align:center;color:var(--text-3)}
.ft-logo{display:inline-flex;align-items:center;gap:10px;margin-bottom:8px}
.ft-logo .logo-mark{width:34px;height:34px;border-radius:10px}
.ft-word{font-family:var(--ff-display);font-weight:800;font-size:17px;color:#fff;letter-spacing:-.3px}
.ft-word em{font-style:normal;background:linear-gradient(90deg,#D08956,#E5B98C);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--accent)}
.ft-tag{font-family:var(--ff-mono);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--text-4);margin-bottom:22px}
.ft-links{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 22px;margin-bottom:14px}
.ft-links a{color:var(--text-3);font-size:12.5px;font-weight:600;font-family:var(--ff-display);transition:color .15s}
.ft-links a:hover{color:var(--accent-lt)}
.ft-legal{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 18px;margin-bottom:22px}
.ft-legal a{color:var(--text-4);font-size:11.5px;transition:color .15s}
.ft-legal a:hover{color:var(--text-2)}
.ft-base{font-size:11px;color:var(--text-4);border-top:1px solid var(--line);padding-top:18px;max-width:680px;margin:0 auto;line-height:1.7}
/* legacy footer markup (pages not yet regenerated keep working) */
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px;margin-bottom:28px;text-align:left}
.footer h4{color:var(--accent-lt);font-family:var(--ff-mono);font-size:10px;font-weight:600;margin-bottom:13px;text-transform:uppercase;letter-spacing:.22em}
.footer p{font-size:12.5px;line-height:1.7}
.footer ul{list-style:none}.footer ul li{margin-bottom:7px}
.footer ul li a{color:var(--text-3);font-size:12.5px}.footer ul li a:hover{color:var(--accent-lt);padding-left:0}
.footer-bottom{border-top:1px solid var(--line);padding-top:18px;display:flex;justify-content:space-between;align-items:center;font-size:11px;flex-wrap:wrap;gap:10px}
.footer-socials{display:flex;gap:12px}.footer-socials a{color:var(--text-4);font-size:16px}.footer-socials a:hover{color:var(--accent-lt);transform:none}

/* ========= AUTH MODALS ========= */
.auth-overlay{display:none;position:fixed;inset:0;background:rgba(5,4,8,.72);z-index:2000;align-items:center;justify-content:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:16px}
.auth-overlay.show{display:flex}
.auth-box{background:var(--surface-2);border:1px solid var(--line-2);border-radius:14px;width:424px;max-width:100%;box-shadow:var(--shadow-lg);overflow:hidden;animation:authIn .35s var(--ease)}
@keyframes authIn{from{opacity:0;transform:scale(.95) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
.auth-head{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.auth-head h3{font-family:var(--ff-display);font-size:17px;font-weight:700;color:#fff;display:flex;align-items:center;gap:9px}
.auth-close{width:32px;height:32px;border:none;background:var(--surface-3);border-radius:50%;cursor:pointer;font-size:16px;color:var(--text-3);display:flex;align-items:center;justify-content:center;transition:all .25s var(--ease)}
.auth-close:hover{background:#332C42;color:#fff;transform:rotate(90deg)}
.auth-body{padding:24px}
.auth-body .fg{margin-bottom:15px}
.auth-body .fg label{display:block;font-size:12.5px;font-weight:700;margin-bottom:6px;color:var(--text-2)}
.auth-body .fg input,.auth-body .fg select{width:100%;padding:11px 14px;border:1px solid var(--line-2);border-radius:12px;font-size:14px;font-family:var(--ff);outline:none;transition:all .2s;background:var(--surface);color:var(--text)}
.auth-body .fg input:focus,.auth-body .fg select:focus{border-color:rgba(208,137,86,.55);box-shadow:var(--glow)}
.auth-body .fg .hint{font-size:11px;color:var(--text-4);margin-top:4px}
.auth-body .fg .err-msg{color:var(--red-600);font-size:11.5px;margin-top:4px;display:none}
.auth-body .btn-auth{width:100%;padding:12px;font-size:14px;font-weight:700;border-radius:12px;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;gap:7px;font-family:var(--ff-display);transition:all .22s var(--ease)}
.auth-body .btn-login{background:linear-gradient(135deg,#857BC0,#5C5494);color:#fff;box-shadow:0 6px 18px -6px rgba(111,102,168,.55)}
.auth-body .btn-login:hover{transform:translateY(-1px);filter:brightness(1.08)}
.auth-body .btn-register{background:linear-gradient(135deg,#D89A66,#B06A3F);color:#1A130C;box-shadow:0 6px 18px -6px rgba(208,137,86,.55)}
.auth-body .btn-register:hover{transform:translateY(-1px);filter:brightness(1.05)}
.auth-body .auth-switch{text-align:center;margin-top:15px;font-size:12.5px;color:var(--text-3)}
.auth-body .auth-divider{text-align:center;margin:17px 0;font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-4);position:relative}
.auth-body .auth-divider::before,.auth-body .auth-divider::after{content:'';position:absolute;top:50%;width:38%;height:1px;background:var(--line)}
.auth-body .auth-divider::before{left:0}.auth-body .auth-divider::after{right:0}
#activCode{font-family:var(--ff-mono)}
.activation-step{display:none}
.activation-step.show{display:block}
.activation-step .code-sent,.code-sent{background:var(--green-100);border:1px solid rgba(95,185,143,.4);border-radius:12px;padding:14px;margin-bottom:16px;font-size:13px;color:var(--green-600);display:flex;align-items:flex-start;gap:10px}
.activation-step .code-sent i,.code-sent i{font-size:18px;margin-top:2px}

/* ========= MOBILE BOTTOM NAV ========= */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:rgba(14,12,19,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--line);z-index:200;padding:7px 0 env(safe-area-inset-bottom,7px);box-shadow:none}
.mobile-nav-inner{display:flex;justify-content:space-around;align-items:center}
.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 13px;font-family:var(--ff-mono);font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-4);text-decoration:none;transition:color .15s;border-radius:12px}
.mobile-nav a i{font-size:17px;transition:transform .2s var(--ease)}
.mobile-nav a.on{color:var(--accent)}
.mobile-nav a.on i{transform:translateY(-2px)}
.mobile-nav a:active{background:rgba(255,255,255,.05)}

/* ========= ENHANCEMENT LAYER ========= */
#ctProgress{position:fixed;top:0;left:0;height:3px;width:0;z-index:5000;border-radius:0 3px 3px 0;pointer-events:none;
    background:linear-gradient(90deg,#D89A66,#B06A3F);box-shadow:0 0 14px rgba(208,137,86,.7)}
#ctTop{position:fixed;right:22px;bottom:24px;width:44px;height:44px;border-radius:14px;background:var(--surface-2);color:var(--accent);border:1px solid rgba(208,137,86,.4);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;z-index:900;opacity:0;visibility:hidden;transform:translateY(12px);transition:all .35s var(--ease);box-shadow:var(--shadow)}
#ctTop.show{opacity:1;visibility:visible;transform:none}
#ctTop:hover{background:var(--accent-dk);color:#fff;transform:translateY(-3px)}
@media (prefers-reduced-motion:no-preference){
    .ct-pre{opacity:0;transform:translateY(18px)}
    .ct-in{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}
}

/* Mobile search overlay */
.ct-msearch{display:none}
#ctSearchOverlay{display:none;position:fixed;inset:0;z-index:2500;background:rgba(8,6,12,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:13vh 18px 0}
#ctSearchOverlay.show{display:block;animation:authIn .3s var(--ease)}
.ct-so-form{display:flex;gap:9px;align-items:center;max-width:560px;margin:0 auto}
.ct-so-box{position:relative;flex:1}
.ct-so-box i{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--text-4);font-size:14px}
.ct-so-box input{width:100%;padding:14px 16px 14px 42px;border-radius:16px;border:1px solid rgba(208,137,86,.4);background:var(--surface);color:#fff;font-size:16px;font-family:var(--ff);outline:none;transition:all .25s var(--ease)}
.ct-so-box input::placeholder{color:var(--text-4)}
.ct-so-box input:focus{border-color:var(--accent);box-shadow:var(--glow)}
.ct-so-cancel{background:none;border:none;color:var(--text-3);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--ff-display);padding:10px 4px}
.ct-so-cancel:hover{color:#fff}
.ct-so-hint{text-align:center;font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-4);margin-top:22px}
.ct-so-tags{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin:12px auto 0;max-width:560px}
.ct-so-tags span{font-family:var(--ff-mono);font-size:11px;padding:6px 14px;border-radius:999px;border:1px solid var(--line-2);color:var(--text-3);cursor:pointer;transition:all .18s var(--ease)}
.ct-so-tags span:hover{background:var(--coral-tint);color:var(--accent-lt);border-color:rgba(208,137,86,.5)}

/* ========= VISUALISATIONS (dark) ========= */
.vz-spark{margin-top:12px;padding:11px 13px 9px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md)}
.vz-spark svg{display:block;width:100%;height:44px}
@media (prefers-reduced-motion:no-preference){
    .vz-spark-line{stroke-dasharray:600;stroke-dashoffset:600;animation:vzDraw 1.6s var(--ease) .3s forwards}
    @keyframes vzDraw{to{stroke-dashoffset:0}}
}
.vz-spark-lbl{display:flex;justify-content:space-between;align-items:center;margin-top:7px;font-family:var(--ff-mono);font-size:8.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-4)}
.vz-spark-lbl .vz-up{color:var(--green-600);font-weight:600}
.vz-heatcard{margin-bottom:16px}
.vz-heat{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,11px);grid-auto-columns:11px;gap:3px;justify-content:center;padding:4px 0}
.vz-heat i,.vz-heat-key i{display:block;width:11px;height:11px;border-radius:3px}
.vz-heat .l0,.vz-heat-key .l0{background:var(--surface-3)}
.vz-heat .l1,.vz-heat-key .l1{background:#3A2E26}
.vz-heat .l2,.vz-heat-key .l2{background:#6B4A36}
.vz-heat .l3,.vz-heat-key .l3{background:#A8744E}
.vz-heat .l4,.vz-heat-key .l4{background:#D08956}
.vz-heat i{transition:transform .15s var(--ease)}
.vz-heat i:hover{transform:scale(1.35)}
.vz-heat-key{display:flex;align-items:center;gap:4px;justify-content:flex-end;margin-top:9px;font-family:var(--ff-mono);font-size:9px;color:var(--text-4)}
.vz-heat-key span{margin:0 3px}
@media(max-width:480px){.vz-heat{grid-template-rows:repeat(7,8px);grid-auto-columns:8px;gap:2px}.vz-heat i{width:8px;height:8px}}
.vz-chart{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;margin:18px 0}
.vz-chart svg{display:block;width:100%;height:auto}
.vz-chart .axis{font-family:var(--ff-mono);font-size:10px;fill:var(--text-4)}
.vz-chart .cap{font-family:var(--ff-mono);font-size:11.5px;font-weight:700}
.vz-chart .gridline{stroke:rgba(255,255,255,.06);stroke-width:1}
.vz-chart-title{font-family:var(--ff-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--text-2);margin-bottom:4px}
.vz-chart-sub{font-size:12px;color:var(--text-3);margin-bottom:14px}
.vz-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.vz-legend span{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-mono);font-size:10.5px;color:var(--text-2)}
.vz-legend i{width:18px;height:3px;border-radius:2px;display:inline-block}
.vz-note{font-family:var(--ff-mono);font-size:10px;color:var(--text-4);margin-top:12px;line-height:1.7}
@media (prefers-reduced-motion:no-preference){
    .vz-line{stroke-dasharray:1400;stroke-dashoffset:1400;animation:vzDraw 2.2s var(--ease) .2s forwards}
    .vz-line2{animation-delay:.5s}
    .vz-line3{animation-delay:.8s}
    .vz-bar{transform:scaleX(0);transform-origin:left;animation:vzBar 1s var(--ease) .3s forwards}
    @keyframes vzBar{to{transform:scaleX(1)}}
}
.vz-barrow{display:grid;grid-template-columns:130px 1fr 52px;align-items:center;gap:12px;margin-bottom:11px}
.vz-barrow .bl{font-size:12.5px;font-weight:700;color:var(--text-2)}
.vz-barrow .bt{height:14px;border-radius:7px;background:var(--surface-3);overflow:hidden}
.vz-barrow .bf{height:100%;border-radius:7px;background:linear-gradient(90deg,#D89A66,#B06A3F)}
.vz-barrow .bf.alt{background:linear-gradient(90deg,#5F5570,#4A4258)}
.vz-barrow .bv{font-family:var(--ff-mono);font-size:11.5px;font-weight:600;color:var(--text-2);text-align:right;font-variant-numeric:tabular-nums}
.vz-barrow.dim .bl,.vz-barrow.dim .bv{color:var(--text-4);font-weight:400}
@media(max-width:600px){.vz-barrow{grid-template-columns:96px 1fr 44px;gap:8px}.vz-barrow .bl{font-size:11px}}
.vz-timeline{position:relative;margin:20px 0 10px;padding-left:26px}
.vz-timeline::before{content:'';position:absolute;left:7px;top:6px;bottom:6px;width:2px;border-radius:2px;background:linear-gradient(180deg,#D89A66,#B06A3F,#6F66A8)}
.vz-tl-item{position:relative;padding:0 0 20px 14px}
.vz-tl-item::before{content:'';position:absolute;left:-25px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--accent);border:3px solid var(--surface);box-shadow:0 0 0 2px rgba(208,137,86,.4)}
.vz-tl-item .yr{font-family:var(--ff-mono);font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--accent);text-transform:uppercase}
.vz-tl-item h3{font-size:14.5px;margin:3px 0 4px!important;font-weight:700;color:#fff}
.vz-tl-item p{font-size:13px!important;margin-bottom:0!important;color:var(--text-3)!important;line-height:1.7!important}
.vz-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:18px 0}
.vz-strip .vs{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 12px;text-align:center}
.vz-strip .vs b{display:block;font-family:var(--ff-display);font-size:23px;font-weight:800;line-height:1.2;background:linear-gradient(90deg,#D89A66,#E5B98C);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--accent)}
.vz-strip .vs span{font-family:var(--ff-mono);font-size:8.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-4)}
.vz-strip .vs b em{font-style:normal;font-size:14px}
.vz-syr{margin:16px 0 4px}
.vz-syr svg{display:block;width:100%;max-width:560px;height:auto;margin:0 auto}
.vz-syr .fill{transition:width .6s var(--ease)}
.vz-syr-read{text-align:center;font-family:var(--ff-mono);font-size:12px;color:var(--text-2);margin-top:8px}
.vz-syr-read b{color:var(--accent-lt);font-size:15px}
.guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:13px;margin:18px 0}
.guide-card{display:block;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;transition:all .25s var(--ease)}
.guide-card:hover{transform:translateY(-3px);border-color:rgba(208,137,86,.45);box-shadow:var(--glow-card)}
.guide-card i{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;background:linear-gradient(135deg,#857BC0,#5C5494);margin-bottom:12px;box-shadow:none}
.guide-card.teal i{background:linear-gradient(135deg,#D89A66,#B06A3F);color:#1A130C}
.guide-card.amber i{background:linear-gradient(135deg,#D6B36A,#A8853F);color:#1A1205}
.guide-card h3{font-family:var(--ff-display);font-size:14px;font-weight:700;margin:0 0 4px!important;color:#fff}
.guide-card p{font-size:12px!important;color:var(--text-3)!important;line-height:1.6!important;margin:0!important}

/* ========= HOMEPAGE HERO ========= */
.hero{padding:30px 0 4px}
.hero-card{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--surface-2),#241731 55%,#3D2333 120%);border:1px solid var(--line-2);border-radius:14px;padding:46px 48px}
.hero-card::before{content:'';position:absolute;inset:0;pointer-events:none;
    background:radial-gradient(560px 260px at 85% -30%,rgba(208,137,86,.22),transparent 60%),radial-gradient(420px 240px at -5% 110%,rgba(111,102,168,.18),transparent 60%)}
.hero-copy{position:relative;max-width:680px}
.hero-eyebrow{font-family:var(--ff-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-lt);background:var(--coral-tint);border:1px solid rgba(208,137,86,.3);padding:5px 13px;border-radius:999px;display:inline-block;margin-bottom:18px}
.hero h1{font-family:var(--ff-display);font-size:38px;font-weight:800;letter-spacing:-1.2px;line-height:1.15;color:#fff;margin-bottom:14px}
.hero h1 em{font-style:normal;background:linear-gradient(90deg,#D08956,#D6B36A);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{font-size:15px;color:var(--text-2);line-height:1.75;max-width:560px;margin-bottom:22px}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.hero-stats{display:flex;gap:9px;flex-wrap:wrap}
.hero-stats span{font-family:var(--ff-mono);font-size:11px;color:var(--text-3);background:rgba(255,255,255,.04);border:1px solid var(--line);padding:7px 13px;border-radius:999px}
.hero-stats b{color:#fff;font-weight:600}
.layout-tight{padding-top:16px}
@media(max-width:768px){.hero{padding:16px 0 0}.hero-card{padding:26px 20px;border-radius:20px}.hero h1{font-size:24px;letter-spacing:-.6px}.hero p{font-size:13.5px}.hero-stats span{font-size:10px;padding:6px 10px}}

/* ========= COMMUNITY PULSE ========= */
.st-grid.pulse{grid-template-columns:repeat(3,1fr)}
.st-box.big{grid-column:1/-1;display:flex;align-items:baseline;justify-content:flex-start;gap:11px;text-align:left;padding:13px 16px;background:linear-gradient(120deg,var(--surface-2),#2E2138);border-color:rgba(208,137,86,.28)}
.st-box.big .sn{font-size:29px}

/* ========= MOBILE / RESPONSIVE ========= */
a,button,.f-row,.t-row,.on-tag,.tag{-webkit-tap-highlight-color:transparent}
@media(max-width:1024px){
    .layout{grid-template-columns:1fr}
    .sidebar{display:none}
    .t-row{grid-template-columns:42px 1fr 60px 60px}
    .t-last{display:none}
}
@media(max-width:900px){
    .cat>div:not(.cat-h){grid-template-columns:1fr}
}
@media(max-width:768px){
    .container{padding:0 14px}
    .hdr{padding:10px 0}
    .hdr-search{display:none}
    .hdr-btn{padding:8px 13px;font-size:12px}
    .logo-type h1,.logo-type .logo-name{font-size:17px}
    .logo-mark{width:34px;height:34px;border-radius:9px}
    .logo-mark svg{width:26px;height:26px}
    .nav{display:none}
    .mobile-nav{display:block}
    body{padding-bottom:66px}
    #ctTop{bottom:82px;right:14px;width:40px;height:40px}
    .ct-msearch{display:inline-flex;width:36px;height:36px;padding:0;justify-content:center;align-items:center;border-radius:50%;font-size:13px}
    .t-row{padding:12px 14px;grid-template-columns:38px 1fr}
    .t-stat{display:none}
    .t-info{padding:0 12px}
    .t-ttl{font-size:13px}
    .t-av{width:38px;height:38px;font-size:12px;border-radius:12px}
    .f-row{padding:14px 15px 12px}
    .f-stat .n{font-size:11.5px}
    .f-info h3{font-size:13.5px}
    .f-info p{font-size:11.5px}
    .f-ico{width:40px;height:40px;font-size:15px;border-radius:12px}
    .tv-h{padding:17px 18px}
    .tv-h h1{font-size:17px}
    .tv-meta{font-size:9.5px;gap:10px}
    .tl-h{flex-direction:column;gap:10px;align-items:flex-start}
    .tl-h h2,.tl-h h1{font-size:17px}
    .p-auth{padding:0 0 8px 2px;border-bottom:none}
    .p-av{width:38px;height:38px;font-size:13px}
    .p-wrap{padding:14px 16px;margin-left:0}
    .p-body{font-size:14px;line-height:1.7}
    .ad{padding:14px 16px;gap:12px}
    .ad-ico{width:40px;height:40px;font-size:17px}
    .ad-body h4{font-size:12.5px}
    .ad-body p{font-size:10.5px}
    .pgn{margin:16px 0}
    .pg{padding:7px 10px;min-width:32px;font-size:11px}
    .prof-banner{padding:22px;flex-direction:column;text-align:center;gap:14px}
    .prof-av{width:72px;height:72px;font-size:26px}
    .prof-info h2,.prof-info h1{font-size:20px}
    .prof-stats{justify-content:center;gap:18px}
    .ps-i .pn{font-size:17px}
    .page-card{padding:24px 20px}
    .page-card h1{font-size:21px}
    .page-card h2{font-size:16px}
    .auth-box{width:100%;max-width:100%;border-radius:14px 22px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:90vh;overflow-y:auto}
    .sw{margin-bottom:12px}
    .sw-h{padding:11px 14px;font-size:9.5px}
    .sw-b{padding:12px 14px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:20px}
    /* prevent iOS focus zoom */
    .auth-body .fg input,.auth-body .fg select,.fi,.calc-box input,.calc-box select,textarea.ta{font-size:16px}
    /* tables scroll */
    .page-card table,.p-body .data-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
    .page-card{overflow:hidden}
    /* cookie banner (inline-styled) */
    #cookieBanner{flex-wrap:wrap!important;gap:8px 10px!important;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px))!important;font-size:11px!important;line-height:1.5;text-align:center}
    #cookieBanner>span{flex:1 1 100%}
}
@media(max-width:400px){
    .container{padding:0 10px}
    .hdr-btn{padding:7px 10px;font-size:11px}
    .logo{gap:8px}
    .logo-type h1,.logo-type .logo-name{font-size:16px}
    .f-row{padding:11px 12px 10px}
    .t-row{padding:10px 11px}
    .footer-grid{grid-template-columns:1fr}
}
