:root{--brand: #004481;--brand-600: #003a6f;--brand-soft: #e7edf6;--accent: #ffb300;--bg: #f5f7fb;--surface: #ffffff;--surface-alt: #fafbfe;--border: #e3e7ef;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--danger: #c0392b;--danger-soft: #fdecea;--ok: #0b8457;--ok-soft: #e6f6ef;--warn: #b45309;--warn-soft: #fef3c7;--radius: 10px;--radius-sm: 6px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow: 0 4px 16px rgba(15, 23, 42, .08);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}a{color:var(--brand)}.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:18px 14px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}.brand{font-weight:700;font-size:18px;color:var(--brand);padding:4px 10px 16px;border-bottom:1px solid var(--border);margin-bottom:12px}.tabbtn{text-align:left;background:transparent;border:0;border-radius:var(--radius-sm);padding:9px 12px;color:var(--text-2);font-size:14px;display:flex;justify-content:space-between;align-items:center}.tabbtn:hover{background:var(--surface-alt);color:var(--text)}.tabbtn.active{background:var(--brand-soft);color:var(--brand-600);font-weight:600}.tabbtn .pill{background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;padding:1px 8px;font-size:11px;color:var(--text-3)}.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--border);font-size:12px;color:var(--text-3)}.sidebar-footer .me{color:var(--text-2);margin-bottom:6px;word-break:break-all}.main{padding:24px 28px 60px;overflow:auto}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px}h1{font-size:20px}h2{font-size:16px;margin-bottom:8px}.btn{background:var(--brand);color:#fff;border:0;border-radius:var(--radius-sm);padding:8px 14px;font-weight:500;font-size:14px}.btn:hover{background:var(--brand-600)}.btn.ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn.ghost:hover{background:var(--surface-alt);color:var(--text)}.btn.danger{background:var(--danger)}.btn.ok{background:var(--ok)}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;margin-bottom:12px}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left}th{background:var(--surface-alt);font-weight:600;color:var(--text-2);font-size:12px;text-transform:uppercase;letter-spacing:.04em}tr.row{cursor:pointer}tr.row:hover{background:var(--surface-alt)}tr.row.selected{background:var(--brand-soft)}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.badge.inbox{background:var(--surface-alt);color:var(--text-2);border:1px solid var(--border)}.badge.review{background:var(--warn-soft);color:var(--warn)}.badge.posted{background:var(--ok-soft);color:var(--ok)}.badge.rejected{background:var(--danger-soft);color:var(--danger)}.split{display:grid;grid-template-columns:1fr 420px;gap:18px}@media(max-width:1100px){.split{grid-template-columns:1fr}}.workbench{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(360px,1fr);gap:18px;align-items:start}@media(max-width:1100px){.workbench{grid-template-columns:1fr}}.preview{position:sticky;top:12px;padding:0;overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 110px);min-height:420px}.preview-head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-alt);font-size:13px}.preview-head .filename{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.preview-body{flex:1;background:#f3f4f6;display:flex;align-items:center;justify-content:center;overflow:auto}.preview-body img{max-width:100%;max-height:100%;object-fit:contain;display:block}.preview-body iframe{width:100%;height:100%;border:0;background:#fff}.preview-body pre{align-self:stretch;flex:1;margin:0;padding:14px;background:#fff;color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word;overflow:auto}.preview-body .empty{color:var(--text-3);padding:24px;text-align:center}.detail label{display:block;font-size:12px;color:var(--text-2);margin-top:10px;margin-bottom:4px}.detail input,.detail textarea,.detail select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:14px}.detail textarea{min-height:60px;resize:vertical}.detail .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eef2f9,#f7f9fd)}.login-card{width:360px;background:var(--surface);padding:28px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}.login-card h1{color:var(--brand);margin-bottom:6px}.login-card p{color:var(--text-2);font-size:13px;margin-bottom:18px}.login-card label{display:block;font-size:12px;color:var(--text-2);margin:10px 0 4px}.login-card input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}.login-card .btn{width:100%;margin-top:16px;padding:10px}.error{background:var(--danger-soft);color:var(--danger);padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:10px}.muted{color:var(--text-3);font-size:12px}.kbd{font-family:Fira Code,Consolas,monospace;font-size:12px;background:var(--surface-alt);border:1px solid var(--border);padding:1px 6px;border-radius:4px;color:var(--text-2)}.audit{font-size:12px;color:var(--text-2)}.audit li{padding:6px 0;border-bottom:1px dashed var(--border);list-style:none}.audit time{color:var(--text-3)}
