.dropzone-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;background:#0f1115c7;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.dropzone-overlay:not(.busy){border:3px dashed var(--accent);border-radius:12px;box-shadow:inset 0 0 0 4px #c4a55a26}.dropzone-card{display:flex;flex-direction:column;align-items:center;gap:14px;pointer-events:none;text-align:center;color:var(--text)}.dropzone-icon{font-size:56px}.dropzone-title{font-size:22px;font-weight:600;color:var(--accent)}.dropzone-sub{font-size:13px;color:var(--text-dim)}:root{--bg: #0f1115;--bg-elev: #161922;--bg-card: #1d2030;--bg-hover: #232739;--border: #2a2f42;--border-strong: #3a4055;--text: #d8dee9;--text-dim: #8a91a6;--text-faint: #5b6178;--accent: #c4a55a;--accent-dim: #7a6a3a;--accent-glow: rgba(196, 165, 90, .5);--link: #8ab8d8;--danger: #c8503f;--ok: #6a9a5a;--c-mystery: #c8503f;--c-faction: #d68641;--c-npc: #c4a55a;--c-setting: #6a9a5a;--c-pc: #5a9ab8;--c-mech: #a570c8;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", "Hiragino Sans GB", sans-serif;--mono: "JetBrains Mono", "Cascadia Code", "Consolas", monospace;--header-h: 50px;--sidebar-w: 270px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;overflow:hidden;-webkit-font-smoothing:antialiased}button{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.app{display:grid;grid-template-rows:var(--header-h) 1fr;grid-template-columns:var(--sidebar-w) 1fr;grid-template-areas:"header header" "sidebar main";height:100vh}.app.sidebar-collapsed{grid-template-columns:0 1fr}.topbar{grid-area:header;background:var(--bg-elev);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 14px;z-index:30}.topbar .brand{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--accent);letter-spacing:.5px;white-space:nowrap}.topbar .brand .icon{font-size:18px}.topbar .spacer{flex:1}.tabs{display:flex;gap:2px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:3px}.tabs button{background:transparent;border:none;color:var(--text-dim);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:6px;transition:all .12s}.tabs button:hover{color:var(--text);background:var(--bg-hover)}.tabs button.active{background:var(--accent);color:#1a1a1a;font-weight:600}.btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;transition:all .12s;display:inline-flex;align-items:center;gap:6px}.btn:hover{background:var(--bg-hover);border-color:var(--accent-dim)}.btn.primary{background:var(--accent);color:#1a1a1a;border-color:var(--accent);font-weight:600}.btn.primary:hover{filter:brightness(1.08)}.btn.danger:hover{border-color:var(--danger);color:var(--danger)}.btn.icon{padding:6px 9px}.btn:disabled{opacity:.45;cursor:not-allowed}input[type=text],input[type=search],input[type=password],textarea,select{background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;font-size:13px;font-family:inherit;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--accent-dim)}.sidebar{grid-area:sidebar;background:var(--bg-elev);border-right:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column}.sidebar-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);padding:14px 16px 6px;display:flex;align-items:center;justify-content:space-between}.campaign-switch{padding:10px 12px;border-bottom:1px solid var(--border)}.campaign-current{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;border:1px solid var(--border);background:var(--bg-card)}.campaign-current:hover{border-color:var(--accent-dim)}.campaign-current .cc-icon{font-size:20px}.campaign-current .cc-name{font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.campaign-current .cc-caret{color:var(--text-dim);font-size:11px}.note-list{overflow-y:auto;flex:1;padding:4px 8px 16px}.note-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;cursor:pointer;color:var(--text-dim);font-size:13px;white-space:nowrap;overflow:hidden}.note-item:hover{background:var(--bg-hover);color:var(--text)}.note-item.active{background:var(--bg-card);color:var(--accent)}.note-item .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.note-item .label{overflow:hidden;text-overflow:ellipsis}.main{grid-area:main;position:relative;overflow:hidden;background:var(--bg)}.center-msg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-dim)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-wrap{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 40%,#181b26,var(--bg))}.login-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:36px 34px;width:340px;text-align:center;box-shadow:0 24px 60px #00000080}.login-card h1{color:var(--accent);font-size:22px;margin:0 0 6px}.login-card p{color:var(--text-dim);font-size:13px;margin:0 0 22px}.login-card input{width:100%;margin-bottom:12px;text-align:center}.login-card .btn{width:100%;justify-content:center}.login-card .err{color:var(--danger);font-size:12px;min-height:16px;margin-bottom:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:22px 24px;width:420px;max-width:92vw;box-shadow:0 20px 50px #00000080}.modal h2{margin:0 0 16px;font-size:17px;color:var(--accent)}.modal .field{margin-bottom:14px}.modal .field label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:5px}.modal .field input,.modal .field textarea{width:100%}.modal .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.campaign-grid{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto;margin-bottom:14px}.campaign-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);cursor:pointer;background:var(--bg-card)}.campaign-row:hover{border-color:var(--accent-dim);background:var(--bg-hover)}.campaign-row.active{border-color:var(--accent)}.campaign-row .cr-icon{font-size:22px}.campaign-row .cr-body{flex:1;overflow:hidden}.campaign-row .cr-name{font-weight:600}.campaign-row .cr-meta{font-size:11px;color:var(--text-dim)}.toast{position:fixed;bottom:18px;left:50%;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text);padding:9px 16px;border-radius:8px;font-size:13px;z-index:200;box-shadow:0 8px 24px #0006;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast.err{border-color:var(--danger)}.toast.ok{border-color:var(--ok)}.save-indicator{font-size:11px;color:var(--text-faint);display:flex;align-items:center;gap:5px}.save-indicator.saving{color:var(--accent)}.save-indicator.saved{color:var(--ok)}
