.cdm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0000008c;justify-content:center;align-items:center;padding:16px;animation:.15s cdm-fade-in;display:flex;position:fixed;inset:0}@keyframes cdm-fade-in{0%{opacity:0}to{opacity:1}}.cdm-modal{background:var(--color-surface,#fff);border-radius:20px;flex-direction:column;width:100%;max-width:620px;max-height:90vh;animation:.2s cdm-slide-up;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000040}@keyframes cdm-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.cdm-header{border-bottom:1px solid var(--color-border,#e5e7eb);justify-content:space-between;align-items:flex-start;gap:12px;padding:22px 24px 16px;display:flex}.cdm-header-left{flex:1;min-width:0}.cdm-class-code{letter-spacing:.08em;color:var(--color-primary,#6366f1);background:#6366f11a;border-radius:999px;align-items:center;gap:4px;margin-bottom:6px;padding:2px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.cdm-title{color:var(--color-text,#111827);word-break:break-word;font-size:1.1rem;font-weight:800;line-height:1.4}.cdm-close{background:var(--color-background,#f3f4f6);cursor:pointer;width:36px;height:36px;color:var(--color-text-muted,#6b7280);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.cdm-close:hover{background:var(--color-border);color:var(--color-text)}.cdm-banner{align-items:flex-start;gap:10px;padding:12px 24px;font-size:.855rem;font-weight:500;line-height:1.5;display:flex}.cdm-banner--error{color:#dc2626;background:#ef444414;border-bottom:1px solid #ef444433}.cdm-banner--success{color:#059669;background:#10b98114;border-bottom:1px solid #10b98133}.cdm-body{flex-direction:column;flex:1;gap:24px;padding:20px 24px;display:flex;overflow-y:auto}.cdm-section{flex-direction:column;gap:12px;display:flex}.cdm-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted,#6b7280);margin-bottom:4px;font-size:.88rem;font-weight:700}.cdm-info-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.cdm-info-item{background:var(--color-background,#f9fafb);border:1px solid var(--color-border,#e5e7eb);border-radius:10px;align-items:flex-start;gap:8px;padding:10px 12px;display:flex}.cdm-info-item--wide{grid-column:span 2}.cdm-icon{color:var(--color-primary,#6366f1);flex-shrink:0;margin-top:2px}.cdm-info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:2px;font-size:.72rem;font-weight:600;display:block}.cdm-info-value{color:var(--color-text,#111827);font-size:.88rem;font-weight:600;display:block}.cdm-fee-row{background:var(--color-background,#f9fafb);border:1px solid var(--color-border);border-radius:10px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.cdm-fee-parent{border-color:#6366f14d}.cdm-fee-label{color:var(--color-text-secondary,#374151);font-size:.875rem;font-weight:600}.cdm-fee-amount{color:var(--color-text);font-size:1.05rem;font-weight:800}.cdm-fee-amount.highlight{color:var(--color-primary,#6366f1);font-size:1.15rem}.cdm-fee-unit{color:var(--color-text-muted);margin-left:2px;font-size:.78rem;font-weight:500}.cdm-fee-percent{color:#f59e0b;font-size:.95rem;font-weight:700}.cdm-level-fees{background:var(--color-background);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.cdm-level-fees-header{border-bottom:1px solid var(--color-border);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);background:var(--color-surface);grid-template-columns:1fr 1fr 1fr;padding:8px 14px;font-size:.7rem;font-weight:700;display:grid}.cdm-level-fee-row{border-bottom:1px solid var(--color-border);grid-template-columns:1fr 1fr 1fr;align-items:center;gap:6px;padding:11px 14px;transition:background .1s;display:grid}.cdm-level-fee-row:last-child{border-bottom:none}.cdm-level-fee-row.my-level{border-left:3px solid var(--color-primary,#6366f1);background:#6366f112}.cdm-level-badge{color:var(--color-text-secondary);flex-wrap:wrap;align-items:center;gap:4px;font-size:.82rem;font-weight:600;display:flex}.cdm-level-fee-row.my-level .cdm-level-badge{color:var(--color-primary,#6366f1)}.cdm-level-amount{color:var(--color-text);font-size:.9rem;font-weight:800}.cdm-level-fee-row.my-level .cdm-level-amount{color:var(--color-primary,#6366f1)}.cdm-admission-fee{color:#f59e0b;font-size:.88rem;font-weight:700}.cdm-my-level-tag{color:var(--color-primary,#6366f1);white-space:nowrap;background:#6366f11f;border-radius:999px;padding:1px 7px;font-size:.68rem;font-weight:700}.cdm-fee-note{color:var(--color-text-muted);background:#f59e0b12;border:1px solid #f59e0b40;border-radius:8px;padding:8px 12px;font-size:.78rem;line-height:1.5}.cdm-fee-ref{background:var(--color-background);border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:6px;padding:10px 14px;display:flex}.cdm-fee-ref-title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:2px;font-size:.72rem;font-weight:700}.cdm-fee-ref-row{color:var(--color-text-secondary);justify-content:space-between;font-size:.82rem;display:flex}.cdm-fee-ref-row span:last-child{color:var(--color-text);font-weight:600}.cdm-req-tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.cdm-req-tag{background:var(--color-background);border:1.5px solid var(--color-border);color:var(--color-text-muted);border-radius:999px;padding:4px 12px;font-size:.78rem;font-weight:600}.cdm-req-tag.active{border-color:var(--color-primary,#6366f1);color:var(--color-primary,#6366f1);background:#6366f11a}.cdm-error{color:#dc2626;background:#ef444414;border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;font-weight:500;display:flex}.cdm-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.cdm-btn-cancel{border:1.5px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:0 0;border-radius:10px;padding:10px 20px;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s}.cdm-btn-cancel:hover{background:var(--color-background)}.cdm-btn-apply{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;padding:10px 24px;font-family:inherit;font-size:.9rem;font-weight:700;transition:opacity .15s,transform .1s;box-shadow:0 4px 12px #6366f159}.cdm-btn-apply:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.cdm-btn-apply:disabled{opacity:.6;cursor:not-allowed}.cdm-note-input{border:1.5px solid var(--color-border,#e5e7eb);background:var(--color-background,#f9fafb);width:100%;color:var(--color-text,#111827);resize:vertical;box-sizing:border-box;border-radius:10px;padding:10px 14px;font-family:inherit;font-size:.875rem;line-height:1.6;transition:border-color .15s,box-shadow .15s}.cdm-note-input:focus{border-color:var(--color-primary,#6366f1);outline:none;box-shadow:0 0 0 3px #6366f11f}.cdm-note-input::placeholder{color:var(--color-text-muted,#9ca3af)}.cdm-note-count{text-align:right;color:var(--color-text-muted);margin-top:4px;font-size:.72rem;display:block}@media (width<=480px){.cdm-info-grid{grid-template-columns:1fr}.cdm-info-item--wide{grid-column:span 1}.cdm-modal{border-radius:16px 16px 0 0;max-height:95vh}.cdm-overlay{align-items:flex-end;padding:0}}.classes-page{background:linear-gradient(180deg, var(--hero-gradient-from) 0%, var(--hero-gradient-mid) 30%, var(--hero-gradient-to) 100%);min-height:100vh}@media (width>=768px){.classes-page{background:var(--color-background)}}.classes-hero{padding:var(--spacing-16) 0 var(--spacing-12);text-align:center;border-bottom:1px solid var(--color-border);opacity:0;background:0 0;animation:.6s ease-out forwards fadeInDown;position:relative;overflow:hidden}.classes-hero:before{content:"";pointer-events:none;background-image:radial-gradient(var(--primaryLight) 1px, transparent 1px);opacity:.1;background-size:40px 40px;position:absolute;inset:0}.hero-title{color:var(--color-text);margin-bottom:var(--spacing-4);letter-spacing:-.02em;font-size:2.5rem;font-weight:800}.hero-title .highlight{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--color-text-secondary);max-width:600px;margin:0 auto;font-size:1.125rem;line-height:1.6}.classes-main{gap:var(--spacing-6);padding:var(--spacing-8) var(--spacing-4);opacity:0;flex-direction:column;align-items:stretch;animation:.6s ease-out .2s forwards fadeInUp;display:flex}.search-filter-bar{background:color-mix(in srgb, var(--color-surface) 90%, transparent);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-4) var(--spacing-5);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:40;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:80px;box-shadow:0 10px 30px -5px #6366f126,0 4px 10px -5px #0000001a}.search-filter-bar.hide{opacity:0;pointer-events:none;transform:translateY(-150%)}.filters-grid{gap:var(--spacing-4);padding-bottom:var(--spacing-2);flex-wrap:wrap;align-items:flex-end;display:flex}.filters-advanced-grid{margin-top:var(--spacing-2)}.filter-group{flex-direction:column;flex:1;min-width:140px;margin-bottom:0;display:flex}.filter-group label{align-items:center;gap:var(--spacing-2);color:var(--color-text-secondary);margin-bottom:var(--spacing-2);font-size:.875rem;font-weight:500;display:flex}.filter-input,.filter-select{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);transition:var(--transition-base);outline:none;padding:.5rem .75rem;font-size:.9375rem}.filter-input:focus,.filter-select:focus{border-color:var(--color-primary,#6366f1);box-shadow:0 0 0 2px #6366f133}.multi-select-wrapper{position:relative}.multi-select-display{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.multi-select-display.open{border-color:var(--color-primary,#6366f1)}.multi-select-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.filter-actions-row{border-top:1px dashed var(--color-border);padding-top:var(--spacing-2);justify-content:space-between;align-items:center;margin-top:0;display:flex}.filter-actions-right{align-items:center;gap:var(--spacing-4);display:flex}.advanced-filter-btn{color:var(--color-primary);font-size:.9375rem;font-weight:600}.advanced-filter-btn:hover{background:0 0;text-decoration:underline}.filter-actions-row .clear-filter-btn{color:var(--color-text-secondary)}.filter-actions-row .clear-filter-btn:hover{color:var(--color-text)}.filter-actions-row .search-btn{flex-direction:row;justify-content:center;align-items:center;gap:8px;min-width:130px;height:40px;font-size:.875rem;font-weight:600;display:flex}.multi-select-arrow{color:var(--color-text-muted);transition:transform var(--transition-base)}.multi-select-display.open .multi-select-arrow{transform:rotate(180deg)}.multi-select-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:999;flex-direction:column;width:100%;min-width:180px;max-height:250px;display:flex;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 10px 25px -3px #0003}.multi-select-actions{padding:var(--spacing-2) var(--spacing-3);border-bottom:1px solid var(--color-border);background:var(--color-surface-hover);z-index:2;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.multi-select-actions .text-btn{color:var(--color-primary);cursor:pointer;transition:var(--transition-base);background:0 0;border:none;padding:0;font-size:.8125rem;font-weight:600}.multi-select-actions .text-btn:hover{color:var(--color-primary-dark,#4f46e5);text-decoration:underline}.multi-select-actions .separator{color:var(--color-border);font-size:.8125rem}.multi-select-items-container{padding:var(--spacing-2) 0;flex:1;overflow-y:auto}.multi-select-dropdown::-webkit-scrollbar{width:4px}.multi-select-dropdown::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:var(--radius-full)}.multi-select-item{align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);cursor:pointer;color:var(--color-text);transition:background-color var(--transition-base);font-size:.875rem;display:flex}.multi-select-item:hover{background-color:var(--color-surface-hover)}.multi-select-item input{cursor:pointer;accent-color:var(--color-primary,#6366f1)}.classes-content{flex:1;min-width:0}.classes-header-info{margin-bottom:var(--spacing-6);color:var(--color-text-secondary);font-size:.9375rem}.classes-grid{gap:var(--spacing-6);margin-bottom:var(--spacing-10);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.class-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-6);flex-direction:column;height:100%;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),border-color .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.class-card:hover{border-color:var(--primaryLight);transform:translateY(-4px);box-shadow:0 12px 24px -8px #6366f126,0 4px 12px -4px #0000000d}.class-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.class-card:hover:before{opacity:1}.card-header{margin-bottom:var(--spacing-3);color:var(--color-text-muted);justify-content:space-between;align-items:center;font-size:.75rem;font-weight:500;display:flex}.class-id{align-items:center;gap:4px;display:flex}.class-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;font-size:.65rem;font-weight:700}.class-badge.fee{color:#fff;background:linear-gradient(135deg,#ef4444,#f97316);border:none;padding:4px 10px;box-shadow:0 4px 10px #ef444440}.class-title{color:var(--color-text);margin-bottom:var(--spacing-4);font-size:1.25rem;font-weight:700;line-height:1.4}.class-details{gap:var(--spacing-3);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px dashed var(--color-border);flex-direction:column;display:flex}.highlight-fee-box{background:color-mix(in srgb, var(--color-success) 10%, transparent);border:1px solid color-mix(in srgb, var(--color-success) 20%, transparent);margin-bottom:var(--spacing-1);padding:var(--spacing-3);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:baseline;gap:4px;display:flex}.highlight-fee-box span{flex-wrap:wrap;align-items:baseline;gap:4px;display:inline-flex}.highlight-fee-box .fee-amount{color:var(--color-success);font-size:1.1rem;font-weight:800}.details-grid{gap:var(--spacing-3);margin-top:var(--spacing-2);grid-template-columns:1fr;display:grid}.detail-item{align-items:flex-start;gap:var(--spacing-3);color:var(--color-text-secondary);font-size:.875rem;display:flex}.icon-money{color:var(--color-success)}.icon-location{color:var(--color-danger)}.icon-session{color:var(--color-primary)}.icon-grade,.icon-student{color:var(--color-secondary)}.icon-time{color:var(--color-warning)}.detail-item strong{color:var(--color-text);font-size:.95rem}.class-requirement{color:var(--color-text-secondary);margin-bottom:var(--spacing-6);flex-grow:1;font-size:.875rem;line-height:1.6}.card-actions{margin-top:auto}.btn-apply{justify-content:center;width:100%}.no-results{padding:var(--spacing-16) var(--spacing-4);text-align:center;background:var(--color-surface);border-radius:var(--radius-xl);border:1px dashed var(--color-border);color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--spacing-4);flex-direction:column;grid-column:1/-1;display:flex}.no-results p{color:var(--color-text-secondary);font-size:1.125rem}.pagination{justify-content:center;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-8);display:flex}.page-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);width:40px;height:40px;color:var(--color-text);cursor:pointer;transition:var(--transition-base);justify-content:center;align-items:center;font-weight:600;display:flex}.page-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--primaryLight)}.page-btn.active{background:var(--color-primary,#6366f1);color:#fff;border-color:var(--color-primary,#6366f1)}.page-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.infinite-loader-icon{color:var(--color-primary);animation:1s linear infinite spin}.back-to-top-btn{bottom:var(--spacing-8);right:var(--spacing-8);background-color:var(--color-primary);color:#fff;cursor:pointer;opacity:0;pointer-events:none;z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;transform:translateY(20px);box-shadow:0 10px 25px -5px #6366f166}.back-to-top-btn.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top-btn:hover{background-color:var(--color-primary-dark);transform:translateY(-5px);box-shadow:0 15px 30px -5px #6366f180}@media (width<=1024px){.classes-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.classes-grid{grid-template-columns:1fr}.filters-grid{flex-wrap:wrap;overflow-x:visible}.filter-group{min-width:100%}.filter-actions-row{align-items:stretch;gap:var(--spacing-4);flex-direction:column}.filter-actions-left{justify-content:center;width:100%;display:flex}.filter-actions-right{flex-direction:column-reverse;width:100%}.filter-actions-right .btn-primary,.filter-actions-right .btn-ghost{width:100%}.search-filter-bar{padding:var(--spacing-4);z-index:auto;box-shadow:none;border-radius:var(--radius-md);margin-bottom:var(--spacing-4);position:static;top:auto;opacity:1!important;transform:none!important}.classes-main{padding:var(--spacing-4)}.classes-hero{padding:var(--spacing-8) 0 var(--spacing-6)}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.9rem}.back-to-top-btn{bottom:var(--spacing-4);right:var(--spacing-4);width:44px;height:44px}.classes-grid{gap:var(--spacing-3)}}
