*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #F5F2FA;--surface: #FFFFFF;--sidebar: #FDFCFF;--ink: #342451;--ink-mid: #6B5C8A;--ink-soft: #A498BE;--ink-faint: #CDC5E0;--p: #7C5FC4;--p-soft: #EDE7FB;--p-mid: #B39EE0;--p-line: rgba(124,95,196,.1);--p-line2: rgba(124,95,196,.06);--green: #4E9E83;--green-bg: #EAF5F1;--amber: #C08038;--amber-bg: #FBF2E5;--red: #B85050;--red-bg: #FBF0F0;--blue: #4E7CB8;--blue-bg: #EBF1FA;--radius: 14px;--radius-sm: 9px;--shadow: 0 2px 12px rgba(124,95,196,.07);--shadow-md: 0 4px 22px rgba(124,95,196,.1)}html,body{height:100%;overflow:hidden}body{font-family:Figtree,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}#root{height:100%}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-thumb{background:var(--p-line);border-radius:3px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:220px;background:var(--sidebar);border-right:1px solid var(--p-line);display:flex;flex-direction:column;z-index:40;transition:width .2s ease}.sidebar.collapsed{width:60px}.logo-zone{padding:22px 20px 20px;border-bottom:1px solid var(--p-line2);display:flex;align-items:center;gap:11px;overflow:hidden;white-space:nowrap}.sidebar.collapsed .logo-zone{padding:22px 14px 20px;justify-content:center}.sidebar.collapsed .logo-text-wrap{display:none}.logo-text-wrap{display:flex;flex-direction:column;gap:1px}.logo-name{font-family:Syne,sans-serif;font-size:16px;font-weight:400;letter-spacing:.14em;color:var(--ink)}.logo-tag{font-size:9px;font-weight:500;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase}.nav{flex:1;padding:14px 12px;overflow-y:auto}.nav-section-label{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);padding:0 10px;margin:14px 0 6px}.nav-section-label:first-child{margin-top:0}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--ink-mid);font-size:13px;font-weight:400;transition:all .16s;position:relative;margin-bottom:1px;-webkit-user-select:none;user-select:none;text-decoration:none}.nav-item:hover{background:var(--p-soft);color:var(--p)}.nav-item.active{background:var(--p-soft);color:var(--p);font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--p);border-radius:0 3px 3px 0}.nav-icon{width:16px;height:16px;flex-shrink:0;text-align:center}.sidebar.collapsed .nav{padding:14px 8px}.sidebar.collapsed .nav-section-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:9px 0;gap:0;overflow:hidden}.sidebar.collapsed .nav-item .nav-icon{width:20px;height:20px;font-size:15px}.sidebar.collapsed .nav-item span:not(.nav-icon){display:none}.sidebar-bottom{padding:14px 12px;border-top:1px solid var(--p-line2)}.sidebar.collapsed .sidebar-bottom{padding:14px 8px}.sidebar.collapsed .user-row{justify-content:center;padding:8px 0}.sidebar.collapsed .user-row>div:not(.av-sm){display:none}.user-row{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.user-row:hover{background:var(--p-soft)}.av-sm{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--p),var(--p-mid));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.user-name{font-size:12px;font-weight:500;color:var(--ink)}.user-role{font-size:10px;color:var(--ink-soft)}.shell{margin-left:220px;height:100vh;display:flex;flex-direction:column;overflow:hidden;transition:margin-left .2s ease}.shell.collapsed{margin-left:60px}.sidebar-toggle{position:absolute;top:16px;right:-12px;width:24px;height:24px;border-radius:50%;background:var(--surface);border:1px solid var(--p-line);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:42;font-size:11px;color:var(--ink-soft);transition:all .16s;box-shadow:0 1px 4px #7c5fc414;padding:0}.sidebar-toggle:hover{background:var(--p-soft);color:var(--p);border-color:var(--p-mid)}.topbar{background:var(--surface);border-bottom:1px solid var(--p-line);height:56px;display:flex;align-items:center;padding:0 28px;gap:14px;flex-shrink:0}.page-title{font-family:Syne,sans-serif;font-size:17px;font-weight:500;color:var(--ink);flex:1;letter-spacing:.01em}.topbar-right{display:flex;align-items:center;gap:8px;position:relative}.dropdown-trigger{cursor:pointer;border:none;background:none;padding:0;display:flex;align-items:center}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--p-line);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:200px;z-index:50;animation:fadeUp .15s ease both;overflow:hidden}.dropdown-header{padding:12px 14px;border-bottom:1px solid var(--p-line2)}.dropdown-header-name{font-size:13px;font-weight:500;color:var(--ink)}.dropdown-header-email{font-size:11px;color:var(--ink-soft);margin-top:1px}.dropdown-divider{height:1px;background:var(--p-line2);margin:0}.dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:12px;font-weight:400;color:var(--ink-mid);cursor:pointer;transition:all .12s;border:none;background:none;width:100%;font-family:Figtree,sans-serif;text-align:left}.dropdown-item:hover{background:var(--p-soft);color:var(--p)}.dropdown-item-danger{color:var(--red)}.dropdown-item-danger:hover{background:var(--red-bg);color:var(--red)}.content{flex:1;overflow-y:auto;padding:24px 28px;animation:fadeUp .22s ease both}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:var(--radius-sm);font-family:Figtree,sans-serif;font-size:12px;font-weight:500;cursor:pointer;border:none;transition:all .16s}.btn-p{background:var(--p);color:#fff;box-shadow:0 2px 8px #7c5fc438}.btn-p:hover{background:#6b50af;box-shadow:0 3px 14px #7c5fc44d}.btn-p:disabled{opacity:.5;cursor:default}.btn-ghost{background:transparent;color:var(--ink-mid);border:1px solid var(--p-line)}.btn-ghost:hover{background:var(--p-soft);color:var(--p);border-color:var(--p-mid)}.btn-ghost.active{background:var(--p);color:#fff;border-color:var(--p)}.btn-ico{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--p-line);border-radius:var(--radius-sm);color:var(--ink-soft);cursor:pointer;transition:all .16s}.btn-ico:hover{background:var(--p-soft);color:var(--p);border-color:var(--p-mid)}.btn-danger{background:var(--red);color:#fff;border:none;padding:7px 15px;border-radius:var(--radius-sm);font-family:Figtree,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .16s}.btn-danger:hover{background:#a04444}.btn-danger:disabled{opacity:.5;cursor:default}.btn-green{background:var(--green);color:#fff;border:none;padding:7px 15px;border-radius:var(--radius-sm);font-family:Figtree,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .16s}.btn-green:hover{background:#3d8a6e}.btn-green:disabled{opacity:.5;cursor:default}.card{background:var(--surface);border:1px solid var(--p-line);border-radius:var(--radius);overflow:hidden}.card-p{padding:18px 20px}.card-h{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--p-line2)}.card-title{font-size:13px;font-weight:500;color:var(--ink)}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.kpi{background:var(--surface);border:1px solid var(--p-line);border-radius:var(--radius);padding:18px 20px;transition:box-shadow .18s}.kpi:hover{box-shadow:var(--shadow-md)}.kpi-label{font-size:11px;font-weight:500;color:var(--ink-soft);margin-bottom:10px;display:flex;align-items:center;gap:6px}.kpi-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.kpi-num{font-family:Syne,sans-serif;font-size:26px;font-weight:500;color:var(--ink);line-height:1;margin-bottom:6px;letter-spacing:-.01em}.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:500;letter-spacing:.02em}.cg{background:var(--green-bg);color:var(--green)}.ca{background:var(--amber-bg);color:var(--amber)}.cr{background:var(--red-bg);color:var(--red)}.cp{background:var(--p-soft);color:var(--p)}.cb{background:var(--blue-bg);color:var(--blue)}.ds-table{width:100%;border-collapse:collapse}.ds-table thead th{text-align:left;padding:10px 18px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);background:var(--bg);border-bottom:1px solid var(--p-line)}.ds-table tbody td{padding:12px 18px;font-size:13px;color:var(--ink);border-bottom:1px solid var(--p-line2);vertical-align:middle}.ds-table tbody tr:last-child td{border-bottom:none}.ds-table tbody tr{transition:background .12s;cursor:pointer}.ds-table tbody tr:hover{background:var(--p-soft)}.av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.section-h{font-family:Syne,sans-serif;font-size:14px;font-weight:500;color:var(--ink);margin-bottom:12px}.chat-msgs{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:10px;background:var(--bg)}.msg{max-width:74%;display:flex;flex-direction:column;gap:3px}.msg.a{align-self:flex-start}.msg.u{align-self:flex-end}.msg-b{padding:9px 13px;border-radius:12px;font-size:13px;line-height:1.5}.msg.a .msg-b{background:var(--surface);border:1px solid var(--p-line);color:var(--ink);border-radius:3px 12px 12px}.msg.u .msg-b{background:var(--p);color:#fff;border-radius:12px 3px 12px 12px}.msg-t{font-size:10px;color:var(--ink-soft);padding:0 3px}.msg.u .msg-t{align-self:flex-end}.chat-in{padding:11px 16px;border-top:1px solid var(--p-line);display:flex;gap:8px;align-items:center;background:var(--surface)}.chat-in input{flex:1;border:1px solid var(--p-line);border-radius:9px;padding:8px 13px;font-family:Figtree,sans-serif;font-size:12px;outline:none;background:var(--bg);color:var(--ink)}.chat-in input:focus{border-color:var(--p-mid)}.esc-card{background:var(--surface);border:1px solid var(--p-line);border-radius:var(--radius);padding:16px 18px;display:flex;gap:12px;margin-bottom:10px;cursor:pointer;transition:box-shadow .16s}.esc-card:hover{box-shadow:var(--shadow-md)}.esc-bar{width:3px;border-radius:3px;align-self:stretch;flex-shrink:0;min-height:42px}.form-input{width:100%;border:1px solid var(--p-line);border-radius:var(--radius-sm);padding:9px 13px;font-family:Figtree,sans-serif;font-size:13px;color:var(--ink);background:var(--bg);outline:none;transition:border-color .16s}.form-input:focus{border-color:var(--p);background:#fff}.form-label{font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--ink-mid);display:block;margin-bottom:5px}.cfg-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--p-line2)}.cfg-row:last-child{border-bottom:none}.toggle{width:36px;height:20px;border-radius:10px;background:var(--ink-faint);cursor:pointer;position:relative;transition:background .18s;flex-shrink:0;border:none}.toggle.on{background:var(--p)}.toggle:after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .18s;box-shadow:0 1px 3px #0000001f}.toggle.on:after{transform:translate(16px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#3424514d;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-body{background:var(--surface);border-radius:var(--radius);padding:24px;max-width:480px;width:90%;box-shadow:var(--shadow-md)}.modal-title{font-family:Syne,sans-serif;font-size:17px;font-weight:500;color:var(--ink);margin-bottom:16px}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:var(--bg);display:flex;align-items:center;justify-content:center}.login-card{background:var(--surface);border:1px solid var(--p-line);border-radius:20px;box-shadow:0 8px 48px #7c5fc41a;display:flex;overflow:hidden;width:820px;max-width:96vw;max-height:96vh}.login-form-side{width:360px;flex-shrink:0;padding:44px 40px;display:flex;flex-direction:column}.login-panel{flex:1;background:var(--p-soft);display:flex;align-items:center;justify-content:center;padding:40px;position:relative;overflow:hidden}.login-panel:before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(124,95,196,.06) 0%,transparent 70%);top:-60px;right:-60px}.cat-card{background:var(--surface);border:1px solid var(--p-line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .18s}.cat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.cat-img{height:80px;display:flex;align-items:center;justify-content:center;font-size:28px;background:var(--bg)}.cat-body{padding:13px 14px}.cat-name{font-size:13px;font-weight:500;margin-bottom:2px}.cat-price{font-family:Syne,sans-serif;font-size:18px;font-weight:500;color:var(--p);margin-bottom:4px}.cat-desc{font-size:11px;color:var(--ink-soft);line-height:1.5;margin-bottom:8px}.tabs{display:flex;border-bottom:1px solid var(--p-line2)}.tab{padding:10px 16px;font-size:12px;font-weight:400;color:var(--ink-soft);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab:hover{color:var(--p)}.tab.on{color:var(--p);border-bottom-color:var(--p);font-weight:500}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-h{text-align:center;font-size:10px;font-weight:500;color:var(--ink-soft);padding:5px 0}.cal-d{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;font-size:12px;color:var(--ink);transition:background .12s}.cal-d:hover{background:var(--p-soft)}.cal-d.today{background:var(--p);color:#fff;font-weight:600}.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.bar{height:4px;background:var(--bg);border-radius:2px;overflow:hidden}.bar-fill{height:100%;border-radius:2px;background:var(--p)}.divider{height:1px;background:var(--p-line2);margin:0}.text-soft{color:var(--ink-soft)}.text-mid{color:var(--ink-mid)}.text-faint{color:var(--ink-faint)}.text-p{color:var(--p)}.text-green{color:var(--green)}.text-amber{color:var(--amber)}.text-red{color:var(--red)}.line{border-bottom:1px solid var(--p-line2)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;animation:fadeUp .25s ease both}.empty-state-icon{font-size:36px;margin-bottom:14px;line-height:1;opacity:.7}.empty-state-title{font-family:Syne,sans-serif;font-size:15px;font-weight:500;color:var(--ink);margin-bottom:5px}.empty-state-sub{font-size:12px;color:var(--ink-soft);max-width:260px;line-height:1.5}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.modal-overlay{animation:fadeUp .15s ease}.modal-body{animation:modalIn .2s ease}.mobile-only{display:none}.desktop-only{display:initial}.hamburger{width:36px;height:36px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:20px;padding:0;border-radius:var(--radius-sm);transition:background .15s}.hamburger:hover{background:var(--p-soft)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#34245159;z-index:39;display:none}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:768px){.mobile-only{display:flex}.desktop-only{display:none}.sidebar{transform:translate(-100%);transition:transform .25s ease;z-index:41}.sidebar.open{transform:translate(0)}.sidebar-backdrop.open{display:block}.shell{margin-left:0}.topbar{padding:0 16px}.content{padding:18px 16px}.kpi-row{grid-template-columns:repeat(2,1fr);gap:10px}.g2{grid-template-columns:1fr}.login-card{flex-direction:column;width:100%;max-width:420px;border-radius:16px}.login-form-side{width:100%;padding:32px 28px}.login-panel{display:none}.modal-body{width:96%;max-width:none;padding:20px}.ds-table{min-width:580px}.esc-card{flex-direction:column;gap:10px}.esc-bar{width:100%;height:3px;min-height:auto}}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:16px}.nav-badge-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--red)}.topbar-alert{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-sm);background:var(--amber-bg);text-decoration:none;margin-right:8px;animation:pulse-alert 2s infinite}.topbar-alert-icon{font-size:12px;color:var(--amber)}.topbar-alert-count{font-size:11px;font-weight:600;color:var(--amber)}@keyframes pulse-alert{0%,to{opacity:1}50%{opacity:.6}}@media(max-width:480px){.kpi-row{grid-template-columns:1fr 1fr;gap:8px}.kpi{padding:14px 16px}.kpi-num{font-size:22px}.content{padding:14px 12px}.topbar{height:50px}}
