:root{
    --bg: #070a12;
    --panel: #0d1220;
    --panel-2: #11182a;
    --border: #1f2a44;
    --border-soft: #16203a;
    --text: #d0d9f0;
    --text-dim: #7a8bb5;
    --text-faint: #4a5a80;
    --lime: #3b82f6;
    --online: #60a5fa;
    --offline: #ff5c5c;
    --pending: #fbbf24;
    --cyan: #38bdf8;
    --font-mono: 'Space Mono', monospace;
    --font-body: 'Inter', sans-serif;
}

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

body{
    background:var(--bg); color:var(--text); font-family:var(--font-body);
    line-height:1.5; -webkit-font-smoothing:antialiased;
    background-image:
        linear-gradient(rgba(59,130,246,0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(59,130,246,0.035) 1px, transparent 1px);
    background-size:44px 44px;
}

@media (prefers-reduced-motion: reduce){
    *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; }
}

a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
input, select, textarea{ font-family:inherit; }
::selection{ background:var(--lime); color:#fff; }
.mono{ font-family:var(--font-mono); }

/* ---------- TOAST ---------- */
.toast-container{
    position:fixed; top:16px; right:16px; z-index:9999;
    display:flex; flex-direction:column; gap:8px; max-width:360px;
}
.toast{
    font-family:var(--font-mono); font-size:12px; padding:12px 16px;
    border:1px solid var(--border); background:var(--panel); color:var(--text);
    animation: toastIn 0.25s ease-out; display:flex; align-items:center; gap:10px;
}
.toast.removing{ animation: toastOut 0.25s ease-in forwards; }
.toast.ok{ border-color:var(--online); }
.toast.warn{ border-color:var(--offline); }
.toast.info{ border-color:var(--lime); }
@keyframes toastIn{ from{ opacity:0; transform:translateX(30px); } to{ opacity:1; transform:translateX(0); } }
@keyframes toastOut{ from{ opacity:1; transform:translateX(0); } to{ opacity:0; transform:translateX(30px); } }

/* ---------- STATUS BAR ---------- */
.statusbar{
    background:#000; border-bottom:1px solid var(--border);
    font-family:var(--font-mono); font-size:11px; color:var(--text-dim);
    padding:7px 20px; display:flex; justify-content:space-between; align-items:center;
    letter-spacing:0.02em; overflow-x:auto; white-space:nowrap;
}
.statusbar .led{
    display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--online);
    box-shadow:0 0 6px var(--online); margin-right:8px; animation:blink 1.8s ease-in-out infinite;
}
@keyframes blink{ 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.statusbar b{ color:var(--lime); font-weight:400; }

/* ---------- HEADER ---------- */
header.top{ border-bottom:1px solid var(--border); background:var(--panel); }
.top-inner{ max-width:1360px; margin:0 auto; padding:22px 20px 18px; }
.logo-row{ display:flex; align-items:flex-start; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.logo{ display:flex; align-items:center; gap:12px; }
.logo .pixel{ width:26px; height:26px; position:relative; flex:none; }
.logo .pixel span{ position:absolute; width:10px; height:10px; }
.logo .pixel span:nth-child(1){ top:0; left:8px; background:var(--lime); box-shadow:0 0 8px rgba(59,130,246,0.6); }
.logo .pixel span:nth-child(2){ top:8px; left:0; background:var(--online); box-shadow:0 0 8px rgba(96,165,250,0.6); }
.logo .pixel span:nth-child(3){ top:8px; left:16px; background:var(--cyan); box-shadow:0 0 8px rgba(56,189,248,0.6); }
.logo-text{ font-family:var(--font-mono); font-size:22px; font-weight:700; letter-spacing:-0.01em; }
.logo-text .dim{ color:var(--text-dim); font-weight:400; }
.logo-sub{ font-size:13px; color:var(--text-dim); margin-top:6px; max-width:520px; }

.filter-tabs{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.ftab{
    font-family:var(--font-mono); font-size:12px; padding:8px 14px; border:1px solid var(--border);
    color:var(--text-dim); background:transparent; transition:all 0.15s;
}
.ftab:hover{ border-color:var(--text-dim); color:var(--text); }
.ftab.active{ background:var(--lime); border-color:var(--lime); color:#fff; font-weight:700; }
.ftab.add{ background:var(--online); border-color:var(--online); color:#fff; font-weight:700; }
.ftab.add:hover{ filter:brightness(1.08); }
.lang-select{
    font-family:var(--font-mono); font-size:11px; padding:8px 10px; border:1px solid var(--border);
    background:var(--panel); color:var(--text-dim); cursor:pointer; outline:none; appearance:none;
    -webkit-appearance:none; -moz-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3E%3Cpath fill='%237a8bb5' d='M0 2h8L4 7z'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 8px center; padding-right:26px;
}
.lang-select:hover{ border-color:var(--text-dim); color:var(--text); }

/* ---------- SEARCH ROW ---------- */
.searchrow{
    max-width:1360px; margin:0 auto; padding:16px 20px; display:flex; gap:10px; flex-wrap:wrap;
    align-items:center; border-bottom:1px solid var(--border-soft); background:var(--bg);
}
.search-box{
    flex:1; min-width:240px; display:flex; align-items:center; gap:10px;
    border:1px solid var(--border); background:var(--panel); padding:11px 14px;
}
.search-box .car{ color:var(--lime); font-family:var(--font-mono); }
.search-box input{
    flex:1; background:none; border:none; outline:none; color:var(--text);
    font-family:var(--font-mono); font-size:13px;
}
.search-box input::placeholder{ color:var(--text-faint); }
.sort-group{ display:flex; gap:6px; }
.sort-btn{
    font-family:var(--font-mono); font-size:11px; padding:11px 13px; border:1px solid var(--border);
    background:var(--panel); color:var(--text-dim);
}
.sort-btn.active{ border-color:var(--lime); color:var(--lime); }

.modechips{
    max-width:1360px; margin:0 auto; padding:14px 20px; display:flex; gap:8px; flex-wrap:wrap;
    border-bottom:1px solid var(--border-soft);
}
.mchip{
    font-family:var(--font-mono); font-size:11px; padding:6px 11px; border:1px solid var(--border-soft);
    color:var(--text-faint); background:var(--panel); cursor:pointer;
}
.mchip.on{ color:var(--lime); border-color:rgba(59,130,246,0.35); background:rgba(59,130,246,0.08); }

/* ---------- LAYOUT ---------- */
main{ max-width:1360px; margin:0 auto; padding:28px 20px 60px; }
.section-label{
    font-family:var(--font-mono); font-size:12px; color:var(--text-dim); display:flex; align-items:center;
    gap:8px; margin-bottom:16px; letter-spacing:0.02em;
}
.section-label .sq{ width:8px; height:8px; background:var(--lime); flex:none; }
.section-label .meta{ color:var(--text-faint); margin-left:auto; font-size:11px; }

/* ---------- SKELETON ---------- */
@keyframes shimmer{ 0%{background-position:-400px 0} 100%{background-position:400px 0} }
.skel{
    background:linear-gradient(90deg, var(--border-soft) 25%, var(--border) 50%, var(--border-soft) 75%);
    background-size:800px 100%; animation:shimmer 1.6s ease-in-out infinite; border-radius:2px;
}

/* recommended cards */
.rec-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:40px; }
@media (max-width:1100px){ .rec-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .rec-grid{ grid-template-columns:1fr; } }

.rec-card{ border:1px solid var(--border); background:var(--panel); padding:16px; display:flex; flex-direction:column; gap:10px; }
.rec-top{ display:flex; gap:10px; align-items:flex-start; }
.rec-icon{
    width:48px; height:48px; flex:none; display:flex; align-items:center; justify-content:center;
    font-family:var(--font-mono); font-weight:700; font-size:15px; color:#0a0c0a; border:1px solid var(--border);
    overflow:hidden; image-rendering:pixelated;
}
.rec-badge{
    font-family:var(--font-mono); font-size:10px; color:var(--pending); border:1px solid rgba(255,204,51,0.35);
    background:rgba(255,204,51,0.08); padding:2px 7px; display:inline-block; margin-bottom:4px;
}
.rec-name{ font-weight:700; font-size:15px; }
.rec-name a{ color:inherit; text-decoration:none; }
.rec-name a:hover{ color:var(--lime); }
.rec-icon-link{ display:contents; }
.rec-icon-link:hover .rec-icon{ filter:brightness(1.15); }
.rec-rank{ font-family:var(--font-mono); font-size:11px; color:var(--text-faint); margin-left:6px; }
.rec-desc{ font-size:12.5px; color:var(--text-dim); line-height:1.5; min-height:36px; }

.rec-tags{ display:flex; flex-wrap:wrap; gap:5px; }
.rtag{ font-family:var(--font-mono); font-size:10px; color:var(--text-dim); border:1px solid var(--border-soft); padding:3px 7px; }

.rec-foot{ display:flex; justify-content:space-between; align-items:center; margin-top:2px; }
.rec-version{ font-family:var(--font-mono); font-size:11px; color:var(--cyan); }

.rec-actions{ display:flex; gap:8px; }
.btn-mini{
    flex:1; font-family:var(--font-mono); font-size:11px; padding:9px 8px; text-align:center; border:1px solid var(--border);
    background:transparent; color:var(--text-dim); transition:all 0.15s;
}
.btn-mini.copy{ background:var(--lime); color:#fff; border-color:var(--lime); font-weight:700; }
.btn-mini.copy:hover{ filter:brightness(1.1); }
.btn-mini.vote:hover{ border-color:var(--text-dim); color:var(--text); }

/* empty states */
.empty-card{
    border:1px dashed var(--border); background:var(--panel); padding:26px 18px; display:flex; flex-direction:column;
    align-items:center; justify-content:center; text-align:center; gap:10px; min-height:190px;
}
.empty-card .ic{ font-family:var(--font-mono); font-size:20px; color:var(--text-faint); }
.empty-card p{ font-size:12.5px; color:var(--text-dim); max-width:200px; }
.empty-card .mini-cta{
    font-family:var(--font-mono); font-size:11px; color:var(--lime); border:1px solid rgba(59,130,246,0.35);
    padding:7px 12px; background:rgba(59,130,246,0.08);
}
.empty-row{ padding:40px 20px; text-align:center; color:var(--text-dim); font-size:13.5px; }
.empty-row .ic{ font-family:var(--font-mono); color:var(--text-faint); font-size:22px; margin-bottom:10px; }
.empty-row .mini-cta{
    display:inline-block; margin-top:14px; font-family:var(--font-mono); font-size:11px; color:var(--lime);
    border:1px solid rgba(59,130,246,0.35); padding:8px 14px; background:rgba(59,130,246,0.08); cursor:pointer;
}

/* ---------- LIST + SIDEBAR ---------- */
.list-layout{ display:grid; grid-template-columns:1fr 260px; gap:22px; align-items:flex-start; }
@media (max-width:900px){ .list-layout{ grid-template-columns:1fr; } }

.ranklist{ border:1px solid var(--border); background:var(--panel); }
.rrow{
    display:grid; grid-template-columns:34px 1fr 90px 110px; gap:14px; align-items:center;
    padding:13px 16px; border-bottom:1px solid var(--border-soft); font-size:13px;
}
.rrow.head{
    font-family:var(--font-mono); font-size:10px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.06em;
    background:var(--panel-2);
}
.rrow:last-child{ border-bottom:none; }
.rrow:not(.head):hover{ background:var(--panel-2); }
.rpos{ font-family:var(--font-mono); color:var(--lime); font-size:13px; }
.rname-wrap{ display:flex; align-items:center; gap:10px; min-width:0; }
.rmini-icon{
    width:30px; height:30px; flex:none; display:flex; align-items:center; justify-content:center;
    font-family:var(--font-mono); font-size:11px; font-weight:700; color:#0a0c0a; border:1px solid var(--border);
    overflow:hidden;
}
.rname-text{ min-width:0; }
.rname-text .n{ font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:flex; align-items:center; gap:6px; }
.rname-text .tags{ font-family:var(--font-mono); font-size:10.5px; color:var(--text-faint); margin-top:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rversion{ font-family:var(--font-mono); font-size:11.5px; color:var(--cyan); }
.rcopy{
    font-family:var(--font-mono); font-size:11px; padding:8px 6px; text-align:center; border:1px solid var(--border);
    background:transparent; color:var(--text-dim); width:100%; transition:all 0.15s;
}
.rcopy:hover{ border-color:var(--lime); color:var(--lime); }
@media (max-width:760px){
    .rrow{ grid-template-columns:26px 1fr 80px; }
    .rrow > :nth-child(4){ display:none; }
}

/* sidebar */
.sidebar{ display:flex; flex-direction:column; gap:16px; }
.side-box{ border:1px solid var(--border); background:var(--panel); padding:16px; }
.side-title{ font-family:var(--font-mono); font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:12px; }
.side-chips{ display:flex; flex-wrap:wrap; gap:6px; }
.schip{
    font-family:var(--font-mono); font-size:11px; padding:6px 10px; border:1px solid var(--border-soft);
    color:var(--text-dim); background:var(--panel-2);
}
.schip:hover{ border-color:var(--lime); color:var(--lime); }
.side-stat{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:12px; padding:7px 0; border-bottom:1px dashed var(--border-soft); color:var(--text-dim); }
.side-stat:last-child{ border-bottom:none; }
.side-stat b{ color:var(--text); font-weight:400; }
.side-ad{
    border:1px dashed var(--border); padding:22px 14px; text-align:center; font-family:var(--font-mono);
    font-size:11px; color:var(--text-faint); letter-spacing:0.04em;
}

/* ---------- ADD SERVER FORM ---------- */
.addwrap{ border-top:1px solid var(--border); padding:56px 0 60px; }
.addwrap .wrap{ max-width:1360px; margin:0 auto; padding:0 20px; }
.add-head{ max-width:640px; margin-bottom:26px; }
.add-head h2{ font-family:var(--font-mono); font-size:clamp(22px,3vw,28px); margin-bottom:8px; }
.add-head p{ color:var(--text-dim); font-size:14px; }

.add-form{
    border:1px solid var(--border); background:var(--panel); padding:24px;
    display:grid; grid-template-columns:1fr 1fr; gap:16px 20px;
}
@media (max-width:720px){ .add-form{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-family:var(--font-mono); font-size:11px; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.05em; }
.field input, .field select, .field textarea{
    background:var(--bg); border:1px solid var(--border); color:var(--text); padding:11px 12px; font-size:13.5px; outline:none;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--lime); }
.field textarea{ resize:vertical; min-height:70px; }
.field-hint{ font-size:11px; color:var(--text-faint); }
.add-submit-row{ grid-column:1 / -1; display:flex; align-items:center; gap:14px; margin-top:4px; flex-wrap:wrap; }
.btn-submit{
    font-family:var(--font-mono); font-weight:700; font-size:13px; background:var(--lime); color:#fff;
    border:1px solid var(--lime); padding:12px 22px;
}
.btn-submit:disabled{ opacity:0.5; cursor:not-allowed; }
.btn-submit:not(:disabled):hover{ filter:brightness(1.08); }
.add-status{ font-family:var(--font-mono); font-size:12px; color:var(--text-dim); }
.add-status.ok{ color:var(--online); }
.add-status.warn{ color:var(--offline); }

/* logo uploader */
.logo-field{ display:flex; align-items:center; gap:14px; }
.logo-drop{
    width:64px; height:64px; flex:none; border:1px dashed var(--border); background:var(--bg);
    display:flex; align-items:center; justify-content:center; cursor:pointer; overflow:hidden; position:relative;
}
.logo-drop:hover{ border-color:var(--lime); }
.logo-drop img{ width:100%; height:100%; object-fit:cover; image-rendering:pixelated; }
.logo-drop .ph{ font-family:var(--font-mono); font-size:9px; color:var(--text-faint); text-align:center; line-height:1.3; padding:4px; }
.logo-drop input[type="file"]{ position:absolute; inset:0; opacity:0; cursor:pointer; }
.logo-info{ font-size:11.5px; color:var(--text-faint); font-family:var(--font-mono); line-height:1.5; }

/* ---------- ADMIN ---------- */
.adminwrap{ border-top:1px solid var(--border); padding:56px 0 60px; background:var(--panel-2); }
.adminwrap .wrap{ max-width:1360px; margin:0 auto; padding:0 20px; }
.admin-head{ max-width:640px; margin-bottom:24px; }
.admin-head h2{ font-family:var(--font-mono); font-size:clamp(22px,3vw,28px); margin-bottom:8px; display:flex; align-items:center; gap:10px; }
.admin-head p{ color:var(--text-dim); font-size:14px; }

.admin-gate{
    border:1px solid var(--border); background:var(--panel); padding:20px; display:flex; gap:10px; align-items:center; flex-wrap:wrap; max-width:520px;
}
.admin-gate input{
    flex:1; min-width:180px; background:var(--bg); border:1px solid var(--border); color:var(--text); padding:11px 12px; font-size:13.5px; outline:none;
}
.admin-gate input:focus{ border-color:var(--lime); }
.admin-gate-hint{ font-family:var(--font-mono); font-size:11px; color:var(--text-faint); margin-top:10px; }

.admin-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--border); border:1px solid var(--border); margin-bottom:30px; max-width:360px; }
@media (max-width:500px){ .admin-stats{ grid-template-columns:repeat(2,1fr); max-width:100%; } }
.astat .val.c-online{ color:var(--online); }
.astat{ background:var(--panel); padding:18px; }
.astat .lbl{ font-family:var(--font-mono); font-size:10.5px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:8px; }
.astat .val{ font-family:var(--font-mono); font-size:24px; font-weight:700; }

.admin-breakdown{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:30px; }
@media (max-width:760px){ .admin-breakdown{ grid-template-columns:1fr; } }
.brk-box{ border:1px solid var(--border); background:var(--panel); padding:16px; }
.brk-row{ display:flex; justify-content:space-between; align-items:center; font-family:var(--font-mono); font-size:12px; padding:8px 0; border-bottom:1px dashed var(--border-soft); color:var(--text-dim); }
.brk-row:last-child{ border-bottom:none; }
.brk-row .brk-bar{ flex:1; height:4px; background:var(--border-soft); margin:0 10px; position:relative; }
.brk-row .brk-bar i{ display:block; height:100%; background:var(--lime); }

.admin-table-toolbar{ display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; flex-wrap:wrap; gap:10px; }
.btn-danger{
    font-family:var(--font-mono); font-size:11px; padding:9px 14px; border:1px solid rgba(255,92,92,0.4);
    background:rgba(255,92,92,0.08); color:var(--offline);
}
.btn-danger:hover{ background:rgba(255,92,92,0.16); }

.admin-table{ border:1px solid var(--border); background:var(--panel); }
.arow{
    display:grid; grid-template-columns:28px 1fr 80px 70px 60px 130px; gap:10px; align-items:center;
    padding:11px 14px; border-bottom:1px solid var(--border-soft); font-size:12.5px;
}
.arow.head{ font-family:var(--font-mono); font-size:10px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.05em; background:var(--panel-2); }
.arow:last-child{ border-bottom:none; }
.arow .an{ font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:flex; align-items:center; gap:6px; }
.arow .aip{ font-family:var(--font-mono); font-size:11px; color:var(--text-faint); }
.a-actions{ display:flex; gap:6px; }
.a-btn{
    font-family:var(--font-mono); font-size:10.5px; padding:6px 8px; border:1px solid var(--border); background:transparent; color:var(--text-dim);
}
.a-btn:hover{ border-color:var(--text-dim); color:var(--text); }
.a-btn.pin.active{ border-color:var(--pending); color:var(--pending); }
.a-btn.del{ border-color:rgba(255,92,92,0.35); color:var(--offline); }
.a-btn.del:hover{ background:rgba(255,92,92,0.12); }
@media (max-width:820px){
    .arow{ grid-template-columns:24px 1fr 60px 100px; }
    .arow > :nth-child(3), .arow > :nth-child(4), .arow > :nth-child(5){ display:none; }
}
.admin-empty{ padding:30px; text-align:center; color:var(--text-dim); font-size:13px; }

/* ---------- FOOTER ---------- */
footer{ border-top:1px solid var(--border); background:var(--panel); }
.footer-inner{
    max-width:1360px; margin:0 auto; padding:26px 20px; display:flex; justify-content:space-between;
    align-items:center; flex-wrap:wrap; gap:10px; font-family:var(--font-mono); font-size:11.5px; color:var(--text-faint);
}

/* ---------- SKELETON CARD ---------- */
.skel-card{
    border:1px solid var(--border); background:var(--panel); padding:16px; display:flex; flex-direction:column; gap:10px; min-height:190px;
}
.skel-card .skel-row{ display:flex; gap:10px; }
.skel-card .skel-icon{ width:48px; height:48px; flex:none; }
.skel-card .skel-text{ flex:1; display:flex; flex-direction:column; gap:6px; }
.skel-card .skel-line{ height:10px; }
.skel-card .skel-line.w60{ width:60%; }
.skel-card .skel-line.w40{ width:40%; }
.skel-card .skel-tags{ display:flex; gap:6px; }
.skel-card .skel-tag{ width:50px; height:18px; display:inline-block; }

/* ---------- DETAIL VIEW ---------- */
.detail-wrap{ max-width:900px; margin:0 auto; padding:30px 20px 60px; }
.detail-back{ font-family:var(--font-mono); font-size:12px; color:var(--lime); display:inline-block; margin-bottom:20px; }
.detail-header{ display:flex; gap:16px; align-items:flex-start; margin-bottom:24px; }
.detail-icon{ width:72px; height:72px; flex:none; display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-weight:700; font-size:20px; color:#fff; border:1px solid var(--border); overflow:hidden; image-rendering:pixelated; }
.detail-icon img{ width:100%; height:100%; object-fit:cover; image-rendering:pixelated; }
.detail-title-group{ flex:1; }
.detail-name{ font-family:var(--font-mono); font-size:clamp(22px,3vw,28px); margin-bottom:8px; }
.detail-meta{ display:flex; gap:6px; flex-wrap:wrap; }
.detail-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:28px; }
@media (max-width:640px){ .detail-stats{ grid-template-columns:repeat(2,1fr); } }
.dstat{ border:1px solid var(--border); background:var(--panel); padding:14px 16px; }
.dstat .lbl{ display:block; font-family:var(--font-mono); font-size:10px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:6px; }
.dstat .val{ font-family:var(--font-mono); font-size:16px; font-weight:600; }
.dstat .val.c-online{ color:var(--online); }
.dstat .val.c-offline{ color:var(--offline); }
.detail-desc{ border:1px solid var(--border); background:var(--panel); padding:20px; margin-bottom:20px; }
.detail-desc h3{ font-family:var(--font-mono); font-size:12px; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:10px; }
.detail-desc p{ font-size:14px; line-height:1.6; color:var(--text); }
.detail-longdesc{ border:1px solid var(--border); background:var(--panel); padding:20px; margin-bottom:20px; }
.detail-longdesc h3{ font-family:var(--font-mono); font-size:12px; color:var(--text-dim); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:10px; }
.longdesc-content{ font-size:14px; line-height:1.7; white-space:pre-wrap; }
.longdesc-content .dim{ color:var(--text-faint); }
.longdesc-textarea{ width:100%; min-height:180px; background:var(--bg); border:1px solid var(--border); color:var(--text); padding:12px; margin:10px 0; font-size:13.5px; font-family:var(--font-body); resize:vertical; outline:none; }
.longdesc-textarea:focus{ border-color:var(--lime); }
.detail-vote{ margin-bottom:24px; }
.detail-vote .btn-submit:disabled{ opacity:0.6; cursor:default; }
.key-prompt{ display:flex; gap:8px; align-items:center; }
.detail-admin{ border:1px solid var(--border); background:var(--panel); padding:20px; }
.detail-admin h3{ font-family:var(--font-mono); font-size:12px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:12px; }
.detail-error{ padding:60px 20px; text-align:center; font-size:16px; color:var(--text-dim); }

/* ---------- VOTE TAG ---------- */
.vtag{ border-color:rgba(251,191,36,0.4); color:var(--pending); }
