*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0d0d11;--bg-surface: #13131a;--bg-card: #191922;--bg-hover: #20202c;--bg-active: #28283a;--border: #2a2a3c;--border-subtle: #1e1e2c;--text-primary: #e4e4f0;--text-secondary: #9494b0;--text-muted: #55556e;--accent: #c9a84c;--accent-light: #e2c97a;--accent-muted: rgba(201, 168, 76, .12);--accent-glow: rgba(201, 168, 76, .25);--red: #e05c5c;--green: #5cb87e;--blue: #5c8fe0;--purple: #9b6be0;--orange: #e09b5c;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 18px;--radius-full: 9999px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--duration: .15s;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 4px 20px rgba(0,0,0,.4);--shadow-lg: 0 8px 40px rgba(0,0,0,.5);--shadow-glow: 0 0 20px var(--accent-glow);--sp-12: 48px;--bg-elevated: var(--bg-card);--border-soft: var(--border);--border-muted: var(--border-subtle);--border-focus: var(--accent);--accent-hover: var(--accent-light);--danger: var(--red);--danger-muted: rgba(224,92,92,.15);--success: var(--green);--success-muted: rgba(92,184,126,.15);--text-disabled: var(--text-muted);--sidebar-width: 220px;--color-character: #a07af5;--color-place: #4ab07c;--color-faction: #d4883a;--color-item: #4a9ed9;--color-creature: #d44a4a;--color-event: #b04ad9;--color-resource: #4ad9c9;--color-lore: #d9c94a}html,body,#app{height:100%;background:var(--bg-base);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}.btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all var(--duration);white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#0d0d11}.btn-primary:not(:disabled):hover{background:var(--accent-light)}.btn-secondary{background:var(--bg-active);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:not(:disabled):hover{color:var(--text-primary);border-color:var(--text-muted)}.btn-ghost{background:none;color:var(--text-secondary);border:none}.btn-ghost:not(:disabled):hover{color:var(--text-primary);background:var(--bg-hover)}.btn-danger{background:#e05c5c26;color:var(--red);border:1px solid rgba(224,92,92,.25)}.btn-danger:not(:disabled):hover{background:#e05c5c40}.btn-sm{padding:var(--sp-1) var(--sp-3);font-size:12px}.btn-lg{padding:var(--sp-3) var(--sp-6);font-size:15px}.input{width:100%;padding:var(--sp-2) var(--sp-3);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--duration);outline:none}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.textarea{width:100%;padding:var(--sp-3);background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);resize:vertical;outline:none;line-height:1.6;min-height:80px;transition:border-color var(--duration)}.textarea:focus{border-color:var(--accent)}.textarea::placeholder{color:var(--text-muted)}.label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--sp-1);text-transform:uppercase;letter-spacing:.05em}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--sp-5)}.divider{height:1px;background:var(--border-subtle);margin:var(--sp-4) 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--sp-4)}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--sp-6);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5)}.modal-title{font-size:18px;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:18px;transition:all var(--duration)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:var(--sp-1);margin-bottom:var(--sp-4)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.form-actions{display:flex;gap:var(--sp-3);justify-content:flex-end;margin-top:var(--sp-5)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--sp-4);text-align:center;padding:var(--sp-10);color:var(--text-muted)}.empty-state-icon{font-size:48px;opacity:.5}.empty-state-text{font-size:15px;font-weight:500;color:var(--text-secondary)}.empty-state-sub{font-size:13px;color:var(--text-muted);max-width:300px;line-height:1.6}.avatar{border-radius:50%;object-fit:cover;background:var(--bg-active);flex-shrink:0}.avatar-placeholder{border-radius:50%;background:var(--accent-muted);border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent);font-weight:700;flex-shrink:0}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}
