:root{--bg: #f5f6f8;--surface: #ffffff;--surface-2: #eef1f5;--line: #e2e6ec;--line-bright: #cdd3dc;--text: #1a1f2e;--muted: #5c6578;--accent: #0e7490;--accent-dim: rgba(14, 116, 144, .1);--accent-glow: rgba(14, 116, 144, .22);--on-accent: #ffffff;--danger: #dc2626;--radius: 6px;--font: "IBM Plex Sans", "Microsoft JhengHei", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;background:var(--bg)}.mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.center{min-height:100vh;display:grid;place-items:center;padding:24px}.muted{color:var(--muted)}.small{font-size:12px}.rating-meter{display:inline-flex;align-items:center;gap:4px;padding:4px 7px;border:1px solid rgba(14,116,144,.18);border-radius:999px;background:var(--accent-dim)}.rating-segment{width:12px;height:4px;border-radius:999px;background:var(--line-bright)}.rating-segment-on{background:var(--accent)}.rating-value{margin-left:4px;color:var(--accent);font-size:12px;font-weight:800;line-height:1}.break-word{word-break:break-all}.image-preview-button{display:block;width:fit-content;padding:0;border:0;background:transparent}.image-preview-button:hover:not(:disabled){background:transparent}.image-preview-thumb{display:block;width:220px;max-width:100%;height:140px;object-fit:cover;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.image-preview-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:24px}.image-preview-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;border-radius:0;background:#000000ad}.image-preview-backdrop:hover:not(:disabled){background:#000000ad}.image-preview-panel{position:relative;width:min(960px,100%);max-height:min(760px,92vh);overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.image-preview-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:10px;border-bottom:1px solid var(--line)}.image-preview-stage{display:grid;place-items:center;height:min(640px,76vh);overflow:auto;background:#111827}.image-preview-full{max-width:90%;max-height:90%;object-fit:contain;transform-origin:center;transition:transform .15s}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}.login{width:min(360px,100%);display:flex;flex-direction:column;gap:20px;padding:32px 28px;position:relative}.login:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);border-radius:var(--radius) var(--radius) 0 0}.login h1{margin:0;font-family:var(--mono);font-size:15px;font-weight:500;letter-spacing:.2em;color:var(--accent)}.login p{margin:-8px 0 0;font-size:13px}.login label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}input,select,textarea{width:100%;background:var(--surface);border:1px solid var(--line-bright);border-radius:var(--radius);padding:10px 12px;color:var(--text);font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-glow)}button{border:1px solid var(--accent);border-radius:var(--radius);padding:10px 16px;background:transparent;color:var(--accent);font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .15s,color .15s}button:hover:not(:disabled){background:var(--accent);color:var(--on-accent)}button:disabled{opacity:.45;cursor:default}button.ghost{border-color:var(--line-bright);color:var(--muted)}button.ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--line-bright)}button.danger,button.ghost.danger{border-color:#fca5a5;color:var(--danger)}button.ghost.danger:hover:not(:disabled){background:#fef2f2;color:var(--danger)}.error{margin:0;padding:10px 12px;border:1px solid #fecaca;border-radius:var(--radius);background:#fef2f2;color:#b91c1c;font-size:13px}.app{display:grid;grid-template-columns:200px minmax(0,1fr);min-height:100vh}.sidebar{display:flex;flex-direction:column;padding:20px 0;border-right:1px solid var(--line);background:var(--surface)}.brand{display:flex;align-items:center;gap:8px;padding:0 16px 20px;margin-bottom:8px;border-bottom:1px solid var(--line)}.brand-mark{display:grid;place-items:center;width:28px;height:28px;border:1px solid var(--accent);border-radius:4px;font-family:var(--mono);font-size:10px;font-weight:600;color:var(--accent)}.brand-name{font-size:13px;font-weight:600;letter-spacing:.02em}.brand-tag{margin-left:auto;font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.12em}.sidebar nav{display:flex;flex-direction:column;flex:1;padding:8px 10px;gap:2px}.sidebar nav a{position:relative;padding:8px 10px 8px 12px;border-radius:4px;color:var(--muted);text-decoration:none;font-size:13px;transition:color .15s,background .15s}.sidebar nav a:hover{color:var(--text);background:var(--surface-2)}.sidebar nav a.active{color:var(--accent);background:var(--accent-dim)}.sidebar nav a.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;background:var(--accent);border-radius:0 1px 1px 0}.sidebar-foot{margin-top:auto;padding:16px 16px 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}.role-badge{display:inline-block;padding:4px 8px;border:1px solid var(--line-bright);border-radius:4px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--accent);width:fit-content}.content{min-width:0;padding:28px 32px 40px}h2{margin:0;font-size:18px;font-weight:600;letter-spacing:-.02em}h3{margin:0;font-size:13px;font-weight:500;color:var(--muted);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--line)}.page-head h2{font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text)}.table{width:100%;border-collapse:collapse;font-size:13px}.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}.table th{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:var(--surface)}.table tbody tr:hover td{background:var(--surface-2)}.table tbody tr:last-child td{border-bottom:0}.center-cell{text-align:center;padding:32px;color:var(--muted)}.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;border:1px solid var(--line-bright);color:var(--muted);background:var(--surface)}.tag.ok{border-color:#0e749059;color:var(--accent);background:var(--accent-dim)}.tag.off{opacity:.7}.tag.warn{border-color:#fde68a;color:#a16207;background:#fffbeb}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.section{margin:28px 0 12px}.stat-card{padding:16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.stat-card.highlight{border-color:#fbbf24;background:#fffbeb}.stat-value{font-family:var(--mono);font-size:24px;font-weight:500;color:var(--accent);line-height:1.2}.stat-label{margin-top:6px;font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}.form-card{padding:16px;margin-bottom:20px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.split-grid{display:grid;grid-template-columns:260px minmax(0,1fr);gap:16px;align-items:start}.side-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:10px;display:grid;gap:8px}.side-item{display:grid;gap:4px;text-align:left;background:transparent;color:var(--text);border:1px solid transparent}.side-item.active{background:#eefbf6;border-color:#b7ead8}.sub-panel{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}.compact td{padding:8px 10px}.form-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.form-row label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase}.form-row label.grow{flex:1;min-width:100%}.form-row label.checkbox{flex-direction:row;align-items:center;gap:8px;text-transform:none;font-family:var(--font);font-size:13px}.form-row textarea{min-height:72px;resize:vertical}.form-row label.checkbox input{width:auto}.form-actions,.row-actions{display:flex;flex-wrap:wrap;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:24px;background:#1a1f2e59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:min(560px,100%);max-height:90vh;overflow:auto;background:var(--surface);border:1px solid var(--line-bright);border-radius:var(--radius);box-shadow:0 16px 40px #1018281f}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text)}.modal-close{border:0;padding:0 4px;background:transparent;color:var(--muted);font-size:20px;line-height:1;letter-spacing:0;text-transform:none}.modal-close:hover:not(:disabled){background:transparent;color:var(--text)}.modal-body{padding:16px}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;padding:12px;gap:8px}.brand{margin:0;padding:0 8px 0 0;border:0}.sidebar nav{flex-direction:row;flex-wrap:wrap;flex:1;padding:0}.sidebar-foot{flex-direction:row;align-items:center;margin:0;padding:0;border:0}.content{padding:20px 16px}}
