:root{--lilac-50: #F8F4FC;--lilac-100: #E8D5F0;--lilac-300: #C39BD3;--lilac-500: #9B59B6;--lilac-700: #7B2D8E;--lilac-900: #4A1A5C;--white: #FFFFFF;--bg: #F8F4FC;--surface: #FFFFFF;--text: #2D1B36;--text-muted: #8E7A93;--radius: 12px;--shadow: 0 2px 8px rgba(155, 89, 182, .12);--shadow-lg: 0 4px 20px rgba(155, 89, 182, .18);--border: var(--lilac-100);--header-bg: var(--white);--select-bg: var(--lilac-50);--input-bg: #FFFFFF;--input-border: var(--lilac-100);--danger: #E74C3C;--success: #2ECC71}[data-theme=dark]{--lilac-50: #2D1B36;--lilac-100: #3D2848;--lilac-300: #9B59B6;--lilac-500: #C39BD3;--lilac-700: #E8D5F0;--lilac-900: #F8F4FC;--white: #1E1E32;--bg: #15152A;--surface: #1E1E32;--text: #E8E0F0;--text-muted: #9B8EB5;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .4);--border: #3D2848;--header-bg: #1E1E32;--select-bg: #2D1B36;--input-bg: #2D1B36;--input-border: #5D3D6E}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100dvh;padding-bottom:80px}#root{min-height:100dvh;display:flex;flex-direction:column}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font:inherit;color:var(--text);background:var(--input-bg);border:2px solid var(--input-border);border-radius:var(--radius);padding:10px 14px}input::placeholder,textarea::placeholder,select::placeholder{color:var(--text-muted);opacity:.7}input[type=date]{color-scheme:var(--date-scheme, light)}[data-theme=dark] input[type=date]{--date-scheme: dark}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{color-scheme:dark}a{color:inherit;text-decoration:none}input:focus,select:focus,textarea:focus,button:focus-visible{outline:2px solid var(--lilac-500);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:all .2s}.btn-primary{background:var(--lilac-500);color:var(--white);box-shadow:var(--shadow)}.btn-primary:hover{background:var(--lilac-700);transform:translateY(-1px)}.btn-outline{border:2px solid var(--lilac-300);color:var(--lilac-700)}.btn-outline:hover{background:var(--lilac-100)}.btn-sm{padding:8px 14px;font-size:.85rem}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.container{padding:16px;display:flex;flex-direction:column;gap:16px;flex:1}.main-content{flex:1;display:flex;flex-direction:column}.page-title{font-size:1.4rem;font-weight:700;color:var(--lilac-900)}.text-muted{color:var(--text-muted);font-size:.9rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--lilac-700)}.stat-label{font-size:.8rem;color:var(--text-muted)}.update-banner{position:fixed;top:0;left:0;right:0;z-index:999;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:var(--lilac-900);color:var(--lilac-50);font-size:.9rem;font-weight:600;box-shadow:var(--shadow-lg)}.update-banner-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.update-btn{padding:6px 16px;border-radius:var(--radius);background:var(--lilac-500);color:var(--white);font-weight:700;font-size:.85rem;border:none;cursor:pointer}.update-btn:hover{background:var(--lilac-700)}.update-dismiss{width:32px;height:32px;border-radius:50%;background:#ffffff26;color:var(--lilac-50);font-size:.9rem;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.update-dismiss:hover{background:#ffffff40}.toast-container{position:fixed;top:12px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--radius);font-weight:600;font-size:.9rem;box-shadow:var(--shadow-lg);animation:toast-in .3s ease-out;pointer-events:auto}@keyframes toast-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:#2ecc71;color:#fff}.toast-error{background:#e74c3c;color:#fff}.toast-info{background:var(--lilac-900);color:var(--lilac-50)}.spinner{display:inline-block;border:3px solid var(--lilac-100);border-top-color:var(--lilac-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-fullpage{display:flex;align-items:center;justify-content:center;padding:40px}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;min-height:100dvh;text-align:center;background:var(--bg)}.error-boundary-icon{font-size:4rem}.error-boundary-title{font-size:1.4rem;font-weight:700;color:var(--lilac-900)}.error-boundary-text{font-size:.95rem;color:var(--text-muted);max-width:320px}.error-boundary-detail{font-size:.8rem;color:var(--text-muted);opacity:.6;max-width:320px;word-break:break-all;font-family:monospace}.error-boundary-actions{display:flex;gap:8px;margin-top:8px}
