@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0f14;--bg2: #13151c;--bg3: #1a1d27;--bg4: #222638;--border: #2a2e42;--border2: #343856;--text: #e8eaf6;--text2: #9ca3c4;--text3: #5c6185;--primary: #6366f1;--primary-d: #4f46e5;--primary-l: #818cf8;--accent: #22d3ee;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--radius: 10px;--radius-lg: 16px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--transition: .18s ease;font-size:15px}html,body,#root{height:100%}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--primary-l);text-decoration:none}a:hover{color:var(--text)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:6px}h1{font-size:1.75rem;font-weight:700}h2{font-size:1.3rem;font-weight:600}h3{font-size:1.1rem;font-weight:600}h4{font-size:.95rem;font-weight:600}.layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.page{flex:1;overflow-y:auto;padding:28px 32px}.sidebar{width:240px;min-width:240px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;transition:width var(--transition)}.sidebar-logo{padding:22px 20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.sidebar-logo span{font-size:1.1rem;font-weight:800;background:linear-gradient(135deg,var(--primary-l),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar-logo svg{color:var(--primary)}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);color:var(--text2);font-size:.88rem;font-weight:500;cursor:pointer;transition:all var(--transition);border:none;background:none;width:100%;text-align:left;position:relative}.nav-item:hover{background:var(--bg3);color:var(--text)}.nav-item.active{background:linear-gradient(135deg,#6366f12e,#22d3ee14);color:var(--primary-l)}.nav-item .badge{margin-left:auto;background:var(--danger);color:#fff;font-size:.7rem;padding:1px 6px;border-radius:20px;font-weight:700}.sidebar-footer{padding:14px 8px;border-top:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);cursor:pointer;transition:background var(--transition)}.user-chip:hover{background:var(--bg3)}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-lg{width:56px;height:56px;font-size:1.3rem}.user-chip-info{flex:1;min-width:0}.user-chip-name{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip-role{font-size:.72rem;color:var(--text3)}.topbar{display:flex;align-items:center;gap:16px;padding:14px 32px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}.topbar-title{font-size:1rem;font-weight:600;flex:1}.topbar-actions{display:flex;align-items:center;gap:10px}.icon-btn{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all var(--transition);position:relative}.icon-btn:hover{background:var(--bg4);color:var(--text);border-color:var(--border2)}.icon-btn .dot{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--bg2)}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.card-sm{padding:14px 16px;border-radius:var(--radius)}.glass{background:#1a1d27a6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border2)}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius);font-size:.88rem;font-weight:600;cursor:pointer;transition:all var(--transition);border:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-d));color:#fff;box-shadow:0 2px 12px #6366f166}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px #6366f180}.btn-ghost{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg4);color:var(--text);border-color:var(--border2)}.btn-danger{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-icon{padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{display:flex;flex-direction:column;gap:6px}.label{font-size:.82rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.04em}.input,.select,.textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:10px 14px;font-size:.9rem;font-family:inherit;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.select{appearance:none;cursor:pointer}.textarea{resize:vertical;min-height:90px}.input::placeholder,.textarea::placeholder{color:var(--text3)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}.w-full{width:100%}.badge-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.badge-active{background:#22c55e26;color:var(--success)}.badge-pending{background:#f59e0b26;color:var(--warning)}.badge-completed{background:#6366f126;color:var(--primary-l)}.badge-cancelled{background:#ef44441a;color:var(--danger)}.badge-admin{background:#22d3ee1a;color:var(--accent)}.badge-user{background:var(--bg4);color:var(--text2)}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}table{width:100%;border-collapse:collapse}thead th{background:var(--bg3);padding:12px 16px;font-size:.78rem;font-weight:700;color:var(--text2);text-align:left;text-transform:uppercase;letter-spacing:.06em}tbody td{padding:13px 16px;border-top:1px solid var(--border);font-size:.88rem}tbody tr:hover td{background:var(--bg3)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999;animation:fadeIn .15s}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);animation:slideUp .18s ease}.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:18px;border-top:1px solid var(--border)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);min-width:240px;z-index:200;box-shadow:var(--shadow);overflow:hidden;animation:fadeIn .12s}.dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:.88rem;color:var(--text2);cursor:pointer;transition:all var(--transition);border:none;background:none;width:100%;text-align:left}.dropdown-item:hover{background:var(--bg3);color:var(--text)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:#ef44441a}.dropdown-divider{height:1px;background:var(--border);margin:4px 0}.spinner{width:24px;height:24px;border:3px solid var(--bg4);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.page-loader{display:flex;align-items:center;justify-content:center;height:100%}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.notif-panel{max-height:400px;overflow-y:auto}.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);transition:background var(--transition);cursor:pointer}.notif-item:hover{background:var(--bg3)}.notif-item.unread{border-left:3px solid var(--primary)}.notif-title{font-size:.88rem;font-weight:600}.notif-content{font-size:.8rem;color:var(--text2);margin-top:3px}.notif-time{font-size:.72rem;color:var(--text3);margin-top:4px}.chat-layout{display:flex;height:100%;overflow:hidden}.chat-sidebar{width:280px;min-width:280px;border-right:1px solid var(--border);flex-direction:column;overflow-y:auto}.chat-room-item{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border)}.chat-room-item:hover{background:var(--bg3)}.chat-room-item.active{background:#6366f11f}.chat-room-name{font-size:.9rem;font-weight:600}.chat-room-last{font-size:.78rem;color:var(--text3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:4px}.msg{display:flex;gap:10px;max-width:70%;animation:slideIn .12s}.msg.own{flex-direction:row-reverse;align-self:flex-end}.msg-bubble{padding:10px 14px;border-radius:14px;font-size:.9rem;line-height:1.4}.msg .msg-bubble{background:var(--bg3);border:1px solid var(--border);border-radius:4px 14px 14px}.msg.own .msg-bubble{background:linear-gradient(135deg,var(--primary),var(--primary-d));color:#fff;border-radius:14px 4px 14px 14px}.msg-sender{font-size:.72rem;font-weight:700;color:var(--primary-l);margin-bottom:3px}.msg-time{font-size:.68rem;color:var(--text3);margin-top:3px;text-align:right}.chat-input-bar{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:10px}.chat-input{background:var(--bg3);border:1px solid var(--border);border-radius:22px;padding:10px 18px;color:var(--text);font-size:.9rem;flex:1;font-family:inherit}.chat-input:focus{outline:none;border-color:var(--primary)}.fc{--fc-border-color: var(--border);--fc-page-bg-color: var(--bg2);--fc-neutral-bg-color: var(--bg3);--fc-list-event-hover-bg-color: var(--bg3);--fc-today-bg-color: rgba(99,102,241,.08);--fc-event-border-color: transparent}.fc .fc-toolbar-title{font-size:1.1rem;font-weight:700}.fc .fc-button{background:var(--bg3)!important;border-color:var(--border)!important;color:var(--text2)!important;font-size:.82rem!important;padding:6px 12px!important;border-radius:var(--radius)!important;transition:all .15s!important}.fc .fc-button:hover{background:var(--bg4)!important;color:var(--text)!important}.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important}.fc .fc-col-header-cell{background:var(--bg3)}.fc .fc-col-header-cell-cushion{color:var(--text2);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.fc .fc-daygrid-day-number{color:var(--text2);font-size:.82rem}.fc .fc-event{border-radius:6px;font-size:.78rem;font-weight:500;cursor:pointer}.fc .fc-toolbar{flex-wrap:wrap;gap:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text3);gap:12px;text-align:center}.empty-state svg{opacity:.3}.empty-state h3{color:var(--text2)}.divider{height:1px;background:var(--border)}.text-muted{color:var(--text2)}.text-sm{font-size:.82rem}.text-xs{font-size:.72rem}.text-primary{color:var(--primary-l)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-title{font-size:1.5rem;font-weight:800}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.stat-value{font-size:2rem;font-weight:800}.stat-label{font-size:.8rem;color:var(--text2);margin-top:2px}.progress{height:6px;background:var(--bg4);border-radius:6px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:6px;transition:width .5s}.tag{display:inline-flex;align-items:center;gap:4px;background:var(--bg4);border:1px solid var(--border);color:var(--text2);font-size:.75rem;padding:2px 8px;border-radius:6px}.upload-zone{border:2px dashed var(--border2);border-radius:var(--radius-lg);padding:32px;text-align:center;color:var(--text3);transition:all .2s;cursor:pointer}.upload-zone:hover,.upload-zone.drag{border-color:var(--primary);background:#6366f10d;color:var(--primary-l)}
