:root{--bg: #f1f5f9;--fg: #0f172a;--panel: #fff;--border: #e2e8f0;--muted: #64748b;--tab-bg: #fff;--tab-br: #cbd5e1;--th-bg: #f8fafc}[data-theme=dark]{--bg: #0f172a;--fg: #e2e8f0;--panel: #1e293b;--border: #334155;--muted: #94a3b8;--tab-bg: #1e293b;--tab-br: #475569;--th-bg: #334155}:root{font-family:system-ui,Segoe UI,Noto Sans,DejaVu Sans,sans-serif;line-height:1.5;color:var(--fg);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--fg)}.app-header{margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}#root{max-width:1200px;margin:0 auto;padding:1.25rem}h1{margin:0 0 1rem;font-size:1.35rem;font-weight:650}.tabs{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:1rem}.tab{border:1px solid var(--tab-br);background:var(--tab-bg);color:var(--fg);padding:.45rem .85rem;border-radius:8px;cursor:pointer;font-size:.9rem}.tab.active{background:#1d4ed8;color:#fff;border-color:#1d4ed8}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:1rem;margin-bottom:1rem}label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.2rem}input,select,button,textarea{font:inherit}input[type=text],input[type=password],input[type=number],input[type=date],input[type=file],select{width:100%;max-width:320px;padding:.4rem .5rem;border:1px solid var(--tab-br);border-radius:6px;margin-bottom:.65rem;background:var(--panel);color:var(--fg)}.row{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;align-items:flex-end;margin-bottom:.75rem}.btn{background:#1d4ed8;color:#fff;border:none;padding:.45rem .9rem;border-radius:6px;cursor:pointer}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.secondary{background:#64748b}.btn.danger{background:#b91c1c}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{border:1px solid var(--border);padding:.35rem .45rem;text-align:left;vertical-align:top}th{background:var(--th-bg)}.muted{color:var(--muted);font-size:.8rem}.err{color:#b91c1c;font-size:.85rem}.ok{color:#15803d;font-size:.85rem}.scroll{overflow-x:auto;max-height:60vh;overflow-y:auto}.theme-switch{position:relative;display:inline-flex;align-items:center;flex-shrink:0;width:2.75rem;height:1.5rem;vertical-align:middle}.theme-switch-input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:2}.theme-switch-input:focus-visible+.theme-switch-track{outline:2px solid #3b82f6;outline-offset:2px}.theme-switch-track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:var(--switch-off, #cbd5e1);transition:background .2s ease;pointer-events:none}.theme-switch-track:after{content:"";position:absolute;top:3px;left:3px;width:1.125rem;height:1.125rem;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s ease}[data-theme=dark] .theme-switch-track{--switch-off: #475569}.theme-switch-input:checked+.theme-switch-track{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.theme-switch-input:checked+.theme-switch-track:after{transform:translate(1.25rem)}.theme-switch-label{font-size:.8rem;color:var(--muted);-webkit-user-select:none;user-select:none}.header-theme{display:inline-flex;align-items:center;gap:.5rem}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(37,99,235,.12),transparent 50%),var(--bg)}[data-theme=dark] .login-screen{background:radial-gradient(ellipse 100% 60% at 50% 0%,rgba(59,130,246,.15),transparent 45%),var(--bg)}.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:2rem 2rem 1.75rem;box-shadow:0 4px 6px -1px #00000012,0 10px 24px -4px #00000014}[data-theme=dark] .login-card{box-shadow:0 4px 24px #00000059}.login-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem}.login-card-header h1{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;background:linear-gradient(135deg,var(--fg) 0%,var(--muted) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}[data-theme=dark] .login-card-header h1{background:linear-gradient(135deg,#f1f5f9,#94a3b8);-webkit-background-clip:text;background-clip:text}.login-theme-inline{display:flex;align-items:center;gap:.5rem;padding-top:.15rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.45rem}.login-input{display:block;width:100%;max-width:none;padding:.75rem 1rem;font-size:1rem;border:1.5px solid var(--border);border-radius:10px;background:var(--panel);color:var(--fg);margin-bottom:0;transition:border-color .15s ease,box-shadow .15s ease}.login-input::placeholder{color:var(--muted);opacity:.7}.login-input:hover{border-color:var(--tab-br)}.login-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.login-submit{width:100%;max-width:none;margin-top:.25rem;padding:.75rem 1rem;font-size:.95rem;font-weight:600;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 2px 8px #2563eb59;transition:transform .12s ease,box-shadow .12s ease}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #2563eb66}.login-submit:active:not(:disabled){transform:translateY(0)}.login-hint{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);font-size:.8rem;line-height:1.45}.login-hint code{font-size:.78em;padding:.1em .35em;border-radius:4px;background:var(--th-bg);border:1px solid var(--border)}.login-msg{margin-top:1rem;text-align:center}.app-shell{min-height:calc(100vh - 2.5rem);padding-bottom:1.5rem;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(37,99,235,.12),transparent 50%),var(--bg)}[data-theme=dark] .app-shell{background:radial-gradient(ellipse 100% 60% at 50% 0%,rgba(59,130,246,.15),transparent 45%),var(--bg)}.app-title{margin:0 0 1.25rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;background:linear-gradient(135deg,var(--fg) 0%,var(--muted) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}[data-theme=dark] .app-title{background:linear-gradient(135deg,#f1f5f9,#94a3b8);-webkit-background-clip:text;background-clip:text}.app-shell .app-header{margin-bottom:1rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:16px;background:var(--panel);box-shadow:0 4px 6px -1px #0000000d,0 10px 20px -4px #0000000f}[data-theme=dark] .app-shell .app-header{box-shadow:0 4px 20px #00000040}.app-shell .tabs{gap:.5rem;margin-bottom:1.25rem}.app-shell .tab{border:1.5px solid var(--border);background:var(--panel);padding:.5rem 1rem;border-radius:10px;font-weight:500;transition:border-color .15s ease,box-shadow .15s ease,transform .12s ease}.app-shell .tab:hover:not(.active){border-color:var(--tab-br);box-shadow:0 2px 8px #2563eb1f}.app-shell .tab.active{border-color:transparent;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 2px 10px #2563eb59}.app-shell .panel{border-radius:16px;padding:1.25rem 1.35rem;box-shadow:0 4px 6px -1px #00000012,0 10px 24px -4px #00000014}[data-theme=dark] .app-shell .panel{box-shadow:0 4px 24px #00000059}.app-shell .panel h2{font-size:1.05rem;font-weight:650;letter-spacing:-.01em}.app-shell .panel input:not([type=checkbox]):not([type=radio]):not([type=hidden]):not([type=range]):not([type=button]):not([type=submit]):not([type=reset]),.app-shell .panel select,.app-shell .panel textarea{max-width:none;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:10px;margin-bottom:.65rem;box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}[data-theme=dark] .app-shell .panel input:not([type=checkbox]):not([type=radio]):not([type=hidden]):not([type=range]):not([type=button]):not([type=submit]):not([type=reset]),[data-theme=dark] .app-shell .panel select,[data-theme=dark] .app-shell .panel textarea{color:#e2e8f0;background-color:#1e293b}.app-shell .panel input:hover,.app-shell .panel select:hover,.app-shell .panel textarea:hover{border-color:var(--tab-br)}.app-shell .panel input:focus,.app-shell .panel select:focus,.app-shell .panel textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.app-shell .btn:not(.secondary):not(.danger){border-radius:10px;font-weight:600;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 2px 8px #2563eb4d;transition:transform .12s ease,box-shadow .12s ease}.app-shell .btn:not(.secondary):not(.danger):hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #2563eb66}.app-shell .btn.secondary{background:var(--panel);color:var(--fg);border:1.5px solid var(--border);box-shadow:none;font-weight:600}.app-shell .btn.secondary:hover:not(:disabled){transform:none;border-color:var(--tab-br);background:var(--th-bg)}.app-shell .btn.danger{border-radius:10px;font-weight:600;box-shadow:0 4px 12px #00000026;border-style:solid;border-width:1px;border-color:#000}.app-shell .scroll{border:1px solid var(--border);border-radius:12px;background:var(--panel)}.app-shell table{font-size:.875rem}.app-shell th:first-child{border-top-left-radius:8px}.app-shell thead tr:first-child th:last-child{border-top-right-radius:8px}.app-shell .panel .form-row-actions{display:flex;flex-direction:column;align-self:flex-end}.app-shell .panel .form-row-actions .form-row-actions-label{display:block;font-size:.8rem;line-height:1.5;margin-bottom:.2rem;min-height:1.2em;visibility:hidden;-webkit-user-select:none;user-select:none}.app-shell .panel .form-row-actions .btn{margin-bottom:.65rem}
