:root{--brand: #1f3a5f;--accent: #2563eb;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--card: #ffffff;--bg: #f1f5f9;--ok: #047857;--warn: #b45309;--danger: #dc2626;font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);-webkit-text-size-adjust:100%}#root{display:flex;flex-direction:column;min-height:100%}a{color:var(--accent)}.muted{color:var(--muted)}.small{font-size:12px}.ltr{direction:ltr;unicode-bidi:isolate}.loading{display:flex;align-items:center;gap:10px;padding:20px 4px}.route-fallback{display:grid;place-items:center;min-height:60vh}.spinner{display:inline-block;width:18px;height:18px;border-radius:50%;border:2px solid rgba(37,99,235,.25);border-top-color:var(--accent);animation:spin .7s linear infinite}.spinner-lg{width:34px;height:34px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spinner{animation-duration:1.6s}}.auth-shell{flex:1;display:grid;place-items:center;padding:32px 16px}.auth-card{background:var(--card);border-radius:12px;box-shadow:0 4px 24px #1f3a5f1a;padding:28px;width:100%;max-width:380px}.auth-brand{display:flex;align-items:center;gap:12px}.auth-brand h1{margin:0;color:var(--brand);font-size:20px}.auth-logo{display:grid;place-items:center;height:40px;width:40px;border-radius:10px;background:var(--brand);color:#fff;font-size:20px;font-weight:700}.auth-card form{display:flex;flex-direction:column;gap:12px;margin-top:18px}.auth-card label{display:flex;flex-direction:column;gap:4px;font-size:13px}.auth-card input{font-size:16px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff}.auth-card button[type=submit]{margin-top:4px;background:var(--brand);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:15px;font-weight:600;cursor:pointer}.auth-card button[disabled]{opacity:.6}.shell{flex:1;display:flex;flex-direction:column;min-height:100vh}.shell-header{background:var(--brand);color:#fff;padding:10px 16px;display:flex;align-items:center;gap:12px}.brand{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:700;text-decoration:none;margin-right:auto}.brand-name{color:#fff;white-space:nowrap;font-size:15px}.shell-header-right{display:flex;align-items:center;gap:10px}.btn-ghost{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.28);border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer}.hamburger{display:none;place-items:center;width:40px;height:40px;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.28);border-radius:8px;font-size:18px;cursor:pointer}.shell-body{flex:1;display:flex;align-items:stretch}.sidebar{width:200px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);padding:16px 12px}.sidebar-nav{display:flex;flex-direction:column;gap:4px}.sidebar-nav a{display:block;color:var(--text);text-decoration:none;font-size:14px;padding:10px 12px;border-radius:8px;border:1px solid transparent}.sidebar-nav a:hover{background:#f1f5f9}.sidebar-nav a.active{background:#2563eb1a;border-color:#2563eb59;color:var(--accent);font-weight:600}.sidebar-backdrop{display:none}.shell-main{flex:1;min-width:0;max-width:960px;width:100%;margin:0 auto;padding:24px 24px 64px;display:flex;flex-direction:column}.page-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.page-head h1{margin:0;color:var(--brand);font-size:22px}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff;background:var(--muted)}.badge-ok{background:var(--ok)}.badge-warn{background:var(--warn)}.badge-link{text-decoration:none;cursor:pointer}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.search-input{flex:1;min-width:180px;padding:10px 12px;font-size:16px;border:1px solid var(--border);border-radius:8px;background:#fff}.toolbar select{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff}.data-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.data-table th,.data-table td{padding:10px 12px;text-align:left;font-size:14px;border-bottom:1px solid var(--border)}.data-table th{background:#f8fafc;color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px}.data-table tbody tr{cursor:pointer}.data-table tbody tr:hover{background:#f8fafc}.empty{padding:28px 16px;text-align:center;color:var(--muted);background:var(--card);border:1px dashed var(--border);border-radius:10px}.form{display:flex;flex-direction:column;gap:16px}.form-section{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px 20px}.form-section h2{margin:0 0 12px;color:var(--brand);font-size:15px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px}.form-grid .span-2{grid-column:span 2}.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px}.form-grid input,.form-grid select{padding:9px 11px;font-size:14px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:inherit}.field-error{color:var(--danger);font-size:12px}.error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;padding:10px 12px;border-radius:8px;font-size:13px}.banner{padding:10px 14px;border-radius:8px;font-size:13px}.banner-ok{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.form-actions{display:flex;justify-content:flex-end;gap:12px}.btn-primary{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}.btn-primary[disabled]{opacity:.6}.page-actions .btn-ghost,.form-actions .btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-danger{color:var(--danger);border-color:#fecaca}.kv{display:grid;grid-template-columns:140px 1fr;row-gap:8px;column-gap:14px;margin:0}.kv dt{color:var(--muted);font-size:13px}.kv dd{margin:0;font-size:14px}.pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px}.pager .btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border)}.pager .btn-ghost[disabled]{opacity:.5}.back-button{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--brand);border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;margin-bottom:12px;min-height:40px}@media (hover: none) and (pointer: coarse){.btn-primary,.btn-ghost,.back-button,input,select{min-height:44px}input,select{font-size:16px}}@media (max-width: 640px){.hamburger{display:grid}.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;z-index:60;transform:translate(-100%);transition:transform .2s ease;box-shadow:0 0 32px #0f172a40;padding-top:64px}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:55}.shell-main{padding:16px 14px 80px}.page-head{flex-direction:column;align-items:stretch;gap:8px}.form-grid{grid-template-columns:1fr}.form-grid .span-2{grid-column:span 1}.kv{grid-template-columns:1fr}.kv dt{margin-top:6px}.data-table,.data-table thead,.data-table tbody,.data-table tr,.data-table td{display:block}.data-table{border:none;background:transparent}.data-table thead{display:none}.data-table tr{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px 14px;margin-bottom:8px}.data-table td{display:flex;justify-content:space-between;gap:12px;padding:4px 0;border:none;text-align:right}.data-table td:before{content:attr(data-label);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;text-align:left}}
