:root{color:#0f172a;background:#f8fafc;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.layout{grid-template-columns:270px 1fr;min-height:100vh;display:grid}.sidebar{color:#fff;background:#0f172a;flex-direction:column;padding:24px;display:flex}.brand{align-items:center;gap:10px;margin-bottom:32px;display:flex}.brand-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 3px 10px #2563eb40}.brand-text{flex-direction:column;min-width:0;line-height:1.15;display:flex}.brand-title{color:#fff;letter-spacing:-.02em;font-size:18px;font-weight:800}.brand-sub{color:#94a3b8;letter-spacing:.01em;font-size:12px;font-weight:400}.nav{gap:6px;display:grid}.nav-item{color:#cbd5e1;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;display:flex}.nav-item.active,.nav-item:hover{color:#fff;background:#1e293b}.sidebar-footer{border-top:1px solid #1e293b;gap:8px;margin-top:auto;padding-top:20px;display:grid}.sidebar-user{color:#94a3b8;align-items:center;gap:8px;font-size:13px;display:flex}.btn-logout{color:#cbd5e1;cursor:pointer;background:0 0;border:0;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:600;display:flex}.btn-logout:hover{color:#f87171;background:#1e293b}.main{padding:28px;overflow:auto}.header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.title{margin:0;font-size:28px;font-weight:850}.subtitle{color:#64748b;margin:6px 0 0}.grid{gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;min-width:0;padding:18px;box-shadow:0 10px 30px #0f172a0a}.form-card{flex-direction:column;gap:16px;display:flex}.form-card .field{flex-direction:column;gap:6px;display:flex}.full-btn{width:100%;margin-top:4px}.metric-label{color:#64748b;font-size:14px}.metric-value{margin-top:8px;font-size:32px;font-weight:850}.toolbar{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.input{background:#fafafa;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;min-width:0;min-height:44px;padding:11px 12px;transition:border-color .15s,box-shadow .15s}.input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}select.input{cursor:pointer;appearance:auto}textarea.input{resize:vertical;min-height:80px}.btn{cursor:pointer;white-space:nowrap;border:0;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:11px 18px;font-weight:700;transition:opacity .15s;display:inline-flex}.btn-primary{color:#fff;background:#2563eb}.btn-dark{color:#fff;background:#0f172a}.btn-soft{color:#0f172a;background:#e2e8f0}.btn-danger{color:#fff;background:#dc2626}.btn-success{color:#fff;background:#16a34a}.btn:disabled{opacity:.55;cursor:not-allowed}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #e2e8f0;padding:12px}th{color:#475569;background:#f8fafc;font-size:13px}.badge{border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;display:inline-flex}.badge-pending{color:#92400e;background:#fef3c7}.badge-ok{color:#166534;background:#dcfce7}.badge-danger{color:#991b1b;background:#fee2e2}.badge-muted{color:#475569;background:#e2e8f0}.form-grid{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.field{gap:6px;display:grid}.field label{color:#475569;font-size:13px;font-weight:700}.full{grid-column:1/-1}.alert{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:14px;margin-bottom:16px;padding:12px 14px}.alert-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.slots{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px;max-height:520px;padding-right:4px;display:grid;overflow:auto}.slot{cursor:pointer;text-align:center;background:#fff;border:1px solid #cbd5e1;border-radius:12px;padding:10px;font-weight:750}.slot:hover{border-color:#2563eb}.slot.selected{color:#fff;background:#2563eb;border-color:#2563eb}.slot.busy{color:#94a3b8;cursor:not-allowed;background:#f1f5f9;text-decoration:line-through}.slot.past{color:#cbd5e1;cursor:not-allowed;background:#f8fafc}.actions{flex-wrap:wrap;gap:8px;display:flex}.loading-screen{color:#64748b;justify-content:center;align-items:center;height:100vh;font-size:18px;display:flex}.login-page{background:#0f172a;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:24px;width:100%;max-width:400px;padding:40px 36px;box-shadow:0 25px 50px #00000040}.login-header{text-align:center;margin-bottom:28px}.login-logo{color:#fff;background:#2563eb;border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 16px;display:flex}.login-header h1{margin:0;font-size:24px;font-weight:850}.login-subtitle{color:#64748b;margin:6px 0 0;font-size:14px}.login-form{gap:16px;display:grid}.login-form .field label{color:#475569;margin-bottom:4px;font-size:13px;font-weight:700;display:block}.login-form .input{background:#f8fafc}.password-wrap{position:relative}.password-wrap .input{padding-right:44px}.btn-eye{color:#94a3b8;cursor:pointer;background:0 0;border:0;padding:8px;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.btn-eye:hover{color:#475569}.login-btn{width:100%;margin-top:4px;padding:14px}.login-hint{text-align:center;color:#94a3b8;margin:20px 0 0;font-size:12px}.login-hint strong{color:#475569}.roles-picker{flex-wrap:wrap;gap:8px;display:flex}.role-chip{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:all .15s;display:inline-flex}.role-chip input[type=checkbox]{display:none}.role-chip.active{color:#fff;background:#2563eb;border-color:#2563eb}.role-chip:hover:not(.active){background:#eff6ff;border-color:#2563eb}.roles-badges{flex-wrap:wrap;gap:4px;display:flex}@media (width<=920px){.layout{grid-template-columns:1fr}.sidebar{position:static}.grid-4,.grid-2,.form-grid{grid-template-columns:1fr}.main{padding:18px}}
