:root{--bg:#f4f7fb;--surface:#fff;--ink:#111827;--muted:#64748b;--line:#dbe3ef;--navy:#0b1220;--navy2:#111c33;--primary:#2563eb;--primary2:#eef5ff;--primary3:#dbeafe;--accent:#b7791f;--success:#15803d;--success2:#ecfdf5;--danger:#dc2626;--red:#dc2626;--danger2:#fef2f2;--warning:#d97706;--warning2:#fffbeb;--purple:#7c3aed;--purple2:#f5f3ff;--side:280px;--shadow:0 22px 60px rgba(15,23,42,.12);--radius:18px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:DM Sans,system-ui,sans-serif}button,input,select,textarea{font:inherit}.btn{border:0;border-radius:12px;padding:10px 15px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:.18s;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.primary{background:linear-gradient(135deg,var(--primary),#1d4ed8);color:#fff;box-shadow:0 10px 22px rgba(37,99,235,.22)}.soft{background:var(--primary2);color:var(--primary);border:1px solid var(--primary3)}.ghost{background:#fff;color:#334155;border:1px solid var(--line)}.danger{background:var(--danger2);color:var(--danger);border:1px solid #fecaca}.btn-primary,.btn.btn-primary{background:linear-gradient(135deg,var(--primary),#1d4ed8);color:#fff;border:0;box-shadow:0 10px 22px rgba(37,99,235,.22)}.btn-primary:hover,.btn.btn-primary:hover{filter:brightness(1.03)}.btn-primary:disabled,.btn.btn-primary:disabled{opacity:.58;cursor:not-allowed;transform:none;box-shadow:none;filter:none}.btn-ghost,.btn.btn-ghost{background:#fff;color:#334155;border:1px solid var(--line)}.btn-ghost:hover,.btn.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}.btn-ghost:disabled,.btn.btn-ghost:disabled{opacity:.58;cursor:not-allowed}.btn-red,.btn.btn-red{background:var(--danger2);color:var(--danger);border:1px solid #fecaca}.btn-red:hover,.btn.btn-red:hover{filter:brightness(.98)}.btn-red:disabled,.btn.btn-red:disabled{opacity:.58;cursor:not-allowed}.sm{padding:7px 10px;font-size:.82rem}.icon-btn{width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:14px;display:grid;place-items:center;position:relative;cursor:pointer;color:#334155}.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 10px;font-weight:800;font-size:.72rem}.b-ok{background:var(--success2);color:var(--success)}.b-warn{background:var(--warning2);color:var(--warning)}.b-red{background:var(--danger2);color:var(--danger)}.b-info{background:var(--primary2);color:var(--primary)}.b-purple{background:var(--purple2);color:var(--purple)}.b-gray{background:#f1f5f9;color:#475569}.form-control,.input{width:100%;padding:10px 12px;border:1.5px solid #d8e0ec;border-radius:11px;background:#fff;color:var(--ink);outline:none}.form-control:focus,.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.08)}textarea.form-control,textarea.input{min-height:92px;resize:vertical}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:.78rem;font-weight:800;color:#475569}.field small{color:var(--muted);font-size:.76rem}.login{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;background:radial-gradient(circle at 18% 12%,rgba(37,99,235,.18),transparent 34%),radial-gradient(circle at 82% 20%,rgba(183,121,31,.16),transparent 32%),linear-gradient(135deg,#f8fbff,#eef5ff 48%,#fffaf3)}.login-brand{padding:56px;display:flex;flex-direction:column;justify-content:space-between}.brand-top{display:flex;align-items:center;gap:12px;font-weight:900;font-size:1.18rem}.brand-mark{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,var(--navy),var(--primary));display:grid;place-items:center;color:#fff;box-shadow:0 4px 14px rgba(15,23,42,.1)}.login-brand h1{font-size:3.7rem;line-height:1.02;margin:78px 0 18px;color:#0f172a;max-width:680px}.login-brand p{max-width:630px;color:#475569;font-size:1.06rem;line-height:1.75}.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px;margin-top:34px}.trust-card{background:rgba(255,255,255,.78);border:1px solid rgba(219,227,239,.9);border-radius:20px;padding:18px;box-shadow:0 4px 14px rgba(15,23,42,.06)}.trust-card strong{display:block;font-size:1.35rem;color:#0f172a}.trust-card span{color:var(--muted);font-size:.86rem}.login-panel{display:grid;place-items:center;padding:38px}.login-card{width:min(480px,100%);background:#fff;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);padding:34px}.login-card h2{margin:0 0 8px;font-size:1.78rem;color:#0f172a}.login-card p{margin:0 0 24px;color:var(--muted);line-height:1.6}.login-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:12px 0 22px;color:var(--muted);font-size:.88rem}.secure-note{margin-top:18px;padding:14px;border-radius:16px;background:#f8fafc;border:1px solid var(--line);color:#64748b;font-size:.86rem;line-height:1.5}.app{display:none}.app.on{display:block}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--side);background:linear-gradient(180deg,var(--navy),var(--navy2));color:#e5e7eb;z-index:50;display:flex;flex-direction:column}.side-head{padding:22px;border-bottom:1px solid rgba(255,255,255,.08)}.side-logo{display:flex;align-items:center;gap:12px;font-weight:900}.side-logo .brand-mark{width:40px;height:40px}.side-sub{margin-top:5px;color:#94a3b8;font-size:.78rem}.astro{display:flex;gap:12px;align-items:center;padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.08)}.avatar{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,#f59e0b,#b7791f);display:grid;place-items:center;font-weight:900;color:#fff;position:relative;flex-shrink:0}.status-dot{position:absolute;right:-2px;bottom:-2px;width:13px;height:13px;border-radius:50%;background:var(--success);border:3px solid var(--navy)}.astro b{display:block}.astro span{color:#94a3b8;font-size:.78rem}.nav{padding:14px;overflow:auto;flex:1 1}.nav-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.13em;color:#94a3b8;padding:14px 10px 8px}.nav button{width:100%;border:0;background:transparent;color:#cbd5e1;display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:12px;text-align:left;font-weight:800;margin:2px 0;cursor:pointer}.nav button:hover{background:rgba(255,255,255,.07);color:#fff}.nav button.active{background:linear-gradient(135deg,var(--primary),#1d4ed8);color:#fff}.nav .count{margin-left:auto;background:#ef4444;color:#fff;border-radius:999px;font-size:.68rem;padding:2px 7px}.side-bottom{padding:14px;border-top:1px solid rgba(255,255,255,.08)}.online-card{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px;margin-bottom:8px}.online-card small{display:block;color:#94a3b8;margin-top:2px}.switch{width:48px;height:27px;border-radius:999px;background:var(--success);position:relative;border:0;cursor:pointer}.switch:after{content:"";position:absolute;width:21px;height:21px;border-radius:50%;background:#fff;right:3px;top:3px}.main{margin-left:var(--side);min-height:100vh}.topbar{height:70px;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:30}.menu{display:none}.topbar h2{margin:0;font-size:1.2rem}.top-actions{display:flex;align-items:center;gap:10px}.pulse{position:absolute;right:7px;top:7px;width:9px;height:9px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 4px rgba(220,38,38,.13)}.page{display:none;padding:28px}.page.active{display:block}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}.page-head h1{margin:0;font-size:1.65rem;color:#0f172a}.sub{margin:6px 0 0;color:var(--muted);line-height:1.6}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 10px 26px rgba(15,23,42,.04);padding:22px}.card+.card{margin-top:18px}.grid{display:grid;grid-gap:18px;gap:18px}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}.stat small{color:var(--muted);font-size:.76rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.stat b{display:block;font-size:2rem;margin-top:8px;color:#0f172a}.stat p{margin:6px 0 0}.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.search{flex:1 1;min-width:220px}.form{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:16px;gap:16px}.full{grid-column:1/-1}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px}table{width:100%;border-collapse:collapse;background:#fff;min-width:760px}th{font-size:.72rem;text-transform:uppercase;color:var(--muted);text-align:left;background:#f8fafc;padding:13px 15px;border-bottom:1px solid var(--line)}td{padding:14px 15px;border-bottom:1px solid #eef2f7}tr:last-child td{border-bottom:0}.row{display:flex;align-items:center;gap:12px}.mini{width:36px;height:36px;border-radius:12px;background:#e0e7ff;display:grid;place-items:center;font-weight:900;color:var(--primary)}.line{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}.line:last-child{border-bottom:0}.calendar{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:10px;gap:10px}.day{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px;min-height:96px}.slot{display:block;background:var(--primary2);color:var(--primary);border-radius:9px;padding:5px 7px;font-size:.75rem;font-weight:900;margin-top:6px}.blocked{background:var(--danger2);color:var(--danger)}.notification-tools{display:flex;gap:10px;flex-wrap:wrap}.notification-list{display:grid;grid-gap:12px;gap:12px}.notice{display:grid;grid-template-columns:auto 1fr auto;grid-gap:14px;gap:14px;border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff;box-shadow:0 8px 20px rgba(15,23,42,.035);position:relative}.notice.unread{background:linear-gradient(90deg,#eff6ff,#ffffff 68%);border-color:#bfdbfe;box-shadow:0 14px 30px rgba(37,99,235,.09)}.notice.read{opacity:.82}.read-label{font-size:.72rem;color:#64748b;font-weight:800}.unread-dot{width:11px;height:11px;border-radius:50%;background:transparent;margin-top:7px}.notice.unread .unread-dot{background:var(--primary);box-shadow:0 0 0 5px rgba(37,99,235,.12)}.notice h4{margin:0 0 5px;color:#0f172a}.notice.unread h4{font-weight:900}.notice p{margin:0;color:var(--muted);line-height:1.5}.notice time{display:block;margin-top:8px;color:#94a3b8;font-size:.78rem}.notice-actions{align-items:flex-start;gap:8px;justify-content:flex-end}.legend,.notice-actions{display:flex;flex-wrap:wrap}.legend{gap:14px;color:#64748b;font-size:.85rem}.legend span{display:inline-flex;align-items:center;gap:7px}.legend .sample{width:10px;height:10px;border-radius:50%;background:var(--primary)}.overlay{inset:0;background:rgba(15,23,42,.45);z-index:45}.drawer,.overlay{display:none;position:fixed}.drawer{right:0;top:0;bottom:0;width:min(540px,100%);background:#fff;z-index:60;box-shadow:-24px 0 60px rgba(15,23,42,.18);padding:24px;overflow:auto}.drawer.open,.overlay.open{display:block}.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.empty{padding:28px;text-align:center;color:var(--muted);background:#f8fafc;border:1px dashed var(--line);border-radius:16px}@media(max-width:1180px){.g3,.g4{grid-template-columns:repeat(2,1fr)}.calendar{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.login{grid-template-columns:1fr}.login-brand{padding:34px 24px}.login-brand h1{font-size:2.55rem;margin:42px 0 14px}.trust-grid{grid-template-columns:1fr}.login-panel{padding:22px}.sidebar{transform:translateX(-100%);transition:.25s}.sidebar.open{transform:translateX(0)}.overlay.mobile-open{display:block}.main{margin-left:0}.menu{display:grid}.topbar{padding:0 16px}.page{padding:18px}.page-head{flex-direction:column}.form,.g2,.g3,.g4{grid-template-columns:1fr}.full{grid-column:auto}.calendar{grid-template-columns:1fr}.hide-sm{display:none}.notice{grid-template-columns:auto 1fr}.notice-actions{grid-column:2;justify-content:flex-start}.line{align-items:flex-start}}@media(max-width:540px){.login-card{padding:24px;border-radius:24px}.login-brand h1{font-size:2.05rem}.page-head h1{font-size:1.38rem}.btn{width:100%}.toolbar .btn,.top-actions .icon-btn{width:42px}.notification-tools .btn{width:100%}.line{flex-direction:column}.stat b{font-size:1.7rem}.topbar h2{font-size:1rem}.top-actions .badge{display:none}}.data-table-toolbar{padding:20px}.data-table-search-row{margin-bottom:16px}@media (max-width:900px){body{overflow-x:clip}.main{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.toolbar,.top-actions{gap:12px}.page-head{gap:14px}.icon-btn{min-width:44px;min-height:44px}.nav button{min-height:44px;padding-top:12px;padding-bottom:12px}.table-wrap{-webkit-overflow-scrolling:touch;max-width:100%}}@media (max-width:540px){.toolbar .btn-primary,.toolbar .btn:not(.sm):not(.icon-btn),.toolbar .primary{width:100%;max-width:320px;min-height:44px;justify-content:center}.notification-tools .btn{min-height:44px}.top-actions .icon-btn{width:44px;height:44px}}