@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@300;400;500&display=swap);:root{--bg:#f0f4f8;--bg2:#fff;--bg3:#f8fafc;--bg4:#eef2f7;--border:#e2e8f0;--border2:#cbd5e1;--text:#0f172a;--text2:#475569;--text3:#94a3b8;--primary:#1e40af;--primary-l:#3b82f6;--primary-dim:#3b82f61a;--primary-dim2:#3b82f62e;--accent:#0ea5e9;--green:#059669;--green-dim:#0596691a;--red:#dc2626;--red-dim:#dc26261a;--amber:#d97706;--amber-dim:#d977061a;--purple:#7c3aed;--purple-dim:#7c3aed1a;--shadow-sm:0 1px 3px #0f172a14,0 1px 2px #0f172a0f;--shadow:0 4px 16px #0f172a1a,0 2px 6px #0f172a0f;--shadow-lg:0 20px 48px #0f172a24,0 8px 20px #0f172a14;--radius:10px;--radius-lg:16px;--radius-xl:24px;--transition:0.16s cubic-bezier(0.4,0,0.2,1);--font:"Plus Jakarta Sans",system-ui,sans-serif;--font-mono:"JetBrains Mono",monospace;--sidebar-w:240px}[data-theme=dark]{--bg:#0a0f1e;--bg2:#111827;--bg3:#1a2236;--bg4:#1e2d45;--border:#ffffff12;--border2:#ffffff21;--text:#f1f5f9;--text2:#94a3b8;--text3:#475569;--primary:#3b82f6;--primary-l:#60a5fa;--primary-dim:#3b82f61f;--primary-dim2:#3b82f638;--accent:#38bdf8;--green:#10b981;--green-dim:#10b9811f;--red:#f87171;--red-dim:#f871711f;--amber:#fbbf24;--amber-dim:#fbbf241f;--purple:#a78bfa;--purple-dim:#a78bfa1f;--shadow-sm:0 1px 3px #0006;--shadow:0 4px 20px #00000080;--shadow-lg:0 20px 60px #0009}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{-webkit-font-smoothing:antialiased;background:#f0f4f8;background:var(--bg);color:#0f172a;color:var(--text);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font);font-weight:400;min-height:100vh;transition:background .16s cubic-bezier(.4,0,.2,1),color .16s cubic-bezier(.4,0,.2,1);transition:background var(--transition),color var(--transition)}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--border2);border-radius:3px}h1,h2,h3{font-weight:600;line-height:1.25}h1{font-size:1.6rem}h2{font-size:1.25rem}h3{font-size:1rem}.btn{align-items:center;border:1.5px solid #0000;border-radius:10px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font);font-size:.875rem;font-weight:500;gap:7px;justify-content:center;padding:9px 20px;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.45}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:#1e40af;background:var(--primary);border-color:#1e40af;border-color:var(--primary);box-shadow:0 2px 8px #3b82f647;color:#fff}.btn-primary:hover:not(:disabled){background:#3b82f6;background:var(--primary-l);border-color:#3b82f6;border-color:var(--primary-l);box-shadow:0 4px 16px #3b82f661;transform:translateY(-1px)}.btn-outline{background:#0000;border-color:#cbd5e1;border-color:var(--border2);color:#1e40af;color:var(--primary)}.btn-outline:hover:not(:disabled){background:#3b82f61a;background:var(--primary-dim);border-color:#1e40af;border-color:var(--primary)}.btn-ghost{background:#0000;border-color:#0000;color:#475569;color:var(--text2)}.btn-ghost:hover:not(:disabled){background:#eef2f7;background:var(--bg4);color:#0f172a;color:var(--text)}.btn-danger{background:#dc26261a;background:var(--red-dim);border-color:#dc2626;border-color:var(--red);color:#dc2626;color:var(--red)}.btn-danger:hover:not(:disabled){background:#dc2626;background:var(--red);color:#fff}.btn-success{background:#0596691a;background:var(--green-dim);border-color:#059669;border-color:var(--green);color:#059669;color:var(--green)}.btn-success:hover:not(:disabled){background:#059669;background:var(--green);color:#fff}.btn-sm{border-radius:8px;font-size:.8rem;padding:6px 14px}.btn-xs{border-radius:6px;font-size:.75rem;padding:4px 10px}.btn-lg{font-size:.95rem;padding:13px 28px}.btn-full{width:100%}.card{background:#fff;background:var(--bg2);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0f172a14,0 1px 2px #0f172a0f;box-shadow:var(--shadow-sm);padding:22px;transition:box-shadow .16s cubic-bezier(.4,0,.2,1),border-color .16s cubic-bezier(.4,0,.2,1);transition:box-shadow var(--transition),border-color var(--transition)}.card-hover:hover{border-color:#cbd5e1;border-color:var(--border2);box-shadow:0 4px 16px #0f172a1a,0 2px 6px #0f172a0f;box-shadow:var(--shadow)}.input,.select,.textarea{background:#f8fafc;background:var(--bg3);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#0f172a;color:var(--text);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font);font-size:.875rem;outline:none;padding:10px 14px;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all var(--transition);width:100%}.input:focus,.select:focus,.textarea:focus{background:#fff;background:var(--bg2);border-color:#1e40af;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a;box-shadow:0 0 0 3px var(--primary-dim)}.input::placeholder,.textarea::placeholder{color:#94a3b8;color:var(--text3)}.textarea{min-height:80px;resize:vertical}select.select option{background:#fff;background:var(--bg2)}.form-group{display:flex;flex-direction:column;gap:6px}.label{color:#475569;color:var(--text2);font-size:.78rem;font-weight:600;letter-spacing:.02em}.input-error{border-color:#dc2626!important;border-color:var(--red)!important}.error-msg{color:#dc2626;color:var(--red);font-size:.75rem;margin-top:3px}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.72rem;font-weight:600;gap:4px;letter-spacing:.03em;padding:3px 10px;white-space:nowrap}.badge-blue{background:#3b82f61a;background:var(--primary-dim);color:#3b82f6;color:var(--primary-l)}.badge-green{background:#0596691a;background:var(--green-dim);color:#059669;color:var(--green)}.badge-red{background:#dc26261a;background:var(--red-dim);color:#dc2626;color:var(--red)}.badge-amber{background:#d977061a;background:var(--amber-dim);color:#d97706;color:var(--amber)}.badge-purple{background:#7c3aed1a;background:var(--purple-dim);color:#7c3aed;color:var(--purple)}.badge-grey{background:#eef2f7;background:var(--bg4);color:#475569;color:var(--text2)}.table{border-collapse:collapse;font-size:.875rem;width:100%}.table th{border-bottom:1.5px solid #e2e8f0;border-bottom:1.5px solid var(--border);color:#94a3b8;color:var(--text3);font-size:.72rem;font-weight:600;letter-spacing:.05em;padding:10px 14px;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);padding:12px 14px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background .16s cubic-bezier(.4,0,.2,1);transition:background var(--transition)}.table tbody tr:hover td{background:#eef2f7;background:var(--bg4)}.divider{background:#e2e8f0;background:var(--border);height:1px;margin:16px 0}.toast-wrap{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{align-items:flex-start;animation:slideUp .25s ease;background:#fff;background:var(--bg2);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 4px 16px #0f172a1a,0 2px 6px #0f172a0f;box-shadow:var(--shadow);display:flex;gap:10px;max-width:360px;min-width:280px;padding:13px 16px}.toast-success{border-left:4px solid #059669;border-left:4px solid var(--green)}.toast-error{border-left:4px solid #dc2626;border-left:4px solid var(--red)}.toast-info{border-left:4px solid #1e40af;border-left:4px solid var(--primary)}.toast-icon{flex-shrink:0;font-size:1rem;margin-top:1px}.toast-success .toast-icon{color:#059669;color:var(--green)}.toast-error .toast-icon{color:#dc2626;color:var(--red)}.toast-info .toast-icon{color:#1e40af;color:var(--primary)}.toast-body{color:#0f172a;color:var(--text);flex:1 1;font-size:.85rem;line-height:1.4}.modal-backdrop{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{animation:scaleIn .2s ease;background:#fff;background:var(--bg2);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 20px 48px #0f172a24,0 8px 20px #0f172a14;box-shadow:var(--shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;padding:32px;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.modal-title{color:#0f172a;color:var(--text);font-size:1.2rem;font-weight:600}.modal-close{background:none;border:none;border-radius:6px;color:#94a3b8;color:var(--text3);cursor:pointer;font-size:1.2rem;padding:4px 8px}.modal-close:hover{background:#eef2f7;background:var(--bg4);color:#0f172a;color:var(--text)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}.spinner{animation:spin .7s linear infinite;border:2px solid #cbd5e1;border-top-color:#1e40af;border:2px solid var(--border2);border-radius:50%;border-top-color:var(--primary);flex-shrink:0;height:18px;width:18px}.page{display:flex;flex-direction:column;gap:24px;padding:28px 32px}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.page-title{color:#0f172a;color:var(--text);font-size:1.5rem;font-weight:700}.page-sub{color:#475569;color:var(--text2);font-size:.83rem;margin-top:3px}.empty{color:#94a3b8;color:var(--text3);font-size:.875rem;padding:40px 20px;text-align:center}.empty-icon{font-size:2rem;margin-bottom:10px;opacity:.5}.tabs{background:#eef2f7;background:var(--bg4);border-radius:10px;border-radius:var(--radius);display:flex;gap:4px;padding:4px}.tab{background:none;border:none;border-radius:8px;color:#475569;color:var(--text2);cursor:pointer;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-family:var(--font);font-size:.84rem;font-weight:500;padding:7px 18px;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all var(--transition)}.tab:hover{color:#0f172a;color:var(--text)}.tab.active{background:#fff;background:var(--bg2);box-shadow:0 1px 3px #0f172a14,0 1px 2px #0f172a0f;box-shadow:var(--shadow-sm);color:#1e40af;color:var(--primary)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:10px}.gap-3{gap:16px}.full{width:100%}.text-muted{color:#475569;color:var(--text2)}.text-sm{font-size:.82rem}.font-mono{font-family:JetBrains Mono,monospace;font-family:var(--font-mono)}.chip{align-items:center;background:#eef2f7;background:var(--bg4);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;color:#475569;color:var(--text2);display:inline-flex;font-size:.78rem;gap:5px;padding:4px 10px}.staff-grid-2{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.staff-grid-sidebar{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 340px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (max-width:1024px){:root{--sidebar-w:220px}}@media (max-width:900px){html{font-size:14px}.page{gap:14px;padding:16px 14px}.page-header{align-items:flex-start;flex-direction:column;gap:10px}.page-title{font-size:1.2rem}.tabs{flex-wrap:wrap}.tab{font-size:.8rem;padding:6px 12px}.card{padding:14px}.modal{border-radius:16px;border-radius:var(--radius-lg);padding:18px}.modal-backdrop{padding:10px}.staff-grid-2,.staff-grid-sidebar{grid-template-columns:1fr}[style*="grid-template-columns: 1fr 1.4fr"],[style*="grid-template-columns: 1fr 1fr"],[style*="grid-template-columns: 1fr 320px"],[style*="grid-template-columns: 1fr 340px"]{grid-template-columns:1fr!important}.btn-lg{font-size:.875rem;padding:11px 18px}}@media (max-width:480px){.page{gap:10px;padding:10px 12px}h1{font-size:1.15rem}.kpi-val{font-size:1.4rem}.tabs{gap:2px}.tab{font-size:.75rem;padding:5px 10px}.card{padding:12px}.btn{font-size:.82rem;padding:8px 14px}}.sidebar{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;height:100vh;min-width:var(--sidebar-w);overflow-x:hidden;overflow-y:auto;position:-webkit-sticky;position:sticky;top:0;transition:transform .28s cubic-bezier(.4,0,.2,1);width:var(--sidebar-w);z-index:100}.sb-brand{border-bottom:1px solid var(--border);gap:12px;padding:20px 20px 18px}.sb-brand,.sb-logo{align-items:center;display:flex;flex-shrink:0}.sb-logo{background:var(--primary);border-radius:10px;box-shadow:0 2px 8px #3b82f659;color:#fff;font-size:1.1rem;font-weight:700;height:36px;justify-content:center;width:36px}.sb-name{color:var(--text);font-size:.95rem;font-weight:700}.sb-sub{color:var(--text3);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.sb-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:14px 10px}.sb-section-label{color:var(--text3);font-size:.67rem;font-weight:700;letter-spacing:.1em;padding:4px 10px 10px;text-transform:uppercase}.sb-link{align-items:center;border-radius:var(--radius);color:var(--text2);display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:10px 12px;text-decoration:none;transition:all var(--transition)}.sb-link:hover{background:var(--bg4);color:var(--text)}.sb-link.active{background:var(--primary-dim);color:var(--primary);font-weight:600}.sb-icon{flex-shrink:0;font-size:.95rem;text-align:center;width:20px}.sb-label{flex:1 1}.sb-bottom{border-top:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:10px;padding:12px 10px 16px}.ws-pill{align-items:center;background:var(--bg4);border-radius:20px;display:flex;font-size:.72rem;font-weight:600;gap:7px;padding:6px 12px}.ws-pill.online{color:var(--green)}.ws-pill.offline{color:var(--text3)}.ws-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.ws-pill.online .ws-dot{animation:pulse 2s infinite}.sb-icon-btn{align-self:flex-start;background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.9rem;padding:7px;transition:all var(--transition)}.sb-icon-btn:hover{box-shadow:var(--shadow-sm)}.sb-user{background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);gap:10px;padding:10px 12px}.sb-avatar,.sb-user{align-items:center;display:flex}.sb-avatar{border-radius:10px;color:#fff;flex-shrink:0;font-size:.78rem;font-weight:700;height:34px;justify-content:center;width:34px}.avatar-purple{background:var(--purple)}.avatar-blue{background:var(--primary)}.avatar-green{background:var(--green)}.avatar-amber{background:var(--amber)}.avatar-red{background:var(--red)}.sb-user-info{flex:1 1;min-width:0}.sb-user-name{color:var(--text);font-size:.8rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-user-role{font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.role-purple{color:var(--purple)}.role-blue{color:var(--primary)}.role-green{color:var(--green)}.role-amber{color:var(--amber)}.role-red{color:var(--red)}.sb-logout{background:none;border:none;border-radius:6px;color:var(--text3);cursor:pointer;flex-shrink:0;font-size:.9rem;padding:4px 6px;transition:all var(--transition)}.sb-logout:hover{background:var(--red-dim);color:var(--red)}.sb-topbar{align-items:center;background:var(--bg2);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);display:none;gap:10px;height:56px;left:0;padding:0 14px;position:fixed;right:0;top:0;z-index:250}.sb-hamburger{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:9px;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:background var(--transition);width:40px}.sb-hamburger:hover{background:var(--primary-dim)}.hb-icon{display:flex;flex-direction:column;gap:4px;transition:all var(--transition);width:18px}.hb-icon span{background:var(--text);border-radius:2px;display:block;height:2px;transform-origin:center;transition:all .25s ease}.hb-icon.open span:first-child{transform:translateY(6px) rotate(45deg)}.hb-icon.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hb-icon.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.sb-topbar-brand{align-items:center;display:flex;flex:1 1;gap:8px}.sb-topbar-logo{align-items:center;background:var(--primary);border-radius:7px;color:#fff;display:flex;font-size:.85rem;font-weight:700;height:28px;justify-content:center;width:28px}.sb-topbar-name{color:var(--text);font-size:.95rem;font-weight:700}.sb-topbar-theme{background:none;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-size:1rem;padding:6px 8px;transition:all var(--transition)}.sb-topbar-theme:hover{background:var(--bg4)}.sb-overlay{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a80;inset:0;position:fixed;z-index:220}@media (max-width:900px){.sb-topbar{display:flex}.sb-brand,.sb-icon-btn{display:none}.sidebar{border-top:1px solid var(--border);bottom:0;box-shadow:none;height:calc(100dvh - 56px);left:0;position:fixed;top:56px;transform:translateX(-100%);z-index:230}.sidebar.mobile-open{box-shadow:var(--shadow-lg);transform:translateX(0)}}.login-root{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.login-left{background:linear-gradient(145deg,#1e3a8a,#1e40af 40%,#1d4ed8 70%,#2563eb);display:flex;flex-direction:column;overflow:hidden;padding:40px 48px;position:relative}[data-theme=dark] .login-left{background:linear-gradient(145deg,#0f172a,#1e2d5a 40%,#1e3a8a)}.login-left:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='2' fill='%23fff' fill-opacity='.04' fill-rule='evenodd'/%3E%3C/svg%3E");content:"";inset:0;position:absolute}.login-brand{gap:14px;position:relative;z-index:1}.brand-mark,.login-brand{align-items:center;display:flex}.brand-mark{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:12px;font-size:1.4rem;height:46px;justify-content:center;width:46px}.brand-mark,.brand-title{color:#fff;font-weight:700}.brand-title{font-size:1.25rem}.brand-tagline{color:#ffffffa6;font-size:.75rem;margin-top:1px}.login-hero{display:flex;flex:1 1;flex-direction:column;gap:28px;justify-content:center;position:relative;z-index:1}.room-visual{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff14;border:1px solid #ffffff26;border-radius:16px;box-shadow:0 24px 64px #0000004d;overflow:hidden}.rv-header{align-items:center;background:#ffffff0f;border-bottom:1px solid #ffffff14;display:flex;gap:8px;padding:12px 16px}.rv-dot{border-radius:50%;height:10px;width:10px}.rv-dot.red{background:#ff5f57}.rv-dot.amber{background:#ffbd2e}.rv-dot.green{background:#28ca41}.rv-title{color:#fff9;font-size:.75rem;margin-left:6px}.rv-body{display:flex;flex-direction:column;gap:10px;padding:16px}.rv-stat{color:#ffffffa6;display:flex;font-size:.82rem;justify-content:space-between}.rv-stat strong{color:#fff;font-size:.95rem}.rv-divider{background:#ffffff1a;height:1px;margin:4px 0}.rv-bar-label{color:#ffffff80;font-size:.72rem}.rv-bars{align-items:flex-end;display:flex;gap:6px;height:72px}.rv-bar{animation:growUp .6s ease forwards;background:#ffffff40;border-radius:3px 3px 0 0;flex:1 1;transform-origin:bottom}@keyframes growUp{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.hero-features{display:flex;flex-direction:column;gap:10px}.hero-feat{align-items:center;color:#ffffffbf;display:flex;font-size:.88rem;gap:8px}.feat-check{color:#86efac;font-weight:700}.login-right{background:var(--bg);padding:40px;position:relative}.login-right,.theme-toggle-btn{align-items:center;display:flex;justify-content:center}.theme-toggle-btn{background:var(--bg2);border:1px solid var(--border);border-radius:50%;box-shadow:var(--shadow-sm);cursor:pointer;font-size:1rem;height:40px;position:absolute;right:20px;top:20px;transition:all var(--transition);width:40px}.theme-toggle-btn:hover{box-shadow:var(--shadow);transform:rotate(15deg)}.login-card{gap:24px;max-width:400px;width:100%}.login-card,.login-card-header{display:flex;flex-direction:column}.login-card-header{gap:4px}.login-title{color:var(--text);font-size:1.75rem;font-weight:700}.login-sub{color:var(--text2);font-size:.875rem}.login-tabs{margin:0}.login-form{display:flex;flex-direction:column;gap:16px}.demo-section{margin-top:4px}.demo-title{color:var(--text3);font-size:.72rem;font-weight:600;letter-spacing:.06em;margin-bottom:10px;text-transform:uppercase}.demo-grid{display:flex;flex-wrap:wrap;gap:6px}.demo-btn{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:20px;color:var(--text2);cursor:pointer;display:flex;font-family:var(--font);font-size:.78rem;gap:6px;padding:5px 12px;transition:all var(--transition)}.demo-btn:hover{background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}.demo-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.demo-purple{background:var(--purple)}.demo-blue{background:var(--primary)}.demo-green{background:var(--green)}.demo-amber{background:var(--amber)}.demo-red{background:var(--red)}.guest-info-box{align-items:flex-start;background:var(--primary-dim);border:1px solid var(--primary-dim2);color:var(--primary-l);font-size:.82rem;gap:10px;padding:12px 14px}.guest-info-box,.guest-mode-tabs{border-radius:var(--radius);display:flex}.guest-mode-tabs{background:var(--bg4);border:1px solid var(--border);gap:0;margin-bottom:16px;padding:3px}.gmt-btn{background:none;border:none;border-radius:8px;color:var(--text2);cursor:pointer;flex:1 1;font-family:var(--font);font-size:.84rem;font-weight:500;padding:8px;transition:all var(--transition)}.gmt-btn.active{background:var(--bg2);box-shadow:var(--shadow-sm);color:var(--primary);font-weight:600}.guest-error-box{background:var(--red-dim);border:1px solid var(--red);border-radius:var(--radius);color:var(--red);font-size:.82rem;margin-bottom:4px;padding:10px 14px}.guest-switch-link{color:var(--text3);font-size:.8rem;text-align:center}.guest-switch-link button{background:none;border:none;color:var(--primary);cursor:pointer;font-family:var(--font);font-size:.8rem;font-weight:600;padding:0;text-decoration:underline}@media (max-width:768px){.login-root{grid-template-columns:1fr}.login-left{display:none}.login-right{align-items:flex-start;padding:40px 20px 24px}.login-card{max-width:100%}}@media (max-width:400px){.login-right{padding:20px 16px}.demo-grid{gap:4px}.demo-btn{font-size:.74rem;padding:4px 10px}}.kpi-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr)}.kpi-card{align-items:center;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:14px;padding:18px 20px;transition:all var(--transition)}.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.kpi-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.3rem;height:46px;justify-content:center;width:46px}.kpi-blue{background:var(--primary-dim)}.kpi-amber{background:var(--amber-dim)}.kpi-green{background:var(--green-dim)}.kpi-red{background:var(--red-dim)}.kpi-val{color:var(--text);font-size:1.75rem;font-weight:700;line-height:1}.kpi-label{color:var(--text2);font-size:.78rem;margin-top:3px}.card-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.row-2{grid-gap:16px;grid-template-columns:1fr 1.4fr}.row-2,.row-3{display:grid;gap:16px}.row-3{grid-gap:16px;grid-template-columns:repeat(3,1fr)}.status-bars{display:flex;flex-direction:column;gap:12px}.status-bar-row{align-items:center;display:flex;gap:10px}.sbr-label{color:var(--text2);display:flex;flex-shrink:0;font-size:.82rem;justify-content:space-between;width:130px}.sbr-count{color:var(--text);font-weight:600}.sbr-track{background:var(--bg4);border-radius:4px;flex:1 1;height:7px;overflow:hidden}.sbr-fill{border-radius:4px;height:100%;transition:width .6s ease}.sbr-pct{color:var(--text3);flex-shrink:0;font-size:.72rem;text-align:right;width:32px}.rooms-card .card{overflow:hidden}.rooms-map{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(68px,1fr))}.room-dot{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);border-top:3px solid var(--dot-color,var(--border));cursor:default;display:flex;flex-direction:column;gap:4px;padding:8px 10px;transition:all var(--transition)}.room-dot:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.rd-num{color:var(--text);font-size:.82rem;font-weight:600}.rd-status{border-radius:50%;height:6px;width:6px}.mini-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}.mini-item{align-items:center;background:var(--bg4);border-radius:var(--radius);display:flex;flex-wrap:wrap;font-size:.8rem;gap:8px;padding:8px 10px}.mi-id{color:var(--text3);font-family:var(--font-mono);font-size:.72rem;min-width:40px}.mi-room{color:var(--text2);font-weight:500}.mi-desc{color:var(--text3);flex:1 1;font-size:.75rem}.mi-price{color:var(--green);font-weight:600;margin-left:auto}@media (max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.row-2,.row-3{grid-template-columns:1fr}}@media (max-width:768px){.kpi-grid{gap:10px;grid-template-columns:repeat(2,1fr)}.kpi-card{padding:14px 16px}.kpi-val{font-size:1.5rem}.rooms-map{gap:6px;grid-template-columns:repeat(auto-fill,minmax(56px,1fr))}.sbr-label{width:100px}}@media (max-width:480px){.kpi-grid{gap:8px;grid-template-columns:1fr 1fr}.kpi-icon{font-size:1.1rem;height:38px;width:38px}}.guest-portal{display:flex;flex-direction:column;min-height:100vh}.guest-hero{align-items:center;background:linear-gradient(135deg,#1e40af,#1d4ed8 50%,#2563eb);display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:36px 32px}[data-theme=dark] .guest-hero{background:linear-gradient(135deg,#0f172a,#1e2d5a 50%,#1e3a8a)}.guest-hero-text{flex:1 1;min-width:180px}.guest-welcome{color:#ffffffbf;font-size:.875rem;margin-bottom:6px}.guest-hero-title{color:#fff;font-size:1.9rem;font-weight:700;line-height:1.15}.guest-hero-sub{color:#ffffffb3;font-size:.85rem;margin-top:6px}.guest-my-room{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1f;border:1px solid #fff3;border-radius:14px;flex-shrink:0;padding:16px 22px;text-align:center}.gmr-label{color:#ffffffa6;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}.gmr-num{color:#fff;font-size:2.4rem;font-weight:700;line-height:1;margin:4px 0}.gmr-type{color:#ffffffbf;font-size:.8rem}.guest-content{display:flex;flex:1 1;flex-direction:column;gap:20px;padding:20px 28px 40px}.guest-home{display:flex;flex-direction:column;gap:20px}.service-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.service-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 16px;text-align:center;transition:all var(--transition)}.service-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.sc-icon{font-size:1.7rem;margin-bottom:9px}.sc-title{color:var(--text);font-size:.9rem;font-weight:600;margin-bottom:4px}.sc-desc{color:var(--text2);font-size:.78rem}.book-cta{align-items:center;background:var(--primary-dim);border:1.5px solid var(--primary-dim2);border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:18px 22px}.avail-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.avail-card{border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:14px;text-align:center;transition:all var(--transition)}.avail-card.ok{background:var(--green-dim);border-color:var(--green)}.avail-card.none{opacity:.55}.avail-icon{display:block;font-size:1.4rem;margin-bottom:5px}.avail-name{color:var(--text);font-size:.82rem;font-weight:600;margin-bottom:3px}.avail-count{color:var(--green);font-size:.8rem;font-weight:700}.avail-card.none .avail-count,.avail-price{color:var(--text3)}.avail-price{font-size:.7rem;margin-top:2px}.booking-grid{grid-gap:18px;align-items:start;display:grid;gap:18px;grid-template-columns:1fr 1fr}.room-types-list{display:flex;flex-direction:column;gap:10px}.room-type-card{align-items:center;background:var(--bg2);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:12px;justify-content:space-between;padding:14px 16px;transition:all var(--transition)}.room-type-card:hover:not(.unavailable){border-color:var(--primary-dim2)}.room-type-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.room-type-card.unavailable{cursor:not-allowed;opacity:.5}.rtc-left{align-items:center;display:flex;flex:1 1;gap:10px;min-width:0}.rtc-icon{flex-shrink:0;font-size:1.3rem}.rtc-name{color:var(--text);font-size:.88rem;font-weight:600}.rtc-desc{color:var(--text2);font-size:.72rem;margin-top:2px}.rtc-right{flex-shrink:0;text-align:right}.rtc-price{color:var(--primary);font-size:.95rem;font-weight:700}.rtc-per{color:var(--text3);font-size:.7rem}.rtc-avail{font-size:.7rem;font-weight:600;margin-top:3px}.rtc-avail.ok{color:var(--green)}.rtc-avail.none{color:var(--red)}.floor-status{border-radius:var(--radius);display:flex;flex-direction:column;font-size:.82rem;gap:5px;line-height:1.5;padding:11px 13px}.floor-status.ok{background:var(--green-dim);border:1px solid var(--green);color:var(--green)}.floor-status.warn{background:var(--amber-dim);border:1px solid var(--amber);color:var(--amber)}.fs-title{font-weight:600}.fs-sub{font-size:.77rem;opacity:.85}.fs-alts{align-items:center;display:flex;flex-wrap:wrap;font-size:.77rem;gap:6px}.fs-alt-btn{background:#d977061f;border:1px solid var(--amber);border-radius:20px;color:var(--amber);cursor:pointer;font-family:var(--font);font-size:.74rem;font-weight:600;padding:2px 9px;transition:all var(--transition)}.fs-alt-btn:hover{background:var(--amber);color:#fff}.room-service-grid{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:1fr 280px}.menu-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.menu-item{background:var(--bg4);border:1.5px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:6px;padding:12px;transition:all var(--transition)}.menu-item.in-cart{background:var(--primary-dim);border-color:var(--primary)}.mi-name{color:var(--text);font-size:.85rem;font-weight:500}.mi-price{color:var(--primary);font-size:.95rem;font-weight:700}.mi-actions{gap:7px;margin-top:3px}.mi-actions,.qty-btn{align-items:center;display:flex}.qty-btn{background:var(--bg2);border:1px solid var(--border2);border-radius:7px;cursor:pointer;font-size:.95rem;font-weight:700;height:26px;justify-content:center;transition:all var(--transition);width:26px}.qty-btn.add{background:var(--primary);border-color:var(--primary);color:#fff;margin-left:auto}.qty-btn.add:hover{background:var(--primary-l)}.qty-num{font-size:.88rem;font-weight:700;min-width:16px;text-align:center}.cart-card{align-self:start;display:flex;flex-direction:column;gap:11px;position:-webkit-sticky;position:sticky;top:16px}.cart-row{align-items:center;border-bottom:1px solid var(--border);display:flex;font-size:.85rem;gap:8px;padding:6px 0}.cr-name{color:var(--text);flex:1 1}.cr-qty{color:var(--text2);font-size:.8rem}.cr-price{color:var(--primary);font-weight:700;min-width:46px;text-align:right}.cr-del{background:none;border:none;color:var(--red);cursor:pointer;font-size:.95rem;padding:2px 3px}.cart-total{border-top:1.5px solid var(--border);display:flex;font-size:1rem;font-weight:700;justify-content:space-between;padding:8px 0}.order-row{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:10px;padding:12px 14px}.profile-info{display:flex;flex-direction:column}.pi-row{align-items:center;border-bottom:1px solid var(--border);display:flex;font-size:.875rem;justify-content:space-between;padding:10px 0}.pi-row:last-child{border-bottom:none}.pi-label{color:var(--text2);font-weight:500;min-width:90px}.profile-edit-form{display:flex;flex-direction:column;gap:14px;margin-top:4px}.profile-edit-actions{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding-top:8px}.pwd-section{background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px;padding:14px}.pwd-section-title{color:var(--text2);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.history-row{align-items:flex-start;background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:13px 15px}.hr-left{flex:1 1;min-width:160px}.hr-room{color:var(--primary);font-size:.95rem;font-weight:700;margin-bottom:3px}.hr-meta{color:var(--text2);font-size:.8rem;margin-bottom:3px}.hr-dates{color:var(--text3);font-size:.72rem}.hr-right{align-items:flex-end;display:flex;flex-direction:column;gap:5px}.hr-total{color:var(--green);font-size:.95rem;font-weight:700}@media (max-width:900px){.avail-grid,.service-grid{grid-template-columns:repeat(2,1fr)}.booking-grid,.room-service-grid{grid-template-columns:1fr}.cart-card{position:static}}@media (max-width:600px){.guest-hero{gap:12px;padding:20px 16px}.guest-hero-title{font-size:1.4rem}.guest-hero-sub{font-size:.78rem}.guest-content{gap:14px;padding:14px 14px 28px}.gmr-num{font-size:2rem}.guest-my-room{padding:12px 16px}.service-grid{gap:8px;grid-template-columns:1fr 1fr}.service-card{padding:14px 10px}.sc-icon{font-size:1.4rem}.avail-grid{gap:8px;grid-template-columns:1fr 1fr}.avail-card{padding:11px}.menu-grid{gap:8px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.booking-grid{gap:12px}.history-row{flex-direction:column;gap:8px}.hr-right,.pi-row{align-items:flex-start}.pi-row{flex-direction:column;gap:2px}.pi-label{font-size:.72rem}}@media (max-width:380px){.avail-grid,.menu-grid,.service-grid{grid-template-columns:1fr 1fr}}.chat-page{background:var(--bg);height:100vh}.chat-page,.chat-rooms{display:flex;overflow:hidden}.chat-rooms{background:var(--bg2);border-right:1px solid var(--border);flex-direction:column;min-width:300px;width:300px}.cr-header{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 16px 14px}.cr-title{color:var(--text);font-size:1rem;font-weight:700}.cr-new-btn{align-items:center;background:var(--primary-dim);border:none;border-radius:8px;color:var(--primary);cursor:pointer;display:flex;font-size:.95rem;height:32px;justify-content:center;transition:all var(--transition);width:32px}.cr-new-btn:hover{background:var(--primary);color:#fff}.cr-user-list{background:var(--bg3);border-bottom:1px solid var(--border);flex-shrink:0;max-height:260px;overflow-y:auto}.cr-ul-title{color:var(--text3);font-size:.68rem;font-weight:700;letter-spacing:.08em;padding:8px 14px 6px;text-transform:uppercase}.cr-ul-empty{color:var(--text3);font-size:.82rem;padding:10px 14px}.cr-user-item{align-items:center;cursor:pointer;display:flex;gap:10px;padding:9px 14px;transition:background var(--transition)}.cr-user-item:hover{background:var(--bg4)}.cr-user-av{align-items:center;background:var(--primary-dim);border-radius:10px;color:var(--primary);display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:36px;justify-content:center;position:relative;width:36px}.cr-user-av-icon{background:var(--bg4);border:1px solid var(--border);color:var(--text2)}.cr-user-info{flex:1 1;min-width:0}.cr-user-name{color:var(--text);font-size:.82rem;font-weight:600}.cr-user-role{color:var(--text3);font-size:.7rem}.cr-dot{border:2px solid var(--bg2);border-radius:50%;bottom:-1px;height:8px;position:absolute;right:-1px;width:8px}.cr-dot.online{background:var(--green)}.cr-list{flex:1 1;overflow-y:auto;padding:6px 0}.cr-empty{color:var(--text3);font-size:.82rem;padding:20px;text-align:center}.cr-offline{align-items:center;display:flex;flex-direction:column;gap:6px;padding:24px 16px;text-align:center}.cr-off-icon{font-size:2rem;opacity:.5}.cr-off-title{color:var(--text2);font-size:.85rem;font-weight:600}.cr-off-sub{color:var(--text3);font-size:.75rem}.cr-item{align-items:center;border-radius:0;cursor:pointer;display:flex;gap:11px;padding:11px 14px;transition:background var(--transition)}.cr-item:hover{background:var(--bg4)}.cr-item.active{background:var(--primary-dim)}.cr-item.active .cr-item-name{color:var(--primary);font-weight:700}.cr-item-av{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:11px;color:var(--text2);display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:40px;justify-content:center;position:relative;width:40px}.cr-item-av.cr-item-av-icon{background:var(--primary-dim);border-color:var(--primary);color:var(--primary)}.cr-group-icon{font-size:1.2rem}.cr-group-icon.lg{font-size:1.4rem}.cr-item-info{flex:1 1;min-width:0}.cr-item-top{align-items:baseline;display:flex;gap:6px;justify-content:space-between}.cr-item-name{color:var(--text);font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cr-item-time{color:var(--text3);flex-shrink:0;font-size:.68rem}.cr-item-preview{align-items:center;color:var(--text3);display:flex;font-size:.75rem;justify-content:space-between;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cr-badge{background:var(--primary);border-radius:10px;color:#fff;flex-shrink:0;font-size:.68rem;font-weight:700;padding:1px 6px}.cr-badge-av{align-items:center;border:2px solid var(--bg2);border-radius:50%;display:flex;font-size:.62rem;height:18px;justify-content:center;padding:0;position:absolute;right:-4px;top:-4px;width:18px}.chat-main{background:var(--bg);overflow:hidden}.chat-empty,.chat-main{display:flex;flex:1 1;flex-direction:column}.chat-empty{align-items:center;color:var(--text3);gap:12px;justify-content:center}.ce-icon{font-size:3rem;opacity:.4}.ce-text{font-size:.9rem}.cm-header{align-items:center;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:12px;padding:14px 20px}.cm-header-av{background:var(--bg4);border:1px solid var(--border);border-radius:11px;color:var(--text2);flex-shrink:0;height:40px;position:relative;width:40px}.cm-av-circle,.cm-header-av{align-items:center;display:flex;font-size:.85rem;font-weight:700;justify-content:center}.cm-av-circle{background:var(--primary-dim);border-radius:inherit;color:var(--primary);height:100%;width:100%}.cm-dot{border:2px solid var(--bg2);border-radius:50%;bottom:-1px;height:10px;position:absolute;right:-1px;width:10px}.cm-dot.online{background:var(--green)}.cm-header-info{flex:1 1}.cm-room-name{color:var(--text);font-size:.95rem;font-weight:700}.cm-room-sub{color:var(--text3);font-size:.72rem;margin-top:1px}.cm-messages{gap:2px;overflow-y:auto;padding:16px 20px}.cm-messages,.cm-no-msgs{display:flex;flex:1 1;flex-direction:column}.cm-no-msgs{align-items:center;color:var(--text3);font-size:.85rem;gap:10px;justify-content:center;text-align:center}.msg-wrap{align-items:flex-end;display:flex;gap:8px;margin-bottom:2px}.msg-wrap.me{flex-direction:row-reverse}.msg-wrap.same-sender{margin-bottom:1px}.msg-wrap.same-sender .msg-av{visibility:hidden}.msg-av{align-items:center;align-self:flex-end;background:var(--primary-dim);border-radius:9px;color:var(--primary);display:flex;font-size:.7rem;font-weight:700;height:30px;justify-content:center}.msg-av,.msg-av-gap{flex-shrink:0;width:30px}.msg-bubble-wrap{display:flex;flex-direction:column;max-width:68%}.msg-wrap.me .msg-bubble-wrap{align-items:flex-end}.msg-sender{color:var(--primary);font-size:.7rem;font-weight:600;margin-bottom:3px;padding-left:4px}.msg-bubble{border-radius:14px;display:flex;flex-direction:column;gap:4px;max-width:100%;padding:9px 13px;position:relative;word-break:break-word}.msg-bubble.pending{opacity:.65}.msg-bubble.mine{background:var(--primary);border-bottom-right-radius:4px;color:#fff}.msg-bubble.theirs{background:var(--bg2);border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--text)}.msg-text{font-size:.875rem;line-height:1.45;white-space:pre-wrap}.msg-time{align-self:flex-end;font-size:.62rem;margin-top:2px;opacity:.65}.msg-bubble.mine .msg-time{color:#ffffffbf}.msg-img-wrap{border-radius:10px;cursor:zoom-in;display:block;max-width:260px;overflow:hidden}.msg-img{display:block;max-height:220px;max-width:100%;object-fit:cover}.msg-file{align-items:center;background:#00000014;border-radius:8px;color:inherit;display:flex;gap:8px;min-width:160px;padding:8px 12px;text-decoration:none}.msg-bubble.mine .msg-file{background:#ffffff26}.mf-icon{flex-shrink:0;font-size:1.2rem}.mf-name{flex:1 1;font-size:.82rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mf-dl{flex-shrink:0;font-size:.85rem;opacity:.7}.typing-av{background:var(--bg4);color:var(--text3);font-size:.9rem}.typing-dots{align-items:center;background:var(--bg2);border:1px solid var(--border);border-radius:14px;border-bottom-left-radius:4px;display:flex;gap:8px;padding:8px 14px}.td-name{color:var(--text3);font-size:.72rem}.td-dots{display:flex;gap:3px}.td-dots i{animation:typing-bounce 1.2s infinite;background:var(--text3);border-radius:50%;display:block;height:6px;width:6px}.td-dots i:nth-child(2){animation-delay:.2s}.td-dots i:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}.cm-input-wrap{align-items:flex-end;background:var(--bg2);border-top:1px solid var(--border);gap:8px;padding:12px 16px}.cm-attach,.cm-input-wrap{display:flex;flex-shrink:0}.cm-attach{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:10px;color:var(--text2);cursor:pointer;font-size:1rem;height:38px;justify-content:center;transition:all var(--transition);-webkit-user-select:none;user-select:none;width:38px}.cm-attach:hover:not(.disabled){background:var(--primary-dim);color:var(--primary)}.cm-attach.disabled{opacity:.45}.cm-input{background:var(--bg3);border:1.5px solid var(--border);border-radius:12px;color:var(--text);flex:1 1;font-family:var(--font);font-size:.875rem;line-height:1.45;max-height:120px;outline:none;overflow-y:auto;padding:9px 13px;resize:none;scrollbar-width:none;transition:border-color var(--transition)}.cm-input:focus{background:var(--bg2);border-color:var(--primary)}.cm-input::placeholder{color:var(--text3)}.cm-input::-webkit-scrollbar{display:none}.cm-send{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:10px;color:var(--text3);cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:38px;justify-content:center;transition:all var(--transition);width:38px}.cm-send.active{background:var(--primary);border-color:var(--primary);box-shadow:0 2px 8px #3b82f64d;color:#fff}.cm-send:disabled{cursor:not-allowed;opacity:.4}.spinner.sm{border-width:2px;height:14px;width:14px}.msg-av.msg-av-icon{background:var(--bg4);border:1px solid var(--border);color:var(--text2)}.msg-av.clickable,.msg-sender.clickable{cursor:pointer;transition:opacity var(--transition)}.msg-av.clickable:hover{opacity:.75}.msg-sender.clickable:hover{text-decoration:underline}.prof-backdrop{animation:fadeIn .18s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;inset:0;justify-content:center;padding:20px;position:fixed;z-index:400}.prof-backdrop,.prof-modal{align-items:center;display:flex}.prof-modal{animation:scaleIn .2s ease;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);flex-direction:column;gap:10px;max-width:320px;padding:36px 32px 28px;position:relative;width:100%}.prof-close{align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:8px;color:var(--text3);cursor:pointer;display:flex;font-size:.85rem;height:30px;justify-content:center;position:absolute;right:14px;top:14px;transition:all var(--transition);width:30px}.prof-close:hover{background:var(--red-dim);color:var(--red)}.prof-avatar{align-items:center;background:var(--primary-dim);border:2px solid var(--border);border-radius:22px;color:var(--primary);display:flex;font-size:1.6rem;font-weight:700;height:80px;justify-content:center;margin-bottom:4px;position:relative;width:80px}.prof-online-dot{border:3px solid var(--bg2);border-radius:50%;bottom:2px;height:14px;position:absolute;right:2px;width:14px}.prof-online-dot.on{background:var(--green)}.prof-online-dot.off{background:var(--text3)}.prof-name{color:var(--text);font-size:1.1rem;font-weight:700;text-align:center}.prof-role{background:var(--primary-dim);border-radius:20px;color:var(--primary);font-size:.78rem;font-weight:600;padding:3px 12px}.prof-status{color:var(--text3);font-size:.82rem;margin-top:2px}.prof-status.on{color:var(--green)}.cr-delete-btn,.prof-status.off{color:var(--text3)}.cr-delete-btn{align-items:center;background:#0000;border:none;border-radius:7px;cursor:pointer;display:flex;flex-shrink:0;font-size:.82rem;height:28px;justify-content:center;margin-left:auto;transition:all var(--transition);width:28px}.cr-delete-btn:hover{background:#dc26261f;color:#dc2626}.msg-row{align-items:center;display:flex;gap:6px}.msg-wrap.other .msg-row{flex-direction:row-reverse}.msg-del-btn{align-items:center;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text3);cursor:pointer;display:flex;flex-shrink:0;font-size:.72rem;height:26px;justify-content:center;transition:all var(--transition);width:26px}.msg-del-btn:hover{background:#dc26261f;border-color:#dc2626;color:#dc2626}.invite-card{background:var(--bg2);border:1.5px solid var(--primary);border-radius:14px;display:flex;flex-direction:column;gap:7px;max-width:280px;min-width:220px;padding:14px 16px}.invite-header{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:7px;padding-bottom:7px}.invite-icon{font-size:1.1rem}.invite-label{color:var(--primary);font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.invite-name{color:var(--text);font-size:.95rem;font-weight:700}.invite-info{color:var(--text2);font-size:.8rem}.invite-status{font-size:.78rem;font-weight:600;margin-top:2px}.invite-status.sent{color:var(--text3)}.invite-status.accepted{color:#059669}.invite-btns{display:flex;gap:8px;margin-top:4px}.invite-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.78rem;font-weight:600;padding:7px 8px;transition:all var(--transition)}.invite-btn.accept{background:var(--primary);color:#fff}.invite-btn.accept:hover{filter:brightness(1.1)}.invite-btn.reject{background:var(--bg4);border:1px solid var(--border);color:var(--text2)}.invite-btn.reject:hover{background:#dc26261f;color:#dc2626}.system-msg-row{display:flex;justify-content:center;padding:6px 0}.system-msg-text{background:var(--bg3);border:1px solid var(--border);border-radius:20px;color:var(--text3);font-size:.72rem;padding:3px 14px;text-align:center}.confirm-backdrop{align-items:center;animation:fadeIn .18s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.confirm-modal{align-items:center;animation:scaleIn .2s ease;background:var(--bg2);border:1px solid var(--border2,var(--border));border-radius:18px;box-shadow:0 20px 60px #0000004d;box-shadow:var(--shadow-lg,0 20px 60px #0000004d);display:flex;flex-direction:column;gap:8px;max-width:300px;padding:28px 28px 22px;width:100%}.confirm-icon{font-size:2rem;margin-bottom:2px}.confirm-title{color:var(--text);font-size:1rem;font-weight:700}.confirm-sub{color:var(--text3);font-size:.82rem;line-height:1.5;margin-bottom:4px;text-align:center}.confirm-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px;width:100%}.confirm-btn{background:var(--bg3);border:1.5px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;font-size:.875rem;font-weight:600;padding:10px 16px;transition:all var(--transition);width:100%}.confirm-btn:hover{background:var(--bg4)}.confirm-btn.danger{background:#dc26261a;border-color:#dc2626;color:#dc2626}.confirm-btn.danger:hover{background:#dc2626;color:#fff}.confirm-btn.secondary{background:#3b82f61a;background:var(--primary-dim,#3b82f61a);border-color:var(--primary);color:var(--primary)}.confirm-btn.secondary:hover{background:var(--primary);color:#fff}.confirm-btn.ghost{background:#0000;border-color:#0000;color:var(--text3)}.confirm-btn.ghost:hover{background:var(--bg4);color:var(--text)}.prof-contact-info{background:var(--bg3);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:7px;margin-top:2px;padding:10px 14px;width:100%}.pci-title{color:var(--text3);font-size:.68rem;font-weight:700;letter-spacing:.07em;margin-bottom:2px;text-transform:uppercase}.prof-contact-row{align-items:center;display:flex;gap:10px}.pci-icon{flex-shrink:0;font-size:.85rem}.pci-val{color:var(--text);font-size:.85rem}.pci-val.muted{color:var(--text3);font-style:italic}.prof-contact-badge{color:#059669;font-size:.8rem;font-weight:600;padding:4px 0;text-align:center}.prof-actions{display:flex;flex-direction:column;gap:8px;margin-top:12px;width:100%}.prof-actions .btn{justify-content:center;width:100%}@media (max-width:900px){.chat-page{height:calc(100vh - 56px)}.chat-rooms{min-width:72px;width:72px}.cr-header{justify-content:center;padding:12px 10px}.cr-title,.cr-user-list{display:none}.cr-item{flex-direction:column;justify-content:center;padding:10px}.cr-item-info{display:none}.cr-item-av{height:44px;width:44px}.cr-badge{align-items:center;border-radius:50%;display:flex;height:18px;justify-content:center;padding:0;position:absolute;right:-4px;top:-4px;width:18px}.cr-item-av{position:relative}}@media (max-width:600px){.cm-messages{padding:12px 10px}.cm-header{padding:10px 14px}.msg-bubble-wrap{max-width:80%}.cm-input-wrap{padding:8px 10px}}.app-layout{display:flex;min-height:100vh}.app-main{background:var(--bg);flex:1 1;min-height:100vh;overflow-y:auto}.event-ticker{align-items:center;background:var(--bg2);border:1px solid var(--border2);border-radius:12px;bottom:20px;box-shadow:var(--shadow);display:flex;gap:10px;max-width:360px;padding:10px 14px;position:fixed;right:20px;z-index:100}.et-live{animation:pulse 2s infinite;color:var(--green);flex-shrink:0;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.et-list{display:flex;flex-direction:column;gap:3px;overflow:hidden}.et-item{color:var(--text2);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap}.et-item:first-child{color:var(--text);font-weight:500}@media (max-width:900px){.app-layout{display:block}.app-main{min-height:100vh;padding-top:56px}.event-ticker{display:none}}
/*# sourceMappingURL=main.a0d1c647.css.map*/