:root{--bg: #0b1218;--bg-soft: #0f1820;--surface: #122029;--surface-2: #16293a;--line: rgba(125, 211, 192, .22);--line-strong: rgba(125, 211, 192, .45);--text: #e8edf4;--muted: rgba(232, 237, 244, .62);--accent: #5eead4;--accent-2: #2d8a79;--accent-soft: rgba(94, 234, 212, .14);--warn: #f87171;--ok: #4ade80;--brand-blue: #38bdf8;--brand-blue-strong: #0ea5e9}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,Segoe UI,system-ui,-apple-system,Roboto,sans-serif;font-size:14px;line-height:1.5;color:var(--text);background:var(--bg);background-image:radial-gradient(1100px 600px at 80% -10%,rgba(94,234,212,.06),transparent 60%),radial-gradient(800px 500px at -10% 110%,rgba(45,138,121,.08),transparent 60%);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}[hidden]{display:none!important}code{font-family:ui-monospace,Cascadia Mono,Consolas,monospace;background:#5eead414;color:var(--accent);padding:.05rem .32rem;border-radius:4px}.app{min-height:100%;display:flex;flex-direction:column}.nav{display:flex;align-items:center;gap:1rem;padding:.85rem 1.25rem;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#0f1820f2,#0b1218eb);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.nav .brand{font-weight:800;letter-spacing:-.02em;font-size:1.1rem;color:var(--text)}.nav-links{display:flex;gap:1.1rem;margin-left:1.5rem}.nav-links a{color:var(--muted);font-size:.88rem;font-weight:500}.nav-links a:hover,.nav-links a.active{color:var(--text);text-decoration:none}.nav-spacer{flex:1}.nav-user{display:flex;align-items:center;gap:.55rem;font-size:.85rem;color:var(--muted)}.nav-user .who{color:var(--text);font-weight:600}.main{flex:1;display:flex;justify-content:center;padding:2rem 1.25rem 4rem}.shell{width:100%;max-width:76rem}.center-card{display:flex;align-items:center;justify-content:center;padding:2rem 0}.btn{cursor:pointer;font-family:inherit;font-size:.88rem;padding:.55rem 1rem;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--text);transition:border-color .12s ease,background .12s ease,transform .06s ease}.btn:hover{border-color:var(--line-strong);background:var(--surface-2)}.btn:active{transform:translateY(1px)}.btn[disabled]{opacity:.4;cursor:not-allowed}.btn.primary{background:linear-gradient(180deg,#5eead4,#2d8a79);color:#052e2a;border:none;font-weight:700}.btn.primary:hover{filter:brightness(1.06)}.btn.warn{background:#be37372e;border-color:#f8717173;color:#fecaca}.btn.ghost{background:transparent;border-color:var(--line)}.btn.ghost:hover{background:#ffffff0a}.btn.mini{padding:.32rem .6rem;font-size:.78rem}.auth-card{width:24rem;max-width:100%;padding:1.7rem 1.7rem 1.8rem;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:0 18px 60px #0006}.auth-card h1{margin:0 0 .35rem;font-size:1.45rem;letter-spacing:-.02em}.auth-card .lede{margin:0 0 1.1rem;color:var(--muted);font-size:.9rem}.tabs{display:flex;gap:.4rem;margin-bottom:1rem;flex-wrap:wrap}.tab{cursor:pointer;border:1px solid transparent;background:transparent;color:var(--muted);font-family:inherit;font-size:.82rem;padding:.4rem .8rem;border-radius:8px;font-weight:500}.tab:hover{color:var(--text);background:#5eead40f}.tab.active{color:var(--accent);background:var(--accent-soft);border-color:#5eead452}label.field{display:block;margin-top:.85rem;font-size:.78rem;color:var(--muted);font-weight:500}label.field input{display:block;width:100%;margin-top:.3rem;padding:.6rem .7rem;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;color:var(--text);font:inherit;font-size:.92rem;transition:border-color .12s ease,outline .12s ease}label.field input:focus{border-color:var(--accent);outline:2px solid rgba(94,234,212,.18);outline-offset:0}.submit-row{margin-top:1.2rem}.submit-row .btn.primary{width:100%;padding:.7rem;font-size:.95rem}.msg{min-height:1.1rem;margin:.7rem 0 0;font-size:.82rem;color:#fbbf24}.msg.ok{color:var(--ok)}.hero-h1{margin:0 0 .5rem;font-size:1.85rem;letter-spacing:-.02em}.hero-sub{margin:0 0 1.85rem;color:var(--muted);font-size:1rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:.85rem;margin-bottom:1.5rem}.stat-card{border:1px solid var(--line);border-radius:12px;padding:.95rem 1.1rem;background:var(--surface)}.stat-card .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.stat-card .value{margin-top:.4rem;font-size:1.4rem;font-weight:700;color:var(--text)}.stat-card .value.ok{color:var(--ok)}.stat-card .value.warn{color:var(--warn)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));gap:.95rem}.feature-card{border:1px solid var(--line);border-radius:12px;padding:1rem 1.15rem 1.15rem;background:var(--surface);display:flex;flex-direction:column;gap:.55rem}.feature-card h3{margin:0;font-size:1rem}.feature-card p{margin:0;color:var(--muted);font-size:.86rem;flex:1}.feature-card .row{display:flex;gap:.4rem;flex-wrap:wrap}.feature-card.coming{opacity:.65}.feature-card .badge{display:inline-block;margin-left:.4rem;font-size:.65rem;padding:.08rem .45rem;border-radius:999px;background:#5eead41a;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.section{border:1px solid var(--line);border-radius:14px;padding:1.25rem 1.4rem 1.35rem;background:var(--surface);margin-bottom:1.25rem}.section h2{margin:0 0 .85rem;font-size:1.05rem}.kv{list-style:none;margin:0;padding:0}.kv li{display:grid;grid-template-columns:9rem 1fr;gap:.6rem;padding:.45rem 0;border-bottom:1px solid rgba(125,211,192,.1);font-size:.92rem}.kv li:last-child{border-bottom:0}.kv li .k{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}.kv li .v{color:var(--text)}.forum{display:flex;flex-direction:column;gap:1rem}.forum-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.forum-head .hero-h1{margin-bottom:.25rem}.forum-head .hero-sub{margin:0}.crumbs{font-size:.85rem;color:var(--muted);display:flex;gap:.4rem;align-items:center}.crumbs a{color:var(--accent)}.forum-cats{display:flex;flex-direction:column;gap:.6rem}.forum-cat{display:grid;grid-template-columns:1fr 8rem 14rem;gap:1rem;padding:1rem 1.15rem;border:1px solid var(--line);border-radius:12px;background:var(--surface);color:var(--text);text-decoration:none;transition:border-color .12s ease,background .12s ease}.forum-cat:hover{border-color:var(--line-strong);background:var(--surface-2);text-decoration:none}.forum-cat-title{font-weight:700;font-size:1rem}.forum-cat-desc{color:var(--muted);font-size:.85rem;margin-top:.2rem}.forum-cat-stats{display:flex;flex-direction:column;gap:.15rem;align-self:center}.forum-cat-stats .kvi{display:flex;justify-content:space-between;gap:.6rem;font-size:.85rem}.forum-cat-last{align-self:center;min-width:0}.forum-last-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.88rem;color:var(--text)}@media (max-width: 720px){.forum-cat{grid-template-columns:1fr}.forum-cat-stats{flex-direction:row;gap:1rem}}.thread-list{display:flex;flex-direction:column;gap:.4rem}.thread-row{display:grid;grid-template-columns:3rem 1fr 7rem 13rem;gap:.85rem;padding:.7rem .95rem;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--text);text-decoration:none;align-items:center}.thread-row:hover{border-color:var(--line-strong);background:var(--surface-2);text-decoration:none}.thread-flags{display:flex;flex-wrap:wrap;gap:.2rem}.thread-title{font-weight:600}.thread-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;font-size:.85rem}.thread-last{text-align:right}@media (max-width: 720px){.thread-row{grid-template-columns:1fr;gap:.4rem}.thread-meta,.thread-last{text-align:left;align-items:flex-start}}.post-list{display:flex;flex-direction:column;gap:.7rem}.post{display:grid;grid-template-columns:11rem 1fr;gap:0;border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden}.post-side{background:linear-gradient(180deg,#2d8a7914,#0b121800);padding:.95rem .95rem 1rem;border-right:1px solid rgba(125,211,192,.08);display:flex;flex-direction:column;gap:.4rem}.post-side-name{font-weight:700;font-size:.95rem}.post-side-stats{margin-top:.55rem;display:flex;flex-direction:column;gap:.2rem}.post-side-stats .kvi{display:flex;justify-content:space-between;gap:.6rem;font-size:.82rem}.rep-pos{color:var(--ok);font-weight:700}.rep-neg{color:var(--warn);font-weight:700}.post-main{padding:.95rem 1.1rem 1.1rem;min-width:0}.post-head{display:flex;justify-content:space-between;align-items:center;gap:.6rem;padding-bottom:.55rem;margin-bottom:.6rem;border-bottom:1px solid rgba(125,211,192,.08)}.post-vote{display:flex;align-items:center;gap:.4rem}.vote-btn{cursor:pointer;background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:6px;padding:.05rem .45rem;font-size:.78rem;font-family:inherit}.vote-btn:hover{color:var(--text);border-color:var(--line-strong)}.vote-btn.up.active{color:var(--ok);border-color:#4ade8073;background:#4ade801a}.vote-btn.down.active{color:var(--warn);border-color:#f8717173;background:#f871711a}.vote-score{font-weight:700;min-width:1.6rem;text-align:center;font-size:.85rem}@media (max-width: 720px){.post{grid-template-columns:1fr}.post-side{border-right:0;border-bottom:1px solid rgba(125,211,192,.08)}.post-side-stats{flex-direction:row;flex-wrap:wrap;gap:.6rem}}.post-body p{margin:0 0 .5rem;word-wrap:break-word}.post-body p:last-child{margin-bottom:0}.md p{margin:0 0 .55rem}.md p:last-child{margin-bottom:0}.md a{color:var(--accent)}.md ul,.md ol{padding-left:1.4rem;margin:0 0 .6rem}.md li{margin-bottom:.2rem}.md blockquote{margin:.4rem 0;padding:.4rem .8rem;border-left:3px solid var(--accent-2);color:var(--muted);background:#5eead40a;border-radius:4px}.md code{font-family:ui-monospace,Cascadia Mono,Consolas,monospace;background:#5eead414;color:var(--accent);padding:.05rem .32rem;border-radius:4px}.md pre{background:var(--bg-soft);border:1px solid var(--line);padding:.7rem .85rem;border-radius:8px;overflow-x:auto;font-size:.85rem}.md pre code{background:transparent;color:var(--text);padding:0}.md table{border-collapse:collapse;margin:.5rem 0}.md th,.md td{border:1px solid var(--line);padding:.3rem .55rem;font-size:.88rem}.md th{background:#5eead40f}.md hr{border:0;border-top:1px solid var(--line);margin:.7rem 0}.chat{display:grid;grid-template-columns:14rem 1fr;gap:1rem;height:calc(100vh - 9rem);min-height:30rem}.chat-sidebar{border:1px solid var(--line);border-radius:12px;background:var(--surface);display:flex;flex-direction:column;overflow:hidden}.chat-sidebar-head{padding:.7rem .85rem;border-bottom:1px solid rgba(125,211,192,.08);display:flex;align-items:center;justify-content:space-between}.chat-sidebar .dot{font-size:1.4rem;line-height:.8;color:var(--muted)}.chat-sidebar .dot.open{color:var(--ok)}.chat-sidebar .dot.handshaking,.chat-sidebar .dot.connecting,.chat-sidebar .dot.refreshing{color:#fbbf24}.chat-sidebar .dot.closed,.chat-sidebar .dot.error{color:var(--warn)}.chat-channels{list-style:none;padding:.4rem;margin:0;display:flex;flex-direction:column;gap:.15rem;flex:1;overflow-y:auto}.chat-channel{display:flex;align-items:center;gap:.4rem;padding:.4rem .55rem;border-radius:8px;cursor:pointer;font-size:.9rem;color:var(--muted)}.chat-channel:hover{background:var(--surface-2);color:var(--text)}.chat-channel.active{background:var(--accent-soft);color:var(--text);border:1px solid rgba(94,234,212,.32)}.chat-channel .hash{color:var(--accent);font-weight:700}.chat-channel .ch-name{flex:1}.chat-sidebar-foot{padding:.6rem .85rem;border-top:1px solid rgba(125,211,192,.08)}.chat-main{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden}.chat-head{padding:.85rem 1rem;border-bottom:1px solid rgba(125,211,192,.08);display:flex;justify-content:space-between;align-items:center;gap:.6rem}.chat-list{flex:1;overflow-y:auto;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.6rem}.chat-empty{padding:2rem 0;text-align:center}.chat-msg{background:var(--bg-soft);border:1px solid rgba(125,211,192,.08);border-radius:10px;padding:.55rem .8rem .6rem}.chat-msg-head{display:flex;align-items:center;gap:.45rem;margin-bottom:.25rem}.chat-msg-user{font-weight:700;font-size:.88rem}.chat-msg-body{font-size:.92rem;line-height:1.45}.chat-msg-body p{margin:0}.chat-input{display:flex;gap:.5rem;padding:.7rem .85rem;border-top:1px solid rgba(125,211,192,.08);background:var(--bg-soft)}.chat-input input{flex:1;padding:.55rem .7rem;background:var(--surface);border:1px solid var(--line);border-radius:8px;color:var(--text);font:inherit;font-size:.92rem}.chat-input input:focus{border-color:var(--accent);outline:2px solid rgba(94,234,212,.18)}.chat-input input:disabled{opacity:.6}@media (max-width: 720px){.chat{grid-template-columns:1fr;height:auto}.chat-sidebar{max-height:14rem}}.shop .card-grid{margin-top:.4rem}.shop .redeem-form .field{margin-top:.6rem}.shop .redeem-form .row{margin-top:.7rem}.reply-form textarea,.section textarea,.section select{display:block;width:100%;margin-top:.3rem;padding:.6rem .7rem;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;color:var(--text);font:inherit;font-size:.92rem;resize:vertical}.reply-form textarea:focus,.section textarea:focus,.section select:focus{border-color:var(--accent);outline:2px solid rgba(94,234,212,.18)}.row-between{display:flex;justify-content:space-between;align-items:center;gap:.6rem;margin-top:.7rem}.pager{display:flex;align-items:center;gap:.7rem;justify-content:center;padding:.4rem 0}.mod-row{display:flex;gap:.4rem;flex-wrap:wrap}.badge.pin{background:#ffbf6929;color:#fbbf24}.badge.lock{background:#f8717129;color:#fecaca}.badge.admin{background:#5eead42e;color:var(--accent)}.badge{display:inline-block;font-size:.65rem;padding:.08rem .45rem;border-radius:999px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}.small{font-size:.78rem}.brand-hero{text-align:center;padding:1.4rem 0 1.2rem}.brand-wordmark{margin:0;font-weight:900;letter-spacing:-.04em;font-size:clamp(2.6rem,6vw,4.2rem);line-height:1;text-shadow:0 8px 40px rgba(56,189,248,.2)}.brand-bart{color:var(--brand-blue)}.brand-hook{color:var(--text)}.brand-tld{color:var(--brand-blue)}.brand-sub{margin:.6rem 0 0;color:var(--muted);font-size:.95rem}.auth-screen{flex-direction:column;gap:.8rem}.auth-screen .brand-hero{padding-top:0;padding-bottom:.4rem}.sub-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.7rem;margin:0 0 1.1rem;padding:.7rem .95rem;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.sub-cell{display:flex;flex-direction:column;gap:.2rem;min-width:0}.sub-val{font-weight:700;font-size:1rem}.sub-val.small{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sub-val.ok{color:var(--ok)}.sub-val.warn{color:var(--warn)}@media (max-width: 720px){.sub-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}.home-dash{display:flex;flex-direction:column}.home-grid{display:grid;grid-template-columns:minmax(0,1fr) 22rem;gap:1.1rem;align-items:start}.home-main{display:flex;flex-direction:column;gap:1rem;min-width:0}.home-side{display:flex;flex-direction:column;gap:1rem}.home-actions{display:flex;flex-wrap:wrap;gap:.5rem}@media (max-width: 1000px){.home-grid{grid-template-columns:1fr}}.shoutbox{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden;min-height:22rem}.shoutbox-head{display:flex;justify-content:space-between;align-items:center;padding:.65rem .95rem;background:linear-gradient(90deg,#38bdf82e,#38bdf80a);border-bottom:1px solid rgba(56,189,248,.18)}.shoutbox-title{font-weight:700;font-size:1rem;display:flex;align-items:center;gap:.4rem}.shoutbox-title .hash{color:var(--brand-blue)}.shoutbox .dot{font-size:1.4rem;line-height:.6;color:var(--muted)}.shoutbox .dot.open{color:var(--ok)}.shoutbox .dot.handshaking,.shoutbox .dot.connecting,.shoutbox .dot.refreshing{color:#fbbf24}.shoutbox .dot.closed,.shoutbox .dot.error{color:var(--warn)}.shout-list{flex:1}.latest-panel{border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden}.latest-head{display:flex;justify-content:space-between;align-items:center;padding:.7rem .95rem;background:linear-gradient(90deg,#38bdf82e,#38bdf80a);border-bottom:1px solid rgba(56,189,248,.18)}.latest-title{font-weight:700;font-size:.95rem}.latest-list{list-style:none;margin:0;padding:0}.latest-item{border-bottom:1px solid rgba(125,211,192,.08)}.latest-item:last-child{border-bottom:0}.latest-link{display:block;padding:.55rem .9rem .65rem;color:var(--text);text-decoration:none}.latest-link:hover{background:var(--surface-2);text-decoration:none}.latest-title-row{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.latest-meta{margin-top:.15rem}.latest-meta .latest-user{color:var(--brand-blue);font-weight:600}.latest-cat{margin-top:.1rem}.sessions{list-style:none;padding:0;margin:0 0 .6rem;border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden}.session-row{display:flex;align-items:center;justify-content:space-between;padding:.7rem .95rem;border-bottom:1px solid rgba(125,211,192,.08);gap:.75rem}.session-row:last-child{border-bottom:0}.session-ua{font-weight:600;font-size:.95rem}.session-meta{margin-top:.15rem;color:var(--muted);font-size:.82rem;display:flex;flex-wrap:wrap;gap:.1rem .3rem}.btn.small{padding:.32rem .7rem;font-size:.82rem}.outbound{max-width:36rem;margin:2rem auto;padding:1.5rem 1.5rem 1.25rem;border:1px solid var(--line);border-radius:14px;background:var(--surface)}.outbound h1{margin:0 0 .6rem;font-size:1.4rem;font-weight:800}.outbound .msg{color:var(--muted);margin-bottom:1rem}.outbound-card{border:1px solid var(--line);border-radius:10px;background:var(--bg-soft);padding:.7rem .95rem;margin-bottom:1rem}.outbound-host{font-weight:700;color:var(--brand-blue);font-size:1rem;margin-bottom:.25rem}.outbound-url{font-family:ui-monospace,JetBrains Mono,monospace;word-break:break-all;color:var(--text);font-size:.85rem;margin:0}.outbound-actions{display:flex;gap:.6rem;margin-bottom:.7rem}.outbound-tip{color:var(--muted);font-size:.82rem;margin:0}.foot{border-top:1px solid var(--line);padding:1rem 1.25rem;text-align:center;font-weight:800;letter-spacing:-.02em;font-size:.95rem}.muted{color:var(--muted)}
