*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,sans-serif}html,body{overflow-x:hidden}:root{--bg:#eef4fb;--bg2:#f8fbff;--card:#ffffffeb;--card-solid:#fff;--text:#111827;--muted:#64748b;--border:#dfe9f5;--primary:#4f46e5;--primary2:#645fbe;--success:#14a44d;--danger:#e11d48}body.dark{--bg:#0b1220;--bg2:#111827;--card:#111827eb;--card-solid:#111827;--text:#f8fafc;--muted:#94a3b8;--border:#243244;--primary:#3b82f6;--primary2:#60a5fa;--success:#22c55e;--danger:#fb7185}body{background:linear-gradient(135deg, var(--bg), var(--bg2));color:var(--text);font-size:14px}.dashboard{min-height:100vh;display:flex}.main{flex:1;min-width:0}.sidebar{background:var(--card);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-right:1px solid var(--border);z-index:999;flex-direction:column;justify-content:space-between;width:280px;min-width:280px;padding:18px;transition:all .35s;display:flex}.logo-box{align-items:center;gap:14px;width:100%;margin-bottom:25px;display:flex;overflow:hidden}.logo-circle{color:#fff;background:#4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:54px;min-width:54px;height:54px;font-size:20px;display:flex;box-shadow:0 10px 25px #0d7cff40}.logo-text{flex:1;min-width:0}.logo-text h2{white-space:nowrap;text-overflow:ellipsis;font-size:25px;font-weight:600;overflow:hidden}.logo-text p{letter-spacing:1px;color:var(--muted);font-size:12px}.menu{margin-top:10px;padding:0;list-style:none}.menu li{margin-bottom:8px}.menu-link{color:var(--muted);border-radius:18px;align-items:center;gap:14px;width:100%;padding:16px 14px;font-size:17px;text-decoration:none;transition:all .25s;display:flex}.menu-link:hover{background:#0d7cff14;transform:translate(4px)}.menu li.active .menu-link{color:var(--primary);box-shadow:inset 3px 0 0 var(--primary);background:#0d7cff1a;font-weight:700}.menu-link svg{min-width:18px;font-size:18px}.menu-link span{white-space:nowrap}.sidebar.collapsed .menu-link{justify-content:center}.sidebar.collapsed .menu-link span{display:none}.sidebar.collapsed{width:92px;min-width:92px}.sidebar.collapsed .logo-text,.sidebar.collapsed .menu li span,.sidebar.collapsed .tip-box{display:none}.sidebar.collapsed .menu li{justify-content:center}.topbar{background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:99;align-items:center;gap:14px;padding:14px 22px;display:flex;position:sticky;top:0}.toggle-btn,.theme-btn{width:46px;height:46px;color:var(--primary);cursor:pointer;background:#0d7cff14;border:none;border-radius:14px;justify-content:center;align-items:center;font-size:18px;transition:all .25s;display:flex}.toggle-btn:hover,.theme-btn:hover{transform:scale(1.05)}.top-right{align-items:center;gap:14px;margin-left:auto;display:flex}.notify{background:var(--card-solid);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.profile{background:var(--card-solid);border:1px solid var(--border);border-radius:40px;align-items:center;gap:10px;padding:6px 12px 6px 6px;display:flex}.avatar{background:linear-gradient(135deg, var(--primary), var(--primary2));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-weight:700;display:flex}.profile h4{font-size:15px}.profile p{color:var(--muted);font-size:12px}.profile-wrap,.profile-menu{position:relative}.profile-menu summary{list-style:none}.profile-menu summary::-webkit-details-marker{display:none}.profile{cursor:pointer;-webkit-user-select:none;user-select:none}.profile-arrow{color:var(--muted);font-size:13px;transition:all .25s}.profile-menu[open] .profile-arrow{color:var(--primary);transform:rotate(180deg)}.profile-dropdown{background:var(--card);border:1px solid var(--border);z-index:9999;border-radius:22px;width:250px;padding:10px;position:absolute;top:calc(100% + 12px);right:0;box-shadow:0 18px 45px #0f172a1f}.profile-dropdown a{color:var(--text);border-radius:16px;align-items:center;gap:12px;padding:14px;font-size:15px;text-decoration:none;transition:all .22s;display:flex}.profile-dropdown a i{width:18px;color:var(--muted)}.profile-dropdown a:hover{color:var(--primary);background:#0d7cff14}.profile-dropdown a:hover i{color:var(--primary)}.profile-dropdown a:last-child,.profile-dropdown a:last-child i{color:var(--danger)}.profile-dropdown a:last-child:hover{background:#e11d4814}@media (max-width:768px){.profile-dropdown{width:220px}}@media (max-width:500px){.profile-dropdown{width:200px}.profile-dropdown a{padding:12px;font-size:14px}}.content{padding:15px}.title-row{flex-wrap:wrap;justify-content:space-between;gap:20px;display:flex}.title-row h1{font-size:52px;line-height:1.1}.title-row p{color:var(--muted);margin-top:8px}.actions{flex-wrap:wrap;gap:12px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-size:16px;font-weight:600;transition:all .25s;display:flex}.btn:hover{transform:translateY(-2px)}.btn.white{background:var(--card-solid);color:var(--text);box-shadow:0 8px 20px #0f172a0f}.btn.blue{background:linear-gradient(135deg, var(--primary), var(--primary2));color:#fff}.cards{grid-template-columns:repeat(4,1fr);gap:18px;margin-top:22px;display:grid}.card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:22px;transition:all .25s;box-shadow:0 10px 30px #0f172a0a}.card:hover{transform:translateY(-4px)}.card-top{justify-content:space-between;gap:12px;display:flex}.card span{color:var(--muted);font-size:14px}.card h2{margin:14px 0;font-size:46px}.icon{color:#fff;border-radius:18px;justify-content:center;align-items:center;display:flex}.blue-bg{background:#0ea5ff}.indigo-bg{background:#5975ff}.green-bg{background:#00c389}.pink-bg{background:#c65cff}.green,.red{border-radius:20px;padding:7px 11px;font-size:14px;display:inline-block}.green{color:var(--success);background:#14a44d1a}.red{color:var(--danger);background:#e11d481a}.chart-grid{grid-template-columns:2fr 1fr;gap:18px;margin-top:20px;display:grid}.chart-box{background:var(--card);border:1px solid var(--border);border-radius:24px;min-height:420px;padding:22px}.chart-box h3{font-size:32px}.chart-box p{color:var(--muted)}.chart-head{flex-wrap:wrap;justify-content:space-between;gap:10px;display:flex}.tag{color:var(--success);background:#14a44d1a;border-radius:20px;padding:8px 14px}.line-chart{border-left:2px solid var(--border);border-bottom:2px solid var(--border);height:300px;margin-top:30px;position:relative;overflow:hidden}.line{clip-path:polygon(0% 82%,15% 79%,30% 74%,45% 63%,60% 56%,75% 49%,90% 41%,100% 36%,100% 100%,0 100%);background:linear-gradient(#0000,#3b82f62e);border-top:4px solid #2563eb;position:absolute;inset:0}.donut{background:conic-gradient(#3b82f6 0 45%, #60a5fa 45% 75%, #93c5fd 75% 100%);border-radius:50%;width:230px;height:230px;margin:40px auto;position:relative}.donut:after{content:"";background:var(--card-solid);border-radius:50%;position:absolute;inset:42px}.overlay{opacity:0;visibility:hidden;z-index:998;background:#0f172a59;transition:all .3s;position:fixed;inset:0}.overlay.show{opacity:1;visibility:visible}@media (max-width:1200px){.cards{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{border-radius:0 24px 24px 0;width:290px;min-width:290px;position:fixed;top:0;bottom:0;left:-100%}.sidebar.show{left:0}.sidebar.collapsed{width:290px;min-width:290px}.sidebar.collapsed .logo-text,.sidebar.collapsed .menu li span,.sidebar.collapsed .tip-box{display:block}.topbar{grid-template-columns:48px 48px 1fr 48px 48px;align-items:center;gap:10px;padding:14px;display:grid}.toggle-btn{grid-column:1}.theme-btn{grid-column:2}.search-box{grid-area:2/1/auto/-1;width:100%;margin-top:4px}.top-right{grid-column:4/6;justify-self:end;gap:10px;margin-left:0}.profile div:last-child{display:none}.cards{grid-template-columns:1fr}.content{padding:16px}.title-row h1{font-size:38px}}@media (max-width:500px){.actions{flex-direction:column;width:100%}.btn{width:100%}.title-row h1{font-size:32px}.title-row p{font-size:14px;line-height:1.5}.donut{width:180px;height:180px}.donut:after{inset:32px}}.close-btn{display:none!important}@media screen and (max-width:768px){.sidebar .close-btn{cursor:pointer;z-index:9999;background:#0d7cff;border:none;border-radius:12px;justify-content:center;align-items:center;width:45px;height:45px;font-size:50px;position:absolute;top:6px;right:-36px;display:flex!important}}.seat-layout{grid-template-columns:2fr 1fr;align-items:start;gap:18px;margin-top:22px;display:grid}.seat-panel,.recent-panel{padding:24px}.seat-head{flex-wrap:wrap;justify-content:space-between;gap:15px;margin-bottom:22px;display:flex}.seat-head h3,.recent-panel h3{margin-bottom:6px;font-size:34px}.seat-head p,.recent-sub{color:var(--muted);font-size:16px}.legend{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.legend span{color:var(--text);align-items:center;gap:8px;font-size:15px;display:flex}.dot{border-radius:4px;width:14px;height:14px;display:inline-block}.dot.free{background:#d8ffee;border:1px solid #86efac}.dot.busy{background:#2563eb}.seat-grid{grid-template-columns:repeat(8,1fr);gap:14px;display:grid}.seat{color:#047857;cursor:pointer;background:#eafff3;border:1.5px solid #8ee7b5;border-radius:22px;justify-content:center;align-items:center;height:72px;font-size:18px;font-weight:700;transition:all .25s;display:flex}.seat:hover{transform:translateY(-3px)scale(1.02)}.seat.busy{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#2563eb;box-shadow:0 12px 20px #2563eb40}.assign-list{flex-direction:column;gap:14px;margin-top:18px;display:flex}.assign-item{border:1px solid var(--border);background:#fff9;border-radius:22px;align-items:center;gap:14px;padding:16px;display:flex}.seat-badge{color:#fff;background:linear-gradient(135deg,#0d7cff,#22b0ff);border-radius:18px;justify-content:center;align-items:center;width:52px;min-width:52px;height:52px;font-size:18px;font-weight:800;display:flex}.assign-info{flex:1;min-width:0}.assign-info h4{white-space:nowrap;text-overflow:ellipsis;font-size:20px;overflow:hidden}.assign-info p{color:var(--muted);margin-top:4px}.pill{color:#2563eb;white-space:nowrap;background:#eef4ff;border-radius:20px;padding:10px 14px;font-size:14px;font-weight:600}body.dark .seat{color:#86efac;background:#0f172a;border-color:#1f9d68}body.dark .assign-item{background:#0b1220}body.dark .pill{color:#93c5fd;background:#1e293b}@media (max-width:1200px){.seat-layout{grid-template-columns:1fr}}@media (max-width:768px){.seat-head h3,.recent-panel h3{font-size:28px}.seat-grid{grid-template-columns:repeat(4,1fr);gap:12px}.seat{border-radius:18px;height:64px;font-size:16px}.assign-item{flex-wrap:wrap;align-items:flex-start}.pill{text-align:center;width:100%}}@media (max-width:500px){.seat-grid{grid-template-columns:repeat(3,1fr)}.seat-panel,.recent-panel{padding:16px}.assign-info h4{font-size:17px}.seat-badge{width:46px;min-width:46px;height:46px}}.student-layout{grid-template-columns:2fr 1fr;gap:18px;margin-top:22px;display:grid}.student-form,.student-side{padding:24px}.student-form h3,.student-side h3{margin-bottom:20px;font-size:28px}.form-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.input-box{flex-direction:column;gap:8px;display:flex}.input-box label{color:var(--text);font-size:14px;font-weight:600}.input-box input,.input-box select,.input-box textarea{border:1px solid var(--border);background:var(--card);width:100%;color:var(--text);border-radius:16px;outline:none;padding:14px 16px;font-size:15px}.input-box input:focus,.input-box select:focus,.input-box textarea:focus{border-color:var(--primary)}.full{margin-top:16px}.summary-box{border:1px solid var(--border);background:#ffffff80;border-radius:20px;margin-bottom:14px;padding:18px}.summary-box span{color:var(--muted);font-size:14px}.summary-box h2{margin-top:8px;font-size:34px}@media (max-width:1100px){.student-layout{grid-template-columns:1fr}}@media (max-width:768px){.form-grid{grid-template-columns:1fr}.student-form,.student-side{padding:18px}.student-form h3,.student-side h3{font-size:24px}}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px;margin-bottom:18px;display:flex}.page-head h1{font-size:40px}.page-head p{color:var(--muted);margin-top:4px}.page-head-right{align-items:center;gap:10px;display:flex}.page-head-right button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;padding:10px 16px;font-weight:600}.page-head-right button:hover{opacity:.9}.add-btn{background:linear-gradient(135deg, var(--primary), var(--primary2));color:#fff;cursor:pointer;border:none;border-radius:14px;padding:12px 18px;font-weight:700}.table-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:18px}.table-top{justify-content:space-between;gap:12px;margin-bottom:16px;display:flex}.search-box{border:1px solid var(--border);background:var(--card-solid);border-radius:14px;align-items:center;gap:10px;min-width:280px;padding:12px 14px;display:flex}.search-box input{width:100%;color:var(--text);background:0 0;border:none;outline:none}.table-wrap{width:100%;overflow:auto}.table-header{margin-bottom:18px}.table-title{color:var(--text);font-size:22px;font-weight:700}.table-subtitle{color:var(--muted);margin-top:4px;font-size:14px}.table-left-actions{flex-wrap:wrap;gap:10px;display:flex}.th-inner{align-items:center;gap:6px;display:flex}.table-left-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.table-left-actions .add-btn,.table-left-actions button{white-space:nowrap;justify-content:center;align-items:center;gap:8px;display:inline-flex}.table-select{color:#111827;cursor:pointer;background:#fff;border:1px solid #dcdfe4;border-radius:10px;outline:none;min-width:130px;height:36px;padding:0 12px;font-size:14px;font-weight:500;transition:all .2s}.table-select:hover{border-color:#6366f1}.table-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.per-page-select{min-width:140px;position:relative}.per-page-select select{color:#111827;cursor:pointer;appearance:none;background:#fff;border:1px solid #dbe2ea;border-radius:12px;outline:none;width:100%;height:42px;padding:0 38px 0 14px;font-size:14px;font-weight:600;transition:all .2s;box-shadow:0 2px 6px #0000000a}.per-page-select select:hover{border-color:#6366f1}.per-page-select select:focus{border-color:#6366f1;box-shadow:0 0 0 4px #6366f11f}.select-arrow{pointer-events:none;color:#6b7280;position:absolute;top:50%;right:12px;transform:translateY(-50%)}@media (max-width:768px){.per-page-select{min-width:120px}.per-page-select select{border-radius:10px;height:38px;font-size:13px}}@media (max-width:992px){.table-top{flex-direction:column;align-items:stretch}.table-left-actions{width:100%}.table-left-actions .add-btn,.table-left-actions button{flex:calc(50% - 10px);min-width:160px}.search-box{width:100%;min-width:100%}}@media (max-width:576px){.table-left-actions .add-btn,.table-left-actions button{flex:100%;width:100%}.table-left-actions .add-btn span,.table-left-actions button span{text-overflow:ellipsis;overflow:hidden}}button[data-label=Export]{color:#fff;background:linear-gradient(135deg,#16a34a,#22c55e)!important}.student-table{border-collapse:collapse;width:100%;min-width:900px}.student-table th,.student-table td{text-align:left;border-bottom:1px solid var(--border);padding:16px}.student-table th{color:var(--muted);cursor:pointer;white-space:nowrap;font-size:14px}.student-table th svg{vertical-align:middle;margin-left:4px}.student-table tbody tr:hover{background:#0d7cff0a}.badge{border-radius:30px;padding:6px 10px;font-size:12px;font-weight:700}.badge.paid,.badge.active{color:#16a34a;background:#22c55e1f}.badge.pending,.badge.inactive{color:#dc2626;background:#ef44441f}.actions-btn{gap:8px;display:flex}.actions-btn button{background:var(--card-solid);border:none;border:1px solid var(--border);cursor:pointer;width:34px;height:34px;color:var(--text);border-radius:10px}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;display:flex}.pagination p{color:var(--muted);font-size:14px}.page-btns{align-items:center;gap:8px;display:flex}.page-btns button{background:var(--card-solid);border:none;border:1px solid var(--border);cursor:pointer;border-radius:10px;width:36px;height:36px}.page-btns button:disabled{opacity:.5;cursor:not-allowed}.empty-row{text-align:center;color:var(--muted);padding:30px}@media (max-width:768px){.page-head h1{font-size:30px}.search-box{min-width:100%}.pagination{flex-direction:column;align-items:flex-start}}.student-form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.input-group{flex-direction:column;gap:8px;display:flex}.input-box{border:1px solid var(--border);background:var(--card-solid);border-radius:14px;align-items:center;gap:10px;height:52px;padding:0 14px;display:flex}.input-box input,.input-box select{width:100%;color:var(--text);background:0 0;border:none;outline:none}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.full-width{grid-column:1/-1}.cancel-btn,.save-btn{cursor:pointer;border:none;border-radius:12px;padding:12px 18px;font-weight:700}.cancel-btn{background:var(--card-solid);border:1px solid var(--border)}.save-btn{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary2))}@keyframes pop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.app-modal{max-height:90vh;padding:18px;overflow:auto}.student-form-grid{grid-template-columns:1fr}.full-width{grid-column:auto}.modal-actions{flex-direction:column-reverse}.cancel-btn,.save-btn{width:100%}}.pm-overlay{z-index:9999;background:#0000008c;justify-content:center;align-items:center;padding:1rem;animation:.18s ease-out fadeModal;display:flex;position:fixed;inset:0}.pm-modal{background:var(--card-solid);width:100%;max-width:600px;color:var(--text);border:1px solid var(--border);border-radius:14px;animation:.22s ease-out modalDrop;position:relative;overflow:hidden;box-shadow:0 18px 40px #00000038}.modal-sm{max-width:420px}.modal-md{max-width:600px}.modal-lg{max-width:900px}.pm-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;display:flex}.pm-title-wrap{align-items:center;gap:12px;display:flex}.pm-icon{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.pm-head h2{font-size:20px;font-weight:700;line-height:1.2}.pm-head p{color:var(--muted);margin-top:2px;font-size:13px}.pm-close{cursor:pointer;width:36px;height:36px;color:var(--muted);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.pm-close:hover{color:var(--text);background:#0000000f}.pm-body{padding:20px}.pm-actions{justify-content:flex-end;gap:10px;padding:0 20px 20px;display:flex}.pm-btn{cursor:pointer;border:none;border-radius:8px;padding:10px 18px;font-weight:600}.pm-btn-light{background:var(--bg);color:var(--text);border:1px solid var(--border)}.pm-btn-primary{background:var(--primary);color:#fff}.btn-primary{background-color:var(--primary);color:#fff;text-align:end;margin-top:10px}.input-group label{margin-top:5px;margin-left:10px}@keyframes fadeModal{0%{opacity:0}to{opacity:1}}@keyframes modalDrop{0%{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.pm-overlay{padding:12px}.pm-modal{border-radius:12px;max-width:100%}.pm-head,.pm-body{padding:16px}.pm-actions{flex-direction:column-reverse;padding:0 16px 16px}.pm-btn{width:100%}}.error-text{color:red;margin-top:5px;font-size:14px}.room-form{flex-direction:column;gap:16px;display:flex}.room-submit-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border:0;border-radius:12px;height:46px;font-weight:700;transition:all .2s}.room-submit-btn:hover{opacity:.95;transform:translateY(-1px)}.room-submit-btn:disabled{opacity:.7;cursor:not-allowed}.dark .room-submit-btn,html.dark .room-submit-btn{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}.dropdown-items{cursor:pointer;width:100%;color:red;background:0 0;border:none;align-items:center;gap:10px;padding:10px 14px;font-size:14px;text-decoration:none;display:flex}.view-btn{cursor:pointer;background:#f1f5f9;border:1px solid #ddd;border-radius:6px;margin-top:8px;padding:6px 10px;font-size:13px;display:inline-block}.view-btn:hover{background:#e2e8f0}.view-actions{gap:12px;margin-top:20px;display:flex}.invoic{color:#fff;background:#22c55e!important}.purple{color:#fff;background:#f59e0b!important}.badge.expiring-soon{color:#d97706;background:#fef3c7}.student-cell{flex-direction:column;gap:2px;display:flex}.student-name{font-size:13px;font-weight:600}.student-id{color:#6b7280;font-size:13px}.expiry-cell{flex-direction:column;gap:4px;display:flex}.expiry-date{font-size:13px;font-weight:500}.days-left{color:#6b7280;font-size:11px}.badge.expired{color:#dc2626;background:#fee2e2}.badge.active{color:#16a34a;background:#dcfce7}.badge.inactive{color:#6b7280;background:#f3f4f6}.dashboard-shimmer{width:100%}:root{--shimmer-base:#e2e8f0;--shimmer-highlight:#ffffffbf;--shimmer-soft:#ffffff40}body.dark{--shimmer-base:#182233;--shimmer-highlight:#ffffff14;--shimmer-soft:#ffffff08}@keyframes shimmer{0%{transform:translate(-120%)}to{transform:translate(220%)}}.shimmer-card,.shimmer-chart-box,.shimmer-line,.shimmer-icon,.shimmer-chart,.shimmer-circle,.shimmer-dot{background:var(--shimmer-base);border:1px solid var(--border);isolation:isolate;position:relative;overflow:hidden}.shimmer-card:before,.shimmer-chart-box:before,.shimmer-line:before,.shimmer-icon:before,.shimmer-chart:before,.shimmer-circle:before,.shimmer-dot:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--shimmer-soft) 25%, var(--shimmer-highlight) 50%, var(--shimmer-soft) 75%, transparent 100%);animation:2.4s cubic-bezier(.4,0,.2,1) infinite shimmer;position:absolute;inset:0;transform:translate(-120%)}.shimmer-stats{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px;display:grid}.shimmer-card{background:var(--card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;height:190px;padding:22px}.shimmer-top{justify-content:space-between;align-items:center;display:flex}.shimmer-line{border-radius:12px}.shimmer-line.short{width:120px;height:16px}.shimmer-line.medium{width:180px;height:18px}.shimmer-line.big{width:180px;height:42px;margin-top:28px}.shimmer-icon{border-radius:20px;width:64px;height:64px}.shimmer-grid{grid-template-columns:1.5fr 420px;gap:20px;display:grid}.shimmer-chart-box{background:var(--card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;min-height:480px;padding:22px}.shimmer-chart{border-radius:24px;width:100%;height:320px;margin-top:30px}.shimmer-circle{border-radius:50%;width:220px;height:220px;margin:40px auto 0}.shimmer-legend{justify-content:center;gap:18px;margin-top:40px;display:flex}.shimmer-dot{border-radius:20px;width:90px;height:14px}@media (max-width:1200px){.shimmer-grid{grid-template-columns:1fr}}@media (max-width:768px){.shimmer-stats{grid-template-columns:1fr}.shimmer-card{border-radius:24px;height:170px}.shimmer-chart-box{border-radius:24px;min-height:auto}.shimmer-chart{height:240px}.shimmer-circle{width:170px;height:170px}}.permission-loading{color:#666;justify-content:center;align-items:center;height:100vh;font-size:15px;display:flex}
