:root{--navy:#031b45;--navy-2:#0a2c67;--navy-3:#08224f;--bg:#edf3ff;--bg-2:#f8fbff;--surface:#ffffff;--surface-soft:rgba(255,255,255,.78);--text:#0f172a;--text-2:#334155;--muted:#526079;--muted-2:#94a3b8;--line:#e2e8f0;--line-soft:#eef2f7;--line-strong:#bfd2ff;--shadow:0 4px 16px rgba(15,23,42,.06);--shadow-md:0 10px 30px rgba(15,23,42,.08);--shadow-lg:0 18px 50px rgba(15,23,42,.14);--radius-xs:8px;--radius-sm:10px;--radius:14px;--radius-lg:20px;--sidebar-w:248px;--sidebar-w-collapsed:72px;--topbar-h:64px;--mobile-nav-h:64px;--sat:env(safe-area-inset-top);--sab:env(safe-area-inset-bottom);--sal:env(safe-area-inset-left);--sar:env(safe-area-inset-right);--success:#16a34a;--success-bg:#dcfce7;--warning:#d97706;--warning-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee2e2;--info:#2563eb;--info-bg:#dbeafe;--green:#15803d;--green-bg:#dcfce7;--blue:#1d4ed8;--blue-bg:#dbeafe;--purple:#7e22ce;--purple-bg:#f3e8ff}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:Raleway,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg);line-height:1.5;font-size:15px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}img{display:block;max-width:100%;height:auto}a{color:var(--navy-2);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}:focus{outline:none}:focus-visible{outline:2px solid var(--navy-2);outline-offset:2px;border-radius:6px}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:1fr;min-height:100vh;background:var(--bg)}.app-main{display:flex;flex-direction:column;min-width:0;min-height:100vh}.app-content{flex:1;padding:24px;max-width:100%}@media (max-width: 1024px){.app-shell{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.app-content{padding:20px 18px}}@media (max-width: 767px){.app-shell{grid-template-columns:1fr}.app-content{padding:20px 16px;padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));padding-bottom:calc(var(--mobile-nav-h) + max(20px,env(safe-area-inset-bottom)))}}.sidebar{background:linear-gradient(180deg,var(--navy),var(--navy-2));color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:50}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar-brand .mark{width:36px;height:36px;border-radius:50%;background:#fff;color:var(--navy);display:grid;place-items:center;font-weight:900;font-size:16px;flex-shrink:0}.sidebar-brand strong{font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-brand small{display:block;font-size:11px;color:#fff9;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.sidebar-nav{flex:1;padding:10px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:#ffffffc7;font-size:14px;font-weight:600;transition:.18s;text-decoration:none;position:relative}.sidebar-link:hover{background:#ffffff14;color:#fff;text-decoration:none}.sidebar-link.active{background:#ffffff24;color:#fff;font-weight:700}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#fff;border-radius:0 4px 4px 0}.sidebar-link svg{width:20px;height:20px;flex-shrink:0}.sidebar-link .badge{margin-left:auto;background:#fff;color:var(--navy);font-size:11px;font-weight:800;padding:2px 7px;border-radius:999px;min-width:20px;text-align:center}.sidebar-foot{padding:14px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;color:#ffffff80;display:flex;align-items:center;gap:8px}@media (max-width:1024px){.sidebar-brand strong,.sidebar-brand small,.sidebar-link span,.sidebar-link .badge,.sidebar-foot{display:none}.sidebar-link{justify-content:center;padding:12px}.sidebar-brand{justify-content:center;padding:14px 8px}.mobile-drawer .sidebar-link span{display:block}.mobile-drawer .sidebar-link .badge{display:inline-block}.mobile-drawer .sidebar-brand strong,.mobile-drawer .sidebar-brand small{display:block}.mobile-drawer .sidebar-link{justify-content:flex-start;padding:11px 14px}.mobile-drawer .sidebar-brand{justify-content:flex-start;padding:18px 20px}}@media (max-width:767px){.sidebar{display:none}}.topbar{min-height:var(--topbar-h);height:calc(var(--topbar-h) + env(safe-area-inset-top));background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:flex-end;padding:0 24px;padding-top:env(safe-area-inset-top);padding-bottom:10px;position:sticky;top:0;z-index:40;gap:16px}.topbar h1{font-size:18px;font-weight:800;color:var(--navy);margin:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.icon-btn{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:var(--text-2);background:transparent;transition:.18s;position:relative}.icon-btn:hover{background:var(--bg);color:var(--navy)}.icon-btn svg{width:20px;height:20px}.icon-btn .dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}.user-menu{position:relative}.user-trigger{display:flex;align-items:center;gap:10px;padding:6px 10px 6px 6px;border-radius:999px;background:var(--bg);transition:.18s}.user-trigger:hover{background:var(--line-soft)}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;flex-shrink:0}.user-name{font-size:13px;font-weight:700;color:var(--navy)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);min-width:200px;padding:6px;z-index:100}.user-dropdown button,.user-dropdown a{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:8px;font-size:14px;font-weight:600;color:var(--text);background:transparent;text-align:left}.user-dropdown button:hover,.user-dropdown a:hover{background:var(--bg);text-decoration:none}.user-dropdown svg{width:16px;height:16px;color:var(--muted)}.user-dropdown .divider{height:1px;background:var(--line);margin:4px 0}.menu-toggle{display:none}@media (max-width:767px){.topbar{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.topbar h1{font-size:16px}.menu-toggle{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:transparent;color:var(--navy)}.user-name{display:none}.user-trigger{padding:4px}}.mobile-nav{display:none}@media (max-width:767px){.mobile-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-top:1px solid var(--line);z-index:60;padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);height:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom));box-shadow:0 -4px 20px #0f172a0d}.mobile-nav-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--muted);font-size:10px;font-weight:700;text-decoration:none;transition:.15s}.mobile-nav-link.active{color:var(--navy)}.mobile-nav-link svg{width:22px;height:22px}.mobile-nav-link:hover{text-decoration:none}}.mobile-drawer-overlay{display:none;position:fixed;inset:0;background:#0f172a80;z-index:90;backdrop-filter:blur(4px)}.mobile-drawer-overlay.open{display:block}.mobile-drawer{position:fixed;left:0;top:0;bottom:0;width:280px;background:linear-gradient(180deg,var(--navy),var(--navy-2));color:#fff;z-index:100;transform:translate(-100%);transition:transform .28s ease;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top)}.mobile-drawer.open{transform:translate(0)}.page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-header h2{font-size:clamp(20px,2.4vw,26px);font-weight:800;color:var(--navy);margin-bottom:4px}.page-header .subtitle{color:var(--muted);font-size:14px}.page-header-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:9px 16px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:13px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:.18s;white-space:nowrap;user-select:none}.btn:hover{background:var(--bg);border-color:var(--line-strong)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px;flex-shrink:0}.btn-primary{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;border-color:var(--navy)}.btn-primary:hover{background:var(--navy-3);color:#fff;border-color:var(--navy-3)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#15803d;color:#fff}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#b91c1c;color:#fff}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--bg);color:var(--navy)}.btn-outline{background:transparent;border-color:var(--line-strong);color:var(--navy)}.btn-outline:hover{background:var(--bg);color:var(--navy)}.btn-sm{min-height:32px;padding:6px 12px;font-size:12px;border-radius:8px}.btn-sm svg{width:14px;height:14px}.btn-lg{min-height:48px;padding:12px 22px;font-size:14px;border-radius:12px}.btn-icon{padding:9px;min-width:40px}.btn-block{width:100%}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-pad{padding:20px}.card-head{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-head h3{font-size:15px;font-weight:800;color:var(--navy);margin:0}.card-foot{padding:14px 20px;border-top:1px solid var(--line);background:var(--bg-2)}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden;transition:.2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card .stat-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--navy),var(--navy-2));margin-bottom:6px}.stat-card .stat-icon svg{width:20px;height:20px}.stat-card .stat-icon.success{background:linear-gradient(135deg,#16a34a,#15803d)}.stat-card .stat-icon.warning{background:linear-gradient(135deg,#d97706,#b45309)}.stat-card .stat-icon.danger{background:linear-gradient(135deg,#dc2626,#b91c1c)}.stat-card .stat-icon.info{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.stat-card .stat-value{font-size:clamp(22px,2.6vw,30px);font-weight:900;color:var(--navy);line-height:1}.stat-card .stat-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-trend{font-size:12px;font-weight:600;color:var(--success)}.stat-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:10px}@media (min-width:900px){.stat-grid{grid-template-columns:repeat(4,1fr)!important;gap:16px}}@media (max-width:899px){.stat-card{padding:14px 12px;gap:5px}.stat-card .stat-icon{width:32px;height:32px;border-radius:8px;margin-bottom:4px}.stat-card .stat-icon svg{width:16px;height:16px}.stat-card .stat-value{font-size:clamp(18px,5vw,26px)}.stat-card .stat-label{font-size:10px;letter-spacing:.03em}}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;font-weight:700;color:var(--navy)}.field .help{font-size:12px;color:var(--muted)}.input,.select,.textarea{width:100%;padding:10px 14px;border:1.5px solid var(--line);border-radius:10px;background:var(--surface);font-size:14px;color:var(--text);min-height:42px;transition:.18s}.input:focus,.select:focus,.textarea:focus{border-color:var(--navy-2);box-shadow:0 0 0 3px #0a2c671f}.textarea{min-height:90px;resize:vertical}.input-group{display:flex;align-items:center;background:var(--surface);border:1.5px solid var(--line);border-radius:10px;padding:0 12px;gap:8px;transition:.18s}.input-group:focus-within{border-color:var(--navy-2);box-shadow:0 0 0 3px #0a2c671f}.input-group input{border:0;background:transparent;flex:1;padding:10px 0;min-height:42px;outline:none}.input-group svg{width:18px;height:18px;color:var(--muted);flex-shrink:0}.input-group .clear{background:transparent;color:var(--muted);width:24px;height:24px;border-radius:50%;display:grid;place-items:center}.input-group .clear:hover{background:var(--bg);color:var(--navy)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.04em;background:var(--bg);color:var(--text-2);white-space:nowrap;border:1px solid transparent}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-green{background:var(--green-bg);color:var(--green)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-navy{background:#031b451a;color:var(--navy)}.badge-soft{background:var(--bg);color:var(--text-2);border:1px solid var(--line)}.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.table-toolbar{padding:14px 16px;display:flex;flex-wrap:wrap;align-items:center;gap:10px;border-bottom:1px solid var(--line);background:var(--bg-2)}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table.data{width:100%;border-collapse:collapse;font-size:14px;min-width:680px}table.data th,table.data td{padding:12px 14px;text-align:left;vertical-align:middle;border-bottom:1px solid var(--line)}table.data thead th{background:var(--bg-2);font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;position:sticky;top:0;white-space:nowrap}table.data tbody tr{transition:background .15s}table.data tbody tr:hover{background:var(--bg-2)}table.data tbody tr:last-child td{border-bottom:0}table.data .row-actions{display:flex;gap:4px;justify-content:flex-end}.row-card{display:none;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:10px;box-shadow:var(--shadow)}.row-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}.row-card-name{font-weight:800;color:var(--navy);font-size:15px}.row-card-meta{font-size:12px;color:var(--muted);margin-top:2px}.row-card-body{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:13px;margin:8px 0}.row-card-body .k{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.row-card-body .v{color:var(--text);font-weight:600}.row-card-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:8px}@media (max-width:767px){.table-wrap.hide-mobile{display:none}.row-card{display:block}}.swipe-wrap{position:relative;overflow:hidden;border-radius:var(--radius);margin-bottom:10px;touch-action:pan-y}.swipe-wrap .row-card{margin-bottom:0;border-radius:var(--radius)}.swipe-action{position:absolute;top:0;bottom:0;display:flex;align-items:center;gap:6px;padding:0 22px;font-weight:700;font-size:13px;color:#fff;pointer-events:none;transition:opacity .18s ease;white-space:nowrap}.swipe-action svg{width:18px;height:18px;flex-shrink:0}.swipe-action-delete{left:0;background:var(--danger)}.swipe-action-assign{right:0;background:#16a34a}.swipe-confirm-btn{display:flex;align-items:center;gap:7px;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.5);border-radius:10px;color:#fff;font-weight:800;font-size:14px;padding:9px 16px;cursor:pointer;pointer-events:auto;white-space:nowrap}.swipe-confirm-btn:active{background:#ffffff52}@keyframes cardExitLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-110%);opacity:0}}@keyframes cardExitRight{0%{transform:translate(0);opacity:1}to{transform:translate(110%);opacity:0}}.card-exit-left{animation:cardExitLeft .36s cubic-bezier(.4,0,.8,1) forwards;pointer-events:none}.card-exit-right{animation:cardExitRight .36s cubic-bezier(.4,0,.8,1) forwards;pointer-events:none}.modal-backdrop{position:fixed;inset:0;background:#0f172a80;backdrop-filter:blur(4px);z-index:250;display:grid;place-items:center;padding:16px;overflow-y:auto;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:calc(100vh - 32px);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-head h3{font-size:17px;font-weight:800;color:var(--navy);margin:0}.modal-body{padding:22px;overflow-y:auto;flex:1}.modal-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;background:var(--bg-2)}.modal-lg{max-width:760px}.modal-xl{max-width:960px}.form-ctrl{width:100%;padding:10px 13px;border:1.5px solid var(--line-strong);border-radius:10px;font-family:inherit;font-size:16px;color:var(--text);background:#fff;transition:border-color .18s;min-height:42px;box-sizing:border-box}.form-ctrl:focus{outline:none;border-color:var(--navy-2);box-shadow:0 0 0 3px #0a2c6714}.form-ctrl::placeholder{color:var(--muted)}select.form-ctrl{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23526079' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.drawer-backdrop{position:fixed;inset:0;background:#0f172a80;backdrop-filter:blur(3px);z-index:200;animation:fadeIn .15s}.drawer{position:fixed;right:0;top:0;bottom:0;width:min(560px,100vw);background:var(--surface);z-index:201;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideInRight .25s ease-out}@keyframes slideInRight{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}.empty-state .icon{width:64px;height:64px;border-radius:50%;background:var(--bg);display:grid;place-items:center;margin:0 auto 14px;color:var(--muted-2)}.empty-state .icon svg{width:32px;height:32px}.empty-state h4{color:var(--text);font-size:16px;font-weight:800;margin-bottom:6px}.empty-state p{font-size:14px;line-height:1.55;max-width:380px;margin:0 auto 16px}.skeleton{background:linear-gradient(90deg,var(--line-soft) 0%,var(--line) 50%,var(--line-soft) 100%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:6px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{width:24px;height:24px;border:2.5px solid var(--line);border-top-color:var(--navy-2);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:300;max-width:calc(100vw - 40px)}@media (max-width:767px){.toast-stack{bottom:calc(var(--mobile-nav-h) + 16px);right:14px;left:14px;max-width:none}}.toast{background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:12px 16px;display:flex;align-items:flex-start;gap:10px;min-width:240px;max-width:380px;animation:slideInRight .25s ease-out}.toast.success{border-left:4px solid var(--success)}.toast.error{border-left:4px solid var(--danger)}.toast.info{border-left:4px solid var(--info)}.toast .toast-icon{flex-shrink:0;width:20px;height:20px;display:grid;place-items:center;margin-top:1px}.toast .toast-text{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;flex:1}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top left,rgba(255,255,255,.95),transparent 28%),radial-gradient(circle at right 20%,rgba(177,207,255,.24),transparent 24%),linear-gradient(180deg,#eef4ff,#e7efff 35%,#f7faff)}.login-card{background:var(--surface);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-lg);padding:36px;width:100%;max-width:420px}.login-brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:24px}.login-brand .mark{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;display:grid;place-items:center;font-weight:900;font-size:20px}.login-brand strong{font-size:18px;font-weight:900;color:var(--navy);text-transform:uppercase;letter-spacing:.08em}.login-card h1{text-align:center;font-size:22px;font-weight:800;color:var(--navy);margin-bottom:6px}.login-card .sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:26px}.login-card .demo-hint{margin-top:14px;padding:12px;background:var(--bg);border-radius:10px;font-size:12px;color:var(--muted);text-align:center}.login-card .demo-hint code{background:var(--surface);padding:2px 6px;border-radius:4px;font-family:monospace;color:var(--navy);font-weight:700}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.row-between{display:flex;justify-content:space-between;align-items:center;gap:12px}.col{display:flex;flex-direction:column;gap:8px}.muted{color:var(--muted)}.small{font-size:12px}.bold{font-weight:800}.nowrap{white-space:nowrap}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.divider{height:1px;background:var(--line);margin:14px 0}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.kv{display:grid;grid-template-columns:140px 1fr;gap:8px 12px;font-size:14px}.kv .k{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.kv .v{color:var(--text);font-weight:600}@media (max-width:480px){.kv{grid-template-columns:1fr}.kv .k{margin-top:6px}}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 16px;font-size:13px;font-weight:700;color:var(--muted);background:transparent;border-bottom:2px solid transparent;white-space:nowrap;transition:.18s}.tab:hover{color:var(--navy)}.tab.active{color:var(--navy);border-bottom-color:var(--navy)}.pill-group{display:flex;flex-wrap:wrap;gap:6px}.pill-check{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border:1.5px solid var(--line);border-radius:999px;background:var(--surface);font-size:12px;font-weight:700;color:var(--text-2);cursor:pointer;transition:.15s}.pill-check input{position:absolute;opacity:0;pointer-events:none}.pill-check:hover{border-color:var(--navy-2);color:var(--navy)}.pill-check:has(input:checked){background:var(--navy);color:#fff;border-color:var(--navy)}.fab{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;display:grid;place-items:center;box-shadow:0 12px 30px #031b454d;z-index:50;transition:.2s}.fab:hover{transform:scale(1.06)}.fab svg{width:24px;height:24px}@media (max-width:767px){.fab{bottom:calc(var(--mobile-nav-h) + 16px)}}.calendar-grid{display:grid;grid-template-columns:60px repeat(7,1fr);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:12px}.calendar-grid .cal-h{padding:10px 6px;background:var(--bg-2);border-bottom:1px solid var(--line);font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;text-align:center}.calendar-grid .cal-time{padding:8px 6px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);text-align:center;color:var(--muted);font-weight:700;font-size:11px}.calendar-grid .cal-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:60px;padding:4px;position:relative}.cal-event{background:var(--navy);color:#fff;border-radius:6px;padding:6px 8px;font-size:11px;font-weight:700;cursor:pointer;transition:.15s;margin-bottom:3px;border-left:4px solid rgba(255,255,255,.4)}.cal-event:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.cal-event.cancelled{opacity:.5;text-decoration:line-through}.cal-event small{display:block;font-weight:500;font-size:10px;opacity:.85}@media (max-width:880px){.calendar-grid{font-size:10px;grid-template-columns:42px repeat(7,1fr)}}
