.datalist-container{width:100%;background:var(--bg-card);border-radius:16px;overflow:visible}.datalist-table-wrapper{overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.datalist-table{width:100%;border-collapse:collapse;font-size:14px}.datalist-table th{text-align:left;padding:14px 20px;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}.datalist-table-header-sticky th{position:sticky;top:0;z-index:10}.datalist-table td{padding:0 20px;height:56px;border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle}.datalist-table-row{cursor:pointer;transition:background-color .15s ease}.datalist-table-row:nth-child(2n){background:#fafbfd}[data-theme=dark] .datalist-table-row:nth-child(2n){background:#ffffff04}.datalist-table-row:hover{background:#f4f5fa}[data-theme=dark] .datalist-table-row:hover{background:#6c63ff0a}.datalist-table-row:active{background:#eef1f6}[data-theme=dark] .datalist-table-row:active{background:#6c63ff14}.datalist-table-actions{padding:8px 12px!important;width:70px}.datalist-cards{display:none;flex-direction:column;gap:10px;padding:12px}.datalist-cards-desktop{display:flex}.datalist-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:16px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000a;-webkit-tap-highlight-color:transparent}.datalist-card:hover{box-shadow:0 4px 12px #00000014;border-color:var(--primary-light)}.datalist-card:active{transform:scale(.99);background:var(--bg-secondary)}.datalist-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}.datalist-card-primary{flex:1;min-width:0}.datalist-card-actions-trigger{flex-shrink:0}.datalist-card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.datalist-card-field{display:flex;flex-direction:column;gap:4px}.datalist-card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.datalist-card-value{font-size:14px;font-weight:500;color:var(--text-primary)}.datalist-card-quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border-light)}.datalist-card-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;min-height:42px}.datalist-card-action-btn:active{transform:scale(.97)}.datalist-card-action-btn-default:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.datalist-card-action-btn-danger{background:#ef444414;border-color:#ef444433;color:#ef4444}.datalist-card-action-btn-danger:hover{background:#ef444426}.datalist-card-action-btn-success{background:#22c55e14;border-color:#22c55e33;color:#22c55e}.datalist-card-action-btn-success:hover{background:#22c55e26}.datalist-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:100px;font-size:12px;font-weight:600;letter-spacing:.01em;white-space:nowrap}.datalist-badge-success{background:#34c7591f;color:#22c55e}.datalist-badge-warning{background:#ff95001f;color:#f59e0b}.datalist-badge-danger{background:#ff3b301f;color:#ef4444}.datalist-badge-info{background:#007aff1f;color:#3b82f6}.datalist-badge-primary{background:#6366f11f;color:#6366f1}.datalist-badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.datalist-badge-muted{background:#8e8e931f;color:#8e8e93}.datalist-entity-cell{display:flex;align-items:center;gap:12px}.datalist-entity-avatar{border-radius:50%;object-fit:cover;border:2px solid var(--border-light);flex-shrink:0;background:var(--bg-tertiary)}.datalist-entity-info{display:flex;flex-direction:column;gap:2px;min-width:0}.datalist-entity-name{font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.datalist-entity-subtitle{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.datalist-rating{display:flex;align-items:center;gap:6px}.datalist-rating-stars{display:flex;color:gold}.datalist-rating-value{font-size:13px;font-weight:700;color:var(--text-primary)}.datalist-rating-count,.datalist-rating-empty{font-size:12px;color:var(--text-muted)}.datalist-action-dropdown{position:relative;display:inline-block}.datalist-action-trigger{width:36px;height:36px;padding:0;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.datalist-action-trigger:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.datalist-action-trigger:active{transform:scale(.95)}.datalist-action-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:6px;z-index:1000;animation:datalist-dropdown-fade-in .15s ease}.datalist-action-menu-up{top:auto;bottom:calc(100% + 6px);animation:datalist-dropdown-fade-in-up .15s ease}@keyframes datalist-dropdown-fade-in-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes datalist-dropdown-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.datalist-action-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;border-radius:8px;text-align:left}.datalist-action-item:hover{background:var(--hover-bg)}.datalist-action-item-default:hover{background:var(--primary-bg);color:var(--primary)}.datalist-action-item-danger{color:#ef4444}.datalist-action-item-danger:hover{background:#ef44441a}.datalist-action-item-success{color:#22c55e}.datalist-action-item-success:hover{background:#22c55e1a}.datalist-action-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.datalist-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-card);flex-wrap:wrap;gap:12px}.datalist-pagination-info{font-size:13px;color:var(--text-muted);font-weight:500}.datalist-pagination-controls{display:flex;gap:4px;align-items:center;flex-wrap:wrap;justify-content:center}.datalist-pagination-btn{min-width:36px;height:36px;padding:0 12px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .15s ease}.datalist-pagination-btn:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.datalist-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.datalist-pagination-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}.datalist-skeleton{padding:20px}.datalist-skeleton-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:20px;margin-bottom:16px}.datalist-skeleton-cell{height:20px;border-radius:6px;overflow:hidden;background:var(--bg-tertiary)}.datalist-skeleton-pulse{width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:datalist-skeleton-shimmer 1.5s infinite}@keyframes datalist-skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.datalist-empty-wrapper{padding:60px 20px}.datalist-empty{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.datalist-empty-icon{width:48px;height:48px;color:var(--text-muted);opacity:.5}.datalist-empty-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.datalist-empty-description{font-size:14px;color:var(--text-muted);margin:0;max-width:300px}@media(max-width:1024px){.datalist-table td:nth-child(n+5){font-size:13px;padding:0 14px}}@media(max-width:680px){.datalist-table-wrapper{display:none}.datalist-cards{display:flex}.datalist-pagination{flex-direction:column;padding:12px 16px}.datalist-pagination-info{text-align:center;font-size:12px;order:2}.datalist-pagination-controls{width:100%;order:1}.datalist-pagination-btn{min-width:32px;height:32px;padding:0 8px;font-size:12px}.datalist-card-body{grid-template-columns:1fr;gap:10px}.datalist-card-field{flex-direction:row;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.datalist-card-field:last-child{border-bottom:none}}@media(max-width:440px){.datalist-cards{padding:10px;gap:8px}.datalist-card{padding:14px;border-radius:14px}.datalist-card-quick-actions{grid-template-columns:1fr}.datalist-card-action-btn{width:100%}.datalist-action-trigger{width:32px;height:32px}.datalist-action-menu{min-width:160px;right:-6px}.datalist-action-item{padding:8px 10px;font-size:13px}}[data-theme=dark] .datalist-card{background:var(--bg-card);border-color:#ffffff14}[data-theme=dark] .datalist-card:hover{border-color:#6366f14d;box-shadow:0 4px 16px #0000004d}[data-theme=dark] .datalist-table th{background:#ffffff08}[data-theme=dark] .datalist-action-menu{box-shadow:0 8px 32px #0006;border-color:#ffffff1a}[data-theme=dark] .datalist-skeleton-cell{background:#ffffff0d}@supports (padding-bottom: env(safe-area-inset-bottom)){.datalist-pagination{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor ul,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"•"}.ql-editor ul[data-checked=true],.ql-editor ul[data-checked=false]{pointer-events:none}.ql-editor ul[data-checked=true]>li *,.ql-editor ul[data-checked=false]>li *{pointer-events:all}.ql-editor ul[data-checked=true]>li:before,.ql-editor ul[data-checked=false]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"☑"}.ql-editor ul[data-checked=false]>li:before{content:"☐"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;counter-increment:list-0}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media(pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{white-space:pre-wrap;margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0px}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0px;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.pkg-card-compact{--pkg-accent: var(--primary);position:relative;display:grid;background:linear-gradient(180deg,color-mix(in srgb,var(--pkg-accent) 5%,var(--bg-card)) 0%,var(--bg-card) 26%,var(--bg-card) 100%);border:1px solid color-mix(in srgb,var(--pkg-accent) 16%,var(--border));border-radius:22px;overflow:hidden;isolation:isolate;box-shadow:0 18px 40px -30px #0f172a59;transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}.pkg-card-compact:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--pkg-accent),color-mix(in srgb,var(--pkg-accent) 58%,white));z-index:1}.pkg-card-compact:after{content:"";position:absolute;top:-88px;right:-64px;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,color-mix(in srgb,var(--pkg-accent) 18%,transparent) 0%,transparent 72%);pointer-events:none}.pkg-card-compact[data-status=active]{--pkg-accent: #22c55e}.pkg-card-compact[data-status=paused]{--pkg-accent: #a855f7}.pkg-card-compact[data-status=debt]{--pkg-accent: #f59e0b}.pkg-card-compact[data-status=completed]{--pkg-accent: #3b82f6}.pkg-card-compact[data-status=cancelled]{--pkg-accent: #94a3b8;opacity:.88}.pkg-card-compact:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--pkg-accent) 24%,var(--border));box-shadow:0 26px 54px -34px #0f172a6b}.pkg-compact__header{position:relative;z-index:1;padding:20px 20px 16px;border-bottom:1px solid color-mix(in srgb,var(--pkg-accent) 12%,var(--border));background:linear-gradient(180deg,color-mix(in srgb,var(--pkg-accent) 8%,var(--bg-secondary)),color-mix(in srgb,var(--pkg-accent) 3%,var(--bg-card)))}.pkg-compact__header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.pkg-compact__title-area{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.pkg-compact__title-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0;flex-wrap:wrap}.pkg-compact__status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.pkg-compact__status-dot--active{background:#22c55e;box-shadow:0 0 0 6px #22c55e24,0 0 14px #22c55e52}.pkg-compact__status-dot--paused{background:#a855f7;box-shadow:0 0 0 6px #a855f724,0 0 14px #a855f74d}.pkg-compact__status-dot--debt{background:#f59e0b;box-shadow:0 0 0 6px #f59e0b24,0 0 14px #f59e0b4d}.pkg-compact__status-dot--completed{background:#3b82f6;box-shadow:0 0 0 6px #3b82f624,0 0 14px #3b82f64d}.pkg-compact__status-dot--cancelled{background:#94a3b8;box-shadow:0 0 0 6px #94a3b824}.pkg-compact__title{margin:0;flex:0 1 auto;min-width:0;font-size:1.08rem;font-weight:800;line-height:1.3;color:var(--text-primary);letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pkg-compact__badge{padding:6px 10px;border-radius:999px;border:1px solid transparent;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.pkg-compact__badge.status--active{background:#22c55e1f;border-color:#22c55e2e;color:#15803d}.pkg-compact__badge.status--paused{background:#a855f71f;border-color:#a855f72e;color:#7e22ce}.pkg-compact__badge.status--debt{background:#f59e0b24;border-color:#f59e0b33;color:#b45309}.pkg-compact__badge.status--completed{background:#3b82f61f;border-color:#3b82f62e;color:#1d4ed8}.pkg-compact__badge.status--cancelled{background:#94a3b81f;border-color:#94a3b82e;color:#64748b}.pkg-compact__header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.pkg-compact__debt{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#ef44441a;border:1px solid rgba(239,68,68,.14);border-radius:999px;font-size:.78rem;font-weight:800;color:#dc2626;box-shadow:inset 0 1px #ffffff40}.pkg-compact__overpayment{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#22c55e1a;border:1px solid rgba(34,197,94,.14);border-radius:999px;font-size:.78rem;font-weight:800;color:#15803d}.pkg-compact__menu-wrapper{position:relative}.pkg-compact__menu-btn{width:38px;height:38px;border-radius:12px;border:1px solid color-mix(in srgb,var(--pkg-accent) 10%,var(--border));background:color-mix(in srgb,var(--bg-card) 92%,white 8%);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 20px -18px #0f172acc;transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease}.pkg-compact__menu-btn:hover{transform:translateY(-1px);background:var(--bg-card);border-color:color-mix(in srgb,var(--pkg-accent) 18%,var(--border));color:var(--text-primary)}.pkg-compact__menu-btn:focus-visible,.pkg-compact__menu-item:focus-visible{outline:3px solid color-mix(in srgb,var(--pkg-accent) 26%,transparent);outline-offset:2px}.pkg-compact__menu{position:absolute;top:100%;right:0;margin-top:8px;padding:6px;background:color-mix(in srgb,var(--bg-card) 96%,white 4%);border:1px solid color-mix(in srgb,var(--pkg-accent) 12%,var(--border));border-radius:16px;box-shadow:0 28px 48px -28px #0f172a80;z-index:100;min-width:188px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.pkg-compact__menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:10px;background:transparent;color:var(--text-primary);font-size:.84rem;font-weight:600;cursor:pointer;text-align:left;transition:background .15s ease,transform .15s ease}.pkg-compact__menu-item:hover{background:color-mix(in srgb,var(--pkg-accent) 8%,var(--bg-secondary))}.pkg-compact__menu-item--danger{color:#dc2626}.pkg-compact__menu-item--danger:hover{background:#ef444414}.pkg-compact__meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.78rem;color:var(--text-muted)}.pkg-compact__meta>:not(.pkg-compact__sep){display:inline-flex;align-items:center;gap:6px;min-height:32px;padding:6px 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--pkg-accent) 10%,var(--border));background:color-mix(in srgb,var(--pkg-accent) 7%,var(--bg-card));color:var(--text-secondary)}.pkg-compact__meta svg{width:13px;height:13px;color:var(--text-muted)}.pkg-compact__sep{display:none}.pkg-compact__body{display:flex;flex-direction:column;gap:10px;padding:14px}.pkg-compact__block{position:relative;padding:14px;border:1px solid color-mix(in srgb,var(--pkg-accent) 12%,var(--border));border-radius:18px;background:linear-gradient(180deg,color-mix(in srgb,var(--pkg-accent) 5%,var(--bg-card)) 0%,var(--bg-card) 100%);box-shadow:inset 0 1px #ffffff8c}.pkg-compact__block:first-child{border-bottom:1px solid color-mix(in srgb,var(--pkg-accent) 12%,var(--border))}.pkg-compact__block--lessons{border-color:color-mix(in srgb,#6366f1 14%,var(--border));background:linear-gradient(180deg,rgba(99,102,241,.05) 0%,var(--bg-card) 100%)}.pkg-compact__block--payment{border-color:color-mix(in srgb,#f59e0b 16%,var(--border));background:linear-gradient(180deg,rgba(245,158,11,.05) 0%,var(--bg-card) 100%)}.pkg-compact__block-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:.88rem;font-weight:700;line-height:1.3;letter-spacing:-.01em;color:var(--text-primary)}.pkg-compact__block-icon{padding:6px;border-radius:10px;border:1px solid color-mix(in srgb,var(--text-muted) 18%,var(--border));background:color-mix(in srgb,var(--bg-secondary) 88%,white 12%);color:var(--text-secondary);box-sizing:content-box;flex-shrink:0}.pkg-compact__block--lessons .pkg-compact__block-icon{border-color:#6366f12e;background:#6366f11a;color:#4f46e5}.pkg-compact__block--payment .pkg-compact__block-icon{border-color:#f59e0b33;background:#f59e0b1f;color:#d97706}.pkg-compact__progress-section{display:flex;flex-direction:column;gap:8px}.pkg-compact__progress-bar-wrapper{display:flex;align-items:center;gap:10px}.pkg-compact__progress-bar{position:relative;flex:1;height:12px;background:color-mix(in srgb,var(--pkg-accent) 10%,var(--bg-secondary));border-radius:999px;overflow:hidden}.pkg-compact__progress-fill{height:100%;background:linear-gradient(90deg,var(--pkg-accent),color-mix(in srgb,var(--pkg-accent) 62%,white));border-radius:999px;transition:width .4s ease}.pkg-compact__block--lessons .pkg-compact__progress-bar{background:#6366f11f}.pkg-compact__block--lessons .pkg-compact__progress-fill{background:linear-gradient(90deg,#6366f1,#8b5cf6)}.pkg-compact__progress-bar--danger .pkg-compact__progress-fill{background:linear-gradient(90deg,#ef4444,#f87171)}.pkg-compact__progress-bar--payment{background:#22c55e1f}.pkg-compact__progress-bar--payment .pkg-compact__progress-fill--payment{background:linear-gradient(90deg,#22c55e,#4ade80)}.pkg-compact__progress-percent{min-width:46px;padding:6px 8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--pkg-accent) 10%,var(--border));background:color-mix(in srgb,var(--bg-card) 92%,white 8%);font-size:.78rem;font-weight:800;color:var(--text-primary);text-align:center}.pkg-compact__block--lessons .pkg-compact__progress-percent{border-color:#6366f12e}.pkg-compact__block--payment .pkg-compact__progress-percent{border-color:#f59e0b2e}.pkg-compact__lesson-info{display:flex;align-items:center;flex-wrap:wrap;gap:5px;font-size:.9rem;color:var(--text-secondary)}.pkg-compact__lesson-info span:first-child{font-weight:800;color:var(--text-primary)}.pkg-compact__lesson-info span:last-child{font-weight:700}.pkg-compact__lesson-divider{color:var(--border)}.pkg-compact__debt-text{color:#dc2626!important;font-weight:800!important}@media(max-width:560px){.pkg-compact__header{padding:18px 16px 14px}.pkg-compact__header-top{flex-wrap:wrap}.pkg-compact__header-right{order:-1;width:100%;justify-content:space-between}.pkg-compact__title-area,.pkg-compact__title-main{width:100%}.pkg-compact__body{padding:12px;gap:10px}.pkg-compact__block{padding:13px}}@media(max-width:420px){.pkg-compact__title{flex-basis:100%;font-size:1rem}.pkg-compact__debt{padding-inline:10px}.pkg-compact__menu{min-width:172px}.pkg-compact__progress-bar-wrapper{gap:10px}}@media(prefers-reduced-motion:reduce){.pkg-card-compact,.pkg-compact__menu-btn,.pkg-compact__menu-item,.pkg-compact__progress-fill{transition:none}}.student-packages-page{position:relative;display:flex;flex-direction:column;gap:24px}.student-packages-hero{position:relative;overflow:hidden;border-radius:32px}.student-packages-hero__orb{position:absolute;border-radius:999px;filter:blur(18px);opacity:.55;pointer-events:none;animation:student-orb-float 9s ease-in-out infinite}.student-packages-hero__orb--pink{width:240px;height:240px;top:-48px;right:-36px;background:radial-gradient(circle at center,#f472b661,#f472b600 72%)}.student-packages-hero__orb--blue{width:280px;height:280px;bottom:-112px;left:-48px;background:radial-gradient(circle at center,#60a5fa52,#60a5fa00 72%);animation-delay:-3s}.student-packages-page .student-header{--student-glass: rgba(255, 255, 255, .7);--student-stroke: rgba(255, 255, 255, .82);position:relative;display:flex;flex-direction:column;gap:20px;padding:22px 24px;background:radial-gradient(circle at top right,rgba(168,85,247,.2),transparent 28%),radial-gradient(circle at left center,rgba(56,189,248,.16),transparent 24%),linear-gradient(135deg,#ffffffe0,#f8fafcd1 52%,#eef2ffe6);border:1px solid var(--student-stroke);border-radius:32px;box-shadow:0 20px 80px #0f172a14,inset 0 1px #fffc;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.student-packages-page .student-header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(120deg,rgba(255,255,255,.18),transparent 28%,transparent 72%,rgba(255,255,255,.14));pointer-events:none}.student-header__main{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px}.student-header__lead{flex:1;min-width:0;display:flex;align-items:center;gap:14px}.student-header__identity{flex:1;display:flex;align-items:center;gap:14px;min-width:0}.student-header__info{flex:1;min-width:0}.student-header__back-btn{width:46px;height:46px;border-radius:14px;background:#ffffffd9;border:1px solid rgba(255,255,255,.9);box-shadow:0 8px 20px #0000000d,inset 0 1px #fff;color:#475569;transition:all .2s cubic-bezier(.4,0,.2,1)}.student-header__back-btn:hover{transform:translate(-3px);background:#fff;color:#6366f1;box-shadow:0 12px 28px #6366f126}.student-header__avatar{width:clamp(64px,5.5vw,82px);height:clamp(64px,5.5vw,82px);border-radius:22px;display:grid;place-items:center;flex-shrink:0;font-size:clamp(1.2rem,1.8vw,1.75rem);font-weight:800;letter-spacing:.08em;color:#fff;background:linear-gradient(145deg,#6366f1,#ec4899);box-shadow:0 12px 32px #6366f133,inset 0 1px #ffffff4d;overflow:hidden}.student-header__avatar-img{width:100%;height:100%;object-fit:cover}.student-header__name-row{display:flex;align-items:center;gap:10px}.student-packages-page .student-header__title{font-size:1.5rem;font-weight:700;color:#0f172a;line-height:1.2;margin:0}.student-header__status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:#22c55e1a;color:#15803d;border:1px solid rgba(34,197,94,.2)}.student-header__status--inactive{background:#64748b1a;color:#64748b;border:1px solid rgba(100,116,139,.2)}.student-header__add-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:.85rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6366f140}.student-header__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.student-header__history-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;font-size:.85rem;font-weight:700}.student-header__add-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f159}.student-header__aside{display:flex;flex-direction:column;gap:14px;align-items:stretch;width:min(100%,320px);min-width:0}.student-header__balance-card{display:flex;flex-direction:column;gap:8px;padding:18px 20px;border-radius:28px;color:#fff;background:linear-gradient(135deg,#0f172a,#1e1b4b,#312e81);box-shadow:0 20px 40px #0f172a2e,inset 0 1px #ffffff1a;position:relative;overflow:hidden}.student-header__balance-card:after{content:"";position:absolute;top:-50%;right:-20%;width:150px;height:150px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);pointer-events:none}.student-header__balance-card--positive{background:linear-gradient(135deg,#064e3b,#065f46 45%,#059669);box-shadow:0 20px 40px #0596692e,inset 0 1px #ffffff1f}.student-header__balance-card-label,.student-header__balance-card-note{color:#ffffffc7}.student-header__balance-card-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700}.student-header__balance-card-value{font-size:clamp(1.5rem,2vw,2.45rem);line-height:1.05}.student-header__balance-card-note{font-size:.9rem;line-height:1.5}.student-header__balance-card__btn{margin-top:14px;width:100%;justify-content:center;min-height:44px;border-radius:14px;font-weight:700;font-size:.9rem;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease}.student-header__balance-card__btn:hover{background:#ffffff2e;transform:translateY(-2px)}.btn--light{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.18)}.btn--light:hover{background:#ffffff2e}.student-header__cta{justify-content:center;min-height:52px;border-radius:18px;font-weight:700;box-shadow:0 16px 30px #6366f12e}.student-header__stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.student-header__stat{display:flex;align-items:center;gap:16px;padding:16px 18px;border-radius:28px;background:#fff9;border:1px solid rgba(255,255,255,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 10px 30px #0f172a08,inset 0 1px #fffc;transition:transform .25s ease,box-shadow .25s ease}.student-header__stat:hover{transform:translateY(-4px);background:#fffc;box-shadow:0 20px 40px #0f172a0f}.student-header__stat-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:16px;color:#fff;box-shadow:0 14px 28px #6366f12e}.student-header__stat--violet .student-header__stat-icon{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.student-header__stat--blue .student-header__stat-icon{background:linear-gradient(135deg,#2563eb,#06b6d4)}.student-header__stat--amber .student-header__stat-icon{background:linear-gradient(135deg,#f59e0b,#fb7185)}.student-header__stat--emerald .student-header__stat-icon{background:linear-gradient(135deg,#059669,#22c55e)}.student-header__stat--balance .student-header__stat-icon{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.student-header__stat--positive .student-header__stat-icon{background:linear-gradient(135deg,#059669,#10b981)}.student-header__stat-content{min-width:0;display:flex;flex-direction:column;gap:2px}.student-header__stat-label,.student-header__stat-note{color:#64748b}.student-header__stat-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.student-header__stat-value{font-size:clamp(1.15rem,1.6vw,1.8rem);color:#0f172a;line-height:1.1}.student-header__stat-note{font-size:.85rem}.student-packages-section{display:flex;flex-direction:column;gap:18px}.student-packages-section__header{display:flex;justify-content:space-between;gap:18px;align-items:end}.student-packages-section__eyebrow{display:inline-block;margin-bottom:10px;font-size:.78rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#7c3aed}.student-packages-section__title{margin:0;font-size:1rem;font-weight:600;letter-spacing:-.01em;color:#0f172a}.student-packages-section__subtitle{margin:8px 0 0;color:#64748b;max-width:72ch;line-height:1.7}.student-packages-section__badge{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;padding:10px 14px;border-radius:999px;color:#4338ca;background:#e0e7ffe0;border:1px solid rgba(165,180,252,.52)}.student-packages-stack{display:grid;grid-template-columns:repeat(auto-fill,minmax(480px,1fr));gap:18px}.student-packages-empty{position:relative;overflow:hidden;padding:42px 28px;border-radius:28px;text-align:center;background:radial-gradient(circle at top center,rgba(129,140,248,.18),transparent 36%),linear-gradient(145deg,#ffffffeb,#f8fafcf5);border:1px solid rgba(226,232,240,.9);box-shadow:0 18px 50px #0f172a0f}.student-packages-empty__icon{width:72px;height:72px;margin:0 auto 18px;border-radius:22px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#8b5cf6,#06b6d4);box-shadow:0 18px 36px #6366f133}.student-packages-empty__title{margin:0;font-size:1.4rem;color:#0f172a}.student-packages-empty__description{max-width:60ch;margin:12px auto 0;color:#64748b;line-height:1.7}.student-packages-empty__cta{margin-top:22px;min-height:48px;border-radius:16px}.student-package-drawer .drawer-content{background:radial-gradient(circle at top right,rgba(129,140,248,.14),transparent 22%),linear-gradient(180deg,#fffffffa,#f8fafcfa)}.student-package-drawer .drawer-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid rgba(226,232,240,.84);background:#ffffffb8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);gap:12px;min-height:48px}.student-package-drawer .drawer-title-group{flex:1;min-width:0;max-width:calc(100% - 50px);overflow:hidden}.student-package-drawer .drawer-title{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.student-package-drawer .drawer-title-separator{color:var(--drawer-border);font-weight:400}.student-package-drawer .drawer-subtitle-inline{color:var(--drawer-subtitle);font-size:.78rem;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-package-drawer .drawer-header-right{margin-left:auto;flex-shrink:0}.student-package-drawer .drawer-close-btn{width:34px;height:34px;border-radius:10px;flex-shrink:0}.student-package-drawer .drawer-body{padding:22px 24px 28px}.student-package-drawer .drawer-footer{padding:18px 24px 24px;border-top:1px solid rgba(226,232,240,.84);background:#ffffffc7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.student-drawer{display:flex;flex-direction:column;gap:18px}.student-drawer .alert--error{background:linear-gradient(135deg,#ef44441f,#dc26261a);border:2px solid rgba(239,68,68,.4);color:#b91c1c;padding:14px 18px;border-radius:14px;font-size:.9rem;font-weight:700;box-shadow:0 4px 12px #ef444426;display:flex;align-items:center;gap:10px}.student-drawer .alert--error:before{content:"⚠️";font-size:1.2rem}.student-drawer__hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;padding:20px;border-radius:24px;color:#fff;box-shadow:0 18px 42px #0f172a24}.student-drawer__hero--success{background:linear-gradient(135deg,#0f766e,#059669 55%,#22c55e)}.student-drawer__hero--info{background:linear-gradient(135deg,#1d4ed8,#06b6d4)}.student-drawer__hero--violet{background:linear-gradient(135deg,#6d28d9,#8b5cf6 48%,#ec4899)}.student-drawer__hero--danger{background:linear-gradient(135deg,#b91c1c,#ea580c 54%,#f59e0b)}.student-drawer__eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;margin-bottom:10px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:#ffffff24;color:#fffffff0}.student-drawer__hero-title{margin:0;font-size:1.4rem;letter-spacing:-.03em}.student-drawer__hero-text{margin:10px 0 0;color:#ffffffd6;line-height:1.65}.student-drawer__hero-stat{min-width:210px;align-self:start;display:flex;flex-direction:column;gap:6px;padding:16px 18px;border-radius:18px;background:#ffffff1f;border:1px solid rgba(255,255,255,.18)}.student-drawer__hero-stat-label,.student-drawer__hero-stat-note{color:#ffffffc7}.student-drawer__hero-stat-label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em}.student-drawer__hero-stat-value{font-size:1.6rem;line-height:1.05}.student-drawer__hero-stat-note{font-size:.84rem;line-height:1.5}.student-drawer__metric-grid,.student-drawer__form-grid,.student-drawer__facts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.student-drawer__metric-card,.student-drawer__fact{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:20px;background:#fffc;border:1px solid rgba(226,232,240,.84);box-shadow:inset 0 1px #ffffffbf}.student-drawer__top-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}.student-drawer__top-cards--compact{gap:10px;margin-bottom:18px}.student-drawer__top-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:18px;background:#ffffffe6;border:1px solid rgba(226,232,240,.6);box-shadow:0 4px 16px #0000000a;transition:transform .2s ease,box-shadow .2s ease}.student-drawer__top-card--compact{gap:10px;padding:12px 14px;border-radius:16px}.student-drawer__top-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000f}.student-drawer__top-card--balance{background:linear-gradient(135deg,#3b82f60f,#9333ea0a);border-color:#3b82f640}.student-drawer__top-card--payment{background:linear-gradient(135deg,#22c55e0f,#10b9810a);border-color:#22c55e40}.student-drawer__top-card--violet{background:linear-gradient(135deg,#8b5cf614,#6366f10d);border-color:#8b5cf63d}.student-drawer__top-card--amber{background:linear-gradient(135deg,#f59e0b14,#f973160d);border-color:#f59e0b3d}.student-drawer__top-card-icon{flex-shrink:0;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff}.student-drawer__top-card--balance .student-drawer__top-card-icon{background:linear-gradient(135deg,#3b82f6,#8b5cf6);box-shadow:0 8px 20px #3b82f640}.student-drawer__top-card--payment .student-drawer__top-card-icon{background:linear-gradient(135deg,#22c55e,#10b981);box-shadow:0 8px 20px #22c55e40}.student-drawer__top-card--violet .student-drawer__top-card-icon{background:linear-gradient(135deg,#8b5cf6,#6366f1);box-shadow:0 8px 20px #8b5cf63d}.student-drawer__top-card--amber .student-drawer__top-card-icon{background:linear-gradient(135deg,#f59e0b,#f97316);box-shadow:0 8px 20px #f59e0b3d}.student-drawer__top-card--compact .student-drawer__top-card-icon{width:34px;height:34px;border-radius:10px}.student-drawer__top-card-content{flex:1;min-width:0}.student-drawer__top-card-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;line-height:1.3}.student-drawer__top-card--compact .student-drawer__top-card-label{font-size:.67rem;letter-spacing:.06em}.student-drawer__top-card-value{display:block;font-size:1.25rem;font-weight:800;color:#0f172a;line-height:1.2}.student-drawer__top-card--compact .student-drawer__top-card-value{font-size:1rem;line-height:1.15}.student-drawer__number-input--no-spin{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.student-drawer__number-input--no-spin::-webkit-outer-spin-button,.student-drawer__number-input--no-spin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.student-drawer__debt-hint{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;border-radius:10px;font-size:.82rem;font-weight:600}.student-drawer__debt-hint--warning{background:linear-gradient(135deg,#f59e0b14,#ef44440f);color:#b45309;border:1px solid rgba(245,158,11,.2)}.student-drawer__debt-hint--success{background:linear-gradient(135deg,#22c55e14,#10b9810f);color:#047857;border:1px solid rgba(34,197,94,.2)}.student-drawer__debt-hint strong{font-weight:800}.student-drawer__overpayment-hint{display:flex;align-items:center;gap:8px;margin-top:10px;padding:10px 14px;border-radius:12px;font-size:.85rem;font-weight:600}.student-drawer__overpayment-hint--info{background:linear-gradient(135deg,#3b82f614,#9333ea0f);color:#1d4ed8;border:1px solid rgba(59,130,246,.25)}.student-drawer__overpayment-hint strong{font-weight:800}.student-drawer__section--summary{background:linear-gradient(145deg,#eff6fff2,#ecfeffeb);border-color:#bae6fdb3}.student-drawer__summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;margin-bottom:8px;border-radius:12px;background:#ffffffb3;font-size:.9rem}.student-drawer__summary-row:last-child{margin-bottom:0}.student-drawer__summary-row--positive{color:#047857}.student-drawer__metric-card-label,.student-drawer__metric-card-meta,.student-drawer__fact-label,.student-drawer__hint{color:#64748b}.student-drawer__metric-card-label,.student-drawer__fact-label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em}.student-drawer__metric-card-value,.student-drawer__fact-value{font-size:1.15rem;color:#0f172a;line-height:1.35}.student-drawer__metric-card-meta,.student-drawer__hint{font-size:.86rem;line-height:1.5}.student-drawer__mini-hint{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;border-radius:10px;font-size:.85rem;font-weight:700}.student-drawer__mini-hint--warning{background:linear-gradient(135deg,#ef44441a,#f59e0b14);color:#dc2626;border:1px solid rgba(239,68,68,.3)}.student-drawer__mini-hint--info{background:linear-gradient(135deg,#22c55e1a,#10b98114);color:#059669;border:1px solid rgba(34,197,94,.3)}.student-drawer__mini-hint--success{background:linear-gradient(135deg,#22c55e1a,#10b98114);color:#047857;border:1px solid rgba(34,197,94,.3)}.student-drawer__mini-hint strong{font-weight:900;font-size:.9rem}.student-drawer__section{padding:18px;border-radius:24px;background:#ffffffbd;border:1px solid rgba(226,232,240,.8)}.student-drawer__section--muted{background:linear-gradient(145deg,#f8fafcfa,#f1f5f9eb)}.student-drawer__section--accent{background:linear-gradient(145deg,#eff6fffa,#ecfefff5);border-color:#bae6fdcc}.student-drawer__section-title{margin-bottom:14px;font-size:.92rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#334155}.student-drawer__summary-grid{display:grid;gap:10px}.student-drawer__summary-row{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:#ffffffbf;color:#334155}.student-drawer__summary-callout{display:grid;gap:10px;margin:14px 0}.student-drawer__summary-text{display:inline-flex;align-items:center;gap:10px;font-weight:600}.student-drawer__summary-text--positive{color:#047857}.student-drawer__summary-text--info{color:#0f766e}.student-drawer__summary-text--muted{color:#64748b}.student-drawer__footer-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.student-choice-stack{display:grid;gap:12px}.student-choice-card{display:block;position:relative;cursor:pointer}.student-choice-card input{position:absolute;opacity:0;pointer-events:none}.student-choice-card__content{display:flex;flex-direction:column;gap:8px;padding:16px 18px;border-radius:20px;border:1px solid rgba(226,232,240,.84);background:#ffffffd1;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.student-choice-card:hover .student-choice-card__content,.student-choice-card.is-active .student-choice-card__content{transform:translateY(-2px);box-shadow:0 16px 34px #0f172a14}.student-header__stat--interactive{width:100%;text-align:left;cursor:pointer}.student-header__stat--interactive:disabled{cursor:default}.student-header__stat--interactive:focus-visible{outline:2px solid rgba(99,102,241,.45);outline-offset:2px}.student-choice-card--balance.is-active .student-choice-card__content{border-color:#22c55eb3;background:linear-gradient(145deg,#f0fdf4fa,#dcfce7f5)}.student-choice-card--refund.is-active .student-choice-card__content{border-color:#3b82f6b3;background:linear-gradient(145deg,#eff6fffa,#e0f2fef5)}.student-choice-card--loss.is-active .student-choice-card__content{border-color:#ef4444b3;background:linear-gradient(145deg,#fef2f2fa,#fee2e2f5)}.student-choice-card--none.is-active .student-choice-card__content{border-color:#f59e0bb3;background:linear-gradient(145deg,#fffbebfa,#fef3c7f5)}.student-choice-card__header{display:flex;justify-content:space-between;gap:12px;align-items:center}.student-choice-card__title{font-weight:800;color:#0f172a}.student-choice-card__value{font-size:1rem;color:#1e293b}.student-choice-card__description{color:#64748b;line-height:1.55}.student-choice-card__field{margin-top:4px}.student-history-empty{text-align:center;padding:28px 18px 14px}.student-history-empty__icon{width:64px;height:64px;margin:0 auto 14px;border-radius:18px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed)}.student-history-empty__title{margin:0;color:#0f172a}.student-history-empty__description{margin:10px auto 0;max-width:38ch;color:#64748b;line-height:1.7}.student-history-list{display:grid;gap:12px}.student-history-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:center;padding:16px 18px;border-radius:22px;border:1px solid rgba(226,232,240,.84);background:#fffc}.student-history-item--in{box-shadow:inset 0 0 0 1px #22c55e1a}.student-history-item--out{box-shadow:inset 0 0 0 1px #ef44441a}.student-history-item__icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;color:#fff}.student-history-item--in .student-history-item__icon{background:linear-gradient(135deg,#16a34a,#0f766e)}.student-history-item--out .student-history-item__icon{background:linear-gradient(135deg,#ef4444,#f97316)}.student-history-item__top{display:flex;justify-content:space-between;gap:12px;align-items:center}.student-history-item__type{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#0f172a}.student-history-item__note{margin-top:4px;color:#334155;line-height:1.55}.student-history-item__meta{margin-top:6px;color:#94a3b8;font-size:.84rem}.student-history-item__amount{font-weight:800}.student-history-item__amount--in{color:#15803d}.student-history-item__amount--out{color:#dc2626}.student-history-item__lessons{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;white-space:nowrap;color:#475569;background:#f8fafceb}@keyframes student-orb-float{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(12px,-10px,0) scale(1.03)}}@media(max-width:1100px){.student-header__main,.student-drawer__hero{grid-template-columns:1fr}.student-header__stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.student-packages-page{gap:18px}.student-packages-page .student-header{padding:18px;border-radius:24px}.student-header__lead,.student-header__identity{flex-direction:column}.student-header__actions{width:100%;justify-content:flex-start}.student-header__aside,.student-drawer__hero-stat{min-width:100%}.student-header__stats,.student-drawer__metric-grid,.student-drawer__form-grid,.student-drawer__facts-grid,.student-history-item{grid-template-columns:1fr}.student-history-item{justify-items:start}.student-packages-section__header,.student-choice-card__header,.student-history-item__top,.student-drawer__footer-actions{flex-direction:column;align-items:stretch}.student-package-drawer .drawer-header,.student-package-drawer .drawer-body,.student-package-drawer .drawer-footer{padding-left:16px;padding-right:16px}}@media(min-width:2560px){.student-packages-page{max-width:2200px;gap:30px}.student-packages-page .student-header{padding:34px;border-radius:36px}.student-header__stats{gap:18px}.student-header__stat,.student-packages-empty,.student-package-drawer .drawer-body{font-size:1.02rem}}[data-theme=dark] .student-packages-page .student-header{--student-glass: rgba(15, 23, 42, .72);--student-stroke: rgba(255, 255, 255, .08);background:radial-gradient(circle at top right,rgba(168,85,247,.18),transparent 28%),radial-gradient(circle at left center,rgba(14,165,233,.16),transparent 24%),linear-gradient(135deg,#0f172aeb,#111827f5 52%,#1e293bf0)}[data-theme=dark] .student-header__description,[data-theme=dark] .student-packages-section__subtitle,[data-theme=dark] .student-drawer__metric-card-label,[data-theme=dark] .student-drawer__metric-card-meta,[data-theme=dark] .student-drawer__fact-label,[data-theme=dark] .student-drawer__hint,[data-theme=dark] .student-choice-card__description,[data-theme=dark] .student-history-item__meta,[data-theme=dark] .student-packages-empty__description{color:#94a3b8}[data-theme=dark] .student-header__stat,[data-theme=dark] .student-packages-empty,[data-theme=dark] .student-drawer__metric-card,[data-theme=dark] .student-drawer__fact,[data-theme=dark] .student-drawer__section,[data-theme=dark] .student-choice-card__content,[data-theme=dark] .student-history-item,[data-theme=dark] .student-history-item__lessons,[data-theme=dark] .student-package-drawer .drawer-content,[data-theme=dark] .student-package-drawer .drawer-header,[data-theme=dark] .student-package-drawer .drawer-footer{background-color:#0f172ad6;border-color:#ffffff14}[data-theme=dark] .student-packages-section__title,[data-theme=dark] .student-packages-empty__title,[data-theme=dark] .student-drawer__metric-card-value,[data-theme=dark] .student-drawer__fact-value,[data-theme=dark] .student-choice-card__title,[data-theme=dark] .student-choice-card__value,[data-theme=dark] .student-history-item__type,[data-theme=dark] .student-history-item__note,[data-theme=dark] .student-header__stat-value{color:#f8fafc}.table-dropdown-trigger{display:inline-flex;align-items:center;justify-content:space-between;gap:10px;min-width:148px;max-width:100%;border:1px solid color-mix(in srgb,var(--primary) 12%,var(--border));border-radius:12px;padding:6px 10px;background:linear-gradient(180deg,#fffffff5,#f8fafcfa);color:var(--text-primary);cursor:pointer;transition:border-color .18s ease,background-color .18s ease}.table-dropdown-trigger:hover{border-color:color-mix(in srgb,var(--primary) 30%,var(--border));background:var(--bg-card)}.table-dropdown-trigger.is-disabled{opacity:.7;cursor:wait}.table-dropdown-trigger-main{display:inline-flex;align-items:center;gap:8px;min-width:0}.table-dropdown-trigger-label{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-dropdown-chevron{color:var(--text-muted);flex-shrink:0}.table-dropdown-menu{display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:14px;border:1px solid color-mix(in srgb,var(--primary) 16%,var(--border));background:color-mix(in srgb,var(--bg-card) 92%,white 8%);box-shadow:0 24px 48px #0f172a2e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overflow:hidden}.table-dropdown-search-wrap{position:relative;flex-shrink:0}.table-dropdown-search-icon{position:absolute;top:50%;left:10px;transform:translateY(-50%);color:var(--text-muted)}.table-dropdown-search-input{width:100%;height:34px;padding:0 10px 0 32px;border:1px solid var(--border);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:12px;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.table-dropdown-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.table-dropdown-options{overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding-right:2px}.table-dropdown-option{display:inline-flex;width:100%;align-items:center;justify-content:space-between;gap:10px;border:none;border-radius:10px;background:transparent;padding:8px;text-align:left;cursor:pointer;transition:background .18s ease,transform .18s ease}.table-dropdown-option:hover,.table-dropdown-option.is-active{background:color-mix(in srgb,var(--primary-bg) 46%,var(--bg-secondary))}.table-dropdown-option:hover{transform:translate(2px)}.table-dropdown-option-main{display:inline-flex;align-items:center;gap:10px;min-width:0}.table-dropdown-icon-box{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.table-dropdown-option-text{display:flex;flex-direction:column;min-width:0}.table-dropdown-option-label{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-dropdown-option-description{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-dropdown-check{color:var(--primary);flex-shrink:0}.table-dropdown-empty{font-size:12px;color:var(--text-muted);padding:8px}[data-theme=dark] .table-dropdown-trigger{background:linear-gradient(180deg,#18181bfa,#121215fa)}[data-theme=dark] .table-dropdown-menu{background:color-mix(in srgb,var(--bg-card) 92%,black 8%)}.cropper-container{position:relative;width:100%;height:400px;background:#333;border-radius:var(--radius);overflow:hidden}.cropper-controls{padding:16px 0;display:flex;flex-direction:column;gap:12px}.cropper-zoom{display:flex;align-items:center;gap:12px}.cropper-slider{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-light);border-radius:3px;outline:none}.cropper-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000001a;border:2px solid #fff}.cropper-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}:root{--primary: #6C63FF;--primary-light: #8B84FF;--primary-dark: #5A52E0;--primary-bg: rgba(108, 99, 255, .08);--bg: #f4f6fb;--bg-card: #ffffff;--bg-sidebar: #ffffff;--bg-header: rgba(255, 255, 255, .98);--text-primary: #111111;--text-secondary: #222222;--text-muted: #888888;--border: #e6e8ee;--border-light: #f0f1f4;--hover-bg: #f9fafc;--success: #10B981;--success-bg: rgba(16, 185, 129, .08);--warning: #F59E0B;--warning-bg: rgba(245, 158, 11, .08);--danger: #EF4444;--danger-bg: rgba(239, 68, 68, .08);--info: #3B82F6;--info-bg: rgba(59, 130, 246, .08);--stat-blue: #EFF6FF;--stat-blue-accent: #3B82F6;--stat-green: #ECFDF5;--stat-green-accent: #10B981;--stat-orange: #FFF7ED;--stat-orange-accent: #F59E0B;--stat-indigo: #EEF2FF;--stat-indigo-accent: #6366f1;--stat-purple: #F5F3FF;--stat-purple-accent: #A855F7;--stat-pink: #FDF2F8;--stat-pink-accent: #EC4899;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--s-16: 64px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .03);--shadow: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 2px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .08);--shadow-xl: 0 8px 28px rgba(0, 0, 0, .1);--shadow-glass: 0 4px 24px rgba(108, 99, 255, .06);--table-header-bg: #fafbfd;--radius-sm: 10px;--radius: 14px;--radius-lg: 18px;--radius-xl: 24px;--transition: .25s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 280px;--sidebar-collapsed-width: 90px;--header-height: 72px;--font-body: "Inter", -apple-system, sans-serif;--font-heading: "Plus Jakarta Sans", sans-serif;--text-xs: .8125rem;--text-sm: .9375rem;--text-base: 1.0625rem;--text-lg: 1.1875rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--z-base: 1;--z-header: 50;--z-sidebar: 100;--z-dropdown: 200;--z-modal: 500;--z-toast: 1000;--premium-zinc-50: #f8fafc;--premium-zinc-100: #f1f5f9;--premium-zinc-200: #e2e8f0;--premium-zinc-300: #cbd5e1;--premium-zinc-400: #94a3b8;--premium-zinc-500: #64748b;--premium-zinc-600: #475569;--premium-zinc-700: #334155;--premium-zinc-800: #1e293b;--premium-zinc-900: #0f172a;--premium-purple-500: #8b5cf6;--premium-purple-600: #7c3aed;--premium-indigo-500: #6366f1;--premium-indigo-600: #4f46e5;--shadow-premium: 0 0 0 1px rgba(0, 0, 0, .05), 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-glow: 0 0 20px rgba(139, 92, 246, .15);--border-premium: 1px solid rgba(0, 0, 0, .08);--bg-tertiary: #f0f4f8;--glass-border: rgba(255, 255, 255, .1);--text-soft: #666666;--border-color: #e2e8f0;--star-color: #FFD700;--star-bg: rgba(255, 215, 0, .05);--entity-student: var(--pastel-pink);--entity-student-accent: var(--pastel-pink-accent);--entity-teacher: var(--pastel-indigo);--entity-teacher-accent: var(--pastel-indigo-accent);--entity-class: var(--pastel-green);--entity-class-accent: var(--pastel-green-accent);--entity-transaction: var(--pastel-orange);--entity-transaction-accent: var(--pastel-orange-accent);--entity-finance: var(--pastel-orange);--entity-finance-accent: var(--pastel-orange-accent);--entity-attendance: var(--pastel-teal);--entity-attendance-accent: var(--pastel-teal-accent);--entity-exam: var(--pastel-purple);--entity-exam-accent: var(--pastel-purple-accent);--entity-warning: var(--pastel-yellow);--entity-warning-accent: var(--pastel-yellow-accent);--entity-refund: var(--pastel-rose);--entity-refund-accent: var(--pastel-rose-accent);--entity-danger: var(--pastel-rose);--entity-danger-accent: var(--pastel-rose-accent);--entity-dashboard: var(--pastel-blue);--entity-dashboard-accent: var(--pastel-blue-accent);--entity-settings: var(--pastel-gray);--entity-settings-accent: var(--pastel-gray-accent)}[data-theme=dark]{--bg: #09090b;--bg-card: #121215;--bg-sidebar: #09090b;--bg-header: rgba(9, 9, 11, .8);--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-muted: #52525b;--border: #27272a;--border-light: #18181b;--table-header-bg: #18181b;--hover-bg: #18181b;--shadow-premium: 0 0 0 1px rgba(255, 255, 255, .05), 0 4px 6px -1px rgba(0, 0, 0, .2), 0 2px 4px -1px rgba(255, 255, 255, .08);--bg-tertiary: #18181b;--glass-border: rgba(255, 255, 255, .05);--text-soft: #a1a1aa;--border-color: #27272a;--entity-student: var(--pastel-pink);--entity-student-accent: var(--pastel-pink-accent);--entity-teacher: var(--pastel-indigo);--entity-teacher-accent: var(--pastel-indigo-accent);--entity-class: var(--pastel-green);--entity-class-accent: var(--pastel-green-accent);--entity-transaction: var(--pastel-orange);--entity-transaction-accent: var(--pastel-orange-accent);--entity-finance: var(--pastel-orange);--entity-finance-accent: var(--pastel-orange-accent);--entity-attendance: var(--pastel-teal);--entity-attendance-accent: var(--pastel-teal-accent);--entity-exam: var(--pastel-purple);--entity-exam-accent: var(--pastel-purple-accent);--entity-warning: var(--pastel-yellow);--entity-warning-accent: var(--pastel-yellow-accent);--entity-refund: var(--pastel-rose);--entity-refund-accent: var(--pastel-rose-accent);--entity-danger: var(--pastel-rose);--entity-danger-accent: var(--pastel-rose-accent);--entity-dashboard: var(--pastel-blue);--entity-dashboard-accent: var(--pastel-blue-accent);--entity-settings: var(--pastel-gray);--entity-settings-accent: var(--pastel-gray-accent)}:root{--pastel-pink: #FDF2F8;--pastel-pink-accent: #EC4899;--pastel-blue: #EFF6FF;--pastel-blue-accent: #3B82F6;--pastel-green: #ECFDF5;--pastel-green-accent: #10B981;--pastel-yellow: #FEFCE8;--pastel-yellow-accent: #EAB308;--pastel-orange: #FFF7ED;--pastel-orange-accent: #F97316;--pastel-purple: #F5F3FF;--pastel-purple-accent: #A855F7;--pastel-teal: #F0FDFB;--pastel-teal-accent: #14B8A6;--pastel-indigo: #EEF2FF;--pastel-indigo-accent: #6366F1;--pastel-rose: #FFF1F2;--pastel-rose-accent: #F43F5E;--pastel-lime: #F7FEE7;--pastel-lime-accent: #84CC16;--pastel-gray: #F3F4F6;--pastel-gray-accent: #6B7280}[data-theme=dark]{--pastel-pink: color-mix(in srgb, var(--pastel-pink-accent) 15%, var(--bg-card));--pastel-blue: color-mix(in srgb, var(--pastel-blue-accent) 15%, var(--bg-card));--pastel-green: color-mix(in srgb, var(--pastel-green-accent) 15%, var(--bg-card));--pastel-yellow: color-mix(in srgb, var(--pastel-yellow-accent) 15%, var(--bg-card));--pastel-orange: color-mix(in srgb, var(--pastel-orange-accent) 15%, var(--bg-card));--pastel-purple: color-mix(in srgb, var(--pastel-purple-accent) 15%, var(--bg-card));--pastel-teal: color-mix(in srgb, var(--pastel-teal-accent) 15%, var(--bg-card));--pastel-indigo: color-mix(in srgb, var(--pastel-indigo-accent) 15%, var(--bg-card));--pastel-rose: color-mix(in srgb, var(--pastel-rose-accent) 15%, var(--bg-card));--pastel-lime: color-mix(in srgb, var(--pastel-lime-accent) 15%, var(--bg-card));--pastel-gray: color-mix(in srgb, var(--pastel-gray-accent) 15%, var(--bg-card))}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.25;letter-spacing:-.02em}h1{font-size:var(--text-3xl);margin-bottom:var(--s-6)}h2{font-size:var(--text-2xl);margin-bottom:var(--s-4)}h3{font-size:var(--text-xl);margin-bottom:var(--s-3)}img{max-width:100%;display:block}button{font-family:inherit}.glass-effect{background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .glass-effect{background:#121215b3;border:1px solid rgba(255,255,255,.05)}.glass-card{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .glass-card{background:#101622b3;border:1px solid rgba(255,255,255,.05)}.noise-bg{position:relative}.noise-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}.card-hover-lift{transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease}.card-hover-lift:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl),var(--shadow-glow)}.button-press-scale{transition:transform .1s ease}.button-press-scale:active{transform:scale(.95)}.p-1{padding:var(--s-1)}.p-2{padding:var(--s-2)}.p-3{padding:var(--s-3)}.p-4{padding:var(--s-4)}.p-5{padding:var(--s-5)}.m-1{margin:var(--s-1)}.m-2{margin:var(--s-2)}.m-3{margin:var(--s-3)}.m-4{margin:var(--s-4)}.m-5{margin:var(--s-5)}.gap-1{gap:var(--s-1)}.gap-2{gap:var(--s-2)}.gap-3{gap:var(--s-3)}.gap-4{gap:var(--s-4)}.h-full{height:100%}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-primary{color:var(--text-primary)}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:var(--z-sidebar);transition:width var(--transition),transform var(--transition);overflow:hidden;background:var(--bg-sidebar),linear-gradient(180deg,var(--bg-card) 0%,var(--bg) 100%)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-sidebar) - 1);animation:fadeIn .2s ease}.sidebar-overlay.open{display:block}.sidebar-fixed-top{padding:var(--s-6) var(--s-6) var(--s-4);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar.collapsed .sidebar-fixed-top{padding:var(--s-6) 0 var(--s-4);flex-direction:column;gap:var(--s-2);justify-content:center;min-height:100px}.sidebar-brand{display:flex;align-items:center;gap:var(--s-3);transition:all var(--transition);text-decoration:none;color:inherit}.sidebar-brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;border-radius:12px;font-weight:800;font-size:20px;box-shadow:0 4px 12px var(--primary-bg)}.sidebar-brand-logo{width:46px;height:46px;object-fit:cover;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-light, var(--border));padding:0;box-shadow:0 4px 12px #00000014;flex-shrink:0}.sidebar-brand-text{font-family:var(--font-heading);font-size:20px;font-weight:800;letter-spacing:-.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:1;transition:opacity .2s ease}.sidebar.collapsed .sidebar-brand-text{opacity:0;width:0;pointer-events:none}.sidebar-scrollable-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 var(--s-4) var(--s-6);display:flex;flex-direction:column}.sidebar.collapsed .sidebar-scrollable-content{padding:0 var(--s-2) var(--s-6);align-items:center}.sidebar-nav{display:flex;flex-direction:column;gap:var(--s-6)}.sidebar-section{display:flex;flex-direction:column;gap:var(--s-1)}.sidebar-section-title{padding:0 var(--s-4) var(--s-2);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);transition:opacity .2s ease}.sidebar.collapsed .sidebar-section-title{opacity:0;height:0;margin:0;padding:0}.sidebar-link{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-2) var(--s-3);border-radius:14px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;border:1px solid transparent}.sidebar-icon-wrapper{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:color-mix(in srgb,var(--icon-color, var(--text-muted)),transparent 92%);color:var(--icon-color, var(--text-muted));transition:all .2s ease;flex-shrink:0}.sidebar-link:hover{background:var(--bg-card);border-color:var(--border-light);color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.sidebar-link:hover .sidebar-icon-wrapper{background:color-mix(in srgb,var(--icon-color),transparent 85%);transform:scale(1.05)}.sidebar-link.active{background:var(--pastel-section-bg, var(--primary-bg));border-left:4px solid var(--pastel-section-accent, var(--primary));color:var(--pastel-section-accent, var(--primary))}.sidebar-link.active .sidebar-icon-wrapper{background:var(--pastel-section-accent, var(--primary));color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--pastel-section-accent, var(--primary)) 40%,transparent)}.sidebar-link.active .sidebar-label{font-weight:600;color:var(--text-primary)}.sidebar-label{white-space:nowrap;opacity:1;transition:opacity .2s ease;flex:1}.sidebar.collapsed .sidebar-label{opacity:0;width:0;pointer-events:none;position:absolute}.sidebar-collapse-btn-simple{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.sidebar-collapse-btn-simple:hover{background:var(--hover-bg);color:var(--pastel-section-accent, var(--primary));border-color:var(--pastel-section-accent, var(--primary))}.rotate-180{transform:rotate(180deg)}.sidebar-theme-toggle{margin-top:auto;display:flex;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:4px;gap:4px}.sidebar.collapsed .sidebar-theme-toggle{flex-direction:column;width:44px;padding:4px}.theme-option{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;border-radius:8px;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.theme-option.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm)}.sidebar.collapsed .theme-text{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);width:280px!important;max-width:calc(100vw - 44px);background:#fff!important;border-right:1px solid var(--border);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:280px!important}.sidebar-overlay{background:#0f172a73;-webkit-backdrop-filter:none;backdrop-filter:none}.sidebar,.sidebar *{filter:none!important}.sidebar.collapsed .sidebar-brand-text,.sidebar.collapsed .sidebar-label,.sidebar.collapsed .sidebar-section-title{opacity:1;width:auto;position:relative;pointer-events:auto}.sidebar.collapsed .sidebar-fixed-top{flex-direction:row;padding:var(--s-6)}.sidebar.collapsed .theme-text{display:block}.sidebar.collapsed .sidebar-theme-toggle{flex-direction:row;width:auto}}.header{height:var(--header-height);padding:0 var(--s-8);background:var(--bg-header);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;transition:all var(--transition)}.header-left,.header-right{display:flex;align-items:center;gap:var(--s-4)}.hamburger{display:none;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;padding:var(--s-2);border-radius:10px;transition:all var(--transition);align-items:center;justify-content:center}.hamburger:hover{background:var(--hover-bg);border-color:var(--primary-light);color:var(--primary)}.header-user{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-1) var(--s-3);background:var(--bg-card);border-radius:14px;border:1px solid var(--border-light);transition:all var(--transition);cursor:pointer}.header-user:hover{border-color:var(--primary-light);background:color-mix(in srgb,var(--primary),transparent 95%);transform:translateY(-1px)}.header-avatar{width:32px;height:32px;border-radius:10px;object-fit:cover;border:1.5px solid var(--primary-light);box-shadow:0 2px 8px var(--primary-bg)}.header-user-info{display:flex;flex-direction:column;line-height:1.2}.header-username{font-size:13px;font-weight:700;color:var(--text-primary)}.header-role{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:capitalize}.logout-btn{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.logout-btn:hover{background:color-mix(in srgb,var(--danger),transparent 92%);color:var(--danger);border-color:var(--danger-light);transform:scale(1.05)}@media(max-width:768px){.hamburger{display:flex}.header{padding:0 var(--s-4);height:64px}.header-user-info{display:none}.header-user{padding:var(--s-1);border-radius:12px}}[data-theme=dark] .header{background:#10121fcc}[data-theme=dark] .header-user,[data-theme=dark] .logout-btn{background:#ffffff08;border-color:#ffffff14}.user-badge{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-2) var(--s-3);border-radius:var(--radius-sm);background:var(--hover-bg);font-size:15px;font-weight:500}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px}.notification-bell{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.notification-bell:hover{background:color-mix(in srgb,var(--primary),transparent 92%);color:var(--primary);border-color:color-mix(in srgb,var(--primary),transparent 80%);transform:scale(1.05)}.notification-bell.active{background:color-mix(in srgb,var(--primary),transparent 90%);color:var(--primary);border-color:color-mix(in srgb,var(--primary),transparent 70%)}.notification-bell.intense{box-shadow:0 0 #ef444480;animation:intense-bell-glow 1.6s ease infinite}@keyframes intense-bell-glow{0%{box-shadow:0 0 #ef44448c}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.notification-bell-icon{transition:transform .2s ease}.notification-bell:hover .notification-bell-icon{transform:rotate(12deg)}.notification-bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;border-radius:20px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-header);box-shadow:0 2px 4px #ef44444d;animation:badge-pop .3s ease}@keyframes badge-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.notification-drawer .drawer-body{padding:0;display:flex;flex-direction:column;height:100%}.notification-filter-tabs{display:flex;gap:4px;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light)}.notification-filter-tab{flex:1;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:6px}.notification-filter-tab:hover{background:var(--hover-bg);color:var(--text-primary)}.notification-filter-tab.active{background:var(--bg-card);color:var(--primary);box-shadow:0 1px 3px #0000001a}.notification-filter-badge{background:var(--primary);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px}.notification-mark-all{padding:8px 16px;border-bottom:1px solid var(--border-light)}.notification-mark-all-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition)}.notification-mark-all-btn:hover{background:color-mix(in srgb,var(--primary),transparent 90%)}.notification-list{flex:1;overflow-y:auto;padding:16px}.notification-group{margin-bottom:24px}.notification-group:last-child{margin-bottom:0}.notification-group-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.notification-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);white-space:nowrap}.notification-group-divider{flex:1;height:1px;background:var(--border-light)}.notification-group-items{display:flex;flex-direction:column;gap:12px}.notification-card{position:relative;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-light);padding:16px;transition:all .2s ease;cursor:pointer}.notification-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px);border-color:color-mix(in srgb,var(--primary),transparent 70%)}.notification-card.unread{background:color-mix(in srgb,var(--primary),transparent 96%);border-left:3px solid var(--primary)}.notification-card.unread:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:16px;pointer-events:none;background:linear-gradient(120deg,color-mix(in srgb,var(--primary),transparent 86%),transparent 35%,color-mix(in srgb,#25D366,transparent 90%));opacity:.5}.notification-card.unread:hover:before{opacity:.75}.notification-unread-dot{position:absolute;top:16px;right:48px;width:8px;height:8px;background:var(--primary);border-radius:50%;animation:pulse-dot 2s ease infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.notification-card-content{display:flex;gap:14px}.notification-avatar-section{position:relative;flex-shrink:0}.notification-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid var(--bg-card);box-shadow:0 2px 8px #0000001a}.notification-type-icon{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card);box-shadow:0 2px 4px #0000001a}.notification-content{flex:1;min-width:0}.notification-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.notification-header-right{display:inline-flex;align-items:center;gap:8px}.notification-whatsapp-btn{width:24px;height:24px;border:none;border-radius:999px;background:#25d366;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #25d36659;transition:transform .15s ease,box-shadow .15s ease}.notification-whatsapp-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #25d36673}.notification-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3}.notification-time{font-size:10px;font-weight:500;color:var(--text-muted);white-space:nowrap}.notification-message{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.4;margin-bottom:4px}.notification-subtitle{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-bottom:8px}.notification-view-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--primary);text-decoration:none;transition:gap .2s ease}.notification-view-link:hover{gap:8px}.notification-delete-btn{position:absolute;top:16px;right:16px;width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.notification-card:hover .notification-delete-btn.visible,.notification-delete-btn:focus{opacity:1}.notification-delete-btn:hover{background:var(--danger-bg);color:var(--danger)}.notification-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.notification-action-btn{padding:6px 14px;border:none;border-radius:8px;font-size:11px;font-weight:700;cursor:pointer;transition:all var(--transition)}.notification-action-btn.primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #ec5b134d}.notification-action-btn.primary:hover{background:color-mix(in srgb,var(--primary),black 15%);transform:translateY(-1px);box-shadow:0 4px 12px #ec5b1366}.notification-action-btn.secondary{background:var(--bg-secondary);color:var(--text-secondary)}.notification-action-btn.secondary:hover{background:var(--hover-bg);color:var(--text-primary)}.notification-action-btn.danger{background:var(--danger-bg);color:var(--danger)}.notification-action-btn.danger:hover{background:var(--danger);color:#fff}.notification-actions-more{font-size:11px;color:var(--text-muted);align-self:center}.notification-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.notification-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--text-muted)}.notification-empty-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.notification-empty-description{font-size:13px;color:var(--text-muted)}.notification-drawer-footer{display:flex;align-items:center;justify-content:space-between;padding:16px;border-top:1px solid var(--border-light);background:var(--bg-secondary)}.notification-view-all{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:all var(--transition)}.notification-view-all:hover{color:var(--primary);gap:10px}.notification-settings-link{padding:8px;border-radius:8px;color:var(--text-muted);transition:all var(--transition)}.notification-settings-link:hover{background:var(--hover-bg);color:var(--primary)}.notification-skeleton-list{padding:16px;display:flex;flex-direction:column;gap:16px}.notification-skeleton-card{display:flex;gap:14px;padding:16px;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-light)}.notification-skeleton-avatar{position:relative;flex-shrink:0}.notification-skeleton-icon{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:50%;overflow:hidden}.notification-skeleton-content{flex:1}.notification-skeleton-header{display:flex;justify-content:space-between;margin-bottom:8px}.notification-skeleton-message{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.notification-skeleton-actions{display:flex;gap:8px}.skeleton-pulse{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--hover-bg) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease infinite}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.skeleton-icon{width:22px;height:22px}.skeleton-title{width:60%;height:14px;border-radius:4px}.skeleton-time{width:60px;height:10px;border-radius:4px}.skeleton-text{height:12px;border-radius:4px}.skeleton-text-full{width:100%}.skeleton-text-70{width:70%}.skeleton-btn{width:80px;height:28px;border-radius:8px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .notification-card{background:var(--bg-sidebar)}[data-theme=dark] .notification-card.unread{background:color-mix(in srgb,var(--primary),transparent 92%)}[data-theme=dark] .notification-card.unread:before{opacity:.42}[data-theme=dark] .notification-filter-tab.active,[data-theme=dark] .notification-skeleton-card{background:var(--bg-sidebar)}@media(max-width:480px){.notification-drawer{width:100%!important;max-width:100%!important}.notification-card{padding:12px}.notification-avatar{width:40px;height:40px}.notification-type-icon{width:18px;height:18px}.notification-action-btn{padding:5px 10px;font-size:10px}}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-base);background:#fff}.data-table th{text-align:left;padding:16px 22px;font-weight:700;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--table-header-bg);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:0 22px;height:56px;border-bottom:1px solid var(--border-light);color:var(--text-primary);line-height:1.4;vertical-align:middle}.data-table tbody tr{transition:all .15s ease;cursor:pointer}.data-table tbody tr:nth-child(2n){background:#fafbfd}[data-theme=dark] .data-table tbody tr:nth-child(2n){background:#ffffff04}.data-table tbody tr:hover{background:#f4f5fa}.badge{display:inline-flex;align-items:center;padding:3px 11px;border-radius:99px;font-size:var(--text-sm);font-weight:600;letter-spacing:.01em}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-primary{background:var(--primary-bg);color:var(--primary)}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .15s ease}.card:hover{box-shadow:var(--shadow-md)}.attendance-card-apple{background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000005,0 1px 2px #0000000a;border:.5px solid rgba(0,0,0,.05);transition:all .2s cubic-bezier(.4,0,.2,1);padding:16px;display:flex;align-items:center;gap:16px;cursor:pointer}.attendance-card-apple:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000000a}.attendance-card-avatar{width:56px;height:56px;border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid white;box-shadow:inset 0 0 0 1px #0000000d}.attendance-card-avatar img{width:100%;height:100%;object-fit:cover}.attendance-card-avatar.initials{background:#f0f0f5;color:#1d1d1f;font-weight:700;font-size:18px}.attendance-card-info{flex:1;min-width:0}.attendance-card-title-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.attendance-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.attendance-status-dot.pending{background:#ff9500}.attendance-status-dot.completed{background:#34c759}.attendance-status-dot.ongoing{background:#af52de}.attendance-status-dot.scheduled{background:#007aff}.attendance-status-dot.low{background:#ff3b30}.attendance-card-title{font-size:14px;font-weight:700;color:#1d1d1f;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.25}.attendance-card-meta{font-size:11px;color:#86868b;display:flex;align-items:center;flex-wrap:wrap;gap:6px}.attendance-card-meta .separator{color:#d1d1d6}.attendance-card-status-section{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.attendance-status-badge{font-size:9px;font-weight:700;text-transform:uppercase;padding:4px 10px;border-radius:8px;letter-spacing:.02em;transform:translateY(-2px)}.attendance-progress-count{font-size:10px;font-weight:700;color:#6e6e73;line-height:1}.attendance-status-badge.pending{background:#fff4e5;color:#ff9500;border:1px solid #FFE4C4}.attendance-status-badge.completed{background:#e8f7ee;color:#34c759;border:1px solid #D4EDE0}.attendance-status-badge.ongoing{background:#f5eefc;color:#af52de;border:1px solid #E8DBF5}.attendance-status-badge.scheduled{background:#e5f2ff;color:#007aff;border:1px solid #CCE4FF}.attendance-status-badge.low{background:#ffe5e5;color:#ff3b30;border:1px solid #FFD4D4}.attendance-progress-mini{width:64px;height:4px;background:#f0f0f5;border-radius:10px;overflow:hidden}.attendance-progress-mini-fill{height:100%;border-radius:10px;transition:width .3s ease}.attendance-progress-mini-fill.pending{background:#ff9500}.attendance-progress-mini-fill.completed{background:#34c759}.attendance-progress-mini-fill.ongoing{background:#af52de}.attendance-progress-mini-fill.scheduled{background:#007aff}.attendance-progress-mini-fill.low{background:#ff3b30}.attendance-add-card{border-radius:16px;border:2px dashed #d1d1d6;display:flex;align-items:center;justify-content:center;padding:20px;opacity:.5;transition:all .2s ease;cursor:pointer;background:transparent}.attendance-add-card:hover{opacity:1;border-color:var(--primary, #007AFF);background:#007aff0d}.attendance-add-card span{font-size:12px;font-weight:700;color:#86868b;letter-spacing:.05em;text-transform:uppercase}.attendance-add-card:hover span{color:var(--primary, #007AFF)}.teacher-payouts-filter-row{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end}.teacher-payouts-quick-filters{display:flex;gap:8px;flex-wrap:wrap}.teacher-payout-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}.teacher-payout-apple-card{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:18px;box-shadow:0 1px 2px #0f172a0a,0 12px 28px #0f172a14;border:1px solid rgba(148,163,184,.24);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:14px;display:flex;flex-direction:column;gap:12px;transition:all .2s cubic-bezier(.4,0,.2,1)}.teacher-payout-apple-card:hover{transform:translateY(-2px);box-shadow:0 1px 2px #0f172a0a,0 16px 32px #0f172a1f}.teacher-payout-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.teacher-payout-card-user{display:flex;align-items:center;gap:10px;min-width:0}.teacher-payout-avatar{width:44px;height:44px;border-radius:14px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#0f172a;font-size:14px;font-weight:700;background:linear-gradient(160deg,#dbeafe,#c7d2fe);border:1px solid rgba(148,163,184,.3);box-shadow:inset 0 1px #fffc}.teacher-payout-avatar img{width:100%;height:100%;object-fit:cover}.teacher-payout-card-name{font-size:15px;line-height:1.25;font-weight:700;color:#1d1d1f}.teacher-payout-card-meta{margin-top:4px;font-size:11px;color:#6e6e73;display:flex;align-items:center;flex-wrap:wrap;gap:5px}.teacher-payout-card-meta .sep{color:#d1d1d6}.teacher-payout-badge{font-size:10px;font-weight:700;padding:4px 8px;border-radius:9px;border:1px solid transparent;line-height:1}.teacher-payout-badge.pending{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.teacher-payout-badge.partial{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.teacher-payout-badge.paid{background:#ecfdf3;color:#166534;border-color:#bbf7d0}.teacher-payout-card-body{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.teacher-payout-card-metric{background:#ffffffad;border:1px solid rgba(148,163,184,.24);border-radius:10px;padding:8px 9px}.teacher-payout-card-metric .metric-label{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.02em;font-weight:700}.teacher-payout-card-metric .metric-value{margin-top:4px;font-size:13px;font-weight:700;color:#0f172a;line-height:1.15}.teacher-payout-card-metric .metric-value.muted{color:#334155}.teacher-payout-card-actions{display:flex;justify-content:space-between;align-items:center;gap:8px}.teacher-payout-card-actions-main{display:flex;align-items:center;gap:8px}.teacher-payout-more-trigger{width:auto!important;height:34px!important;padding:0 12px!important;border-radius:11px!important;border:1px solid rgba(148,163,184,.36)!important;background:#ffffffbd!important}.teacher-payout-more-label{font-size:12px;font-weight:700;color:#334155}.teacher-payout-card-actions .action-dropdown-menu{min-width:190px;border-radius:12px;border-color:#94a3b84d;box-shadow:0 10px 24px #0f172a24}.teacher-payout-card-actions .btn{border-radius:11px;font-weight:600}@media(max-width:768px){.teacher-payouts-filter-row{grid-template-columns:1fr}.teacher-payouts-quick-filters{width:100%}.teacher-payouts-quick-filters .btn{flex:1;justify-content:center}.teacher-payout-apple-card{padding:12px}.teacher-payout-card-body{grid-template-columns:1fr}.teacher-payout-card-actions{justify-content:stretch;flex-direction:column;align-items:stretch}.teacher-payout-card-actions-main{width:100%}.teacher-payout-card-actions .btn{flex:1;justify-content:center}.teacher-payout-more-trigger{width:100%!important;justify-content:center!important}}.card-header{padding:20px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.card-body{padding:24px 28px}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(160px,auto);gap:var(--s-5);margin-bottom:var(--s-8)}@media(max-width:1200px){.bento-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.bento-grid{grid-template-columns:1fr;gap:var(--s-4)}}.stats-container-mobile{display:flex;gap:var(--s-4);overflow-x:auto;padding:4px 4px 16px;margin:0 -4px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;scroll-snap-type:x mandatory}.stats-container-mobile::-webkit-scrollbar{display:none}.premium-stat-card{min-width:180px;flex:1;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--s-5);display:flex;flex-direction:column;justify-content:space-between;gap:var(--s-4);transition:all var(--transition);position:relative;overflow:hidden;scroll-snap-align:start;-webkit-user-select:none;user-select:none}.premium-stat-card:active{transform:scale(.97);background:var(--hover-bg)}.premium-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.premium-stat-card .stat-icon-wrapper{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:auto;transition:transform var(--transition)}.premium-stat-card:hover .stat-icon-wrapper{transform:rotate(-10deg) scale(1.1)}.premium-stat-content{display:flex;flex-direction:column}.premium-stat-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.premium-stat-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1}.premium-stat-trend{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;margin-top:4px}.premium-stat-trend.up{color:var(--success)}.premium-stat-trend.down{color:var(--danger)}.premium-stat-card.blue .stat-icon-wrapper{background:var(--stat-blue-accent);color:#fff}.premium-stat-card.green .stat-icon-wrapper{background:var(--stat-green-accent);color:#fff}.premium-stat-card.orange .stat-icon-wrapper{background:var(--stat-orange-accent);color:#fff}.premium-stat-card.purple .stat-icon-wrapper{background:var(--stat-purple-accent);color:#fff}.premium-stat-card.red .stat-icon-wrapper{background:var(--stat-red-accent);color:#fff}.premium-stat-card.pink .stat-icon-wrapper{background:var(--stat-pink-accent);color:#fff}.bento-chart-main,.bento-chart-side,.bento-list{grid-column:span 2;grid-row:span 2}@media(max-width:1200px){.bento-chart-main,.bento-chart-side,.bento-list{grid-column:span 2}}@media(max-width:768px){.bento-chart-main,.bento-chart-side,.bento-list{grid-column:span 1}.premium-stat-card{min-width:160px;padding:var(--s-4)}}.bento-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--s-6);box-shadow:var(--shadow-sm);display:flex;flex-direction:column}[data-theme=dark] .bento-card{background:#18181b99;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-color:#ffffff0d}.hero-card-premium{background:linear-gradient(135deg,#8b84ff,#6c63ff);color:#fff;border-radius:var(--radius-xl);padding:var(--s-8);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;grid-column:span 2;grid-row:span 2;box-shadow:0 20px 40px -10px #6c63ff4d}.hero-card-premium h2{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--s-4);line-height:1.1;max-width:70%}.hero-card-premium p{font-size:var(--text-sm);opacity:.9;max-width:60%}.hero-illustration{position:absolute;right:-20px;top:50%;transform:translateY(-50%);width:240px;height:240px;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(0,0,0,.1))}.bento-card.progress-card{background:#ffad7c;border:none;color:#331a0d;padding:var(--s-8);grid-column:span 2;grid-row:span 4}.progress-pills-container{display:flex;align-items:flex-end;justify-content:space-between;height:200px;margin-top:var(--s-8);gap:var(--s-4)}.progress-pill-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--s-3);flex:1}.progress-pill-bar{width:60px;height:100%;background:#0000000d;border-radius:30px;position:relative;overflow:hidden}.progress-pill-fill{position:absolute;bottom:0;left:0;width:100%;background:#4d2612;border-radius:30px;transition:height 1s cubic-bezier(.34,1.56,.64,1)}.progress-pill-fill.striped{background:repeating-linear-gradient(45deg,#4d2612,#4d2612 10px,#5d3622 10px,#5d3622 20px)}.progress-pill-label{font-size:13px;font-weight:600;opacity:.7}.dark-highlight-card{background:#25282c;color:#fff;border-radius:var(--radius-xl);padding:var(--s-8);grid-column:span 2;grid-row:span 1;display:flex;align-items:center;justify-content:space-between}.visual-tile{background:var(--bg-card);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border);transition:transform var(--transition);cursor:pointer}.visual-tile:hover{transform:translateY(-8px)}.visual-tile-img{width:100%;height:160px;object-fit:cover}.visual-tile-content{padding:var(--s-5)}.visual-tile-title{font-size:var(--text-base);font-weight:700;margin-bottom:4px}.subject-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #0000000a}.pastel-stat-card{background:linear-gradient(135deg,var(--pastel-bg, var(--pastel-blue)) 0%,var(--bg-card) 100%);border-radius:18px;box-shadow:var(--shadow),0 0 20px var(--pastel-glow, transparent);position:relative;overflow:hidden}.pastel-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--pastel-accent, var(--primary)) 0%,var(--pastel-bg, var(--pastel-blue)) 100%)}.pastel-stat-icon{width:48px;height:48px;border-radius:50%;background:var(--pastel-bg, var(--pastel-blue));display:flex;align-items:center;justify-content:center;color:var(--pastel-accent, var(--primary))}.pastel-stat-icon svg{width:24px;height:24px}.pastel-data-card{background:var(--bg-card);border-radius:16px;border-left:4px solid var(--pastel-accent, var(--primary));box-shadow:var(--shadow-sm);transition:all .2s ease}.pastel-data-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-pastel-primary{background:linear-gradient(135deg,var(--pastel-accent, var(--primary)) 0%,var(--primary-dark, #5A52E0) 100%);color:#fff;border:none;border-radius:12px;padding:10px 20px;font-weight:600;transition:all .2s ease}.btn-pastel-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--pastel-accent, var(--primary)) 40%,transparent)}.btn-pastel-secondary{background:transparent;color:var(--pastel-accent, var(--primary));border:2px solid var(--pastel-accent, var(--primary));border-radius:12px;padding:8px 18px;font-weight:600;transition:all .2s ease}.btn-pastel-secondary:hover{background:var(--pastel-accent, var(--primary));color:#fff}.ph-main{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--bg-card);border-radius:14px;box-shadow:var(--shadow-md);flex-wrap:wrap;transition:margin-bottom .2s ease}.ph-title-wrap{display:flex;align-items:center;gap:10px;min-width:0}.ph-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em;line-height:1.2}.ph-count{padding:4px 12px;border-radius:100px;font-size:.9rem;font-weight:600;white-space:nowrap}.ph-divider{width:1px;height:28px;background:var(--border)}.ph-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.ph-stat-pill{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--text-primary)}.ph-stat-pill.is-clickable{padding:6px 12px;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid transparent}.ph-stat-pill.is-clickable:hover{background:var(--bg);border-color:var(--border)}.ph-stat-pill.is-active{background:var(--ph-stat-bg)}.ph-stat-pill.is-active .ph-stat-icon,.ph-stat-pill.is-active .ph-stat-label,.ph-stat-pill.is-active .ph-stat-value{color:var(--ph-stat-color)}.ph-stat-icon,.ph-stat-label{color:var(--text-muted)}.ph-spacer{flex:1}.ph-search{display:flex;align-items:center;gap:8px;background:var(--bg);border-radius:10px;border:1px solid var(--border);padding:0 12px;height:38px;min-width:200px;max-width:320px;flex:1 1 240px}.ph-search-input{border:none;background:transparent;width:100%;font-size:.9rem;outline:none;color:var(--text-primary)}.ph-filter-btn,.ph-add-btn,.ph-reset-btn{height:38px;padding:0 16px;border-radius:10px;border:1px solid var(--border);font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.ph-add-btn{padding:0 20px;border-radius:100px;background:var(--primary);color:#fff;border:none;box-shadow:0 2px 8px #6c63ff4d}.ph-filters-panel{display:flex;gap:10px;padding:12px;background:var(--bg-card);border-radius:0 0 14px 14px;margin-bottom:16px;box-shadow:var(--shadow-sm);flex-wrap:wrap;animation:slideDown .2s ease}.ph-filter-select{height:36px;padding:0 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);font-size:.85rem;min-width:120px;color:var(--text-primary);cursor:pointer}.ph-reset-btn{height:36px;background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}@media(max-width:900px){.ph-main{gap:10px;padding:12px}.ph-divider,.ph-spacer{display:none}.ph-title{font-size:1.2rem}.ph-title-wrap,.ph-stats,.ph-search,.ph-custom-actions,.ph-filter-btn,.ph-add-btn{width:100%}.ph-stats{justify-content:flex-start}.ph-search{max-width:none;min-width:0}.ph-filter-btn,.ph-add-btn{justify-content:center}.ph-filters-panel{padding:10px}.ph-filter-select,.ph-reset-btn{width:100%}}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);text-decoration:none;line-height:1.4}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-md)}.form-group{margin-bottom:var(--s-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--s-1)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-card);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:42px;cursor:pointer;background-image:linear-gradient(180deg,#ffffffd9,#f8fafceb),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:center,right 14px center;background-size:auto,14px;box-shadow:0 1px 2px #0f172a0a}[data-theme=dark] .form-select{background-image:linear-gradient(180deg,#18181bfa,#121215fa),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.form-select:hover{border-color:color-mix(in srgb,var(--primary) 20%,var(--border));box-shadow:0 6px 16px #0f172a0f}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.form-select:disabled{cursor:not-allowed;opacity:.68;box-shadow:none}.form-select option{color:var(--text-primary);background:var(--bg-card)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .2s ease;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;animation:scaleIn .2s ease}.modal-lg{max-width:900px}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:var(--s-3)}.confirm-dialog{display:flex;flex-direction:column;gap:16px}.confirm-dialog-icon-wrap{display:flex;align-items:flex-start;gap:16px}.confirm-dialog-icon{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 10px 25px #0f172a14}.confirm-dialog-danger .confirm-dialog-icon{color:#dc2626;background:linear-gradient(135deg,#fee2e2f2,#fef2f2f2);border:1px solid rgba(239,68,68,.18)}.confirm-dialog-info .confirm-dialog-icon{color:#2563eb;background:linear-gradient(135deg,#dbeafef2,#eff6fff2);border:1px solid rgba(59,130,246,.18)}.confirm-dialog-text{min-width:0;display:flex;flex-direction:column;gap:8px}.confirm-dialog-message{font-size:1rem;font-weight:700;line-height:1.5;color:var(--text-primary)}.confirm-dialog-details{font-size:.92rem;line-height:1.6;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:14px;padding:12px 14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.modal-backdrop{align-items:center;padding:10px;background:#00000080}.modal,.modal-lg{width:calc(100% - 4px);max-width:100%;max-height:92vh;border-radius:16px;box-shadow:0 14px 30px #00000038;animation:slideUpIn .22s ease;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:14px 16px;position:sticky;top:0;z-index:2;background:var(--bg-card);flex-shrink:0}.modal-header h2{font-size:1rem;line-height:1.3}.modal-body{padding:14px 16px;overflow-y:auto;flex:1 1 auto;min-height:0}.confirm-dialog-icon-wrap{gap:12px}.confirm-dialog-icon{width:46px;height:46px;border-radius:14px}.confirm-dialog-message{font-size:.95rem}.confirm-dialog-details{font-size:.88rem;padding:10px 12px}.modal-footer{padding:12px 16px calc(12px + env(safe-area-inset-bottom));position:sticky;bottom:0;background:var(--bg-card);z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:10px;flex-shrink:0}.modal-footer .btn{width:100%;min-height:42px;justify-content:center}}@media(max-width:420px){.modal-footer{grid-template-columns:1fr}}@keyframes slideUpIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition)}.main-content.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.page-content{flex:1;padding:var(--s-8) var(--s-10);max-width:1600px}.search-box{position:relative;max-width:320px}.search-box .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:18px;height:18px}.search-box .form-input{padding-left:38px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s-6);flex-wrap:wrap;gap:var(--s-4)}.page-header h1{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.tabs{display:flex;gap:4px;padding:4px;background:var(--hover-bg);border-radius:var(--radius);margin-bottom:var(--s-5);overflow-x:auto}.tab{padding:8px 16px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all var(--transition);white-space:nowrap}.tab.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-5)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden;padding:20px}.login-bg-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:float 20s ease-in-out infinite;pointer-events:none}.login-bg-orb:nth-child(1){width:400px;height:400px;background:linear-gradient(135deg,var(--primary),var(--primary-light));top:-150px;left:-100px;animation-delay:0s}.login-bg-orb:nth-child(2){width:300px;height:300px;background:linear-gradient(135deg,var(--premium-purple-500),var(--premium-indigo-500));bottom:-100px;right:-50px;animation-delay:-7s}.login-bg-orb:nth-child(3){width:250px;height:250px;background:linear-gradient(135deg,var(--success),var(--info));top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s;opacity:.3}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-20px) scale(1.02)}}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(108,99,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(108,99,255,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.login-card{width:100%;max-width:440px;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);padding:48px 40px;box-shadow:0 0 0 1px #00000005,0 4px 6px -1px #00000005,0 10px 40px -10px #6c63ff26;position:relative;z-index:10;animation:cardAppear .6s cubic-bezier(.16,1,.3,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}[data-theme=dark] .login-card{background:#121215d9;border:1px solid rgba(255,255,255,.08);box-shadow:0 0 0 1px #ffffff08,0 4px 6px -1px #0003,0 10px 40px -10px #6c63ff33}.login-card-header{text-align:center;margin-bottom:36px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:20px;margin-bottom:20px;box-shadow:0 4px 12px #6c63ff4d,inset 0 1px #ffffff4d;animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.login-logo svg{width:36px;height:36px;color:#fff}.login-card h1{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.02em}.login-card p{font-size:var(--text-sm);color:var(--text-muted);margin:0;line-height:1.5}.login-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:var(--danger);padding:14px 18px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;margin-bottom:24px;display:flex;align-items:center;gap:10px;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.login-error svg{flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form .form-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.login-form .form-input{width:100%;height:52px;padding:0 18px;font-size:var(--text-base);font-family:var(--font-body);color:var(--text-primary);background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);transition:all var(--transition);box-shadow:inset 0 1px 2px #00000005}.login-form .form-input:hover{border-color:var(--primary-light);background:var(--hover-bg)}.login-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:inset 0 1px 2px #00000005,0 0 0 4px #6c63ff1a}.login-form .form-input::placeholder{color:var(--text-muted);opacity:.7}.login-submit-btn{width:100%;height:54px;padding:0 24px;font-size:var(--text-base);font-weight:600;font-family:var(--font-body);color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;position:relative;overflow:hidden;letter-spacing:-.01em}.login-submit-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translate(-100%);transition:transform .6s ease}.login-submit-btn:hover:not(:disabled):before{transform:translate(100%)}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6c63ff59}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed;background:var(--premium-zinc-400)}.login-submit-btn .spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin:0}.login-footer{margin-top:28px;text-align:center;display:flex;flex-direction:column;gap:12px}.login-forgot{font-size:var(--text-sm);color:var(--text-muted)}.login-forgot a{color:var(--primary);text-decoration:none;font-weight:600;transition:color var(--transition)}.login-forgot a:hover{color:var(--primary-dark);text-decoration:underline}.login-back{font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:6px}.login-back a{color:var(--primary);text-decoration:none;font-weight:600;transition:color var(--transition)}.login-back a:hover{color:var(--primary-dark)}.login-input-wrapper{position:relative}.login-input-wrapper .form-input{padding-left:48px}.login-input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--transition)}.login-input-wrapper:focus-within .login-input-icon{color:var(--primary)}.login-password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition)}.login-password-toggle:hover{color:var(--primary)}.login-remember{display:flex;align-items:center;gap:10px;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer}.login-remember input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}@media(max-width:520px){.login-page{padding:40px 16px 16px;align-items:flex-start}.login-card{padding:36px 24px;border-radius:var(--radius-lg);max-width:100%}.login-logo{width:64px;height:64px;border-radius:18px}.login-logo svg{width:30px;height:30px}.login-card h1{font-size:var(--text-xl)}.login-form .form-input,.login-submit-btn{height:50px;font-size:var(--text-sm)}}.login-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:20}[data-theme=dark] .login-loading-overlay{background:#121215cc}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:var(--text-sm)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}:root{--drawer-width: 640px;--drawer-overlay: rgba(15, 23, 42, .2);--drawer-surface: var(--bg-card, #ffffff);--drawer-surface-muted: var(--bg-secondary, #f6f7f8);--drawer-border: var(--border, #e2e8f0);--drawer-title: var(--text-primary, #0f172a);--drawer-subtitle: var(--text-muted, #64748b);--drawer-shadow: none;--drawer-radius: 0;--drawer-transition: .32s cubic-bezier(.22, 1, .36, 1)}[data-theme=dark]{--drawer-overlay: rgba(2, 6, 23, .55);--drawer-shadow: none}.side-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:var(--drawer-overlay);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}.side-drawer-overlay.open{opacity:1;visibility:visible}.side-drawer{position:fixed;inset:0 0 0 auto;width:100%;max-width:var(--drawer-width);background:var(--drawer-surface);border-left:1px solid var(--drawer-border);border-top:4px solid var(--entity-color, var(--primary));box-shadow:var(--drawer-shadow);z-index:9999;transform:translate(100%);transition:transform var(--drawer-transition);display:flex;flex-direction:column;overflow:hidden;border-radius:var(--drawer-radius)}.side-drawer.open{transform:translate(0)}.drawer-content{height:100%;display:flex;flex-direction:column}.drawer-header{position:sticky;top:0;z-index:5;padding:10px 22px;border-bottom:1px solid var(--drawer-border);background:color-mix(in srgb,var(--entity-color, var(--primary)) 8%,var(--bg-card));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:48px;flex-wrap:nowrap}.drawer-header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.drawer-title-group{flex:1;min-width:0;max-width:calc(100% - 50px);overflow:hidden;display:flex;align-items:center}.drawer-title{margin:0;font-size:.9rem;font-weight:700;line-height:1.2;color:var(--drawer-title);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.drawer-title-separator{color:var(--drawer-border);font-weight:400}.drawer-subtitle-inline{color:var(--drawer-subtitle);font-size:.75rem;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}.drawer-header-actions{display:flex;align-items:center;gap:8px}.drawer-close-btn{width:34px;height:34px;border:0;border-radius:10px;background:var(--drawer-surface-muted);color:var(--drawer-subtitle);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s ease;box-shadow:0 1px 3px #00000014;flex-shrink:0}.drawer-close-btn:hover{background:var(--hover-bg, #eef2f7);color:#ef4444;transform:scale(1.05);box-shadow:0 2px 6px #0000001f}.drawer-body{flex:1;overflow:auto;padding:22px;display:flex;flex-direction:column;gap:22px}.drawer-body::-webkit-scrollbar{width:6px}.drawer-body::-webkit-scrollbar-thumb{background:var(--drawer-border);border-radius:999px}.drawer-footer{position:sticky;bottom:0;z-index:5;display:flex;gap:10px;justify-content:flex-end;padding:16px 22px 20px;border-top:1px solid var(--drawer-border);background:color-mix(in srgb,var(--drawer-surface) 90%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.drawer-section{display:flex;flex-direction:column;gap:14px}.section-title{margin:4px 2px 0;font-size:.7rem;line-height:1;text-transform:uppercase;letter-spacing:.15em;color:var(--drawer-subtitle);font-weight:700;display:inline-flex;align-items:center;gap:8px}.side-drawer .form-group,.side-drawer .form-row,.side-drawer .drawer-section>.credentials-box,.side-drawer .drawer-section>.rating-summary-box,.side-drawer .drawer-section>.feedback-card,.side-drawer .drawer-section>.student-info-popup,.side-drawer .drawer-section>.tab-content{margin:0}.side-drawer .form-label{font-size:.84rem;font-weight:600}.side-drawer .form-input,.side-drawer .form-select,.side-drawer .form-textarea{border-radius:12px;border:1px solid transparent;background:var(--drawer-surface-muted);box-shadow:none}.side-drawer .form-input:focus,.side-drawer .form-select:focus,.side-drawer .form-textarea:focus{border-color:color-mix(in srgb,var(--primary, #137fec) 35%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary, #137fec) 15%,transparent)}.drawer-empty-state{border:1px dashed var(--drawer-border);border-radius:16px;padding:42px 24px;text-align:center}.drawer-empty-state-icon{width:60px;height:60px;border-radius:16px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;background:var(--drawer-surface-muted)}.credentials-box{background:var(--drawer-surface-muted);border:1px solid var(--drawer-border);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:10px}.credentials-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.credentials-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--drawer-subtitle);font-weight:700}.credentials-value{font-size:1rem;font-weight:700;color:var(--drawer-title)}.credentials-hint{margin:2px 0 0;padding-top:10px;border-top:1px dashed var(--drawer-border);color:var(--drawer-subtitle);font-size:.8rem}.drawer-section-pastel{background:var(--pastel-section-bg, var(--bg-tertiary));border:1px solid var(--pastel-section-border, var(--border-color));border-radius:16px;padding:16px;margin-bottom:12px}.drawer-section-pastel:last-child{margin-bottom:0}.drawer-empty-state-icon,.drawer-close-btn:hover{background:var(--pastel-section-bg, var(--bg-tertiary))}.pastel-data-row{border-radius:12px;transition:background .15s ease}.pastel-data-row:nth-child(odd){background:color-mix(in srgb,var(--pastel-section-bg, var(--bg-tertiary)) 50%,transparent)}.pastel-data-row:hover{background:var(--pastel-section-bg, var(--bg-tertiary))}@media(max-width:768px){.side-drawer{inset:auto 0 0 0;max-width:100%!important;height:min(92vh,820px);border-left:0;border-top:1px solid var(--drawer-border);border-radius:16px 16px 0 0;transform:translateY(100%)}.side-drawer.open{transform:translateY(0)}.drawer-header,.drawer-body,.drawer-footer{padding-left:16px;padding-right:16px}.drawer-footer{flex-direction:column-reverse;padding-bottom:calc(14px + env(safe-area-inset-bottom))}.drawer-footer .btn{width:100%;justify-content:center}}.dashboard-page{padding:var(--s-6);background:var(--bg);min-height:calc(100vh - var(--header-height))}.elite-dashboard-container{max-width:1440px;margin:0 auto;display:flex;flex-direction:column;gap:var(--s-8)}.elite-header-minimal{margin-bottom:var(--s-2);display:flex;justify-content:space-between;align-items:center}.elite-welcome-title{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin-bottom:4px;font-family:var(--font-heading)}.elite-welcome-sub{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.header-actions{display:flex;gap:var(--s-3)}.glass-btn{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-4);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.glass-btn:hover{background:var(--hover-bg);border-color:var(--primary-light);transform:translateY(-1px)}.elite-grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--s-6)}.elite-stat-card{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:var(--s-4)}.elite-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.elite-stat-header{display:flex;justify-content:space-between;align-items:center}.elite-stat-icon-wrapper{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;background:var(--bg)}.elite-stat-avatars{display:flex;align-items:center}.elite-stat-avatars img{width:32px;height:32px;border-radius:50%;border:2px solid var(--bg-card);margin-left:-10px}.elite-stat-avatars img:first-child{margin-left:0}.avatar-more{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:2px solid var(--bg-card);margin-left:-10px}.elite-stat-badge{padding:4px 10px;border-radius:99px;font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;gap:2px}.elite-stat-badge.positive{background:var(--success-bg);color:var(--success)}.elite-stat-badge.negative{background:var(--danger-bg);color:var(--danger)}.elite-stat-title{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.elite-stat-value-row{display:flex;align-items:baseline;gap:var(--s-3);margin-top:4px}.elite-stat-value{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin:0}.elite-stat-trend-mini{font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;gap:2px}.elite-stat-trend-mini.positive{color:var(--success)}.elite-stat-trend-mini.negative{color:var(--danger)}.charts-stack{display:flex;flex-direction:column;gap:var(--s-8)}.elite-grid-charts{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-6)}.elite-chart-card{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm)}.elite-chart-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--s-4);font-family:var(--font-heading)}.risk-center{display:flex;flex-direction:column;gap:var(--s-6)}.risk-widget{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--s-4);position:relative;overflow:hidden}.risk-widget.warning{border-top:4px solid var(--warning)}.risk-header{display:flex;justify-content:space-between;align-items:center}.risk-title{display:flex;align-items:center;gap:var(--s-2);font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin:0}.risk-list{display:flex;flex-direction:column;gap:var(--s-3)}.risk-item{display:flex;justify-content:space-between;align-items:center;padding:var(--s-3) var(--s-4);background:var(--bg);border-radius:var(--radius);transition:all var(--transition)}.risk-item:hover{background:var(--hover-bg)}.risk-info{display:flex;flex-direction:column}.risk-name{font-weight:700;font-size:var(--text-sm);color:var(--text-primary)}.risk-sub{font-size:var(--text-xs);color:var(--text-muted)}.risk-value{font-weight:700;font-size:var(--text-sm)}.risk-value.danger{color:var(--danger)}.follow-up-btn{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);color:var(--primary);border:none;cursor:pointer;transition:all var(--transition)}.follow-up-btn:hover{background:var(--primary);color:#fff}.transaction-card{background:var(--bg-card);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);padding:0!important;overflow:hidden}.elite-card-header{padding:var(--s-6);display:flex;justify-content:space-between;align-items:center}.elite-btn-view-all{background:transparent;border:1px solid var(--border);padding:var(--s-2) var(--s-4);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:var(--s-2);cursor:pointer;transition:all var(--transition)}.elite-btn-view-all:hover{background:var(--hover-bg);border-color:var(--primary-light)}.elite-table-wrapper{overflow-x:auto}.elite-table{width:100%;border-collapse:collapse}.elite-table th{text-align:left;padding:16px 24px;font-size:var(--text-xs);font-weight:700;color:var(--text-muted);background:var(--table-header-bg);border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.05em}.elite-table td{padding:16px 24px;border-bottom:1px solid var(--border-light);vertical-align:middle}.td-customer{display:flex;align-items:center;gap:12px}.td-avatar{width:40px;height:40px;border-radius:12px}.td-info{display:flex;flex-direction:column}.td-name{font-weight:700;color:var(--text-primary);font-size:var(--text-sm)}.td-sub{font-size:var(--text-xs);color:var(--text-muted)}.td-price{font-weight:700;color:var(--text-primary)}.td-payment{display:flex;align-items:center;gap:8px;font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.td-payment img{height:18px}.elite-badge{padding:4px 12px;border-radius:8px;font-size:var(--text-xs);font-weight:700;display:inline-block}.tx-status-success{background:#dcfce7;color:#166534}.tx-status-cancel{background:#fee2e2;color:#991b1b}.tx-status-pending{background:#fef9c3;color:#854d0e}.td-actions{display:flex;gap:8px}.action-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s}.action-btn.view{background:#e0e7ff;color:#4338ca}.action-btn.edit{background:#dcfce7;color:#166534}.action-btn.delete{background:#fee2e2;color:#991b1b}.action-btn:hover{transform:scale(1.1)}.elite-grid-main{display:grid;grid-template-columns:2fr 1fr;gap:var(--s-8);align-items:start}@media(max-width:1280px){.elite-grid-main{grid-template-columns:1fr}}.elite-activity-card{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--s-6);height:100%}.activity-header{display:flex;justify-content:space-between;align-items:center}.activity-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0;font-family:var(--font-heading)}.activity-list{display:flex;flex-direction:column;gap:var(--s-6)}.activity-item{display:flex;gap:var(--s-4);position:relative}.activity-item:not(:last-child):after{content:"";position:absolute;left:20px;top:48px;bottom:-24px;width:2px;background:var(--border-light)}.activity-user{position:relative;z-index:1}.activity-avatar{width:40px;height:40px;border-radius:12px;border:2px solid var(--bg-card);object-fit:cover}.activity-icon-badge{position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.activity-content{display:flex;flex-direction:column;gap:4px}.activity-text{font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary)}.activity-username{font-weight:700;color:var(--text-primary)}.activity-action{font-weight:600}.activity-entity{color:var(--primary);font-weight:600}.activity-meta{display:flex;align-items:center;gap:6px;font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.meta-dot{opacity:.5}.clickable{cursor:pointer;transition:color var(--transition)}.clickable:hover{color:var(--primary)}.activity-empty{text-align:center;padding:var(--s-8) 0;color:var(--text-muted);font-size:var(--text-sm)}@media(max-width:1024px){.elite-grid-charts{grid-template-columns:1fr}}.package-history-page{display:grid;gap:14px;padding-bottom:24px}.package-history-page--error{gap:16px}.package-history-panel,.package-history-stat{border:1px solid rgba(148,163,184,.16);background:#fffffff5;box-shadow:0 10px 24px #0f172a0d}.package-history-stat__content,.package-history-event__body,.package-history-mini-card,.package-history-summary-fact{display:grid;gap:8px}.package-history-panel__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--premium-indigo-600)}.package-history-stat__note,.package-history-event__subtitle,.package-history-event__description,.package-history-empty__description{margin:0;font-size:13px;line-height:1.5;color:var(--premium-zinc-600)}.package-history-source-group,.package-history-event__labels,.package-history-panel__actions,.package-history-pagination,.package-history-pagination__pages,.package-history-event__meta{display:flex;flex-wrap:wrap;gap:8px}.package-history-pill,.package-history-source-chip,.package-history-metric,.package-history-event__event-key,.package-history-status-badge,.package-history-page-chip{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:30px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.01em;border:1px solid transparent}.package-history-pill--violet,.package-history-source-chip--violet,.package-history-metric--violet,.package-history-page-chip--active{color:#6d28d9;background:#8b5cf61f}.package-history-pill--sky,.package-history-source-chip--sky,.package-history-metric--sky{color:#0369a1;background:#38bdf81f}.package-history-pill--emerald,.package-history-source-chip--emerald,.package-history-metric--emerald{color:#047857;background:#10b9811f}.package-history-pill--amber,.package-history-source-chip--amber,.package-history-metric--amber{color:#b45309;background:#f59e0b24}.package-history-source-chip--slate,.package-history-metric--slate,.package-history-event__event-key,.package-history-page-chip{color:#475569;background:#94a3b81f}.package-history-metric--rose{color:#be123c;background:#f43f5e1f}.package-history-stat__label,.package-history-field__label,.package-history-summary-fact span,.package-history-list-head span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--premium-zinc-500)}.package-history-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.package-history-stat{display:grid;gap:8px;padding:12px;border-radius:14px;border:1px solid rgba(148,163,184,.12);border-left-width:4px;transition:transform var(--transition),box-shadow var(--transition)}.package-history-stat:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0f172a0f}.package-history-stat__top{display:flex;align-items:center;gap:10px}.package-history-stat__numbers{display:flex;flex-direction:column;gap:1px;min-width:0}.package-history-stat__icon,.package-history-event__icon,.package-history-empty__icon{display:inline-flex;align-items:center;justify-content:center;border-radius:14px}.package-history-stat__icon{width:32px;height:32px;flex-shrink:0}.package-history-stat__value,.package-history-event__title,.package-history-kv__row strong,.package-history-mini-card strong{color:var(--premium-zinc-900)}.package-history-stat__value{font-size:22px;font-weight:800;line-height:1.15;letter-spacing:-.02em}.package-history-stat__chips{display:flex;flex-wrap:wrap;gap:4px}.package-history-stat__chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;line-height:1.4;letter-spacing:.01em}.package-history-stat--emerald{border-left-color:#059669;background:linear-gradient(135deg,#10b9810f,#fffffff2)}.package-history-stat--emerald .package-history-stat__icon,.package-history-event__icon--emerald{color:#047857;background:#10b98124}.package-history-stat--emerald .package-history-stat__chip{color:#047857;background:#10b9811f}.package-history-stat--rose{border-left-color:#e11d48;background:linear-gradient(135deg,#f43f5e0f,#fffffff2)}.package-history-stat--rose .package-history-stat__icon,.package-history-event__icon--rose{color:#be123c;background:#f43f5e24}.package-history-stat--rose .package-history-stat__chip{color:#be123c;background:#f43f5e1f}.package-history-stat--amber{border-left-color:#d97706;background:linear-gradient(135deg,#f59e0b0f,#fffffff2)}.package-history-stat--amber .package-history-stat__icon,.package-history-event__icon--amber{color:#b45309;background:#f59e0b24}.package-history-stat--amber .package-history-stat__chip{color:#b45309;background:#f59e0b1f}.package-history-stat--violet{border-left-color:#7c3aed;background:linear-gradient(135deg,#8b5cf60f,#fffffff2)}.package-history-stat--violet .package-history-stat__icon,.package-history-event__icon--violet{color:#6d28d9;background:#8b5cf624}.package-history-stat--violet .package-history-stat__chip{color:#6d28d9;background:#8b5cf61f}.package-history-stat--sky{border-left-color:#0284c7;background:linear-gradient(135deg,#38bdf80f,#fffffff2)}.package-history-stat--sky .package-history-stat__icon,.package-history-event__icon--sky{color:#0369a1;background:#38bdf824}.package-history-stat--sky .package-history-stat__chip{color:#0369a1;background:#38bdf81f}.package-history-event__icon--slate{color:#475569;background:#94a3b824}.package-history-panel{display:grid;gap:14px;padding:16px;border-radius:18px}.package-history-panel__header{display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.package-history-panel__header--compact{align-items:center}.package-history-panel__title{margin:4px 0 0;font-size:18px;line-height:1.25;letter-spacing:-.02em;color:var(--premium-zinc-900)}.package-history-summary-bar,.package-history-timeline,.package-history-mini-grid{display:grid;gap:12px}.package-history-summary-bar{display:flex;flex-wrap:wrap;gap:8px}.package-history-filters-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.package-history-filters-row .package-history-panel__eyebrow{display:inline-flex;align-items:center;white-space:nowrap;padding-bottom:10px}.package-history-primary-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.package-history-field{display:flex;flex-direction:column;gap:4px;flex:1 1 150px;min-width:0}.package-history-field--search{flex:2 1 200px;min-width:0}.package-history-filters-row .package-history-field__label{display:none}.package-history-filters-row .package-history-filter-reset{align-self:flex-end;min-height:42px;flex-shrink:0}.package-history-search,.package-history-input-wrap,.package-history-input,.package-history-select{width:100%;min-height:42px;border-radius:14px;border:1px solid rgba(148,163,184,.22);background:#fff;color:var(--premium-zinc-900);transition:border-color var(--transition),box-shadow var(--transition)}.package-history-search,.package-history-input-wrap{display:flex;align-items:center;gap:10px;padding:0 12px}.package-history-input,.package-history-select{padding:0 12px;font:inherit}.package-history-search svg,.package-history-input-wrap svg{color:var(--premium-zinc-400);flex-shrink:0}.package-history-search .package-history-input,.package-history-input-wrap .package-history-input{min-height:40px;padding:0;border:none;box-shadow:none;background:transparent}.package-history-search:focus-within,.package-history-input-wrap:focus-within,.package-history-input:focus,.package-history-select:focus,.package-history-page-chip:focus{outline:none;border-color:#6366f16b;box-shadow:0 0 0 4px #6366f11a}.package-history-panel--summary{gap:12px}.package-history-summary__back{flex-shrink:0}.package-history-summary-fact{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;border:1px solid rgba(148,163,184,.12);border-left-width:3px;min-width:0;flex:1 1 150px}.package-history-summary-fact__icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;flex-shrink:0}.package-history-summary-fact__text{display:flex;flex-direction:column;gap:1px;min-width:0}.package-history-summary-fact strong{font-size:13px;font-weight:800;line-height:1.35;color:var(--premium-zinc-900);overflow-wrap:anywhere}.package-history-summary-fact--indigo{border-left-color:#6366f1;background:linear-gradient(135deg,#6366f10f,#fffffff2)}.package-history-summary-fact--indigo .package-history-summary-fact__icon{color:#4f46e5;background:#6366f11f}.package-history-summary-fact--violet{border-left-color:#7c3aed;background:linear-gradient(135deg,#8b5cf60f,#fffffff2)}.package-history-summary-fact--violet .package-history-summary-fact__icon{color:#6d28d9;background:#8b5cf61f}.package-history-summary-fact--sky{border-left-color:#0284c7;background:linear-gradient(135deg,#38bdf80f,#fffffff2)}.package-history-summary-fact--sky .package-history-summary-fact__icon{color:#0369a1;background:#38bdf81f}.package-history-summary-fact--amber{border-left-color:#d97706;background:linear-gradient(135deg,#f59e0b0f,#fffffff2)}.package-history-summary-fact--amber .package-history-summary-fact__icon{color:#b45309;background:#f59e0b1f}.package-history-summary-fact--emerald{border-left-color:#059669;background:linear-gradient(135deg,#10b9810f,#fffffff2)}.package-history-summary-fact--emerald .package-history-summary-fact__icon{color:#047857;background:#10b9811f}.package-history-summary-fact--rose{border-left-color:#e11d48;background:linear-gradient(135deg,#f43f5e0f,#fffffff2)}.package-history-summary-fact--rose .package-history-summary-fact__icon{color:#be123c;background:#f43f5e1f}.package-history-kv{display:grid;gap:8px}.package-history-kv--compact{grid-template-columns:repeat(2,minmax(0,1fr))}.package-history-panel--timeline{gap:10px}.package-history-timeline-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.package-history-pagination-summary{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--premium-zinc-600)}.package-history-timeline{display:grid;gap:10px}.package-history-timeline--table{gap:8px}.package-history-list-head{display:grid;grid-template-columns:130px 150px 160px minmax(0,1.25fr) 140px 110px;gap:10px;padding:0 12px}.package-history-event{display:block;padding:10px 12px;border-radius:14px;border:1px solid rgba(148,163,184,.12);border-left-width:3px;box-shadow:0 4px 12px #0f172a08;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.package-history-event:hover{transform:translateY(-1px);box-shadow:0 8px 20px #0f172a0f}.package-history-event--emerald{border-left-color:#059669;background:linear-gradient(135deg,#10b9810d,#fffffff7)}.package-history-event--rose{border-left-color:#e11d48;background:linear-gradient(135deg,#f43f5e0d,#fffffff7)}.package-history-event--amber{border-left-color:#d97706;background:linear-gradient(135deg,#f59e0b0d,#fffffff7)}.package-history-event--violet{border-left-color:#7c3aed;background:linear-gradient(135deg,#8b5cf60d,#fffffff7)}.package-history-event--sky{border-left-color:#0284c7;background:linear-gradient(135deg,#38bdf80d,#fffffff7)}.package-history-event--slate{border-left-color:#64748b;background:linear-gradient(135deg,#94a3b80d,#fffffff7)}.package-history-event__icon{width:38px;height:38px;flex-shrink:0}.package-history-event__icon--inline{width:32px;height:32px;border-radius:12px}.package-history-event__row{display:grid;grid-template-columns:130px 150px 160px minmax(0,1.25fr) 140px 110px;gap:10px;align-items:start}.package-history-event__main{display:grid;gap:6px;min-width:0}.package-history-event__cell{min-width:0}.package-history-event__cell--event,.package-history-event__cell--teacher,.package-history-event__cell--class{display:grid;align-content:start;gap:6px}.package-history-event__labels--event-inline{align-items:center;flex-wrap:nowrap}.package-history-event__value{display:block;min-height:30px;font-size:13px;font-weight:700;line-height:1.45;color:var(--premium-zinc-700)}.package-history-event__title{margin:0;font-size:14px;font-weight:800;line-height:1.35}.package-history-event__subtitle{font-size:12px;font-weight:700;line-height:1.45;color:var(--premium-zinc-700)}.package-history-event__time{display:block;font-size:12px;font-weight:700;color:var(--premium-zinc-700)}.package-history-event__date-label{display:inline-block;margin-top:4px;font-size:11px;font-weight:700;color:var(--premium-zinc-500)}.package-history-event__labels--stacked{display:grid;gap:8px;justify-items:start}.package-history-event__event-key{min-height:24px;padding:4px 8px;font-size:11px;font-weight:700;letter-spacing:.03em}.package-history-event__meta{gap:6px}.package-history-event__meta-item{display:inline-flex;align-items:center;min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.14);background:#f8fafce6;font-size:11px;font-weight:700;color:var(--premium-zinc-600)}.package-history-event__cell--date,.package-history-event__cell--status,.package-history-event__cell--amount{display:grid;align-content:start;gap:6px}.package-history-event__cell--amount{justify-items:end}.package-history-status-badge--emerald{color:#047857;background:#10b98124}.package-history-status-badge--rose{color:#be123c;background:#f43f5e1f}.package-history-status-badge--amber{color:#b45309;background:#f59e0b24}.package-history-status-badge--violet{color:#6d28d9;background:#8b5cf61f}.package-history-status-badge--sky{color:#0369a1;background:#38bdf81f}.package-history-status-badge--slate{color:#475569;background:#94a3b824}.package-history-empty{display:grid;gap:10px;justify-items:center;padding:36px 18px;border-radius:20px;border:1px dashed rgba(148,163,184,.24);background:#f8fafcd1;text-align:center}.package-history-empty__icon{width:52px;height:52px;color:#6d28d9;background:#8b5cf61f}.package-history-empty__title{margin:0;font-size:20px;color:var(--premium-zinc-900)}.package-history-pagination{justify-content:space-between;align-items:center}.package-history-pagination__button{display:inline-flex;align-items:center;gap:8px}.package-history-page-chip{min-width:34px;cursor:pointer}@media(max-width:1280px){.package-history-stats,.package-history-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.package-history-list-head,.package-history-event__row{grid-template-columns:120px 130px 140px minmax(0,1.1fr) 120px 100px}}@media(max-width:1024px){.package-history-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.package-history-filters-row{flex-wrap:wrap}.package-history-filters-row .package-history-field{flex:1 1 45%}.package-history-filters-row .package-history-field--search{flex:1 1 100%}.package-history-list-head{display:none}.package-history-event__row{grid-template-columns:1fr;align-items:flex-start}.package-history-event__cell--amount{justify-items:start}}@media(max-width:768px){.package-history-page{gap:14px}.package-history-panel,.package-history-event{padding:14px;border-radius:16px}.package-history-stat{padding:10px;border-radius:12px}.package-history-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.package-history-mini-grid{grid-template-columns:1fr}.package-history-filters-row{flex-direction:column;align-items:stretch}.package-history-filters-row .package-history-field{flex:1 1 100%}.package-history-event__time{white-space:normal}.package-history-event{grid-template-columns:1fr}.package-history-event__meta{gap:6px}}.teacher-dashboard{display:flex;flex-direction:column;gap:var(--s-8)}.teacher-grid-top{display:grid;grid-template-columns:3fr 1fr;gap:var(--s-6);align-items:start}.class-card{background:var(--bg-card);padding:var(--s-5);border-radius:var(--radius-lg);border:var(--border-premium);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;gap:var(--s-2)}.class-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.class-card.active{border-color:var(--primary);background:var(--primary-bg)}.class-card h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0}.class-subject{font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;gap:var(--s-1)}.class-meta{display:flex;gap:var(--s-4);margin-top:var(--s-2);font-size:var(--text-sm);color:var(--text-secondary)}.class-meta span{display:flex;align-items:center;gap:var(--s-1)}.homework-widget{background:var(--bg-card);border-radius:var(--radius-lg);border:var(--border-premium);box-shadow:var(--shadow-sm);overflow:hidden}.homework-header{padding:var(--s-4) var(--s-4);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.homework-header h3{font-size:var(--text-base);font-weight:700;margin:0}.homework-list{padding:0 var(--s-4)}.homework-item{padding:var(--s-3) 0;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:4px}.homework-item:last-child{border-bottom:none}.homework-title{font-weight:700;font-size:var(--text-sm);color:var(--text-primary)}.homework-meta{font-size:var(--text-xs);color:var(--text-muted)}.attendance-section{margin-top:var(--s-6)}@media(max-width:1024px){.teacher-grid-top{grid-template-columns:1fr}}.student-dashboard{display:flex;flex-direction:column;gap:var(--s-8)}.welcome-banner{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-xl);padding:var(--s-10);color:#fff;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-xl);position:relative;overflow:hidden}.welcome-banner:after{content:"";position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.banner-content h1{font-size:var(--text-3xl);font-weight:800;margin:0;font-family:var(--font-heading)}.banner-content p{font-size:var(--text-lg);opacity:.9;margin-top:var(--s-2)}.banner-stats{display:flex;gap:var(--s-6);z-index:var(--z-base)}.stat-card-glass{background:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--s-4) var(--s-6);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--s-4);border:1px solid rgba(255,255,255,.2);box-shadow:var(--shadow-glass)}.stat-icon.xp{color:#fbbf24}.stat-icon.badge-icon{color:#818cf8}.stat-value{display:block;font-size:var(--text-2xl);font-weight:800}.stat-label{font-size:var(--text-xs);text-transform:uppercase;font-weight:700;opacity:.8}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--s-8)}.dashboard-section{display:flex;flex-direction:column;gap:var(--s-4)}.section-header{display:flex;align-items:center;gap:var(--s-3)}.section-header h2{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin:0;font-family:var(--font-heading)}.exams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s-4)}.exam-card-mini{background:var(--bg-card);padding:var(--s-5);border-radius:var(--radius-lg);border:var(--border-premium);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;text-decoration:none;transition:all var(--transition)}.exam-card-mini:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.subject-tag{font-size:var(--text-xs);font-weight:800;color:var(--primary);text-transform:uppercase;margin-bottom:var(--s-1);display:block}.exam-info h3{margin:0;font-size:var(--text-base);color:var(--text-primary)}.exam-meta{display:flex;gap:var(--s-4);margin-top:var(--s-2);font-size:var(--text-xs);color:var(--text-muted)}.exam-meta span{display:flex;align-items:center;gap:var(--s-1)}.progress-card{background:var(--bg-card);padding:var(--s-5);border-radius:var(--radius-lg);border:var(--border-premium)}.progress-info{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--s-3)}.subject-meta h3{margin:0;font-size:var(--text-lg);font-weight:700}.level-badge{padding:2px 8px;background:var(--primary-bg);color:var(--primary);border-radius:99px;font-size:var(--text-xs);font-weight:700}.xp-details{font-size:var(--text-sm);font-weight:700;color:var(--text-muted)}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s-4)}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--s-4)}.badge-item{display:flex;flex-direction:column;align-items:center;gap:var(--s-2);text-align:center}.badge-circle{width:64px;height:64px;background:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.badge-item:hover .badge-circle{transform:scale(1.1) rotate(5deg);border-color:var(--primary)}.badge-circle img{width:40px;height:40px;object-fit:contain}.badge-name{font-size:var(--text-xs);font-weight:700;color:var(--text-muted)}.action-btn-premium{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-primary);background:var(--bg-card);border:var(--border-premium);transition:all var(--transition)}.action-btn-premium:hover{background:var(--hover-bg);transform:translate(4px);border-color:var(--primary-light)}.action-icon-wrapper{width:40px;height:40px;background:var(--primary-bg);color:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center}.action-icon-wrapper.trophy{background:var(--warning-bg);color:var(--warning)}.action-label-stack{flex:1;display:flex;flex-direction:column}.action-label-stack span{font-weight:700;font-size:var(--text-base)}.action-label-stack small{font-size:var(--text-xs);color:var(--text-muted)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.welcome-banner{flex-direction:column;text-align:center;gap:var(--s-6)}}.uc-page{display:flex;flex-direction:column;gap:20px}.uc-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.uc-title-row{display:flex;align-items:center;gap:14px}.uc-title-icon{color:#ef4444;flex-shrink:0}.uc-title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.uc-subtitle{font-size:14px;color:var(--text-muted);margin:2px 0 0}.uc-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition)}.uc-btn-primary:hover:not(:disabled){background:var(--primary-dark, #4F46E5);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.uc-btn-primary:disabled{opacity:.6;cursor:not-allowed}.uc-btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all var(--transition)}.uc-btn-ghost:hover{background:var(--hover-bg);color:var(--text-primary)}.uc-btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:#ef4444;color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition)}.uc-btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.uc-stats{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.uc-stat-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:99px;font-size:13px;font-weight:500;transition:all var(--transition)}.uc-stat-total{background:var(--bg-tertiary, var(--hover-bg));color:var(--text-secondary);border:1px solid var(--border)}.uc-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.uc-search-wrap{position:relative;flex:1;min-width:200px;max-width:380px}.uc-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.uc-search{width:100%;padding:9px 36px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;box-sizing:border-box;transition:border-color var(--transition)}.uc-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.uc-search::placeholder{color:var(--text-muted)}.uc-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;border-radius:4px;display:flex;align-items:center}.uc-search-clear:hover{color:var(--text-primary)}.uc-select-wrap{position:relative;display:inline-flex;align-items:center}.uc-select-icon{position:absolute;right:10px;pointer-events:none;color:var(--text-muted)}.uc-select{padding:9px 32px 9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:border-color var(--transition)}.uc-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.uc-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.uc-table{width:100%;border-collapse:collapse}.uc-table thead th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg-secondary, var(--hover-bg));border-bottom:1px solid var(--border)}.uc-table tbody td{padding:13px 16px;border-bottom:1px solid var(--border-light, var(--border));font-size:14px;color:var(--text-primary);vertical-align:middle}.uc-table tbody tr:last-child td{border-bottom:none}.uc-table tbody tr{transition:background var(--transition)}.uc-table tbody tr:hover{background:var(--hover-bg)}.uc-row-disabled td{opacity:.45}.uc-user-cell{display:flex;align-items:center;gap:10px}.uc-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--border-light, var(--border))}.uc-fullname{font-weight:600}.uc-username{font-size:13px;color:var(--text-muted);background:var(--hover-bg);padding:2px 7px;border-radius:6px}.uc-contact{display:flex;flex-direction:column;gap:3px;font-size:13px;color:var(--text-muted)}.uc-contact span{display:flex;align-items:center;gap:5px}.uc-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.uc-status-active{background:#10b9811f;color:#10b981}.uc-status-inactive{background:#ef44441a;color:#ef4444}.uc-actions{display:flex;gap:6px;align-items:center}.uc-action-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);cursor:pointer;transition:all var(--transition);color:var(--text-muted)}.uc-action-btn:disabled{opacity:.3;cursor:not-allowed}.uc-action-edit:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-bg, rgba(99,102,241,.08))}.uc-action-disable:hover{color:#ef4444;border-color:#ef4444;background:#ef444414}.uc-action-enable:hover{color:#10b981;border-color:#10b981;background:#10b98114}.uc-loading{display:flex;align-items:center;justify-content:center;min-height:200px}.uc-error{padding:12px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius);color:#ef4444;font-size:14px}.uc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.uc-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;animation:slideUp .2s ease;max-height:90vh;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.uc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.uc-modal-title{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;color:var(--text-primary)}.uc-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;align-items:center;transition:all var(--transition)}.uc-modal-close:hover{color:var(--text-primary);background:var(--hover-bg)}.uc-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.uc-modal-footer{padding:16px 24px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.uc-field{display:flex;flex-direction:column;gap:5px}.uc-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.uc-label{font-size:13px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center}.uc-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary, var(--hover-bg));color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;width:100%;box-sizing:border-box;transition:border-color var(--transition)}.uc-input:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px #6366f11a}.uc-input::placeholder{color:var(--text-muted)}.uc-form-error{padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius);color:#ef4444;font-size:13px}.uc-confirm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:28px;box-shadow:0 20px 60px #0003;animation:slideUp .2s ease}.uc-confirm-modal h3{margin:0 0 12px;font-size:18px;font-weight:700;color:var(--text-primary)}.uc-confirm-modal p{margin:0 0 24px;font-size:14px;color:var(--text-secondary);line-height:1.6}.uc-confirm-actions{display:flex;gap:10px;justify-content:flex-end}@media(max-width:768px){.uc-header{flex-direction:column;align-items:flex-start}.uc-filters{flex-direction:column;align-items:stretch}.uc-search-wrap{max-width:100%}.uc-field-row{grid-template-columns:1fr}.uc-table thead{display:none}.uc-table tbody td{display:block;padding:6px 16px}.uc-table tbody td:before{content:attr(data-label);font-weight:600;font-size:11px;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:2px}.uc-table tbody tr{display:block;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:8px 0}}.package-students-page{display:grid;gap:14px}@media(max-width:1440px),(max-height:900px){.package-students-page{gap:10px}.package-students-shell,.package-students-table-card{padding:12px;border-radius:14px}.package-students-title{font-size:clamp(20px,2.2vw,24px)}.package-students-description{font-size:12px;line-height:1.4}.package-students-chip{padding:5px 9px;font-size:11px}.package-students-stat-card{padding:10px}.package-students-stat-value{margin-top:7px;font-size:18px}.package-students-stat-meta{font-size:11px}.package-students-table-header h2{font-size:18px}.package-students-table-header p{font-size:12px}.package-students-count-pill{font-size:11px;padding:6px 10px}.package-students-search-wrap{width:min(100%,300px)}.package-students-datalist .datalist-table th{padding:9px 12px;font-size:10px}.package-students-datalist .datalist-table td{padding:0 12px;height:46px;font-size:12px}.package-students-datalist .datalist-entity-cell{gap:8px}.package-students-table-metric{font-size:12px}}@media(max-width:1200px){.package-students-overview-grid{grid-template-columns:1fr}}.package-students-shell{padding:16px;border-radius:18px;border:1px solid rgba(148,163,184,.2);background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 2px 12px #0f172a0d}.package-students-shell-topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}.package-students-back-btn{border-radius:999px;padding-inline:12px}.package-students-status-badge{font-size:11px;padding:5px 10px}.package-students-overview-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:12px;align-items:stretch}.package-students-overview-card{border-radius:14px;border:1px solid rgba(148,163,184,.22);background:#ffffffb3;padding:14px}.package-students-eyebrow{margin:0;font-size:11px;font-weight:700;letter-spacing:.07em;color:var(--text-muted);text-transform:uppercase}.package-students-title{margin:6px 0 0;font-size:clamp(22px,2.6vw,28px);line-height:1.1;letter-spacing:-.02em}.package-students-description{margin:8px 0 0;color:var(--text-muted);font-size:13px;line-height:1.45;max-width:72ch}.package-students-chip-row{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}.package-students-chip{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600;color:var(--text-secondary);background:#0f172a0a;border:1px solid rgba(148,163,184,.22)}.package-students-chip.is-active{color:#047857;background:#10b9811a;border-color:#10b98147}.package-students-chip.is-archived{color:#64748b;background:#64748b1f;border-color:#64748b38}.package-students-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.package-students-stat-card{border-radius:12px;border:1px solid rgba(148,163,184,.2);background:#ffffffe6;padding:11px}.package-students-stat-card-primary{background:linear-gradient(180deg,#eff6ffcc,#f8fafcf2)}.package-students-stat-card-info{background:linear-gradient(180deg,#e0f2fea8,#f8fafcf2)}.package-students-stat-card-success{background:linear-gradient(180deg,#dcfce7ad,#f8fafcf2)}.package-students-stat-card-muted{background:linear-gradient(180deg,#f1f5f9cc,#f8fafcf2)}.package-students-stat-head{display:flex;align-items:center;gap:8px}.package-students-stat-icon{width:28px;height:28px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffd9;border:1px solid rgba(148,163,184,.24);color:var(--text-secondary)}.package-students-stat-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.package-students-stat-value{margin-top:9px;font-size:20px;line-height:1.2;font-weight:800;color:var(--text-primary)}.package-students-stat-meta{margin-top:4px;font-size:12px;color:var(--text-muted)}.package-students-table-card{padding:12px;border-radius:16px}.package-students-table-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px;padding:2px 2px 4px}.package-students-table-header h2{margin:0;font-size:20px;line-height:1.15}.package-students-table-header p{margin:4px 0 0;font-size:13px}.package-students-table-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.package-students-count-pill{border-radius:999px;border:1px solid rgba(148,163,184,.24);background:#0f172a0a;color:var(--text-secondary);font-size:12px;font-weight:600;padding:7px 11px;line-height:1}.package-students-search-wrap{position:relative;width:min(100%,340px)}.package-students-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.package-students-search-input{border-radius:999px;padding-left:38px;background:var(--bg-secondary, var(--hover-bg))}.package-students-datalist{border:1px solid var(--border);border-radius:14px;overflow:hidden}.package-students-datalist .datalist-table th{padding:10px 14px;font-size:10.5px;letter-spacing:.075em}.package-students-datalist .datalist-table td{padding:0 14px;height:50px;font-size:13px}.package-students-datalist .datalist-table-actions{padding:6px 10px!important}.package-students-datalist .datalist-entity-cell{gap:10px}.package-students-datalist .datalist-entity-subtitle{font-size:11px}.package-students-datalist .datalist-card{padding:12px}.package-students-datalist .datalist-card-body{gap:8px}.package-students-open-btn{border-radius:999px;min-height:30px;padding:0 10px;font-size:12px}.package-students-table-metric{font-weight:700;font-size:13px;color:var(--text-primary)}@media(max-width:1080px){.package-students-overview-grid{grid-template-columns:1fr}}@media(max-width:768px){.package-students-page{gap:10px}.package-students-shell,.package-students-table-card{padding:12px;border-radius:14px}.package-students-title{font-size:21px}.package-students-description{font-size:12px}.package-students-stats-grid{grid-template-columns:1fr}.package-students-table-header h2{font-size:18px}.package-students-table-controls{width:100%;justify-content:stretch;gap:8px}.package-students-count-pill{width:100%;text-align:center}.package-students-search-wrap{width:100%}.package-students-datalist .datalist-card{padding:10px;border-radius:12px}.package-students-datalist .datalist-card-label{font-size:10px}.package-students-datalist .datalist-card-value{font-size:12px}.package-students-datalist .datalist-card-field{padding:6px 0}.package-students-open-btn{min-height:28px;font-size:11px}}@media(min-width:681px)and (max-width:768px){.package-students-datalist .datalist-table-wrapper{display:block}.package-students-datalist .datalist-cards{display:none}}[data-theme=dark] .package-students-shell{border-color:#94a3b833;background:linear-gradient(180deg,#0f172ae0,#0f172ab8)}[data-theme=dark] .package-students-overview-card,[data-theme=dark] .package-students-stat-card{background:#02061770;border-color:#94a3b83d}[data-theme=dark] .package-students-chip,[data-theme=dark] .package-students-count-pill{background:#94a3b824;border-color:#94a3b83d}[data-theme=dark] .package-students-stat-icon{background:#0f172aa6;border-color:#94a3b84d}[data-theme=dark] .package-students-datalist{border-color:#94a3b833}.contract-standalone-screen{min-height:100vh;padding:24px 16px 40px;background:linear-gradient(180deg,#f8fafc,#eef2ff)}.contract-print-page{width:min(210mm,100%);margin:0 auto;padding:0;display:flex;flex-direction:column;align-items:center;gap:14px}.contract-print-toolbar{width:100%;max-width:none;display:flex;justify-content:space-between;gap:10px}.contract-a4-sheet{width:100%;min-height:297mm;background:linear-gradient(180deg,#fff,#fcfdff);color:#111827;box-shadow:0 18px 40px #0f172a24;border:1px solid rgba(203,213,225,.9);border-radius:14px;padding:12mm 11mm 10mm;box-sizing:border-box;display:flex;flex-direction:column;gap:9px}.contract-header{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(180px,1fr) minmax(0,.9fr);align-items:center;gap:12px;border-bottom:1px solid #e2e8f0;padding-bottom:10px}.contract-brand{display:flex;align-items:center;gap:10px;min-width:0}.contract-brand-mark{width:58px;height:58px;border-radius:16px;overflow:hidden;flex:0 0 auto;border:1px solid #dbe3f1;background:linear-gradient(135deg,#eef4ff,#dbeafe);display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px #fffc}.contract-brand-mark img{width:100%;height:100%;object-fit:cover}.contract-brand-fallback{font-size:20px;font-weight:800;letter-spacing:.1em;color:#1d4ed8}.contract-brand-copy{min-width:0;display:grid;gap:2px}.contract-brand-label{font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:#64748b}.contract-brand-copy h2{margin:0;font-size:18px;line-height:1.15}.contract-brand-copy p{margin:0;font-size:12px;color:#475569}.contract-brand-copy strong{color:#0f172a}.contract-title-block{text-align:center;display:grid;gap:2px}.contract-title-overline{font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:#64748b}.contract-title-block h1{margin:0;font-size:28px;font-weight:800;letter-spacing:.16em}.contract-title-block p{margin:0;font-size:12px;font-weight:600;color:#334155}.contract-header-meta{display:grid;gap:6px}.contract-meta-pill{padding:8px 10px;border-radius:12px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fbfdff,#f8fafc);display:grid;gap:2px}.contract-meta-pill span{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:#64748b}.contract-meta-pill strong{font-size:13px;color:#0f172a}.contract-summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.contract-summary-item{padding:8px 10px;border-radius:12px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff,#f8fafc);display:grid;gap:3px}.contract-summary-item span{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:#64748b}.contract-summary-item strong{font-size:12.5px;line-height:1.3;color:#0f172a;word-break:break-word}.contract-compact-section{display:grid;gap:8px}.contract-summary-strip--student{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.contract-summary-item--student{min-height:58px}.contract-summary-item--span-2{grid-column:span 2}.contract-panel,.contract-section{padding:9px 10px;border-radius:14px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a08;page-break-inside:avoid}.contract-panel-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.contract-panel-index{width:26px;height:26px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;background:#eff6ff;color:#1d4ed8;font-size:11px;font-weight:800}.contract-panel-header h2{margin:0;font-size:13px;letter-spacing:.04em;text-transform:uppercase}.contract-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px 10px}.contract-field{display:grid;gap:1px;min-width:0}.contract-field span{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.contract-field strong{font-size:12px;line-height:1.35;font-weight:600;color:#0f172a;word-break:break-word}.contract-rules-list{margin:0;padding-left:20px;display:grid;gap:8px;font-size:14px;line-height:1.5}.contract-rules-html{font-size:11.25px;line-height:1.4;color:#0f172a}.contract-rules-html p{margin:0 0 6px}.contract-rules-html h1,.contract-rules-html h2,.contract-rules-html h3{margin:0 0 8px;color:#0f172a;line-height:1.25}.contract-rules-html h1{font-size:16px}.contract-rules-html h2{font-size:14px}.contract-rules-html h3{font-size:12.5px}.contract-rules-html ul,.contract-rules-html ol{margin:0 0 6px;padding-left:16px}.contract-rules-html li{margin:0 0 3px}.contract-rules-html a{color:#2563eb;text-decoration:underline}.contract-rules-html blockquote{margin:0 0 8px;padding:8px 10px;border-left:3px solid #bfdbfe;background:#f8fbff;color:#334155}.contract-rules-html .ql-align-center{text-align:center}.contract-rules-html .ql-align-right{text-align:right}.contract-rules-html .ql-align-justify{text-align:justify}.contract-rules-html .ql-size-small{font-size:.875em}.contract-rules-html .ql-size-large{font-size:1.35em}.contract-rules-html .ql-size-huge{font-size:1.75em}.contract-editor-modal-body{display:grid;gap:10px}.contract-editor-quill .ql-toolbar{border-top-left-radius:10px;border-top-right-radius:10px}.contract-editor-quill .ql-editor{min-height:240px;font-size:14px}.contract-editor-quill .ql-container{min-height:300px;border-bottom-left-radius:10px;border-bottom-right-radius:10px}.contract-empty-rules{margin:0;font-size:11.5px;color:#64748b}.contract-signatures{margin-top:auto;padding-top:10px;border-top:1px solid #e2e8f0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;page-break-inside:avoid}.contract-sign-block{display:grid;gap:6px;font-size:11px;color:#475569}.contract-sign-line{width:100%;border-bottom:1px solid #0f172a;height:28px}.contract-print-page--compact .contract-a4-sheet{padding:9mm 9mm 8mm;gap:7px}.contract-print-page--compact .contract-header{gap:10px;padding-bottom:8px}.contract-print-page--compact .contract-brand-mark{width:50px;height:50px;border-radius:14px}.contract-print-page--compact .contract-brand-copy h2{font-size:16px}.contract-print-page--compact .contract-brand-copy p,.contract-print-page--compact .contract-title-block p,.contract-print-page--compact .contract-meta-pill strong,.contract-print-page--compact .contract-summary-item strong,.contract-print-page--compact .contract-rules-html,.contract-print-page--compact .contract-sign-block{font-size:11px}.contract-print-page--compact .contract-title-block h1{font-size:24px}.contract-print-page--compact .contract-summary-strip{gap:6px}.contract-print-page--compact .contract-summary-item,.contract-print-page--compact .contract-panel,.contract-print-page--compact .contract-section{padding:7px 8px}.contract-print-page--compact .contract-summary-item--student{min-height:44px}.contract-print-page--compact .contract-summary-item span,.contract-print-page--compact .contract-brand-label,.contract-print-page--compact .contract-title-overline,.contract-print-page--compact .contract-meta-pill span,.contract-print-page--compact .contract-panel-header h2,.contract-print-page--compact .contract-panel-index{font-size:9px}.contract-print-page--compact .contract-panel-header{margin-bottom:6px}.contract-print-page--compact .contract-panel-index{width:22px;height:22px}.contract-print-page--compact .contract-rules-html{line-height:1.3}.contract-print-page--compact .contract-rules-html p,.contract-print-page--compact .contract-rules-html ul,.contract-print-page--compact .contract-rules-html ol,.contract-print-page--compact .contract-rules-html blockquote{margin-bottom:4px}.contract-print-page--compact .contract-rules-html ul,.contract-print-page--compact .contract-rules-html ol{padding-left:14px}.contract-print-page--compact .contract-signatures{padding-top:8px;gap:12px}.contract-print-page--compact .contract-sign-line{height:20px}@media screen and (max-width:900px){.contract-a4-sheet,.contract-print-toolbar{width:100%}.contract-header,.contract-summary-strip,.contract-grid,.contract-signatures{grid-template-columns:1fr}.contract-summary-item--span-2{grid-column:span 1}.contract-header,.contract-title-block{text-align:left}}@media print{@page{size:A4;margin:0}html,body{margin:0!important;padding:0!important;width:210mm;min-height:297mm;background:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}body{overflow:visible!important}.no-print,.header,.sidebar,.main-content>.header{display:none!important}body>*{visibility:hidden}.contract-standalone-screen,.contract-standalone-screen *{visibility:visible}.contract-standalone-screen{position:absolute;top:0;right:0;bottom:0;left:0;min-height:auto!important}.app-layout,.main-content,.page-content,.contract-standalone-screen,.contract-print-page{display:block!important;margin:0!important;padding:0!important;background:#fff!important}.contract-print-page{width:210mm!important;margin:0 auto!important;gap:0!important;display:block!important}.contract-a4-sheet,.contract-panel,.contract-section,.contract-summary-item,.contract-meta-pill{box-shadow:none!important}.contract-a4-sheet{width:210mm!important;min-height:297mm!important;margin:0!important;padding:12mm 11mm 10mm!important;box-shadow:none!important;background:linear-gradient(180deg,#fff,#fcfdff)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.contract-header{display:grid!important;grid-template-columns:minmax(0,1.25fr) minmax(180px,1fr) minmax(0,.9fr)!important;align-items:center!important;gap:12px!important;text-align:initial!important}.contract-title-block{text-align:center!important}.contract-summary-strip{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:8px!important}.contract-summary-strip--student{grid-template-columns:repeat(4,minmax(0,1fr))!important}.contract-summary-item--span-2{grid-column:span 2!important}.contract-signatures{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:16px!important}.contract-header,.contract-summary-strip,.contract-compact-section,.contract-signatures{break-inside:avoid-page;page-break-inside:avoid}.contract-section--rules,.contract-section--rules .contract-rules-html,.contract-section--rules .contract-rules-html>*{break-inside:auto!important;page-break-inside:auto!important}}.profile-role{font-size:13px;color:var(--text-muted);text-transform:capitalize}.attendance-grid{display:grid;gap:10px}.attendance-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius)}.attendance-student{font-weight:500;font-size:15px}.attendance-actions{display:flex;gap:6px}.attendance-btn{padding:6px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:2px solid transparent;cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}.attendance-btn.join{background:var(--success-bg);color:var(--success);border-color:var(--success)}.attendance-btn.join.active,.attendance-btn.join:hover{background:var(--success);color:#fff}.attendance-btn.absence{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.attendance-btn.absence.active,.attendance-btn.absence:hover{background:var(--danger);color:#fff}.attendance-btn.excuse{background:var(--warning-bg);color:var(--warning);border-color:var(--warning)}.attendance-btn.excuse.active,.attendance-btn.excuse:hover{background:var(--warning);color:#fff}.chart-container{width:100%;height:300px}.warning-list{display:flex;flex-direction:column;gap:8px}.warning-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px}.warning-item.debt{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2)}.warning-item.lesson{background:var(--warning-bg);border:1px solid rgba(245,158,11,.2)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:24px auto}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:16px}.weekday-picker{display:flex;gap:6px}.weekday-btn{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}.weekday-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pipeline-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.pipeline-btn{padding:6px 14px;border-radius:99px;font-size:14px;font-weight:500;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}.pipeline-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pipeline-btn:hover:not(.active){background:var(--hover-bg)}@media(max-width:768px){.sidebar{transform:translate(-100%);background:#fff!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:90}.sidebar-overlay.open{display:block;animation:fadeIn .2s ease}.main-content{margin-left:0}.hamburger{display:flex;align-items:center;justify-content:center}.header{padding:0 20px;height:64px}.header-title{font-size:18px}.page-content{padding:20px}.stats-grid{grid-template-columns:1fr;gap:16px}.grid-2,.grid-3,.grid-4,.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.toolbar{flex-direction:column;align-items:stretch;width:100%}.modal{max-height:95vh;margin:16px;width:calc(100% - 32px)}.login-card{padding:28px 20px;margin:16px}}@media(max-width:480px){.attendance-row{flex-direction:column;gap:8px;align-items:stretch}.attendance-actions{justify-content:stretch}.attendance-btn{flex:1;text-align:center}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.gap-1{gap:8px}.gap-2{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.w-full{width:100%}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-icon{width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition)}.btn-icon:hover{background:var(--hover-bg);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:var(--text-sm)}.form-checkbox{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition)}.form-checkbox:has(input:checked){background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.form-checkbox input[type=checkbox]{margin:0}.actions-row{display:flex;align-items:center;gap:6px}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;border-radius:99px;background:var(--primary-bg);color:var(--primary);font-size:14px;font-weight:600;margin-left:8px;vertical-align:middle}.btn[title]{position:relative}.btn[title]:hover:after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:4px 10px;border-radius:6px;background:var(--text-primary);color:var(--bg-card);font-size:13px;font-weight:500;white-space:nowrap;pointer-events:none;z-index:200;opacity:0;animation:tooltipIn .15s ease forwards}@keyframes tooltipIn{to{opacity:1}}.modern-list{display:flex;flex-direction:column;gap:16px}.modern-list-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:20px 28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition);cursor:pointer}.modern-list-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-light)}.modern-list-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;background:var(--bg-tertiary, #f0f4f8);border:2px solid var(--border-light);box-shadow:var(--shadow-sm)}.modern-list-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;align-items:center}.modern-list-info{display:flex;flex-direction:column;gap:4px}.modern-list-name{font-family:var(--font-heading);font-size:19px;font-weight:700;color:var(--text-primary)}.modern-list-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.modern-list-actions{display:flex;gap:10px}@media(max-width:768px){.modern-list-item{grid-template-columns:1fr;padding:24px;gap:16px;text-align:center}.modern-list-avatar{margin:0 auto;width:80px;height:80px}.modern-list-content{grid-template-columns:1fr;gap:16px}.modern-list-badge-row{justify-content:center}.modern-list-actions{justify-content:center;border-top:1px solid var(--border-light);padding-top:16px;width:100%}}.card-2025{background:var(--bg-card);border-radius:20px;box-shadow:0 4px 20px -5px #0000000d,inset 0 1px #ffffffb3;border:1px solid var(--border);transition:all .3s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}[data-theme=dark] .card-2025{box-shadow:0 10px 40px -10px #0000004d,inset 0 1px #ffffff0d}.card-2025:hover{transform:translateY(-4px);box-shadow:0 12px 30px -8px #0000001a,inset 0 1px #ffffffb3;border-color:#6366f180}[data-theme=dark] .card-2025:hover{box-shadow:0 20px 50px -10px #0006,inset 0 1px #ffffff1a;border-color:#6366f166}.glass-icon-wrapper{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f11a,#6366f105);border:1px solid rgba(99,102,241,.2);box-shadow:inset 0 1px #ffffff80,0 4px 10px -2px #6366f126;color:var(--primary);flex-shrink:0}[data-theme=dark] .glass-icon-wrapper{background:linear-gradient(135deg,#6366f133,#6366f10d);box-shadow:inset 0 1px #ffffff1a,0 4px 10px -2px #6366f14d}.floating-filters{position:sticky;top:60px;z-index:40;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffb3;border-radius:16px;border:1px solid var(--border);box-shadow:0 8px 30px -10px #0000000f;padding:16px;margin-bottom:24px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}[data-theme=dark] .floating-filters{background:#141622bf}.floating-filters .form-input,.floating-filters .form-select{border-radius:12px;background:var(--bg-card);box-shadow:inset 0 1px 2px #00000005}.capacity-progress-bg{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:6px;position:relative;box-shadow:inset 0 1px 2px #0000000d}.capacity-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-light),var(--primary));border-radius:3px;transition:width .5s ease-out}.capacity-progress-fill.full{background:linear-gradient(90deg,var(--warning),var(--danger))}.floating-actions-group{opacity:0;transform:translate(10px);transition:all .2s ease;display:flex;gap:4px}.card-2025:hover .floating-actions-group{opacity:1;transform:translate(0)}@media(max-width:768px){.floating-actions-group{opacity:1;transform:none}}.subjects-alert{margin:0 16px 12px;padding:10px 12px;border-radius:12px;border:1px solid rgba(239,68,68,.25);background:#ef444414;color:#b91c1c;font-weight:500;font-size:14px}.subjects-mobile-list{display:none}.subjects-overview-card{position:relative;overflow:hidden;border:1px solid rgba(148,163,184,.16);background:radial-gradient(circle at top right,rgba(168,85,247,.12),transparent 24%),radial-gradient(circle at left center,rgba(59,130,246,.08),transparent 18%),linear-gradient(180deg,#fffffffc,#f8fafcf5)}.subjects-overview-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(120deg,rgba(255,255,255,.34),transparent 34%,transparent 68%,rgba(255,255,255,.12))}.subjects-overview-card>*{position:relative;z-index:1}.subjects-table .subjects-table__row td{vertical-align:middle}.subjects-name-cell{display:flex;align-items:center;gap:14px;min-width:220px}.subjects-avatar{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden;color:#fff;background:var(--subject-gradient, linear-gradient(135deg, #6366f1, #ec4899));box-shadow:0 16px 28px color-mix(in srgb,var(--subject-accent, #6366f1),transparent 74%)}.subjects-avatar:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.28),transparent 60%)}.subjects-avatar svg{position:relative;z-index:1}.subjects-name-title,.subjects-mobile-card__title{font-size:15px;font-weight:700;color:#0f172a}.subjects-description-cell,.subjects-mobile-card__desc{font-size:13px;line-height:1.55;color:#64748b}.subjects-description-cell{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;max-width:46ch}.subjects-mobile-card--enhanced{position:relative;overflow:hidden;border-radius:20px;border:1px solid var(--subject-border, rgba(129, 140, 248, .24));background:var(--subject-soft, linear-gradient(135deg, rgba(99, 102, 241, .08), rgba(236, 72, 153, .12)));box-shadow:0 18px 34px #0f172a0f}.subjects-mobile-card--enhanced:before{content:"";position:absolute;right:-26px;bottom:-34px;width:120px;height:120px;pointer-events:none;background:radial-gradient(circle,color-mix(in srgb,var(--subject-accent, #6366f1),transparent 76%),transparent 70%)}.subjects-mobile-card__identity{display:flex;align-items:center;gap:12px;min-width:0}.subjects-mobile-card__title{font-size:16px}.subjects-mobile-card__desc{margin-bottom:12px}.subjects-mobile-card--enhanced .subjects-mobile-actions{padding-top:12px;border-top:1px solid rgba(255,255,255,.44)}.subjects-mobile-card{border:1px solid var(--border);border-radius:16px;background:var(--bg-card);padding:14px;box-shadow:var(--shadow-sm)}.subjects-mobile-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.subjects-mobile-desc{font-size:14px;line-height:1.5;margin-bottom:12px}.subjects-mobile-actions{display:flex;gap:8px}.subjects-mobile-actions .btn{flex:1;justify-content:center}@media(max-width:768px){.subjects-table-desktop{display:none}.subjects-name-cell{min-width:0}.subjects-mobile-list{display:grid;gap:10px;padding:12px}}[data-theme=dark] .subjects-overview-card{border-color:#94a3b829;background:radial-gradient(circle at top right,rgba(168,85,247,.16),transparent 24%),radial-gradient(circle at left center,rgba(59,130,246,.12),transparent 18%),linear-gradient(180deg,#0f172aeb,#0f172ad6)}[data-theme=dark] .subjects-name-title,[data-theme=dark] .subjects-mobile-card__title{color:#e2e8f0}[data-theme=dark] .subjects-description-cell,[data-theme=dark] .subjects-mobile-card__desc{color:#94a3b8}[data-theme=dark] .subjects-mobile-card--enhanced{box-shadow:0 18px 34px #02061757}[data-theme=dark] .subjects-mobile-card--enhanced .subjects-mobile-actions{border-top-color:#94a3b829}.teachers-list-item{border-radius:18px}.teachers-actions{flex-wrap:wrap}@media(max-width:768px){.teachers-list-item{padding:14px;gap:12px;border-radius:16px}.teachers-list-item .modern-list-content{gap:10px;text-align:left}.teachers-list-item .modern-list-name{font-size:17px}.teachers-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid var(--border-light);padding-top:10px}.teachers-actions .btn{width:100%;justify-content:center;min-height:40px}}@media(max-width:420px){.teachers-actions{grid-template-columns:1fr}}@media(max-width:768px){.classes-grid{grid-template-columns:1fr!important;gap:10px!important}.classes-card{border-radius:14px!important;padding:10px!important}.classes-card-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:6px!important}.classes-card-actions .btn{min-height:36px;font-size:.8rem!important;padding:6px!important}.classes-schedule-row{flex-wrap:wrap;gap:8px!important}.classes-schedule-row>div:first-child{width:100%!important}.classes-schedule-row .form-input{flex:1;min-width:120px}}@media(max-width:420px){.classes-card-actions{grid-template-columns:1fr}}.packages-overview-card{position:relative;overflow:hidden;border:1px solid rgba(148,163,184,.16);background:radial-gradient(circle at top right,rgba(129,140,248,.12),transparent 24%),radial-gradient(circle at left center,rgba(6,182,212,.08),transparent 18%),linear-gradient(180deg,#fffffffc,#f8fafcf5)}.packages-overview-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(120deg,rgba(255,255,255,.34),transparent 34%,transparent 68%,rgba(255,255,255,.12))}.packages-overview-card>*{position:relative;z-index:1}.packages-table .packages-table__row td{vertical-align:middle}.packages-name-cell{display:flex;align-items:center;gap:14px;min-width:240px}.packages-avatar{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden;color:#fff;background:var(--package-gradient, linear-gradient(135deg, #6366f1, #ec4899));box-shadow:0 16px 28px color-mix(in srgb,var(--package-accent, #6366f1),transparent 74%)}.packages-avatar:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.28),transparent 60%)}.packages-avatar svg{position:relative;z-index:1}.packages-name-copy{min-width:0}.packages-name-title,.packages-mobile-card__title{font-size:15px;font-weight:700;color:#0f172a}.packages-inline-chip-row{display:flex;flex-wrap:wrap;gap:8px}.packages-inline-chip,.packages-metric-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.packages-inline-chip{color:var(--package-accent, #4f46e5);border:1px solid color-mix(in srgb,var(--package-accent, #6366f1),transparent 74%);background:color-mix(in srgb,var(--package-accent, #6366f1),transparent 91%)}.packages-inline-chip--muted{color:#475569;border-color:#94a3b838;background:#94a3b81a}.packages-metric-pill{justify-content:center;border:1px solid rgba(148,163,184,.18);background:#f8fafce0;color:#0f172a}.packages-metric-pill svg{flex-shrink:0}.packages-metric-pill--lessons{color:#4338ca;border-color:#818cf83d;background:linear-gradient(135deg,#eef2ffeb,#f5f3fffa)}.packages-metric-pill--price{color:#047857;border-color:#10b9813d;background:linear-gradient(135deg,#ecfdf5eb,#f0fdfafa)}.packages-metric-pill--duration{color:#b45309;border-color:#f59e0b3d;background:linear-gradient(135deg,#fff7edf0,#fffbebfa)}.packages-mobile-card{position:relative;overflow:hidden;border-radius:20px;border:1px solid var(--package-border, rgba(129, 140, 248, .24));background:var(--package-soft, linear-gradient(135deg, rgba(99, 102, 241, .08), rgba(236, 72, 153, .12)));box-shadow:0 18px 34px #0f172a0f}.packages-mobile-card:before{content:"";position:absolute;right:-26px;bottom:-34px;width:120px;height:120px;pointer-events:none;background:radial-gradient(circle,color-mix(in srgb,var(--package-accent, #6366f1),transparent 76%),transparent 70%)}.packages-mobile-card .packages-avatar{width:46px;height:46px;border-radius:16px}.packages-mobile-card__identity{display:flex;align-items:center;gap:12px;min-width:0}.packages-mobile-card__meta{min-width:0}.packages-mobile-card__title{font-size:16px}.packages-mobile-card__metrics{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.packages-mobile-card .subjects-mobile-actions{padding-top:12px;border-top:1px solid rgba(255,255,255,.44)}.packages-mobile-list{display:none}@media(max-width:768px){.packages-table-desktop{display:none}.packages-mobile-list{display:grid;gap:10px;padding:12px}.packages-name-cell{min-width:0}.packages-mobile-card__metrics .packages-metric-pill{width:calc(50% - 4px)}.packages-mobile-card__metrics .packages-metric-pill--price{width:100%}}@media(max-width:420px){.packages-mobile-card .subjects-mobile-actions{display:grid;grid-template-columns:1fr}.packages-mobile-card__metrics .packages-metric-pill{width:100%}}[data-theme=dark] .packages-overview-card{border-color:#94a3b829;background:radial-gradient(circle at top right,rgba(99,102,241,.16),transparent 24%),radial-gradient(circle at left center,rgba(6,182,212,.12),transparent 18%),linear-gradient(180deg,#0f172aeb,#0f172ad6)}[data-theme=dark] .packages-name-title,[data-theme=dark] .packages-mobile-card__title{color:#e2e8f0}[data-theme=dark] .packages-inline-chip--muted{color:#cbd5e1;border-color:#94a3b82e;background:#94a3b81f}[data-theme=dark] .packages-metric-pill{color:#e2e8f0;border-color:#94a3b82e;background:#0f172a9e}[data-theme=dark] .packages-metric-pill--lessons{color:#c4b5fd}[data-theme=dark] .packages-metric-pill--price{color:#6ee7b7}[data-theme=dark] .packages-metric-pill--duration{color:#fbbf24}[data-theme=dark] .packages-mobile-card{box-shadow:0 18px 34px #02061757}[data-theme=dark] .packages-mobile-card .subjects-mobile-actions{border-top-color:#94a3b829}@media(max-width:1440px),(max-height:900px){.subjects-mobile-list,.packages-mobile-list{gap:8px;padding:10px}.subjects-mobile-card,.subjects-mobile-card--enhanced,.packages-mobile-card{border-radius:14px;padding:12px}.subjects-mobile-card__title,.packages-mobile-card__title,.subjects-name-title,.packages-name-title,.students-list-item .modern-list-name,.teachers-list-item .modern-list-name{font-size:14px}.subjects-mobile-card__desc,.subjects-description-cell,.students-list-item .modern-list-sub,.teachers-list-item .modern-list-sub{font-size:12px;line-height:1.4}.packages-inline-chip,.packages-metric-pill,.subjects-mobile-actions .btn,.students-actions .btn,.teachers-actions .btn{min-height:34px;font-size:12px}}.students-list-item{border-radius:18px}.students-actions{flex-wrap:wrap}@media(max-width:768px){.students-list-item{padding:14px;gap:12px;border-radius:16px}.students-list-item .modern-list-content{grid-template-columns:1fr;gap:10px;text-align:left}.students-list-item .modern-list-name{font-size:17px}.students-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid var(--border-light);padding-top:10px}.students-actions .btn{width:100%;justify-content:center;min-height:40px;font-size:.85rem}.students-credentials-modal,.students-info-modal{width:calc(100% - 20px)!important;max-width:none!important;max-height:92vh!important;border-radius:14px!important;margin:10px!important}}@media(max-width:420px){.students-actions{grid-template-columns:1fr}}.students-list-item{cursor:pointer}.student-info-popup{display:flex;flex-direction:column;gap:12px;margin:0 24px;width:calc(100% - 48px);max-width:100%;box-sizing:border-box}.student-info-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%}.student-info-summary-card{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--bg-card);box-sizing:border-box;min-width:0}.student-info-section-title{margin:4px 24px;font-size:1rem}.student-info-enrollment-list,.student-info-payment-list{display:flex;flex-direction:column;gap:8px;width:100%;min-width:0}.student-info-enrollment-card,.student-info-payment-row{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--bg-card);box-sizing:border-box;width:100%;min-width:0;overflow:hidden}.student-info-enrollment-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;min-width:0}.student-info-enrollment-head .font-semibold{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.student-info-metrics-row{margin-top:8px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;font-size:.85rem;width:100%}.student-info-metrics-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.student-info-payment-row{display:flex;justify-content:space-between;align-items:center;gap:10px;min-width:0}.student-info-payment-row>div{min-width:0;overflow:hidden}.student-info-enrollment-head-btn{width:100%;background:transparent;border:0;padding:0;text-align:left;cursor:pointer;min-width:0}.student-info-attendance-list{margin-top:8px;display:flex;flex-direction:column;gap:6px;width:100%;min-width:0}.student-info-attendance-row{display:flex;justify-content:space-between;align-items:center;padding:8px;border-radius:8px;background:var(--bg-secondary);font-size:.85rem;min-width:0}@media(max-width:768px){.student-info-popup{margin:0 20px;width:calc(100% - 40px)}.student-info-section-title{margin:4px 20px}.student-info-summary-grid{grid-template-columns:1fr}.student-info-metrics-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:480px){.student-info-popup{margin:0 16px;width:calc(100% - 32px)}.student-info-section-title{margin:4px 16px}.student-info-metrics-row{grid-template-columns:1fr 1fr;gap:4px;font-size:.8rem}.student-info-enrollment-card,.student-info-payment-row{padding:8px}}.enrollments-list-item{border-radius:18px}.enrollments-actions{flex-wrap:wrap}.enrollments-drawer-content,.side-drawer .tab-content{margin:0 24px;width:calc(100% - 48px);max-width:100%;box-sizing:border-box}.side-drawer .table-wrapper-sm{width:100%;overflow-x:auto;min-width:0}.side-drawer .data-table{width:100%;min-width:0;border-collapse:collapse}.side-drawer .data-table th,.side-drawer .data-table td{padding:10px 12px;text-align:left;white-space:nowrap}.side-drawer .data-table th:first-child,.side-drawer .data-table td:first-child{padding-left:0}.side-drawer .data-table th:last-child,.side-drawer .data-table td:last-child{padding-right:0}.side-drawer .mb-6{margin-bottom:24px}.side-drawer .mb-3{margin-bottom:12px}.side-drawer h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.side-drawer .flex{display:flex}.side-drawer .items-center{align-items:center}.side-drawer .gap-2{gap:8px}@media(max-width:768px){.enrollments-list-item{padding:14px;gap:12px;border-radius:16px}.enrollments-list-item .modern-list-content{grid-template-columns:1fr;gap:10px}.enrollments-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid var(--border-light);padding-top:10px}.enrollments-actions .btn{width:100%;min-height:40px;justify-content:center;font-size:.84rem}.enrollments-actions .btn svg{width:14px;height:14px}.enrollments-drawer-content,.side-drawer .tab-content{margin:0 20px;width:calc(100% - 40px)}.side-drawer .data-table th,.side-drawer .data-table td{padding:8px 10px;font-size:.875rem}}@media(max-width:420px){.enrollments-actions{grid-template-columns:1fr}.enrollments-drawer-content,.side-drawer .tab-content{margin:0 16px;width:calc(100% - 32px)}.side-drawer .data-table th,.side-drawer .data-table td{padding:6px 8px;font-size:.8rem}}.enrollments-table-wrapper{display:block}.enrollments-mobile-list{display:none}.enrollments-table .enrollments-table-student{display:flex;align-items:center;gap:12px}.enrollments-table .enrollments-table-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border-light);flex-shrink:0}.enrollments-table .enrollments-table-badges{display:flex;flex-wrap:wrap;gap:6px}.enrollments-table .enrollments-table-actions{display:flex;gap:6px;flex-wrap:wrap}.enrollments-table .enrollments-table-actions .btn{padding:6px 10px}@media(max-width:768px){.enrollments-table-wrapper{display:none}.enrollments-mobile-list{display:flex}}@media(min-width:769px)and (max-width:1024px){.enrollments-table .enrollments-table-student{gap:8px}.enrollments-table .enrollments-table-avatar{width:32px;height:32px}.enrollments-table th,.enrollments-table td{padding:12px 14px;font-size:.9rem}.enrollments-table .enrollments-table-actions .btn{padding:5px 8px;font-size:.85rem}.enrollments-table .badge{padding:2px 8px;font-size:.75rem}}@media(max-width:768px){.hierarchy-page-v2 .page-header-premium{flex-direction:column;align-items:flex-start;gap:10px}.hierarchy-page-v2 .header-actions{width:100%;display:grid!important;grid-template-columns:1fr;gap:8px}.hierarchy-page-v2 .main-layout{display:block!important}.hierarchy-page-v2 .subject-sidebar{width:100%!important;margin-bottom:10px;max-height:220px;overflow:auto}.hierarchy-page-v2 .levels-grid{grid-template-columns:1fr!important;gap:10px!important}.hierarchy-page-v2 .level-card,.hierarchy-page-v2 .unit-card,.hierarchy-page-v2 .topic-item{border-radius:14px!important}.ai-modal-container{width:calc(100% - 16px)!important;margin:8px!important;max-height:94vh!important;border-radius:14px!important}}@media(max-width:768px){.questions-page{padding:12px!important}.questions-page .q-card-header{flex-wrap:wrap;align-items:flex-start!important}.questions-page .q-actions{width:100%;justify-content:flex-end}.questions-page .q-content-body{font-size:1rem!important}.questions-page .floating-filters{padding:12px!important}.questions-page .floating-filters .form-select,.questions-page .floating-filters .btn{width:100%!important;min-width:0!important}.questions-page .ai-grid{grid-template-columns:1fr!important}.questions-page .ai-modal-container{border-radius:14px!important;max-height:94vh!important}}@media(max-width:768px){.exams-page .page-header{flex-direction:column;align-items:flex-start!important;gap:10px}.exams-page [style*="repeat(auto-fill, minmax(300px, 1fr))"]{grid-template-columns:1fr!important}.exams-page [style*="width: 'fit-content'"]{width:100%!important;overflow-x:auto}}@media(max-width:768px){.ai-modal-overlay{align-items:center!important;padding:10px!important}.ai-modal-container{width:100%!important;max-width:100%!important;max-height:92vh!important;border-radius:16px!important;margin:0!important}.side-drawer{width:100%!important;max-width:100%!important;border-radius:16px 16px 0 0}.side-drawer .drawer-header{padding:12px 14px!important}.side-drawer .drawer-body{padding:14px 0!important}.side-drawer .drawer-info-bar,.side-drawer .drawer-section>.description-content,.side-drawer .drawer-section>.resources-grid,.side-drawer .drawer-section>h3:not(.discussion-section-wrapper h3){margin:0 14px!important}}@media(max-width:768px){.attendance-page{padding-bottom:90px!important}.attendance-page>div:first-child{gap:12px!important}.attendance-page [style*="justify-content: space-between"][style*="margin-bottom: '32px'"]{flex-direction:column!important;align-items:stretch!important}.attendance-page [style*="background: 'var(--bg-card)'"][style*="padding: '12px 20px'"]{padding:12px!important}.attendance-desktop-table{display:none!important}.attendance-mobile-list{display:grid!important;gap:10px}.attendance-mobile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:12px;box-shadow:var(--shadow-sm)}.attendance-mobile-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.attendance-mobile-actions .btn{min-height:42px;justify-content:center}}@media(max-width:420px){.attendance-mobile-actions{grid-template-columns:1fr}}.attendance-pill{border:1.5px solid var(--border);background:#fff;color:var(--text-secondary);border-radius:12px;min-height:42px;font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}.attendance-pill.join.active{background:#e8f7ee;border-color:#22c55e;color:#15803d}.attendance-pill.absence.active{background:#feecec;border-color:#ef4444;color:#b91c1c}.attendance-pill.excuse.active{background:#fff7e6;border-color:#f59e0b;color:#b45309}.attendance-fab-save{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));width:56px;height:56px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:none;align-items:center;justify-content:center;box-shadow:0 10px 24px #2563eb59;z-index:70}.attendance-fab-save:disabled{background:#94a3b8;box-shadow:none}.attendance-fab-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;animation:spin .8s linear infinite}.attendance-save-toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(86px + env(safe-area-inset-bottom));background:#16a34a;color:#fff;font-weight:700;border-radius:12px;padding:10px 14px;z-index:71;box-shadow:0 8px 20px #0003}@media(max-width:768px){.attendance-save-top{display:none!important}.attendance-fab-save{display:inline-flex}}.attendance-page,.attendance-page *{box-sizing:border-box}.attendance-fab-save{right:16px;bottom:calc(84px + env(safe-area-inset-bottom));background:linear-gradient(135deg,#2563eb,#7c3aed)}.attendance-fab-icon{animation:attendanceFabPulse 1.8s ease-in-out infinite}@keyframes attendanceFabPulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@media(max-width:768px){.attendance-page{padding-left:10px;padding-right:10px}.attendance-page [style*="display: 'flex'"][style*="alignItems: 'center'"][style*="padding: '6px'"]{width:100%;overflow:hidden;flex-wrap:wrap;gap:6px;justify-content:center}.attendance-page input[type=date]{min-width:0;width:100%}.attendance-mobile-list{width:100%;max-width:100%;overflow:hidden}.attendance-mobile-card{width:100%;max-width:100%;margin:0}.attendance-mobile-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.attendance-mobile-actions .attendance-pill{width:100%;padding:8px 4px;font-size:12px}}.attendance-class-grid,.attendance-class-card{min-width:0}.attendance-save-top-icon{animation:attendanceTopIconFloat 1.6s ease-in-out infinite}@keyframes attendanceTopIconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}@media(max-width:768px){.attendance-class-grid{grid-template-columns:1fr!important;gap:12px!important}.attendance-class-card{width:100%!important;max-width:100%!important;padding:14px!important;overflow:hidden}.attendance-class-card *{min-width:0}}.teacher-payouts-mobile-list{display:none}@media(max-width:768px){.teacher-payouts-table-desktop{display:none}.teacher-payouts-mobile-list{display:grid;gap:10px}}.teachers-table th{position:sticky;top:0;background:var(--table-header-bg);z-index:10;box-shadow:0 2px 4px #0000000a}.teachers-table td{vertical-align:middle}.teachers-table tbody tr{cursor:pointer;transition:all .15s ease}.teachers-table tbody tr:nth-child(2n){background:#fafbfd}[data-theme=dark] .teachers-table tbody tr:nth-child(2n){background:#ffffff04}.teachers-table tbody tr:hover{background:#f4f5fa}[data-theme=dark] .teachers-table tbody tr:hover{background:#6c63ff0a}.action-dropdown-container{position:relative;display:inline-block}.action-dropdown-trigger{width:36px;height:36px;padding:0;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.action-dropdown-trigger:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.action-dropdown-trigger:focus{outline:none;box-shadow:0 0 0 3px var(--primary-bg)}.action-dropdown-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;padding:6px;z-index:1000;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.action-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .15s ease;border-radius:var(--radius-sm);text-align:left}.action-dropdown-item:hover{background:var(--hover-bg)}.action-dropdown-item-default:hover{background:var(--primary-bg);color:var(--primary)}.action-dropdown-item-danger{color:var(--danger)}.action-dropdown-item-danger:hover{background:var(--danger-bg)}.action-dropdown-item-success{color:var(--success)}.action-dropdown-item-success:hover{background:var(--success-bg)}.action-dropdown-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-dropdown-label{flex:1;white-space:nowrap}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-card);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pagination-info{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.pagination{display:flex;gap:6px;align-items:center}.pagination-btn{min-width:36px;height:36px;padding:0 12px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}@media(max-width:1024px){.teachers-table th:nth-child(3),.teachers-table td:nth-child(3){display:none}}@media(max-width:768px){.pagination-container{flex-direction:column;gap:12px;padding:12px 16px}.pagination-info{text-align:center;font-size:12px}.pagination{width:100%;justify-content:center}.pagination-btn{min-width:32px;height:32px;padding:0 8px;font-size:12px}.teachers-table th,.teachers-table td{padding:10px 12px}.teachers-table th:nth-child(5),.teachers-table td:nth-child(5),.teachers-table th:nth-child(4),.teachers-table td:nth-child(4){display:none}.teachers-table td:first-child img{width:32px;height:32px}.action-dropdown-menu{right:-10px}}@media(max-width:480px){.teachers-table th:nth-child(2),.teachers-table td:nth-child(2){display:none}.action-dropdown-trigger{width:32px;height:32px}.action-dropdown-menu{min-width:160px}.action-dropdown-item{padding:8px 10px;font-size:13px}.pagination-btn:first-child,.pagination-btn:last-child{padding:0 16px}}
