:root{--life-blue: #004A80;--life-blue-dark: #00355c;--life-blue-mid: #0070c0;--life-blue-soft: #e8f4fd;--life-green: #16c79a;--life-green-dark: #0ea87f;--bg: #f7f8fa;--surface: #ffffff;--surface-soft: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #334155;--muted: #64748b;--muted-2: #94a3b8;--ok-bg: #dcfce7;--ok-fg: #16a34a;--warn-bg: #fef9c3;--warn-fg: #ca8a04;--danger-bg: #fee2e2;--danger-fg: #dc2626;--radius: 8px;--radius-sm: 6px;--radius-pill: 999px;--font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{min-width:0}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{background:var(--life-blue-dark);color:#fff;display:flex;flex-direction:column;padding:18px 14px}.brand{font-weight:700;font-size:18px;letter-spacing:.3px;padding:8px 10px 18px}.brand span{color:var(--life-green)}.nav{display:flex;flex-direction:column;gap:4px}.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#cfe3f3;font-size:14px}.nav a.active,.nav a:hover{background:#ffffff1f;color:#fff}.sidebar .role{margin-top:auto;font-size:12px;color:#9fc3e0;padding:10px}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--border)}.topbar .who{font-size:13px;color:var(--muted)}.content{padding:24px}.page-head{margin-bottom:18px}.page-head h1{margin:0;font-size:22px}.page-head p{margin:4px 0 0;color:var(--muted);font-size:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stat .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.stat .value{font-size:26px;font-weight:700;margin-top:6px;color:var(--life-blue)}.stat.green .value{color:var(--life-green-dark)}.stat .sub{font-size:12px;color:var(--muted);margin-top:4px}.stat .ico{float:right;color:var(--life-blue-mid);opacity:.8}.card-title{font-size:15px;font-weight:600;margin:0 0 2px}.card-sub{font-size:12px;color:var(--muted);margin:0 0 12px}.section{margin-top:16px}table{width:100%;min-width:640px;border-collapse:collapse;font-size:14px}th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:8px 10px}td{padding:10px;border-top:1px solid var(--border)}.tr-empty td{color:var(--muted)}.right{text-align:right}.badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:600}.badge.high{background:var(--danger-bg);color:var(--danger-fg)}.badge.medium{background:var(--warn-bg);color:var(--warn-fg)}.badge.low{background:var(--surface-soft);color:var(--muted)}.btn{border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--radius-sm);padding:6px 12px;font-size:13px;font-weight:500}.btn:hover{border-color:var(--life-blue-mid)}.btn.primary{background:var(--life-blue);border-color:var(--life-blue);color:#fff}.btn.primary:hover{background:var(--life-blue-dark)}.btn.sm{padding:4px 10px;font-size:12px}.row-actions{display:flex;gap:8px;justify-content:flex-end}.state{padding:28px;text-align:center;color:var(--muted)}.state.error{color:var(--danger-fg)}.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#f7f8fa 0%,var(--life-blue-soft) 58%,#e9fbf6 100%);padding:16px}.login-card{background:var(--surface);border-radius:var(--radius);padding:28px;width:100%;max-width:360px}.login-card h1{margin:8px 0 2px;font-size:22px}.login-card h1 span{color:var(--life-green)}.login-card p{margin:0 0 18px;color:var(--muted);font-size:13px}.field{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px}.err{color:var(--danger-fg);font-size:13px;margin-bottom:8px}.ok{color:var(--ok-fg);font-size:13px;margin-bottom:8px}.ticket-form{display:grid;grid-template-columns:minmax(0,1fr) 160px;gap:10px;align-items:start}.ticket-form input,.ticket-form textarea,.ticket-form select{font:inherit}.ticket-form textarea,.ticket-form input,.ticket-form .err,.ticket-form .ok,.ticket-form button{grid-column:1 / -1}@media (max-width: 900px){.shell{grid-template-columns:minmax(0,1fr)}.sidebar{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:auto minmax(0,1fr);grid-template-areas:"brand role" "nav nav";gap:8px 12px;padding:10px 12px}.brand{grid-area:brand;padding:0;font-size:16px;align-self:center}.nav{grid-area:nav;flex-direction:row;gap:8px;overflow-x:auto;padding-bottom:2px}.nav a{flex:0 0 auto;padding:8px 10px;white-space:nowrap}.sidebar .role{grid-area:role;margin-top:0;padding:0;justify-self:end;align-self:center;text-align:right;font-size:11px}.topbar{padding:10px 14px}.content{padding:14px}.page-head h1{font-size:20px;overflow-wrap:anywhere}.grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,150px),1fr));gap:10px}.card{padding:12px}.stat .value{font-size:22px}.row-actions{flex-wrap:wrap;justify-content:flex-start}.ticket-form{grid-template-columns:minmax(0,1fr)}th,td{padding:8px}}
