:root{--woneasy-primary: #5BBFBA;--woneasy-primary-dark: #4AB0AB;--woneasy-primary-light: rgba(91, 191, 186, .1);--woneasy-primary-hover: rgba(91, 191, 186, .15);--woneasy-bg-primary: #F9FAFB;--woneasy-bg-secondary: #f5f7fa;--woneasy-bg-white: #ffffff;--woneasy-bg-card: #ffffff;--woneasy-bg-hover: #fafafa;--woneasy-bg-muted: #f8f9fa;--woneasy-text-primary: #333333;--woneasy-text-secondary: #666666;--woneasy-text-muted: #888888;--woneasy-text-light: #999999;--woneasy-border-primary: #e8e8e8;--woneasy-border-light: #f0f0f0;--woneasy-border-lighter: #f5f5f5;--status-present: #4CAF50;--status-present-bg: rgba(76, 175, 80, .1);--status-present-light: rgba(76, 175, 80, .15);--status-late: #FF9800;--status-late-bg: rgba(255, 152, 0, .1);--status-late-light: rgba(255, 152, 0, .15);--status-absent: #E85A5A;--status-absent-bg: rgba(232, 90, 90, .1);--status-absent-light: rgba(232, 90, 90, .15);--status-excused: #2196F3;--status-excused-bg: rgba(33, 150, 243, .1);--status-excused-light: rgba(33, 150, 243, .15);--status-pending: #9E9E9E;--status-pending-bg: rgba(158, 158, 158, .1);--status-pending-light: rgba(158, 158, 158, .15);--class-icon-orange: linear-gradient(135deg, #F5A26B, #E89555);--class-icon-green: linear-gradient(135deg, #8DC63F, #7AB82E);--class-icon-purple: linear-gradient(135deg, #9C7BE3, #8668D0);--class-icon-blue: linear-gradient(135deg, #5BBFBA, #4AB0AB);--stat-teal: #5BBFBA;--stat-teal-bg: rgba(91, 191, 186, .15);--stat-orange: #F5A26B;--stat-orange-bg: rgba(245, 162, 107, .15);--stat-green: #8DC63F;--stat-green-bg: rgba(141, 198, 63, .15);--stat-red: #E85A5A;--stat-red-bg: rgba(232, 90, 90, .15);--font-family-base: "Pretendard", "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .7rem;--font-size-sm: .75rem;--font-size-base: .85rem;--font-size-md: .9rem;--font-size-lg: .95rem;--font-size-xl: 1rem;--font-size-2xl: 1.25rem;--header-height: 60px;--sidebar-width: 250px;--sidebar-width-tablet: 220px;--panel-radius: 10px;--border-radius-sm: 5px;--border-radius-md: 6px;--border-radius-lg: 10px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-base: 1rem;--spacing-lg: 1.25rem;--spacing-xl: 1.5rem;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500}.status-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:10px;font-size:var(--font-size-xs);font-weight:500}.status-badge.present{background:var(--status-present-bg);color:var(--status-present)}.status-badge.late{background:var(--status-late-bg);color:var(--status-late)}.status-badge.absent{background:var(--status-absent-bg);color:var(--status-absent)}.status-badge.excused{background:var(--status-excused-bg);color:var(--status-excused)}.status-badge.pending{background:var(--status-pending-bg);color:var(--woneasy-text-secondary)}.status-dot{width:6px;height:6px;border-radius:50%}.status-dot.present{background:var(--status-present)}.status-dot.late{background:var(--status-late)}.status-dot.absent{background:var(--status-absent)}.status-dot.excused{background:var(--status-excused)}.status-dot.pending{background:var(--status-pending)}.status-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm)}.status-icon.present{background:var(--status-present-light);color:var(--status-present)}.status-icon.late{background:var(--status-late-light);color:var(--status-late)}.status-icon.absent{background:var(--status-absent-light);color:var(--status-absent)}.status-icon.excused{background:var(--status-excused-light);color:var(--status-excused)}.status-icon.pending{background:var(--status-pending-light);color:var(--status-pending)}.panel{background:var(--woneasy-bg-white);border-radius:var(--panel-radius);box-shadow:var(--shadow-sm);border:1px solid var(--woneasy-border-light);display:flex;flex-direction:column}.panel-header{padding:.85rem 1rem;border-bottom:1px solid var(--woneasy-border-light);font-weight:600;font-size:var(--font-size-base);color:var(--woneasy-text-primary)}.panel-content{flex:1;overflow-y:auto}.panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--woneasy-text-light);text-align:center;padding:var(--spacing-xl)}.panel-empty h3{font-size:var(--font-size-lg);margin-bottom:.35rem;color:var(--woneasy-text-secondary);line-height:1.5}.panel-empty p{font-size:var(--font-size-base);color:var(--woneasy-text-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.3rem;padding:.5rem 1rem;border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all var(--transition-base);border:none}.btn-sm{padding:.35rem .75rem;font-size:var(--font-size-sm)}.btn-primary{background:var(--woneasy-primary);color:#fff}.btn-primary:hover{background:var(--woneasy-primary-dark)}.btn-outline{background:transparent;border:1px solid var(--woneasy-primary);color:var(--woneasy-primary)}.btn-outline:hover{background:var(--woneasy-primary);color:#fff}.btn-ghost{background:transparent;border:1px solid var(--woneasy-border-primary);color:var(--woneasy-text-secondary)}.btn-ghost:hover{border-color:var(--woneasy-primary);color:var(--woneasy-primary)}.class-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-md);flex-shrink:0}.class-icon.orange{background:var(--class-icon-orange)}.class-icon.green{background:var(--class-icon-green)}.class-icon.purple{background:var(--class-icon-purple)}.class-icon.blue{background:var(--class-icon-blue)}.progress-bar{height:6px;background:var(--woneasy-border-primary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--woneasy-primary),var(--woneasy-primary-dark));border-radius:3px;transition:width var(--transition-slow)}.date-selector{display:flex;align-items:center;gap:.4rem}.date-selector button{background:none;border:none;color:var(--woneasy-text-secondary);cursor:pointer;padding:.35rem;font-size:var(--font-size-lg);transition:color var(--transition-base)}.date-selector button:hover{color:var(--woneasy-text-primary)}.date-selector .current-date{font-weight:500;color:var(--woneasy-text-primary);font-size:var(--font-size-md)}.date-selector .today-btn{background:var(--woneasy-primary);color:#fff;padding:.35rem .75rem;border-radius:var(--border-radius-md);font-weight:500;font-size:var(--font-size-base);margin-left:.4rem}.date-selector .today-btn:hover{background:var(--woneasy-primary-dark)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-base)}.page-title h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--woneasy-text-primary);margin-bottom:.2rem}.page-title p{color:var(--woneasy-text-muted);font-size:var(--font-size-base)}.stat-item{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:var(--woneasy-bg-muted);border-radius:var(--border-radius-md);min-width:70px}.stat-label{font-size:var(--font-size-xs);color:var(--woneasy-text-muted)}.stat-count{font-size:var(--font-size-lg);font-weight:700;color:var(--woneasy-text-primary);margin-left:auto}.list-item{transition:background var(--transition-base);cursor:pointer}.list-item:hover{background:var(--woneasy-bg-hover)}.list-item.active{background:var(--woneasy-primary-light)}.text-muted{color:var(--woneasy-text-muted)}.text-primary{color:var(--woneasy-primary)}.text-success{color:var(--status-present)}.text-warning{color:var(--status-late)}.text-danger{color:var(--status-absent)}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-base{gap:var(--spacing-base)}.student-list-panel,.enrollment-list-panel{flex:1;min-width:280px;min-height:380px}.detail-panel,.learning-log-panel{width:280px;flex-shrink:0;min-height:380px}@media (max-width: 1200px){.detail-panel,.learning-log-panel{width:240px}.class-list-panel{width:250px}}@media (max-width: 991px){.stat-item .stat-label{display:none}.stat-item{min-width:45px;padding:.4rem .5rem;justify-content:center}.stat-item .stat-count{margin-left:0;font-size:var(--font-size-md)}.stat-item .status-dot{width:8px;height:8px}.progress-section{min-width:200px}.progress-info{white-space:nowrap}.auto-refresh-text{font-size:.65rem}}@media (max-width: 991px) and (min-width: 721px){.content-split{flex-wrap:nowrap;gap:.5rem}.class-list-panel{width:140px;min-width:140px;flex-shrink:0}.student-list-panel,.enrollment-list-panel{flex:1;min-width:280px}.detail-panel,.learning-log-panel{width:200px;min-width:200px;flex-shrink:0;min-height:auto}.class-icon,.class-arrow{display:none}.class-stats-row{padding-left:0}}@media (max-width: 720px){.content-split{flex-wrap:wrap}.class-list-panel,.student-list-panel,.enrollment-list-panel,.detail-panel,.learning-log-panel{width:100%;min-width:100%;min-height:auto}.summary-row{flex-direction:column;align-items:stretch;gap:.75rem}.status-row{flex-wrap:nowrap;justify-content:space-between}.stat-item .stat-label{display:none}.stat-item{flex:1;min-width:40px;max-width:60px}.page-header{flex-direction:row;align-items:center;gap:.5rem}.page-title h1{font-size:1.1rem}.page-title p{display:none}.date-selector{flex-shrink:0}.date-selector .current-date{font-size:.8rem}.date-selector .today-btn{padding:.25rem .5rem;font-size:.75rem}.progress-text{font-size:var(--font-size-sm)}.refresh-btn span,.refresh-btn-text{display:none}.refresh-btn{padding:.3rem .5rem}.auto-refresh-text{font-size:.7rem}.auto-refresh-text .auto-refresh-label{display:none}.class-item{padding:.6rem .75rem}.class-item-header{margin-bottom:0;align-items:center}.class-icon{width:28px;height:28px;font-size:.8rem}.class-meta{display:flex;width:100%;font-size:.7rem;margin-top:.15rem}.class-name{font-size:.85rem;margin-bottom:0}.class-arrow,.class-stats-row{display:none}.class-info{display:flex;flex-wrap:wrap;align-items:flex-start;gap:.25rem .5rem;flex:1}.class-name{flex-shrink:0}.class-stats-inline{display:flex;gap:.4rem;margin-left:auto}.class-stats-inline .stat-num{display:flex;align-items:center;gap:.2rem;font-weight:600;font-size:.8rem}.class-stats-inline .stat-num .status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.class-stats-inline .stat-num.present .status-dot{background-color:var(--status-present)}.class-stats-inline .stat-num.late .status-dot{background-color:var(--status-late)}.class-stats-inline .stat-num.absent .status-dot{background-color:var(--status-absent)}.class-stats-inline .stat-num.excused .status-dot{background-color:var(--status-excused)}.class-stats-inline .stat-num.pending .status-dot{background-color:var(--status-pending)}}html,body{height:100%;width:100%;overflow-x:hidden}body{font-family:var(--font-family-base, "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);line-height:1.6;font-weight:400;background-color:#f5f5f5;min-height:100vh}#root{width:100%;min-height:100vh}:root{--brand-orange: #F1845C;--brand-teal: #5BA8A0;--woneasy-primary: #5BBFBA;--woneasy-primary-dark: #4AA9A4;--woneasy-secondary: #F5A26B;--woneasy-accent: #8DC63F;--woneasy-danger: #E85A5A;--woneasy-text-primary: #333333;--woneasy-bg-primary: #F9FAFB}.login-page{font-family:Noto Sans KR,sans-serif;overflow-x:hidden;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#f5f5f5;padding:1rem}.login-container{max-width:900px;border-radius:20px;border:1px solid #e0e0e0;box-shadow:0 4px 20px #00000014;overflow:hidden;background-color:var(--brand-orange);padding:0!important}.login-container>.row{margin:0!important}.login-container .row>[class*=col]{padding:0}.brand-section{background-color:var(--brand-orange);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:2rem;border-radius:20px 0 0 20px;min-height:350px}.form-section{background-color:#fff;display:flex;justify-content:center;align-items:center;padding:1rem 2rem;border-radius:0 16px 16px 0;min-height:350px;margin:-1px -1px -1px 0}.form-wrapper{width:100%;max-width:400px;padding:1rem 0}.login-container .form-control{border-radius:8px;padding:12px;border:1px solid #ddd;font-size:1rem}.login-container .form-control:focus{border-color:var(--brand-orange);box-shadow:0 0 0 .25rem #f1845c40}.password-input-wrapper{position:relative;width:100%}.password-input-wrapper .form-control{padding-right:45px}.password-toggle{position:absolute;top:50%;right:15px;transform:translateY(-50%);background:none;border:none;color:#999;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:color .2s;z-index:5}.password-toggle:hover{color:var(--brand-orange)}.password-toggle:focus{outline:none;color:var(--brand-teal)}.btn-login{background-color:var(--brand-teal);border:none;color:#fff;padding:12px;border-radius:25px;font-weight:700;font-size:1.1rem;width:100%;transition:all .3s}.btn-login:hover{background-color:#4c9b93;color:#fff;transform:translateY(-2px)}.btn-login:focus{background-color:var(--brand-teal);color:#fff;box-shadow:none;outline:none}.btn-login:active{background-color:#4c9b93!important;color:#fff!important;transform:translateY(0)}.divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:#aaa;font-size:.9rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #ddd}.divider:not(:empty):before{margin-right:.5em}.divider:not(:empty):after{margin-left:.5em}.bottom-links{display:flex;justify-content:space-between;gap:10px}.btn-outline-custom{border:1px solid #ddd;color:#666;border-radius:25px;padding:8px 16px;font-size:.9rem;text-decoration:none;width:100%;text-align:center;transition:all .2s}.btn-outline-custom:hover{background-color:#5ba8a026;color:var(--brand-teal);border-color:var(--brand-teal)}.brand-logo{width:200px;max-width:250px;margin-bottom:20px}.brand-text-mobile{color:#333;text-align:center;margin-bottom:1rem;font-weight:700;display:none}.brand-logo-mobile{display:none;max-width:180px;margin:1rem auto}.login-footer{width:100%;text-align:center;padding:1rem;margin-top:1rem;color:#666;font-size:.85rem}.login-footer .footer-links a{color:#666;text-decoration:none;transition:color .2s}.login-footer .footer-links a:hover{color:var(--brand-orange)}.login-footer .separator{margin:0 .5rem;color:#ccc}.login-footer .footer-info p{margin-bottom:.3rem}.login-container .alert{border-radius:8px;font-size:.9rem}@media (max-width: 900px) and (min-width: 768px){.form-wrapper{max-width:320px;padding:1rem .5rem}.form-section{padding:1rem 1.5rem}}@media (max-width: 767px){.login-container{flex-direction:column;margin:16px;width:calc(100% - 32px)}.brand-section{display:none}.form-section{border-radius:20px;min-height:auto;padding:.5rem}.form-wrapper{padding:.5rem}.brand-logo-mobile{display:block}.brand-text-mobile{display:block;margin-top:0}.bottom-links{margin-bottom:1rem}.login-footer{padding:1.5rem 1rem;margin-top:1.5rem;font-size:.75rem}}:root{--primary-color: #5D9C93;--accent-color: #E88C64;--text-color: #333333;--border-color: #dddddd;--bg-color: #f5f7fa}.signup-page{font-family:Noto Sans KR,sans-serif;background-color:var(--bg-color);color:var(--text-color);display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.signup-container{background-color:#fff;width:100%;max-width:780px;padding:40px;border-radius:16px;box-shadow:0 4px 20px #00000014}.step-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:30px}.step{display:flex;flex-direction:column;align-items:center;gap:8px}.step-number{width:32px;height:32px;border-radius:50%;background-color:#e0e0e0;color:#999;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.step.active .step-number,.step.completed .step-number{background-color:var(--primary-color);color:#fff}.step-label{font-size:12px;color:#999;white-space:nowrap}.step.active .step-label,.step.completed .step-label{color:var(--primary-color);font-weight:500}.step-line{width:60px;height:2px;background-color:#e0e0e0;margin:0 15px 20px}.step-line.completed{background-color:var(--primary-color)}.terms-section{margin-bottom:20px}.agree-all-box{border:2px solid var(--primary-color);border-radius:8px;padding:20px;margin-bottom:15px}.agree-all-box .checkbox-label{font-size:16px;font-weight:500}.terms-note{font-size:12px;color:#666;line-height:1.6;margin-bottom:20px}.agree-item{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border:1px solid var(--border-color);border-radius:8px;margin-bottom:10px}.view-btn{background:none;border:none;color:var(--primary-color);font-size:14px;font-weight:500;cursor:pointer}.view-btn:hover{text-decoration:underline}.complete-section{text-align:center;padding:40px 0}.complete-icon{font-size:64px;margin-bottom:20px}.complete-title{font-size:24px;font-weight:700;color:var(--text-color);margin-bottom:15px}.complete-message{font-size:14px;color:#666;line-height:1.8}.info-box{background-color:#f0f9f8;border:1px solid var(--primary-color);border-radius:8px;padding:20px;margin-bottom:30px;text-align:center}.info-box p{margin:0;font-size:14px;line-height:1.6;color:var(--text-color)}.divider-text{display:flex;align-items:center;text-align:center;margin:20px 0}.divider-text:before,.divider-text:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.divider-text span{padding:0 15px;color:#999;font-size:13px}.signup-container .header{text-align:center;margin-bottom:20px}.signup-container .logo{font-size:32px;font-weight:700;margin-bottom:5px;display:inline-block;text-decoration:none}.signup-container .logo .won{color:var(--accent-color)}.signup-container .logo .easy{color:var(--primary-color)}.signup-container .header-logo{width:180px;height:auto}.signup-container .subtitle{font-size:14px;color:#666;margin-top:-5px;margin-bottom:20px;font-weight:500}.signup-container .page-title{font-size:24px;font-weight:700;margin-top:10px}.signup-container .alert{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.signup-container .alert-danger{background-color:#fee2e2;border:1px solid #fecaca;color:#dc2626}.signup-container .form-section{display:block;width:100%;border-radius:0}.signup-container .form-row{display:flex!important;flex-direction:row!important;border-bottom:1px solid var(--border-color);padding:20px 0;align-items:flex-start;width:100%}.signup-container .form-row.no-border{border-bottom:none}.signup-container .row-label{width:140px;min-width:140px;font-weight:700;padding-top:12px;flex-shrink:0;display:flex;align-items:flex-start}.signup-container .row-content{flex-grow:1;display:flex;flex-direction:column;gap:10px;width:calc(100% - 150px)}.signup-container .input-group{display:flex;flex-direction:row;flex-wrap:nowrap;gap:10px;width:100%;align-items:center}.signup-container .input-half{width:50%;flex:1}.signup-container .input-group.no-wrap{gap:0;align-items:stretch}.signup-container .input-group.no-wrap input{border-radius:8px 0 0 8px;border-right:none;height:46px}.signup-container .input-group.no-wrap .btn,.signup-container .input-group.no-wrap .verified-badge{border-radius:0 8px 8px 0;height:46px}.signup-container .input-zip{max-width:120px;flex:none!important}.signup-container .form-select{flex:1;padding:12px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-color);background-color:#fff;cursor:pointer}.signup-container .form-select:focus{outline:none;border-color:var(--primary-color)}.plan-options{display:flex;gap:10px;flex-wrap:wrap}.plan-card{flex:1;min-width:100px;display:flex;flex-direction:column;align-items:center;padding:15px 10px;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease}.plan-card input[type=radio]{display:none}.plan-card:hover{border-color:var(--primary-color)}.plan-card.selected{border-color:var(--primary-color);background-color:#f0f9f8}.plan-name{font-size:14px;font-weight:700;color:var(--text-color);margin-bottom:5px}.plan-card.selected .plan-name{color:var(--primary-color)}.plan-price{font-size:12px;color:#666}.file-upload-wrapper{flex:1}.btn-file{display:inline-flex;align-items:center;gap:6px;padding:12px 16px;background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.btn-file:hover{background-color:#4a8a81}.file-name{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--primary-color);margin-top:8px}.btn-file-remove{background:none;border:none;color:#dc3545;font-size:14px;cursor:pointer;padding:2px 6px;border-radius:50%;transition:background-color .2s ease}.btn-file-remove:hover{background-color:#fee2e2}.plan-card.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.disabled-section{opacity:.6}.plan-options{display:flex;gap:8px;flex-wrap:nowrap}.plan-card{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;padding:12px 15px;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease}.signup-container input[type=text],.signup-container input[type=password],.signup-container input[type=email],.signup-container input[type=tel],.signup-container input[type=url]{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-family:Noto Sans KR,sans-serif;transition:border-color .2s}.signup-container input:focus{outline:none;border-color:var(--primary-color)}.signup-container .btn{border:none;border-radius:8px;cursor:pointer;font-weight:500;font-family:Noto Sans KR,sans-serif;transition:background .2s}.signup-container .btn-outline{background-color:#fff;border:1px solid var(--primary-color);color:var(--primary-color);padding:11px 15px;font-size:14px;white-space:nowrap;box-sizing:border-box}.signup-container .btn-outline:hover{background-color:#f0fcf9}.signup-container .btn-primary{background-color:var(--primary-color);color:#fff;width:100%;padding:16px;font-size:18px;font-weight:700;margin-top:30px}.signup-container .btn-primary:hover{background-color:#4a827a}.signup-container .btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.signup-container .btn-search{background-color:var(--primary-color);color:#fff;padding:12px 20px;white-space:nowrap;min-width:fit-content}.signup-container .btn-search:hover{background-color:#4a827a}.radio-group{display:flex;gap:20px;padding-top:10px;align-items:center}.radio-item{display:flex;align-items:center;gap:6px;cursor:pointer}.signup-container input[type=radio]{accent-color:var(--primary-color);width:18px;height:18px}.academy-search-area{margin-top:10px}.signup-container .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.signup-container .form-row.no-border{align-items:center}.signup-container .form-row.no-border .row-label{padding-top:0}.signup-container input[type=checkbox]{accent-color:var(--primary-color);width:18px;height:18px;flex-shrink:0}.verification-input-area{margin-top:10px;padding:12px;background-color:#f8f9fa;border-radius:8px}.verification-input-area .input-group.no-wrap{display:flex!important;align-items:stretch!important;gap:0!important}.verification-input-area .input-group.no-wrap input{height:46px!important;padding:12px!important;margin:0!important;border-radius:8px 0 0 8px!important;border-right:none!important}.verification-input-area .input-group.no-wrap .btn{height:46px!important;padding:12px 20px!important;margin:0!important;border-radius:0 8px 8px 0!important;white-space:nowrap}.verification-hint{font-size:12px;color:#666;margin-top:8px}.verified-badge{display:inline-flex;align-items:center;justify-content:center;gap:4px;height:46px;padding:0 16px;background-color:#d1fae5;color:#059669;border-radius:8px;font-size:14px;font-weight:500;white-space:nowrap;box-sizing:border-box}.verified-badge i{font-size:16px}.login-link{text-align:center;margin-top:20px;font-size:14px;color:#666}.login-link a{color:var(--primary-color);text-decoration:none;font-weight:500}.login-link a:hover{text-decoration:underline}@media (max-width: 600px){.signup-container{padding:20px}.signup-container .form-row{flex-direction:column!important;gap:10px}.signup-container .row-label{width:100%;padding-top:0}.signup-container .input-group{flex-direction:column!important;flex-wrap:wrap!important}.signup-container .input-group.no-wrap{flex-direction:row!important;flex-wrap:nowrap!important}.signup-container .input-half{width:100%!important;flex:none!important;border-radius:8px!important}.signup-container .row-content{width:100%}.signup-container .input-group input[type=text],.signup-container .input-group input[type=password],.signup-container .input-group input[type=email],.signup-container .input-group input[type=tel]{border-radius:8px!important}.signup-container .input-group.no-wrap input{border-radius:8px 0 0 8px!important}.signup-container .input-group.no-wrap .btn{border-radius:0 8px 8px 0!important}.signup-container .input-group .form-select{width:100%!important;flex:none!important;border-radius:8px!important}.plan-options{flex-wrap:wrap!important}.plan-card{flex:1 1 45%!important;min-width:45%!important}.signup-container .header{margin-bottom:10px;position:relative;z-index:1}.signup-container .header-logo{width:120px;position:static!important;transform:none!important;left:auto!important}.terms-section{margin-top:15px;clear:both;position:relative;z-index:2}.agree-all-box{padding:15px}.terms-note{font-size:11px}}.academy-list{display:flex;flex-direction:column;gap:12px;margin-top:20px}.academy-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease;background-color:#fff}.academy-item:hover{border-color:var(--primary-color);background-color:#f8fbfa;transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.academy-item.disabled{background-color:#f8f9fa;border-color:#eee;cursor:default;opacity:.8}.academy-item.disabled:hover{transform:none;box-shadow:none}.academy-info{flex:1}.academy-name{font-size:16px;font-weight:700;color:var(--text-color);margin-bottom:4px;display:flex;align-items:center;gap:8px}.academy-address{font-size:13px;color:#666}.role-badge{font-size:11px;padding:2px 6px;border-radius:4px;font-weight:500}.role-badge.owner{background-color:#e3f2fd;color:#1976d2}.role-badge.staff{background-color:#f3e5f5;color:#7b1fa2}.academy-action{margin-left:16px;color:#ccc}.academy-item:hover .academy-action i{color:var(--primary-color)}.status-badge.pending{font-size:12px;color:#ff9800;background-color:#fff3e0;padding:4px 8px;border-radius:4px}.pending-content{display:flex;flex-direction:column;align-items:center;padding:20px 0}.pending-icon-wrapper{width:80px;height:80px;background-color:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.pending-icon{font-size:40px;color:var(--primary-color)}.description-text{font-size:16px;line-height:1.5;color:var(--text-color);margin:0}.description-text.sm{font-size:14px}.no-decoration{text-decoration:none}.text-center{text-align:center}.academy-search-section{margin-top:10px}.search-results{margin-top:10px;border:1px solid var(--border-color);border-radius:8px;max-height:200px;overflow-y:auto;background-color:#fff}.search-result-item{padding:12px 15px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .2s}.search-result-item:hover{background-color:#f0f9f8}.search-result-item .academy-name{font-size:14px;font-weight:600;color:var(--text-color);margin-bottom:2px}.search-result-item .academy-info{font-size:12px;color:#666}.selected-academy{margin-top:10px;padding:10px 15px;background-color:#f0f9f8;border-radius:8px;border:1px solid var(--primary-color);display:flex;align-items:center}.selected-academy .text-success{color:var(--primary-color)!important}.search-error{color:#dc3545;font-size:13px}.btn-outline-secondary{background-color:#fff;border:1px solid #6c757d;color:#6c757d;padding:12px 20px;white-space:nowrap}.main-header{position:fixed;top:0;left:0;right:0;height:60px;background-color:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 8px #0000000f;z-index:1000;display:flex;align-items:center;padding:0 1.5rem}.header-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--woneasy-text-primary, #333)}.header-logo img{height:32px;width:auto}.header-logo-text{font-size:1.25rem;font-weight:700;color:var(--woneasy-primary, #5BBFBA)}.academy-selector{margin-left:2rem;position:relative}.academy-selector-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;color:#333;transition:all .2s}.academy-selector-btn:hover{background:#f8f9fa}.academy-selector-btn i{font-size:.8rem;color:#666}.academy-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:200px;background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1001;display:none}.academy-dropdown.show{display:block}.academy-dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0}.academy-dropdown-item:last-child{border-bottom:none}.academy-dropdown-item:hover{background:#f8f9fa}.academy-dropdown-item.active{background:#5bbfba1a;color:var(--woneasy-primary, #5BBFBA);font-weight:500}.header-right{margin-left:auto;display:flex;align-items:center;gap:1rem}.user-menu{position:relative}.user-menu-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;cursor:pointer;font-size:.95rem;font-weight:500;color:#333;border-radius:8px;transition:all .2s}.user-menu-btn:hover{background:#f8f9fa}.user-menu-btn .user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--woneasy-primary, #5BBFBA),var(--woneasy-secondary, #F5A26B));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem}.user-menu-btn i.bi-chevron-down{font-size:.75rem;color:#666}.user-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1001;display:none}.user-dropdown.show{display:block}.user-dropdown-header{padding:.75rem 1rem;border-bottom:1px solid #e9ecef}.user-dropdown-header .user-name{font-weight:600;color:#333}.user-dropdown-header .user-email{font-size:.8rem;color:#666}.user-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .2s;color:#333;text-decoration:none}.user-dropdown-item:hover{background:#f8f9fa}.user-dropdown-item i{font-size:1rem;color:#666;width:18px}.user-dropdown-divider{height:1px;background:#e9ecef;margin:.25rem 0}.user-dropdown-item.logout,.user-dropdown-item.logout i{color:var(--woneasy-danger, #E85A5A)}.header-hamburger{display:none;padding:.5rem;background:none;border:none;cursor:pointer;font-size:1.25rem;color:#333;margin-right:.5rem}@media (max-width: 991px){.academy-selector{margin-left:1rem}}@media (max-width: 720px) and (min-width: 481px){.academy-selector,.user-menu-btn span,.user-menu-btn i.bi-chevron-down{display:none}}@media (max-width: 480px){.main-header{padding:0 1rem;position:relative}.header-hamburger{display:block;position:relative;z-index:2}.header-logo{position:absolute;left:50%;transform:translate(-50%)}.academy-selector,.header-logo-text{display:none}.header-right{position:relative;z-index:2}.user-menu-btn span,.user-menu-btn i.bi-chevron-down{display:none}}.sidebar{position:fixed;top:60px;left:0;width:250px;height:calc(100vh - 60px);background-color:#fff;border-right:1px solid #e9ecef;overflow-y:auto;z-index:999;transition:transform .3s ease}.sidebar-menu{padding:1rem 0}.sidebar-menu-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;color:#555;text-decoration:none;font-size:.95rem;font-weight:500;transition:all .2s;border-left:3px solid transparent}.sidebar-menu-item:hover{background:#f8f9fa;color:var(--woneasy-primary, #5BBFBA)}.sidebar-menu-item.active{background:#5bbfba1a;color:var(--woneasy-primary, #5BBFBA);border-left-color:var(--woneasy-primary, #5BBFBA);font-weight:600}.sidebar-menu-item i{font-size:1.1rem;width:22px;text-align:center}.sidebar-section-title{padding:1rem 1.5rem .5rem;font-size:.75rem;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.sidebar-divider{height:1px;background:#e9ecef;margin:.5rem 1rem}.sidebar-overlay{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;background:#0006;z-index:998}.sidebar-overlay.show{display:block}@media (max-width: 1300px) and (min-width: 1025px){.sidebar{width:200px}.sidebar-menu-item{padding:.75rem 1.25rem;font-size:.9rem}.sidebar-section-title{padding:.875rem 1.25rem .4rem;font-size:.7rem}}@media (max-width: 1024px) and (min-width: 481px){.sidebar{width:60px;overflow-x:hidden}.sidebar-menu{padding:.5rem 0}.sidebar-menu-item{justify-content:center;padding:.875rem 0;gap:0}.sidebar-menu-item span{display:none}.sidebar-menu-item i{font-size:1.25rem;width:auto}.sidebar-menu-item.active{border-left-width:2px}.sidebar-section-title{display:none}.sidebar-divider{margin:.5rem}}@media (max-width: 480px){.sidebar{transform:translate(-100%);width:260px;box-shadow:2px 0 12px #0000001a;overflow-x:visible}.sidebar.open{transform:translate(0)}.sidebar-menu-item{justify-content:flex-start;padding:.875rem 1.5rem;gap:.75rem}.sidebar-menu-item span{display:inline}.sidebar-menu-item i{font-size:1.1rem;width:22px}.sidebar-section-title{display:block}.sidebar-divider{margin:.5rem 1rem}}.main-layout{min-height:100vh;background-color:var(--woneasy-bg-primary, #F9FAFB)}.main-content{margin-left:250px;margin-top:60px;min-height:calc(100vh - 60px);padding:1.5rem;display:flex;flex-direction:column}.main-content-inner{flex:1}.main-footer{margin-top:auto;padding:1.5rem 0;text-align:center;color:#888;font-size:.85rem;border-top:1px solid #e9ecef}.main-footer a{color:#666;text-decoration:none;margin:0 .5rem;transition:color .2s}.main-footer a:hover{color:var(--woneasy-primary, #5BBFBA)}@media (max-width: 1300px) and (min-width: 1025px){.main-content{margin-left:200px}}@media (max-width: 1024px) and (min-width: 721px){.main-content{margin-left:60px}}@media (max-width: 720px) and (min-width: 481px){.main-content{margin-left:60px;margin-top:15px;padding:.25rem .75rem 1rem}}@media (max-width: 480px){.main-content{margin-left:0;margin-top:15px;padding:.25rem .75rem 1rem}}.dashboard{max-width:1200px}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:1.75rem;font-weight:700;color:#333;margin-bottom:.25rem}.dashboard-subtitle{color:#666;font-size:.95rem;margin:0}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-info{flex:1}.stat-value{font-size:1.75rem;font-weight:700;color:#333;line-height:1}.stat-label{font-size:.85rem;color:#888;margin-top:.25rem}.dashboard-content{background:#fff;border-radius:12px;padding:3rem;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0}.content-placeholder{text-align:center;color:#999}.content-placeholder i{font-size:3rem;margin-bottom:1rem;opacity:.5}.content-placeholder h3{color:#666;font-size:1.25rem;margin-bottom:.5rem}.content-placeholder p{font-size:.95rem;line-height:1.6;margin:0}@media (max-width: 1199px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 575px){.dashboard-stats{grid-template-columns:1fr}.dashboard-header h1{font-size:1.5rem}.stat-card{padding:1rem}.stat-icon{width:44px;height:44px;font-size:1.25rem}.stat-value{font-size:1.5rem}}.students-page{max-width:1200px}.students-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.students-page .page-title h1{font-size:1.4rem;font-weight:700;color:#333;margin:0}.students-page .page-title p{color:#888;font-size:.85rem;margin:.15rem 0 0}.btn-register{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,#5bbfba,#4ab0ab);border:none;border-radius:10px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s;font-size:.88rem;font-family:var(--font-family-base);white-space:nowrap}.btn-register:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5bbfba59}.stats-row{display:flex;gap:.75rem;margin-bottom:1.25rem}.stat-card{background:#fff;border-radius:12px;padding:.875rem 1.25rem;flex:1;box-shadow:0 1px 4px #0000000a;border:1px solid #f0f0f0;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.75rem}.stat-card:hover{border-color:#5bbfba;transform:translateY(-1px)}.stat-card.active{border-color:#5bbfba;background:#5bbfba0a}.stat-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.stat-icon.total{background:#5bbfba1f;color:#5bbfba}.stat-icon.enrolled{background:#4caf501f;color:#4caf50}.stat-icon.on-leave{background:#ff98001f;color:#ff9800}.stat-icon.pending{background:#2196f31f;color:#2196f3}.stat-icon.unpaid{background:#e85a5a1f;color:#e85a5a}.stat-info{display:flex;flex-direction:column}.stat-label{font-size:.75rem;color:#888}.stat-value{font-size:1.2rem;font-weight:700;color:#333}.stat-value.danger{color:#e85a5a}.filter-bar{background:#fff;border-radius:12px;padding:.875rem 1.25rem;margin-bottom:1rem;box-shadow:0 1px 4px #0000000a;border:1px solid #f0f0f0;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.search-box{position:relative;flex:1;min-width:200px}.search-box i{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#999;font-size:.85rem}.search-box input{width:100%;padding:.5rem 1rem .5rem 2.25rem;border:1px solid #e8e8e8;border-radius:8px;font-size:.85rem;font-family:var(--font-family-base);background:#f5f7fa;outline:none;transition:border-color .2s}.search-box input:focus{border-color:#5bbfba;background:#fff}.filter-group{display:flex;gap:.5rem}.filter-group select{padding:.5rem .75rem;border:1px solid #e8e8e8;border-radius:8px;font-size:.85rem;font-family:var(--font-family-base);background:#f5f7fa;color:#555;cursor:pointer;outline:none}.filter-group select:focus{border-color:#5bbfba}.student-list{display:flex;flex-direction:column;gap:.5rem}.students-page .student-item{display:flex;flex-direction:column;align-items:stretch;width:100%;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000a;border:1px solid #f0f0f0;overflow:hidden;transition:all .2s}.students-page .student-item:hover{border-color:#ddd}.students-page .student-item.expanded{border-color:#5bbfba;box-shadow:0 2px 12px #5bbfba1f}.students-page .student-row{display:flex;align-items:center;width:100%;padding:.875rem 1.25rem;cursor:pointer;gap:1rem;transition:background .15s}.student-row:hover{background:#fafbfc}.student-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0}.student-main-info{flex:1;min-width:0}.student-name-line{display:flex;align-items:center;gap:.5rem;margin-bottom:.2rem;flex-wrap:wrap}.student-name{font-weight:700;font-size:.95rem;color:#333}.student-grade{font-size:.8rem;color:#888}.status-badge{padding:.15rem .55rem;border-radius:10px;font-size:.68rem;font-weight:600;white-space:nowrap}.status-badge.on_leave{background:#ff98001f;color:#e68900}.status-badge.pending{background:#2196f31f;color:#1976d2}.status-badge.withdrawn{background:#9e9e9e1f;color:#757575}.student-sub-line{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:#888;flex-wrap:wrap}.student-sub-line i{font-size:.75rem;color:#aaa}.student-classes{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.class-tag{padding:.15rem .5rem;border-radius:6px;font-size:.72rem;font-weight:500;background:#5bbfba14;color:#4ab0ab;border:1px solid rgba(91,191,186,.15);white-space:nowrap}.student-alerts{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}.alert-badge{padding:.2rem .6rem;border-radius:8px;font-size:.72rem;font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:.25rem}.alert-badge.unpaid{background:#e85a5a1a;color:#e85a5a}.alert-badge.low-session{background:#ff98001a;color:#e68900}.expand-btn{width:32px;height:32px;border-radius:8px;border:1px solid #e8e8e8;background:#fff;display:flex;align-items:center;justify-content:center;color:#999;cursor:pointer;transition:all .2s;flex-shrink:0;font-size:.85rem}.expand-btn:hover{border-color:#5bbfba;color:#5bbfba}.expand-btn.active{background:#5bbfba;border-color:#5bbfba;color:#fff;transform:rotate(180deg)}.student-card{border-top:1px solid #f0f0f0;background:#fafbfc;width:100%}.tab-nav{display:flex;border-bottom:1px solid #e8e8e8;padding:0 1.25rem;background:#fff;overflow-x:auto}.tab-btn{display:flex;align-items:center;gap:.35rem;padding:.75rem 1rem;border:none;background:none;font-size:.82rem;color:#888;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;font-family:var(--font-family-base)}.tab-btn:hover{color:#555}.tab-btn.active{color:#5bbfba;border-bottom-color:#5bbfba;font-weight:600}.tab-btn i{font-size:.9rem}.tab-content{padding:1.25rem;min-height:160px}.tab-loading,.loading-state,.empty-state{display:flex;align-items:center;justify-content:center;gap:8px;padding:40px;color:#888;font-size:.85rem}.empty-state{flex-direction:column;gap:12px}.empty-state i{font-size:2rem;color:#ddd}.btn-register-small{padding:8px 16px;background:#5bbfba;color:#fff;border:none;border-radius:8px;font-size:.82rem;cursor:pointer;font-family:var(--font-family-base)}.no-data{text-align:center;color:#888;padding:20px;font-size:.82rem}@keyframes spin{to{transform:rotate(360deg)}}.attendance-tab .att-body{display:flex;gap:1.25rem;align-items:flex-start}.attendance-tab .att-left{width:280px;flex-shrink:0}.attendance-tab .att-right{flex:1;min-width:0}.att-summary-compact{background:#fff;border:1px solid #f0f0f0;border-radius:10px;padding:.75rem 1rem;margin-bottom:.75rem}.att-rate-row{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.5rem}.att-rate{font-size:1.4rem;font-weight:700;color:#5bbfba}.att-rate-label{font-size:.82rem;color:#888}.att-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.25rem .75rem}.att-inline-stat{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:#555;white-space:nowrap}.att-inline-stat strong{font-weight:700;color:#333}.att-inline-stat .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.att-inline-stat .dot.present{background:#4caf50}.att-inline-stat .dot.late{background:#ff9800}.att-inline-stat .dot.absent{background:#e85a5a}.att-inline-stat .dot.excused{background:#2196f3}.attendance-tab .mini-calendar{background:#fff;border:1px solid #f0f0f0;border-radius:10px;padding:.875rem 1rem}.attendance-tab .cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.attendance-tab .cal-header h4{font-size:.9rem;font-weight:600;margin:0;color:#333}.attendance-tab .cal-nav{display:flex;gap:.25rem}.attendance-tab .cal-nav button{width:28px;height:28px;border-radius:6px;border:1px solid #e8e8e8;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#666;transition:all .15s}.attendance-tab .cal-nav button:hover{border-color:#5bbfba;color:#5bbfba}.attendance-tab .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}.attendance-tab .cal-day-name{font-size:.68rem;color:#999;padding:.25rem 0;font-weight:600}.attendance-tab .cal-cell{padding:.3rem 0;border-radius:6px;font-size:.75rem;position:relative;min-height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center}.attendance-tab .cal-cell.empty{visibility:hidden}.attendance-tab .cal-cell .day-num{color:#666;margin-bottom:1px;font-size:.72rem}.attendance-tab .cal-cell .day-dot{width:10px;height:10px;border-radius:50%;margin-top:2px}.attendance-tab .cal-cell .day-dot.st-present{background:#4caf50}.attendance-tab .cal-cell .day-dot.st-late{background:#ff9800}.attendance-tab .cal-cell .day-dot.st-absent{background:#e85a5a}.attendance-tab .cal-cell .day-dot.st-excused{background:#2196f3}.attendance-tab .cal-day-name.sunday{color:#e85a5a}.attendance-tab .cal-cell.holiday .day-num{color:#e85a5a;font-weight:600}.attendance-tab .cal-cell.today{background:#5bbfba14;border:1px solid rgba(91,191,186,.3)}.attendance-tab .cal-cell.clickable{cursor:pointer}.attendance-tab .cal-cell.clickable:hover{background:#f3f4f6}.att-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:9999;display:flex;align-items:center;justify-content:center}.att-modal{background:#fff;border-radius:12px;width:480px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003}.att-modal-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid #eee}.att-modal-header h3{margin:0;font-size:1rem;font-weight:700;color:#333}.att-modal-date{font-size:.85rem;color:#5bbfba;font-weight:600;background:#5bbfba1a;padding:.15rem .5rem;border-radius:4px}.att-modal-close{margin-left:auto;background:none;border:none;font-size:1.1rem;color:#999;cursor:pointer;padding:.25rem}.att-modal-close:hover{color:#333}.att-modal-body{padding:1rem 1.25rem;overflow-y:auto;flex:1}.att-modal-field{margin-bottom:.75rem}.att-modal-field label{display:block;font-size:.78rem;font-weight:600;color:#666;margin-bottom:.3rem}.att-modal-field input[type=text],.att-modal-field input[type=time],.att-modal-field textarea,.att-modal-field select{width:100%;padding:.5rem .65rem;border:1px solid #ddd;border-radius:6px;font-size:.85rem;outline:none;transition:border .2s;box-sizing:border-box;font-family:inherit}.att-modal-field input:focus,.att-modal-field textarea:focus,.att-modal-field select:focus{border-color:#5bbfba}.att-modal-field textarea{resize:vertical;min-height:2.5rem}.att-modal-static{display:inline-block;font-size:.85rem;color:#333;font-weight:500;padding:.4rem 0}.att-modal-row{display:flex;gap:.75rem}.att-modal-field.half{flex:1}.att-modal-divider{border:none;border-top:1px solid #eee;margin:.5rem 0 .75rem}.att-status-btns{display:flex;gap:.4rem}.att-status-btn{flex:1;padding:.45rem 0;border:1.5px solid #ddd;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;background:#fff;color:#888;transition:all .2s}.att-status-btn.st-present.active{background:#4caf50;color:#fff;border-color:#4caf50}.att-status-btn.st-late.active{background:#ff9800;color:#fff;border-color:#ff9800}.att-status-btn.st-absent.active{background:#e85a5a;color:#fff;border-color:#e85a5a}.att-status-btn.st-excused.active{background:#2196f3;color:#fff;border-color:#2196f3}.att-status-btn:not(.active):hover{border-color:#bbb;color:#555}.att-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid #eee}.att-modal-cancel{padding:.5rem 1.25rem;border:1px solid #ddd;border-radius:6px;background:#fff;color:#666;font-size:.85rem;cursor:pointer}.att-modal-cancel:hover{background:#f5f5f5}.att-modal-save{padding:.5rem 1.5rem;border:none;border-radius:6px;background:#5bbfba;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer}.att-modal-save:hover{background:#4aa9a4}.att-modal-save:disabled{opacity:.6;cursor:not-allowed}.att-history .section-label{font-size:.88rem;font-weight:600;color:#333;margin-bottom:.75rem;display:flex;align-items:center;gap:.35rem}.recent-list{display:flex;flex-direction:column}.recent-item{border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .15s}.recent-item:last-child{border-bottom:none}.recent-item:hover{background:#5bbfba08}.recent-item-header{display:flex;align-items:center;gap:.75rem;padding:.75rem .5rem;font-size:.85rem}.recent-item-header .date{color:#888;min-width:75px;font-variant-numeric:tabular-nums}.recent-item-header .class-name{color:#333;flex:1;font-weight:500}.session-badge{font-size:.68rem;color:#888;background:#f0f0f0;padding:.1rem .4rem;border-radius:4px;white-space:nowrap;flex-shrink:0}.recent-time{color:#999;font-size:.78rem;white-space:nowrap;font-variant-numeric:tabular-nums}.recent-status{padding:.15rem .6rem;border-radius:10px;font-size:.72rem;font-weight:600;white-space:nowrap}.recent-status.present,.recent-status.makeup{background:#4caf501f;color:#4caf50}.recent-status.late{background:#ff98001f;color:#ff9800}.recent-status.absent{background:#e85a5a1f;color:#e85a5a}.recent-status.excused{background:#2196f31f;color:#2196f3}.recent-status.early_leave{background:#ff98001f;color:#ff9800}.recent-item .expand-icon{color:#ccc;font-size:.75rem;transition:transform .2s;flex-shrink:0}.recent-item.open .expand-icon{transform:rotate(180deg);color:#5bbfba}.learning-detail{background:#f8f9fa;border-radius:8px;padding:.875rem 1rem;margin:0 .5rem .75rem;border:1px solid #f0f0f0}.learning-row{display:flex;align-items:flex-start;gap:.5rem;padding:.35rem 0;font-size:.82rem}.learning-label{color:#888;min-width:55px;font-weight:500;display:flex;align-items:center;gap:.25rem;flex-shrink:0}.learning-label i{font-size:.75rem;color:#aaa}.learning-value{color:#333;flex:1;line-height:1.5;white-space:pre-wrap}.attendance-memo-line{font-size:.78rem;color:#888;padding:.25rem .75rem .35rem;display:flex;align-items:flex-start;gap:.35rem}.attendance-memo-line i{color:#bbb;margin-top:1px}.teacher-name{font-size:.75rem;color:#aaa;margin-top:.5rem;padding-top:.35rem;border-top:1px solid #eee;display:flex;align-items:center;gap:.25rem}.no-learning-data{color:#aaa;font-size:.82rem;display:flex;align-items:center;gap:.35rem}.hw-badge{padding:.1rem .4rem;border-radius:4px;font-size:.65rem;font-weight:600}.hw-badge.done{background:#4caf501f;color:#4caf50}.hw-badge.not-done{background:#e85a5a1f;color:#e85a5a}.enrollment-tab h4{font-size:.82rem;color:#555;margin:0 0 .5rem}.section-divider{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #f0f0f0}.enrollment-list{display:flex;flex-direction:column;gap:.5rem}.enrollment-card{padding:.875rem 1rem;background:#fff;border:1px solid #f0f0f0;border-radius:8px}.enrollment-card.ended{opacity:.6}.enr-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.enr-class-name{font-size:.88rem;font-weight:600;color:#333}.enr-status{padding:.15rem .55rem;border-radius:10px;font-size:.68rem;font-weight:600}.enr-status.enrolled{background:#4caf501f;color:#388e3c}.enr-status.paused{background:#ff98001f;color:#e68900}.enr-status.ended{background:#f5f5f5;color:#9e9e9e}.enr-details{display:flex;flex-wrap:wrap;gap:.75rem}.enr-detail-item{display:flex;align-items:center;gap:.3rem;font-size:.82rem;color:#666}.enr-detail-item i{font-size:.75rem;color:#aaa}.students-page .session-bar{margin-top:.625rem;height:5px;background:#f0f0f0;border-radius:3px;overflow:hidden}.students-page .session-fill{height:100%;background:linear-gradient(90deg,#5bbfba,#4ab0ab);border-radius:3px;transition:width .3s}.pay-summary-row{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.pay-stat{display:flex;flex-direction:column;padding:.625rem 1.25rem;background:#fff;border:1px solid #f0f0f0;border-radius:8px;flex:1;min-width:100px}.pay-stat-label{font-size:.72rem;color:#888;margin-bottom:2px}.pay-stat-value{font-size:1rem;font-weight:700;color:#333}.pay-stat-value.paid{color:#4caf50}.pay-stat-value.unpaid{color:#e85a5a}.payment-list{display:flex;flex-direction:column;gap:.4rem}.payment-item{display:flex;flex-direction:column;padding:.6rem .875rem;background:#f8f9fa;border-radius:8px;border-left:3px solid transparent}.payment-item.pending,.payment-item.overdue{border-left-color:#e85a5a}.payment-item.paid{border-left-color:#4caf50}.pay-row-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem}.pay-title{font-size:.82rem;font-weight:600;color:#333}.pay-status{padding:.1rem .5rem;border-radius:10px;font-size:.68rem;font-weight:600}.pay-status.pending,.pay-status.overdue{background:#e85a5a1a;color:#e85a5a}.pay-status.paid{background:#4caf501f;color:#388e3c}.pay-status.partial{background:#ff98001f;color:#e68900}.pay-row-bottom{display:flex;gap:.75rem;font-size:.75rem;color:#999}.pay-amount{font-weight:600;color:#333}.counseling-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.counseling-header h4{font-size:.82rem;color:#555;margin:0}.btn-add-counseling{display:flex;align-items:center;gap:.3rem;padding:.35rem .75rem;background:#5bbfba;color:#fff;border:none;border-radius:6px;font-size:.75rem;cursor:pointer;font-family:var(--font-family-base);font-weight:600}.counseling-form{background:#fff;border:1px solid #e8e8e8;border-radius:8px;padding:1rem;margin-bottom:1rem}.form-row{display:flex;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:.25rem;min-width:120px}.form-group.full{width:100%;margin-bottom:.75rem}.form-group label{font-size:.72rem;color:#888;font-weight:600}.form-group input,.form-group select,.form-group textarea{padding:.5rem .625rem;border:1px solid #e8e8e8;border-radius:6px;font-size:.82rem;font-family:var(--font-family-base);outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#5bbfba}.form-group textarea{resize:vertical}.form-actions{display:flex;justify-content:flex-end}.btn-submit{padding:.45rem 1.25rem;background:#5bbfba;color:#fff;border:none;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--font-family-base)}.counseling-list{display:flex;flex-direction:column;gap:.5rem}.counseling-item{padding:.875rem 1rem;background:#f8f9fa;border-radius:8px}.couns-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.couns-meta{display:flex;gap:.5rem;align-items:center;font-size:.82rem}.couns-date{color:#888}.couns-channel,.couns-category{display:flex;align-items:center;gap:.2rem;font-size:.72rem;background:#5bbfba14;color:#4ab0ab;padding:.1rem .45rem;border-radius:4px}.btn-delete-counseling{background:none;border:none;color:#bbb;cursor:pointer;padding:4px;font-size:.82rem}.btn-delete-counseling:hover{color:#e85a5a}.couns-content{font-size:.82rem;color:#555;line-height:1.5;margin:0 0 .25rem}.couns-staff{font-size:.75rem;color:#999}.status-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.5rem}.current-status{font-size:.82rem;color:#666}.status-buttons{display:flex;gap:.5rem}.btn-status{padding:.45rem .875rem;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;background:#fff;font-family:var(--font-family-base);transition:all .15s}.btn-status.enrolled{border:1px solid #5BBFBA;color:#5bbfba}.btn-status.enrolled:hover{background:#5bbfba14}.btn-status.on-leave{border:1px solid #FF9800;color:#e68900}.btn-status.on-leave:hover{background:#ff980014}.btn-status.withdrawn{border:1px solid #E85A5A;color:#e85a5a}.btn-status.withdrawn:hover{background:#e85a5a14}.info-section{margin-bottom:1.25rem}.info-section h4{font-size:.88rem;font-weight:600;margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid #f0f0f0;color:#333}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 2rem}.info-item{display:flex;font-size:.82rem}.info-label{color:#888;min-width:80px;flex-shrink:0}.info-value{color:#333;font-weight:500}.info-memo{font-size:.82rem;color:#555;line-height:1.6;padding:.75rem 1rem;background:#fff;border-radius:8px;border:1px solid #f0f0f0;white-space:pre-wrap;margin:0}.register-page{padding:1.5rem;max-width:700px;margin:0 auto}.register-page .page-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.btn-back{background:none;border:none;font-size:1.2rem;color:#888;cursor:pointer;padding:4px}.register-form{background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:1.5rem;box-shadow:0 1px 4px #0000000a}.register-form .form-section{margin-bottom:1.5rem}.register-form .form-section h3{font-size:.9rem;color:#333;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #f0f0f0;font-weight:600}.register-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}.register-form .form-group{display:flex;flex-direction:column;gap:.25rem}.register-form .form-group.full-width{grid-column:1 / -1}.register-form .form-group label{font-size:.82rem;color:#555;font-weight:600}.register-form .form-group label .required{color:#e85a5a;margin-left:2px}.register-form .form-group input,.register-form .form-group select,.register-form .form-group textarea{padding:.625rem .75rem;border:1px solid #e8e8e8;border-radius:8px;font-size:.85rem;font-family:var(--font-family-base);outline:none;transition:border-color .2s}.register-form .form-group input:focus,.register-form .form-group select:focus,.register-form .form-group textarea:focus{border-color:#5bbfba}.register-form .form-actions{display:flex;justify-content:flex-end;gap:.625rem;margin-top:1.25rem}.btn-cancel{padding:.625rem 1.5rem;background:#fff;color:#666;border:1px solid #e8e8e8;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;font-family:var(--font-family-base)}.btn-save{padding:.625rem 1.75rem;background:linear-gradient(135deg,#5bbfba,#4ab0ab);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;font-family:var(--font-family-base);transition:all .2s}.btn-save:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5bbfba59}@media (max-width: 991px){.stats-row{flex-wrap:wrap}.stat-card{min-width:calc(50% - .5rem)}.info-grid{grid-template-columns:1fr}}@media (max-width: 820px){.attendance-tab .att-body{flex-direction:column}.attendance-tab .att-left{width:100%}}@media (max-width: 720px){.students-page{padding:.75rem}.students-page .page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.stats-row{flex-wrap:wrap}.stat-card{min-width:calc(50% - .4rem)}.stat-card .stat-label{font-size:.68rem}.filter-bar{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.student-sub-line{display:none}.student-alerts{flex-wrap:wrap}.tab-nav{overflow-x:auto}.info-grid,.register-form .form-grid{grid-template-columns:1fr}}.attendance-page{flex:1;display:flex;flex-direction:column;max-width:1400px}.attendance-summary{background:var(--woneasy-bg-white);border-radius:var(--panel-radius);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--woneasy-border-light)}.summary-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.summary-title{font-size:var(--font-size-md);font-weight:600;color:var(--woneasy-text-primary)}.summary-actions{display:flex;align-items:center;gap:.6rem}.refresh-btn{display:flex;align-items:center;gap:.3rem;padding:.3rem .6rem;background:transparent;border:1px solid var(--woneasy-border-primary);border-radius:var(--border-radius-sm);color:var(--woneasy-text-secondary);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-base)}.refresh-btn:hover{border-color:var(--woneasy-primary);color:var(--woneasy-primary)}.refresh-btn.loading{opacity:.6;pointer-events:none}.refresh-btn.loading i{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auto-refresh-text{font-size:var(--font-size-xs);color:var(--woneasy-text-light);display:flex;align-items:center;gap:.25rem}.summary-row{display:flex;align-items:center;gap:1.5rem}.progress-section{flex:1}.progress-info{display:flex;justify-content:space-between;margin-bottom:.3rem;font-size:var(--font-size-base)}.progress-text{color:var(--woneasy-text-secondary)}.progress-percentage{color:var(--woneasy-primary);font-weight:600}.status-row{display:flex;gap:.25rem}.content-split{display:flex;gap:1rem;flex:1;min-height:0}.class-list-panel{width:280px;flex-shrink:0;min-height:380px}.attendance-page .panel-header{background:#f5a26b33;border-radius:var(--panel-radius) var(--panel-radius) 0 0}.class-item{padding:.85rem 1rem;border-bottom:1px solid var(--woneasy-border-lighter);cursor:pointer;transition:all var(--transition-base)}.class-item:hover{background:var(--woneasy-bg-hover)}.class-item.active{background:var(--woneasy-primary-light);border-left:3px solid var(--woneasy-primary)}.class-item-header{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.5rem}.class-info{flex:1;min-width:0}.class-name{font-weight:600;color:var(--woneasy-text-primary);font-size:var(--font-size-base);margin-bottom:.15rem}.class-meta{display:flex;gap:.6rem;font-size:var(--font-size-xs);color:var(--woneasy-text-muted)}.class-meta i{margin-right:.2rem}.class-arrow{color:#ccc;font-size:var(--font-size-md);align-self:center}.class-item.active .class-arrow{color:var(--woneasy-primary)}.class-stats-row{display:flex;align-items:center;gap:.6rem;font-size:var(--font-size-sm);padding-left:38px}.class-stat{display:flex;align-items:center;gap:.25rem}.class-stat .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.class-stat span:last-child{font-weight:600;color:var(--woneasy-text-primary)}.class-stat.present .status-dot{background-color:var(--status-present)}.class-stat.late .status-dot{background-color:var(--status-late)}.class-stat.absent .status-dot{background-color:var(--status-absent)}.class-stat.excused .status-dot{background-color:var(--status-excused)}.class-stat.pending .status-dot{background-color:var(--status-pending)}.class-stats-inline{display:none}.student-list-panel{flex:1;min-width:280px;min-height:380px}.attendance-page .student-item{display:flex;align-items:center;padding:.7rem 1rem;border-bottom:1px solid var(--woneasy-border-lighter);cursor:pointer;transition:background var(--transition-base)}.attendance-page .student-item:hover{background:var(--woneasy-bg-hover)}.attendance-page .student-item.active{background:var(--woneasy-primary-light)}.student-status-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:.7rem;font-size:var(--font-size-sm)}.student-status-icon.present{background:var(--status-present-light);color:var(--status-present)}.student-status-icon.pending{background:var(--status-pending-light);color:var(--status-pending)}.student-status-icon.late{background:var(--status-late-light);color:var(--status-late)}.student-status-icon.absent{background:var(--status-absent-light);color:var(--status-absent)}.student-status-icon.excused{background:var(--status-excused-light);color:var(--status-excused)}.attendance-page .student-name{flex:1;font-weight:500;color:var(--woneasy-text-primary);font-size:var(--font-size-base)}.student-item.paused .student-name{color:#9e9e9e}.student-status-icon.paused-enrollment{background:#ffc10726;color:#ffc107}.student-time{color:var(--woneasy-text-muted);font-size:var(--font-size-sm);margin-right:.75rem}.student-status-badge{padding:.15rem .5rem;border-radius:10px;font-size:var(--font-size-xs);font-weight:500}.student-status-badge.present{background:var(--status-present-bg);color:var(--status-present)}.student-status-badge.pending{background:var(--status-pending-bg);color:var(--woneasy-text-secondary)}.student-status-badge.late{background:var(--status-late-bg);color:var(--status-late)}.student-status-badge.absent{background:var(--status-absent-bg);color:var(--status-absent)}.student-status-badge.excused{background:var(--status-excused-bg);color:var(--status-excused)}.learning-log-panel{width:280px;flex-shrink:0;min-height:380px}.learning-log-content{padding:1rem}.learning-log-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--woneasy-text-light);text-align:center;padding:var(--spacing-xl)}.learning-log-empty h3{font-size:var(--font-size-md);margin-bottom:.35rem;color:var(--woneasy-text-secondary);line-height:1.5}.learning-log-empty p{font-size:var(--font-size-sm);color:var(--woneasy-text-light);line-height:1.5}.contact-info-section{background:var(--woneasy-bg-muted);border-radius:var(--border-radius-md);padding:.75rem;margin-bottom:.75rem;display:flex;flex-direction:column;gap:.4rem}.contact-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.contact-label{font-size:var(--font-size-sm);color:var(--woneasy-text-secondary);font-weight:500;min-width:45px}.contact-phone{font-size:var(--font-size-sm);color:var(--woneasy-primary);text-decoration:none;font-weight:500;padding:.2rem .5rem;background:#fff;border-radius:var(--border-radius-sm);border:1px solid var(--woneasy-border-light);transition:all var(--transition-base)}.contact-phone:hover{background:var(--woneasy-primary);color:#fff;border-color:var(--woneasy-primary)}.learning-log-panel .panel-subheader{font-size:var(--font-size-sm);color:var(--woneasy-text-muted);padding:.5rem 1rem;background:var(--woneasy-bg-muted);border-bottom:1px solid var(--woneasy-border-lighter)}.log-date{font-size:var(--font-size-sm);color:var(--woneasy-text-muted);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--woneasy-border-light)}.log-section{margin-bottom:1rem}.log-label{font-size:var(--font-size-sm);font-weight:600;color:var(--woneasy-text-secondary);margin-bottom:.3rem}.log-text{font-size:var(--font-size-base);color:var(--woneasy-text-primary);line-height:1.5;background:var(--woneasy-bg-muted);padding:.5rem .75rem;border-radius:var(--border-radius-md)}.edit-log-btn{width:100%;padding:.6rem;background:#fff;border:1px solid var(--woneasy-primary);color:var(--woneasy-primary);border-radius:var(--border-radius-md);font-size:var(--font-size-base);cursor:pointer;margin-top:.5rem;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.3rem}.edit-log-btn:hover{background:var(--woneasy-primary);color:#fff}.attendance-time-section{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;border-radius:var(--border-radius-md);margin-bottom:.75rem}.time-input-row{display:flex;align-items:flex-start;gap:.35rem}.time-input-group{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.time-label{font-size:.65rem;color:var(--woneasy-text-muted);font-weight:500;padding-left:.15rem}.time-input{width:100%;padding:.4rem .3rem;border:1px solid var(--woneasy-border-primary);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);color:var(--woneasy-text-primary);background:#fff;text-align:center}.time-input:focus{outline:none;border-color:var(--woneasy-primary);box-shadow:0 0 0 2px #5bbfba1a}.time-quick-btn{border:none;border-radius:var(--border-radius-sm);font-size:.65rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:.2rem}.time-quick-btn.class-time-btn{width:100%;padding:.4rem .5rem;background:#5bbfba14;color:var(--woneasy-primary);border:1px dashed var(--woneasy-primary);font-size:.7rem}.time-quick-btn.class-time-btn:hover{background:var(--woneasy-primary);color:#fff;border-style:solid}.time-quick-btn.class-time-btn i{font-size:.75rem}.time-quick-btn.now-btn{width:100%;padding:.3rem .35rem;background:#f5a26b1a;color:#e89555;border:1px solid rgba(245,162,107,.4)}.time-quick-btn.now-btn:hover{background:#f5a26b;color:#fff;border-color:#f5a26b}.time-separator{color:var(--woneasy-text-muted);font-size:var(--font-size-base);padding-top:1.1rem;flex-shrink:0}.log-divider{height:1px;background:var(--woneasy-border-light);margin:.5rem 0 .75rem}.pause-info-section{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#ffc10714;border-radius:var(--border-radius-md);border:1px solid rgba(255,193,7,.3);margin-bottom:.75rem}.pause-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:#ffc10726;border-radius:var(--border-radius-md);color:#f9a825;font-weight:600;font-size:var(--font-size-md)}.pause-badge i{font-size:1.2rem}.pause-period,.pause-reason{display:flex;flex-direction:column;gap:.25rem}.pause-label{font-size:var(--font-size-xs);color:var(--woneasy-text-muted);font-weight:500}.pause-dates{font-size:var(--font-size-sm);color:var(--woneasy-text-primary);font-weight:500}.pause-memo{font-size:var(--font-size-sm);color:var(--woneasy-text-secondary);line-height:1.5;margin:0;padding:.5rem;background:#fff;border-radius:var(--border-radius-sm)}.student-item.dropped{opacity:.75}.student-item.dropped .student-name{color:#9e9e9e}.dropped-badge{display:inline-block;font-size:.6rem;font-weight:600;color:#fff;background:#9e9e9e;padding:.05rem .35rem;border-radius:4px;margin-left:.35rem;vertical-align:middle}.dropped-badge.graduated{background:#7986cb}.pause-badge.dropped{background:#9e9e9e26;color:#757575}.dropped-readonly-notice{font-size:var(--font-size-sm);color:var(--woneasy-text-muted);line-height:1.5;margin:0;padding:.5rem;text-align:center}.status-buttons{display:flex;flex-wrap:nowrap;gap:.25rem}.status-btn{flex:1;min-width:0;padding:.4rem .15rem;border:1px solid var(--woneasy-border-primary);border-radius:var(--border-radius-sm);background:#fff;font-size:.7rem;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.status-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.status-btn:disabled{opacity:.6;cursor:not-allowed}.status-btn.present{border-color:var(--status-present);color:var(--status-present)}.status-btn.present:hover,.status-btn.present.active{background:var(--status-present);color:#fff}.status-btn.late{border-color:var(--status-late);color:var(--status-late)}.status-btn.late:hover,.status-btn.late.active{background:var(--status-late);color:#fff}.status-btn.absent{border-color:var(--status-absent);color:var(--status-absent)}.status-btn.absent:hover,.status-btn.absent.active{background:var(--status-absent);color:#fff}.status-btn.excused{border-color:var(--status-excused);color:var(--status-excused)}.status-btn.excused:hover,.status-btn.excused.active{background:var(--status-excused);color:#fff}.status-btn.pending{border-color:var(--status-pending);color:var(--status-pending)}.status-btn.pending:hover,.status-btn.pending.active{background:var(--status-pending);color:#fff}.time-save-btn{width:32px;height:32px;padding:0;border:1px solid var(--woneasy-primary);border-radius:var(--border-radius-sm);background:#fff;color:var(--woneasy-primary);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;flex-shrink:0}.time-save-btn:hover{background:var(--woneasy-primary);color:#fff}.time-save-btn:disabled{opacity:.6;cursor:not-allowed}.current-status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:var(--border-radius-md);font-size:var(--font-size-md);font-weight:600}.current-status-badge.present{background:var(--status-present-bg);color:var(--status-present)}.current-status-badge.late{background:var(--status-late-bg);color:var(--status-late)}.current-status-badge.absent{background:var(--status-absent-bg);color:var(--status-absent)}.current-status-badge.excused{background:var(--status-excused-bg);color:var(--status-excused)}.current-status-badge.pending{background:var(--status-pending-bg);color:var(--status-pending)}.current-status-badge.early_leave{background:var(--status-late-bg);color:var(--status-late)}.learning-section{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.learning-section-empty{margin-top:1rem;padding:1.5rem;text-align:center;color:var(--woneasy-text-muted);font-size:var(--font-size-sm);background:var(--woneasy-bg-secondary);border-radius:var(--border-radius-md)}.progress-buttons{display:flex;gap:.4rem}.progress-btn{flex:1;padding:.4rem .15rem;border:1px solid var(--woneasy-border-primary);border-radius:var(--border-radius-sm);background:#fff;font-size:.7rem;cursor:pointer;transition:all var(--transition-base)}.progress-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.progress-btn.ahead{border-color:#5bbfba;color:#5bbfba}.progress-btn.ahead:hover,.progress-btn.ahead.active{background:#5bbfba;color:#fff}.progress-btn.normal{border-color:#6ebf6e;color:#6ebf6e}.progress-btn.normal:hover,.progress-btn.normal.active{background:#6ebf6e;color:#fff}.progress-btn.delayed{border-color:#e57373;color:#e57373}.progress-btn.delayed:hover,.progress-btn.delayed.active{background:#e57373;color:#fff}.learning-field{display:flex;flex-direction:column;gap:.4rem}.learning-label{display:flex;align-items:center;gap:.4rem;font-size:var(--font-size-sm);font-weight:600;color:var(--woneasy-text-primary)}.learning-icon{font-size:.9rem}.learning-input{width:100%;padding:.6rem .75rem;border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--woneasy-text-primary);background:var(--woneasy-bg-secondary);transition:all var(--transition-base)}.learning-input:focus{outline:none;border-color:var(--woneasy-primary);background:#fff;box-shadow:0 0 0 2px #5bbfba1a}.learning-textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--woneasy-text-primary);background:var(--woneasy-bg-secondary);resize:none;font-family:inherit;line-height:1.5;transition:all var(--transition-base)}.learning-textarea:focus{outline:none;border-color:var(--woneasy-primary);background:#fff;box-shadow:0 0 0 2px #5bbfba1a}.learning-input::placeholder,.learning-textarea::placeholder{color:var(--woneasy-text-muted)}.date-selector{position:relative}.date-caret{font-size:.55rem;margin-left:.25rem;opacity:.5;vertical-align:middle}.current-date:hover .date-caret{opacity:1}.date-picker-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border-radius:14px;box-shadow:0 8px 32px #00000026,0 2px 8px #00000014;padding:1rem;z-index:100;width:290px;animation:datePickerSlideDown .2s ease-out}@keyframes datePickerSlideDown{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.date-picker-header button{background:none;border:none;cursor:pointer;padding:.35rem .5rem;border-radius:8px;color:var(--woneasy-text-secondary);transition:all .15s;font-size:.85rem}.date-picker-header button:hover{background:var(--woneasy-bg-hover, #f0f2f5);color:var(--woneasy-text-primary)}.date-picker-title{font-weight:600;font-size:.95rem;color:var(--woneasy-text-primary)}.date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.35rem}.date-picker-weekdays .weekday{text-align:center;font-size:.7rem;font-weight:600;color:var(--woneasy-text-muted);padding:.25rem 0}.date-picker-weekdays .weekday.sun{color:#e57373}.date-picker-weekdays .weekday.sat{color:#5c9ce6}.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.date-picker-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:50%;font-size:.8rem;color:var(--woneasy-text-primary);cursor:pointer;transition:all .15s;font-weight:400}.date-picker-day:hover:not(.empty):not(.selected){background:var(--woneasy-bg-hover, #f0f2f5)}.date-picker-day.empty{cursor:default}.date-picker-day.sun{color:#e57373}.date-picker-day.sat{color:#5c9ce6}.date-picker-day.today{font-weight:700;box-shadow:inset 0 0 0 1.5px var(--woneasy-primary)}.date-picker-day.selected{background:var(--woneasy-primary);color:#fff!important;font-weight:600}.date-picker-day.selected.today{box-shadow:none}.date-picker-footer{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--woneasy-border-lighter, #f0f0f0);text-align:center}.date-picker-today-btn{background:none;border:1px solid var(--woneasy-primary);color:var(--woneasy-primary);padding:.35rem 1rem;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.date-picker-today-btn:hover{background:var(--woneasy-primary);color:#fff}@media (max-width: 1200px){.learning-log-panel{width:240px}.class-list-panel{width:250px}}@media (max-width: 991px){.stat-item .stat-label{display:none}.stat-item{min-width:45px;padding:.4rem .5rem;justify-content:center}.stat-item .stat-count{margin-left:0;font-size:var(--font-size-md)}.stat-item .status-dot{width:8px;height:8px}.progress-section{min-width:200px}.progress-info{white-space:nowrap}.auto-refresh-text{font-size:.65rem}.auto-refresh-text:before{content:""}}@media (max-width: 1024px) and (min-width: 721px){.content-split{flex-wrap:nowrap;gap:.5rem}.class-list-panel{width:190px;min-width:190px;flex-shrink:0}.student-list-panel{flex:1;min-width:180px}.learning-log-panel{min-width:280px;flex-shrink:0;min-height:auto}.class-icon,.class-arrow{display:none}.class-stats-row{padding-left:0}.student-status-badge{display:none}}@media (max-width: 720px){.content-split{flex-wrap:wrap}.class-list-panel,.student-list-panel,.learning-log-panel{width:100%;min-width:100%;min-height:auto}.summary-row{flex-direction:column;align-items:stretch;gap:.75rem}.status-row{flex-wrap:nowrap;justify-content:space-between}.stat-item .stat-label{display:none}.stat-item{flex:1;min-width:40px;max-width:60px}.page-header{flex-direction:row;align-items:center;gap:.5rem}.page-title h1{font-size:1.1rem}.page-title p{display:none}.date-selector{flex-shrink:0}.date-selector .current-date{font-size:.8rem}.date-selector .today-btn{padding:.25rem .5rem;font-size:.75rem}.progress-text{font-size:var(--font-size-sm)}.refresh-btn span,.refresh-btn-text{display:none}.refresh-btn{padding:.3rem .5rem}.auto-refresh-text{font-size:.7rem}.auto-refresh-text .auto-refresh-label{display:none}.class-item{padding:.6rem .75rem}.class-item-header{margin-bottom:0;align-items:center}.class-icon{width:28px;height:28px;font-size:.8rem}.class-meta{display:flex;width:100%;font-size:.7rem;margin-top:.15rem}.class-name-wrapper{display:flex;flex-direction:column}.class-name{font-size:.85rem;margin-bottom:0}.class-arrow,.class-stats-row{display:none}.class-info{display:flex;flex-wrap:wrap;align-items:flex-start;gap:.25rem .5rem;flex:1}.class-name{flex-shrink:0}.class-stats-inline{display:flex;gap:.4rem;margin-left:auto}.class-stats-inline .stat-num{display:flex;align-items:center;gap:.2rem;font-weight:600;font-size:.8rem}.class-stats-inline .stat-num .status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.class-stats-inline .stat-num.present .status-dot{background-color:var(--status-present)}.class-stats-inline .stat-num.late .status-dot{background-color:var(--status-late)}.class-stats-inline .stat-num.absent .status-dot{background-color:var(--status-absent)}.class-stats-inline .stat-num.excused .status-dot{background-color:var(--status-excused)}.class-stats-inline .stat-num.pending .status-dot{background-color:var(--status-pending)}}.select-all-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;font-size:inherit;font-weight:inherit;color:inherit;cursor:pointer;padding:0;width:100%;text-align:left;transition:color var(--transition-base)}.select-all-btn:hover{color:var(--woneasy-primary)}.select-all-btn:disabled{cursor:default;color:inherit}.select-all-btn i{font-size:.8rem;color:var(--woneasy-text-muted);transition:color var(--transition-base)}.select-all-btn:hover i,.select-all-btn.all-selected i{color:var(--woneasy-primary)}.history-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem;background:#fff;border:1px solid var(--woneasy-primary);color:var(--woneasy-primary);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);cursor:pointer;margin-bottom:.75rem;transition:all var(--transition-base)}.history-btn:hover{background:var(--woneasy-primary);color:#fff}.history-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.history-modal{background:#fff;border-radius:var(--panel-radius);width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.history-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--woneasy-border-light)}.history-modal-header h3{margin:0;font-size:var(--font-size-lg);color:var(--woneasy-text-primary);display:flex;align-items:center;gap:.5rem}.history-modal-header h3 i{color:var(--woneasy-primary)}.modal-close-btn{background:transparent;border:none;font-size:1.25rem;color:var(--woneasy-text-muted);cursor:pointer;padding:.25rem;transition:color var(--transition-base)}.modal-close-btn:hover{color:var(--woneasy-text-primary)}.history-view-toggle{display:flex;gap:.5rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--woneasy-border-lighter)}.view-btn{display:flex;align-items:center;gap:.35rem;padding:.5rem 1rem;background:var(--woneasy-bg-secondary);border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--woneasy-text-secondary);cursor:pointer;transition:all var(--transition-base)}.view-btn:hover{border-color:var(--woneasy-primary);color:var(--woneasy-primary)}.view-btn.active{background:var(--woneasy-primary);border-color:var(--woneasy-primary);color:#fff}.history-class-filter{margin-left:auto;display:flex;align-items:center}.class-filter-select{padding:.4rem .75rem;border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--woneasy-text-primary);background:#fff;cursor:pointer;min-width:120px}.class-filter-select:focus{outline:none;border-color:var(--woneasy-primary)}.class-name-display{font-size:var(--font-size-sm);color:var(--woneasy-text-secondary);background:var(--woneasy-bg-muted);padding:.4rem .75rem;border-radius:var(--border-radius-md)}.history-memo{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--woneasy-text-muted);font-size:var(--font-size-xs)}.history-modal-content{flex:1;overflow-y:auto;padding:1rem 1.25rem}.history-loading,.history-empty{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--woneasy-text-muted);font-size:var(--font-size-base)}.history-loading i{margin-right:.5rem}.spin{animation:spin 1s linear infinite}.history-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.history-table th,.history-table td{white-space:nowrap}.history-table th:last-child,.history-table td:last-child{width:50px;text-align:center}.history-table .history-memo{white-space:normal;word-break:break-word}.history-table thead th{text-align:left;padding:.5rem;border-bottom:2px solid var(--woneasy-border-light);color:var(--woneasy-text-secondary);font-weight:600}.history-table tbody tr{border-bottom:1px solid var(--woneasy-border-lighter)}.history-table tbody tr:hover{background:var(--woneasy-bg-hover)}.history-table td{padding:.6rem .5rem}.history-actions{width:30px;text-align:center}.history-delete-btn{display:none;width:24px;height:24px;padding:0;background:transparent;border:none;color:#dc3545;cursor:pointer;border-radius:4px;transition:all .2s ease}.history-delete-btn:hover{background:#dc35451a}.history-table tbody tr:hover .history-delete-btn{display:inline-flex;align-items:center;justify-content:center}.history-status-badge{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:var(--font-size-xs);font-weight:500}.history-status-badge.present{background:var(--status-present-bg);color:var(--status-present)}.history-status-badge.late{background:var(--status-late-bg);color:var(--status-late)}.history-status-badge.absent{background:var(--status-absent-bg);color:var(--status-absent)}.history-status-badge.excused{background:var(--status-excused-bg);color:var(--status-excused)}.history-status-badge.cancelled{background:#f3e8ff;color:#7c3aed}.history-status-badge.makeup{background:#dbeafe;color:#2563eb}.enrollment-start-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:.35rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:10px;font-weight:700;border-radius:4px;vertical-align:middle}.day-enrollment-start{position:absolute;top:2px;right:2px;width:14px;height:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:8px;font-weight:700;border-radius:3px;display:flex;align-items:center;justify-content:center}.legend-badge-s{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;margin-right:.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:8px;font-weight:700;border-radius:3px}.history-calendar{padding:.5rem 0}.calendar-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.calendar-nav button{background:transparent;border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-sm);padding:.35rem .6rem;cursor:pointer;color:var(--woneasy-text-secondary);transition:all var(--transition-base)}.calendar-nav button:hover{border-color:var(--woneasy-primary);color:var(--woneasy-primary)}.calendar-title{font-weight:600;font-size:var(--font-size-md);color:var(--woneasy-text-primary);min-width:100px;text-align:center}.calendar-grid{border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-md);overflow:hidden}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--woneasy-bg-muted);text-align:center;font-size:var(--font-size-xs);font-weight:600;color:var(--woneasy-text-secondary)}.calendar-header span{padding:.5rem}.calendar-header span:first-child{color:#e74c3c}.calendar-header span:last-child{color:#3498db}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;border-top:1px solid var(--woneasy-border-lighter);border-left:1px solid var(--woneasy-border-lighter);transition:background var(--transition-base)}.calendar-day:not(.empty){cursor:pointer}.calendar-day:hover:not(.empty){background:var(--woneasy-bg-hover)}.calendar-day.selected{background:#5bbfba1f;box-shadow:inset 0 0 0 2px var(--woneasy-primary);z-index:1}.calendar-day.selected .day-number{color:var(--woneasy-primary);font-weight:700}.calendar-day.empty{background:var(--woneasy-bg-secondary)}.calendar-attendance-form{margin-top:1rem;padding:1rem;background:var(--woneasy-bg-secondary);border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-md);animation:calendarFormSlideDown .2s ease-out}@keyframes calendarFormSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.calendar-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.calendar-form-date{display:flex;align-items:center;gap:.4rem;font-size:var(--font-size-base);font-weight:600;color:var(--woneasy-text-primary)}.calendar-form-date i{color:var(--woneasy-primary);font-size:1rem}.calendar-form-close{background:transparent;border:none;color:var(--woneasy-text-muted);cursor:pointer;padding:.25rem;font-size:.9rem;transition:color var(--transition-base)}.calendar-form-close:hover{color:var(--woneasy-text-primary)}.calendar-form-subtitle{font-size:var(--font-size-sm);font-weight:600;color:var(--woneasy-text-secondary);margin-bottom:.5rem;padding-bottom:.25rem}.calendar-form-divider{height:1px;background:var(--woneasy-border-light);margin:.75rem 0}.calendar-form-records{margin-bottom:.5rem}.calendar-record-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;background:#fff;border:1px solid var(--woneasy-border-lighter);border-radius:var(--border-radius-sm);margin-bottom:.35rem;font-size:var(--font-size-sm)}.calendar-record-time{color:var(--woneasy-text-muted);font-size:var(--font-size-xs)}.calendar-record-class{margin-left:auto;color:var(--woneasy-text-light);font-size:var(--font-size-xs);background:var(--woneasy-bg-muted);padding:.1rem .4rem;border-radius:var(--border-radius-sm)}.calendar-record-delete{background:transparent;border:none;color:var(--woneasy-text-light);cursor:pointer;padding:.2rem;font-size:.75rem;transition:color var(--transition-base);flex-shrink:0}.calendar-record-delete:hover{color:#dc3545}.calendar-form-class-hint{display:flex;align-items:flex-start;gap:.4rem;padding:.5rem .65rem;margin-bottom:.75rem;background:#5bbfba14;border:1px solid rgba(91,191,186,.2);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);color:var(--woneasy-text-secondary);line-height:1.4}.calendar-form-class-hint i{color:var(--woneasy-primary);margin-top:.1rem;flex-shrink:0}.calendar-form-statuses{display:flex;gap:.35rem;margin-bottom:.75rem}.calendar-form-status-btn{flex:1;padding:.45rem;border:1px solid var(--woneasy-border-primary);border-radius:var(--border-radius-sm);background:#fff;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base);text-align:center}.calendar-form-status-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.calendar-form-status-btn.present{border-color:var(--status-present);color:var(--status-present)}.calendar-form-status-btn.present:hover,.calendar-form-status-btn.present.active{background:var(--status-present);color:#fff}.calendar-form-status-btn.late{border-color:var(--status-late);color:var(--status-late)}.calendar-form-status-btn.late:hover,.calendar-form-status-btn.late.active{background:var(--status-late);color:#fff}.calendar-form-status-btn.absent{border-color:var(--status-absent);color:var(--status-absent)}.calendar-form-status-btn.absent:hover,.calendar-form-status-btn.absent.active{background:var(--status-absent);color:#fff}.calendar-form-status-btn.excused{border-color:var(--status-excused);color:var(--status-excused)}.calendar-form-status-btn.excused:hover,.calendar-form-status-btn.excused.active{background:var(--status-excused);color:#fff}.calendar-form-status-btn.pending{border-color:var(--status-pending);color:var(--status-pending)}.calendar-form-status-btn.pending:hover,.calendar-form-status-btn.pending.active{background:var(--status-pending);color:#fff}.calendar-form-times{display:flex;align-items:flex-end;gap:.5rem;margin-bottom:.75rem}.calendar-form-time-group{flex:1;display:flex;flex-direction:column;gap:.2rem}.calendar-form-time-group label{font-size:var(--font-size-xs);color:var(--woneasy-text-muted);font-weight:500}.calendar-form-time-input{padding:.4rem .5rem;border:1px solid var(--woneasy-border-light);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);color:var(--woneasy-text-primary);background:#fff;width:100%;box-sizing:border-box}.calendar-form-time-input:focus{outline:none;border-color:var(--woneasy-primary);box-shadow:0 0 0 2px #5bbfba26}.calendar-form-time-sep{color:var(--woneasy-text-muted);font-size:var(--font-size-base);padding-bottom:.4rem}.calendar-form-actions{display:flex;gap:.5rem}.calendar-form-cancel{flex:1;padding:.5rem;background:#fff;border:1px solid var(--woneasy-border-primary);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);color:var(--woneasy-text-secondary);cursor:pointer;transition:all var(--transition-base)}.calendar-form-cancel:hover{background:var(--woneasy-bg-muted)}.calendar-form-save{flex:1.5;padding:.5rem;background:var(--woneasy-primary);border:1px solid var(--woneasy-primary);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);font-weight:600;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.35rem;transition:all var(--transition-base)}.calendar-form-save:hover:not(:disabled){background:var(--woneasy-primary-dark, #4aa8a3);box-shadow:0 2px 8px #5bbfba4d}.calendar-form-save:disabled{opacity:.7;cursor:not-allowed}.day-number{font-size:var(--font-size-sm);color:var(--woneasy-text-primary)}.day-status{width:8px;height:8px;border-radius:50%}.day-status-container{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;align-items:center;max-width:100%}.day-status.present{background:var(--status-present)}.day-status.late{background:var(--status-late)}.day-status.absent{background:var(--status-absent)}.day-status.excused{background:var(--status-excused)}.calendar-legend{display:flex;justify-content:center;gap:1rem;margin-top:1rem;font-size:var(--font-size-xs);color:var(--woneasy-text-secondary)}.calendar-legend>span{display:flex;align-items:center;gap:.3rem}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.present{background:var(--status-present)}.legend-dot.late{background:var(--status-late)}.legend-dot.absent{background:var(--status-absent)}.legend-dot.excused{background:var(--status-excused)}@media (max-width: 720px){.history-modal{max-height:90vh}.history-table{font-size:var(--font-size-xs)}.history-table th,.history-table td{padding:.4rem .25rem}}.attendance-action-buttons{display:flex;flex-wrap:nowrap;align-items:stretch;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.attendance-action-buttons .history-btn,.attendance-action-buttons .add-attendance-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem;border-radius:8px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease;white-space:nowrap;height:40px;box-sizing:border-box;margin:0;width:auto}.attendance-action-buttons .history-btn{background:#fff;color:#5bbfba;border:1px solid #e0e0e0}.attendance-action-buttons .history-btn:hover{border-color:#5bbfba;background:#5bbfba0d;color:#5bbfba}.attendance-action-buttons .add-attendance-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:1px solid transparent}.attendance-action-buttons .add-attendance-btn:hover{box-shadow:0 4px 12px #10b9814d}.attendance-index{font-size:.75rem;color:#6366f1;font-weight:600;margin-left:.25rem}.enrollment-page{max-width:1400px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-title h1{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:.25rem}.page-title p{color:#888;font-size:.9rem}.enrollment-summary{background:var(--woneasy-bg-white);border-radius:var(--panel-radius);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--woneasy-border-light)}.summary-row{display:flex;align-items:center;justify-content:space-between}.summary-stats{display:flex;gap:.5rem}.stat-item{display:flex;align-items:center;gap:.5rem}.stat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.stat-dot.not-enrolled{background:#2196f3}.stat-dot.enrolled{background:#4caf50}.stat-dot.paused{background:#ffc107}.stat-dot.dropped{background:#f44336}.stat-dot.graduated,.stat-dot.completed{background:#9e9e9e}.stat-label{font-size:.9rem;color:#666;line-height:1;margin-top:0}.stat-count{font-size:1.1rem;font-weight:700;color:#333;margin-left:.25rem;line-height:1}.search-section{display:flex;align-items:center}.filter-btn{padding:.5rem 1rem;background:#f5f7fa;border:1px solid #e8e8e8;border-radius:8px;color:#666;cursor:pointer;font-size:.85rem;transition:all .2s}.filter-btn:hover{background:#eef1f4;border-color:#ddd}.filter-btn.active{background:#5bbfba;border-color:#5bbfba;color:#fff}.search-input{padding:.5rem 1rem .5rem 2.25rem;border:1px solid #e8e8e8;border-radius:8px;font-size:.85rem;width:200px;background:#f5f7fa url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23999' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E") no-repeat .75rem center}.search-input:focus{outline:none;border-color:#5bbfba;background-color:#fff}.search-wrapper{position:relative;flex:1;min-width:180px}.search-wrapper .search-input{width:100%}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e8e8e8;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;z-index:1000;margin-top:4px}.search-result-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .2s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#f5f7fa}.search-result-name{font-weight:600;font-size:.9rem;color:#333;margin-bottom:.25rem}.search-result-class{font-size:.75rem;color:#888;display:flex;align-items:center;gap:.25rem}.search-result-class i{color:#5bbfba;font-size:.7rem}.search-result-empty{padding:1rem;text-align:center;color:#999;font-size:.85rem}.enrollment-page .panel{background:var(--woneasy-bg-white);border-radius:var(--panel-radius);box-shadow:var(--shadow-sm);border:1px solid var(--woneasy-border-light);display:flex;flex-direction:column;overflow:hidden}.enrollment-page .panel-header{padding:.2rem 1rem;font-weight:600;color:var(--woneasy-text-primary);border-bottom:1px solid var(--woneasy-border-light);display:flex;align-items:center;justify-content:space-between;background:#f5a26b33;min-height:52px;box-sizing:border-box;border-radius:var(--panel-radius) var(--panel-radius) 0 0}.enrollment-page .panel-header .count{font-weight:400;color:#888;font-size:.9rem}.enrollment-page .panel-header-left{display:flex;align-items:center;gap:.5rem}.enrollment-page .panel-title{font-weight:600}.btn-add-student{display:flex;align-items:center;gap:.375rem;padding:.35rem .75rem;background:linear-gradient(135deg,#5bbfba,#4ab0ab);border:none;border-radius:6px;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-add-student:hover{transform:translateY(-1px);box-shadow:0 3px 8px #5bbfba59}.enrollment-page .panel-content{flex:1;overflow-y:auto;padding:.5rem}.enrollment-page .class-list-panel .panel-content,.enrollment-page .enrollment-list-panel .panel-content{padding:0}.enrollment-page .class-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-bottom:1px solid var(--woneasy-border-lighter);cursor:pointer;transition:all .2s}.enrollment-page .class-item:hover{background:var(--woneasy-bg-hover)}.enrollment-page .class-item.active{background:var(--woneasy-primary-light);border-left:3px solid var(--woneasy-primary)}.enrollment-page .class-icon{width:32px;height:32px;background:linear-gradient(135deg,#f5a26b,#e89555);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-md);flex-shrink:0}.enrollment-page .class-icon.math,.enrollment-page .class-icon.수학{background:linear-gradient(135deg,#5bbfba,#4ab0ab)}.enrollment-page .class-icon.english,.enrollment-page .class-icon.영어{background:linear-gradient(135deg,#7c8ce8,#6670d8)}.enrollment-page .class-icon.science,.enrollment-page .class-icon.과학{background:linear-gradient(135deg,#f5a26b,#e89555)}.enrollment-page .class-info{flex:1;min-width:0}.enrollment-page .class-name{font-weight:600;color:var(--woneasy-text-primary);font-size:var(--font-size-base);margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.enrollment-page .class-meta{display:flex;gap:.6rem;font-size:var(--font-size-xs);color:var(--woneasy-text-muted)}.enrollment-page .class-meta i{margin-right:.2rem}.enrollment-page .class-student-count{background:#f0f0f0;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600;color:#666;flex-shrink:0}.class-info-summary{padding:.875rem 1.25rem;background:#fafbfc;border-bottom:1px solid #f0f0f0}.class-info-row{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:.5rem}.class-fee-type{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600}.class-meta-item{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:#666}.class-meta-item i{color:#999}.class-status-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;background:#f0f0f0;color:#888}.class-status-badge.active{background:#388e3c1f;color:#388e3c}.class-info-summary{padding:.5rem 1rem;background:#fafbfc;border-bottom:1px solid #f0f0f0;font-size:.75rem}.class-info-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.25rem}.class-info-row:last-child{margin-bottom:0}.class-fee-type{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border-radius:4px;font-size:.65rem;font-weight:600}.class-fee-type.session{background:#7c8ce81a;color:#6670d8}.class-fee-type.monthly{background:#5bbfba1a;color:#4ab0ab}.class-meta-item{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:#666}.class-meta-item i{color:#999;font-size:.7rem}.class-meta-item.tuition{color:#333}.class-meta-item.tuition strong{color:#5bbfba}.class-description{font-size:.75rem;color:#888;line-height:1.4;margin-top:.25rem}.enrollment-card{background:#fff;border:none;border-bottom:1px solid var(--woneasy-border-lighter);border-radius:0;padding:.875rem 1rem;margin-bottom:0;cursor:pointer;transition:background var(--transition-base)}.enrollment-card:hover{background:var(--woneasy-bg-hover)}.enrollment-card.selected{background:var(--woneasy-primary-light)}.enrollment-card.completed{opacity:.7}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.student-info{display:flex;align-items:center;gap:.75rem}.student-avatar{width:44px;height:44px;background:linear-gradient(135deg,#5bbfba,#4ab0ab);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.1rem;flex-shrink:0}.enrollment-page .student-name-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;flex-wrap:nowrap;width:fit-content}.enrollment-page .student-name{font-weight:600;color:#333;font-size:1rem}.enrollment-page .status-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;flex-shrink:0;white-space:nowrap}.status-badge.enrolled{background:#4caf501f;color:#388e3c}.status-badge.paused{background:#ffc10726;color:#f9a825}.status-badge.completed{background:#9e9e9e26;color:#757575}.student-enrollment-info{display:flex;flex-wrap:wrap;gap:1rem}.enrollment-date{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:#888}.enrollment-date i{font-size:.75rem;color:#aaa}.enrollment-date .info-label{color:#999;font-size:.75rem;min-width:auto}.recharge-controls{display:flex;flex-direction:column;align-items:flex-end;gap:.375rem}.recharge-count{font-size:.8rem;color:#888}.btn-recharge-mini{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:linear-gradient(135deg,#5bbfba,#4ab0ab);border:none;border-radius:6px;color:#fff;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-recharge-mini:hover{transform:scale(1.05);box-shadow:0 2px 6px #5bbfba66}.card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;padding-bottom:.75rem}.info-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.info-row i{color:#888;font-size:.9rem}.info-row .info-label{color:#666}.info-row .info-value{color:#333;font-weight:500}.info-row.session-row{grid-column:1 / -1}.session-info{flex:1}.session-bar{display:inline-flex;align-items:center;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.session-segment{display:inline-flex;align-items:center;justify-content:center;gap:3px;padding:4px 0;min-width:36px;min-height:24px;font-size:.85rem;font-weight:600;color:#fff;border-right:1px solid rgba(255,255,255,.3)}.session-segment:last-child{border-right:none}.session-segment i{font-size:.85rem;color:#fff!important}.session-segment.present{background:#4caf50}.session-segment.late{background:#ff9800}.session-segment.absent{background:#e85a5a}.session-segment.excused{background:#2196f3}.session-segment.makeup{background:#81c784}.session-segment.unused{background:#bbb}.card-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e8e8e8}.action-btn{flex:1;padding:.5rem;border:1px solid #e0e0e0;background:#fff;border-radius:8px;font-size:.8rem;color:#666;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.375rem}.action-btn:hover{background:#f5f7fa;border-color:#ccc}.action-btn.pause:hover{background:#ffc1071a;border-color:#ffc107;color:#f9a825}.action-btn.complete:hover{background:#9e9e9e1a;border-color:#9e9e9e;color:#757575}.action-btn.recharge{background:#5bbfba;border-color:#5bbfba;color:#fff}.action-btn.recharge:hover{background:#4ab0ab}.detail-panel .panel-content{padding:1rem}.detail-section{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.detail-section:last-child{border-bottom:none;margin-bottom:0}.detail-section-title{font-size:.85rem;font-weight:600;color:#555;margin-bottom:.75rem;display:flex;align-items:center;gap:.375rem}.detail-section-title i{color:#888}.detail-actions{display:flex;flex-wrap:wrap;gap:.25rem}.detail-actions .action-btn{flex:0 0 auto;padding:.3rem .4rem;font-size:.7rem}.action-btn.transfer:hover{background:#2196f31a;border-color:#2196f3;color:#1976d2}.action-btn.drop:hover{background:#e85a5a1a;border-color:#e85a5a;color:#d32f2f}.action-btn.graduate:hover{background:#9c27b01a;border-color:#9c27b0;color:#7b1fa2}.enrollment-history{display:flex;flex-direction:column;gap:.5rem}.enrollment-page .history-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:#f8f9fa;border-radius:6px;font-size:.8rem}.enrollment-page .history-row{display:flex;align-items:center;gap:.5rem}.history-row.payment-row{padding-left:0}.enrollment-page .history-date{font-size:.75rem;color:#888;min-width:55px}.history-content{flex:1;display:flex;flex-direction:column;gap:.125rem}.history-label{color:#333}.history-amount{font-weight:600;color:#5bbfba}.payment-info{display:flex;align-items:center;gap:.5rem}.payment-date{font-size:.75rem;color:#666}.payment-badge{padding:.2rem .5rem;border-radius:4px;font-size:.65rem;font-weight:600}.payment-badge.paid{background:#4caf501f;color:#388e3c}.payment-badge.unpaid{background:#e85a5a1f;color:#e85a5a}.status-history{display:flex;flex-direction:column;gap:.5rem}.status-history-item{background:#f8f9fa;border-radius:6px;padding:.625rem .75rem;display:grid;grid-template-columns:auto 1fr;gap:.25rem .5rem}.status-history-item .status-badge{font-size:.7rem;padding:.2rem .5rem;display:inline-flex;justify-content:center;align-items:center;grid-row:1;grid-column:1;align-self:start;min-width:45px}.status-history-item .status-badge.enrolled{background:#4caf5026;color:#388e3c;border-radius:4px}.status-history-item .status-badge.paused{background:#ffc10726;color:#f9a825;border-radius:4px}.status-history-item .status-badge.completed{background:#9e9e9e26;color:#757575;border-radius:4px}.history-info{font-size:.8rem;color:#555;grid-row:1;grid-column:2;display:flex;align-items:center;gap:.5rem}.history-delete-btn{background:none;border:none;color:#aaa;cursor:pointer;padding:0 .2rem;font-size:.9rem;line-height:1;opacity:.5;transition:all .2s}.history-delete-btn:hover{color:#e85a5a;opacity:1}.history-edit-btn{background:none;border:none;color:#aaa;cursor:pointer;padding:0 .1rem;font-size:.75rem;line-height:1;opacity:.5;transition:all .2s;margin-left:.3rem}.history-edit-btn:hover{color:#5bbfba;opacity:1}.history-sub{font-size:.75rem;color:#666;grid-column:2;line-height:1.4}.send-actions{display:flex;gap:.5rem}.send-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;font-size:.8rem;color:#666;cursor:pointer}.send-btn:disabled{opacity:.5;cursor:not-allowed}.coming-soon{font-size:.7rem;color:#aaa;margin-top:.5rem;text-align:center}.enrollment-page .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#888;text-align:center}.enrollment-page .empty-state i{font-size:3rem;margin-bottom:1rem;opacity:.4}.enrollment-page .empty-state h3{font-size:1.1rem;color:#666;margin-bottom:.5rem}.enrollment-page .empty-state p{font-size:.9rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.modal-content.modal-sm{max-width:380px}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1.1rem;font-weight:600;color:#333;margin:0}.modal-close{background:none;border:none;color:#888;cursor:pointer;padding:.25rem;font-size:1.1rem;transition:color .2s}.modal-close:hover{color:#333}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-class-info{padding:.75rem 1rem;background:#f8f9fa;border-radius:8px;margin-bottom:1rem;font-size:.9rem;color:#666}.modal-class-info strong{color:#333}.modal-body .search-box{position:relative;margin-bottom:1rem}.modal-body .search-box i{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#999}.modal-body .search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9rem}.modal-body .search-box input:focus{outline:none;border-color:#5bbfba}.modal-body .student-list{max-height:300px;overflow-y:auto}.modal-body .student-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;transition:all .2s}.modal-body .student-item:hover{background:#f5f7fa}.modal-body .student-item.selected{background:#5bbfba1a;border:1px solid rgba(91,191,186,.3)}.student-item .student-avatar{width:40px;height:40px;font-size:1rem}.student-details{flex:1}.student-details .student-name{font-weight:600;font-size:.95rem}.student-details .student-sub{font-size:.8rem;color:#888}.selected-icon{color:#5bbfba;font-size:1.25rem}.no-results{text-align:center;padding:2rem;color:#888;font-size:.9rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end;gap:.75rem}.btn-cancel{padding:.625rem 1.25rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;color:#666;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#eee}.btn-confirm{padding:.625rem 1.25rem;background:linear-gradient(135deg,#5bbfba,#4ab0ab);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-confirm:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 8px #5bbfba59}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}.recharge-info{display:flex;flex-direction:column;gap:1.5rem}.recharge-student{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f8f9fa;border-radius:12px}.recharge-student .student-avatar{width:48px;height:48px;font-size:1.2rem}.recharge-student .student-name{font-weight:600;font-size:1rem;margin-bottom:.25rem}.recharge-student .student-sub{font-size:.8rem;color:#888}.recharge-details{display:flex;flex-direction:column;gap:.75rem}.recharge-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8f9fa;border-radius:8px}.recharge-row span{color:#666}.recharge-row strong{color:#333;font-size:1.05rem}@media (max-width: 991px) and (min-width: 721px){.enrollment-page .class-list-panel{width:140px;min-width:140px}.enrollment-page .class-icon{display:none}.enrollment-page .class-item{gap:.5rem}.enrollment-page .class-name{font-size:.85rem}.enrollment-page .class-meta{font-size:.65rem;flex-wrap:wrap;gap:.2rem .4rem}.enrollment-page .student-avatar{display:none}.enrollment-page .student-info{gap:.5rem}.enrollment-page .student-name{font-size:.9rem}.enrollment-page .student-name-row{flex-wrap:nowrap;gap:.4rem}.enrollment-page .student-enrollment-info{font-size:.7rem;gap:.4rem .6rem;flex-wrap:nowrap;white-space:nowrap}.enrollment-page .status-badge{font-size:.6rem;padding:.1rem .35rem;white-space:nowrap}.enrollment-page .panel-header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.enrollment-page .panel-header-left{flex:1;min-width:0}.enrollment-page .panel-title{font-size:.9rem}.enrollment-page .class-status-badge{font-size:.65rem;padding:.15rem .4rem}.enrollment-page .btn-add-student{padding:.4rem .65rem;font-size:.75rem}.enrollment-page .class-info-summary{padding:.5rem .75rem}.enrollment-page .class-info-row{gap:.5rem .75rem;flex-wrap:wrap}.enrollment-page .class-fee-type{font-size:.65rem;padding:.2rem .5rem}.enrollment-page .class-meta-item{font-size:.75rem}.enrollment-page .enrollment-card{padding:.75rem}.enrollment-page .card-header{flex-wrap:wrap}.enrollment-page .student-info{flex:1;min-width:0}.enrollment-page .student-enrollment-info{flex-direction:row;flex-wrap:wrap;gap:.5rem;font-size:.7rem}.enrollment-page .enrollment-date{font-size:.7rem}.enrollment-page .recharge-controls{gap:.25rem;flex-shrink:0}.enrollment-page .recharge-count{font-size:.7rem}.enrollment-page .btn-recharge-mini{padding:.2rem .4rem;font-size:.65rem}.enrollment-page .session-bar{width:100%;justify-content:space-between}.enrollment-page .session-segment{flex:1;min-width:0;padding:5px 0;font-size:.8rem}.enrollment-page .session-segment i{font-size:.75rem}.enrollment-page .btn-text-full{display:none}.enrollment-page .btn-text-mobile{display:inline}.enrollment-page .detail-actions{display:flex;flex-wrap:nowrap;gap:.25rem}.enrollment-page .detail-actions .action-btn{flex:1;padding:.35rem .25rem;font-size:.65rem;text-align:center;white-space:nowrap}.enrollment-page .detail-actions .action-btn i{display:none}.enrollment-page .payment-info{flex-direction:column;align-items:flex-start;gap:.25rem}.enrollment-page .history-item{font-size:.75rem;padding:.4rem}.enrollment-page .history-date{font-size:.7rem;min-width:50px}.enrollment-page .history-amount{font-size:.75rem}.enrollment-page .payment-badge{font-size:.6rem;padding:.15rem .35rem}}.static-value{font-size:1rem;font-weight:600;color:#333;padding:.5rem 0}.no-classes-message{color:#888;font-size:.9rem;padding:1rem;text-align:center;background:#f5f5f5;border-radius:8px}.transfer-origin-info{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin-bottom:1rem;background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-radius:8px;font-size:.85rem;color:#2e7d32;border-left:3px solid #4caf50}.transfer-origin-info i{font-size:1.1rem}.transfer-origin-info strong{color:#1b5e20}.transfer-link{color:#1976d2;cursor:pointer;text-decoration:underline;transition:color .2s}.transfer-link:hover{color:#1565c0}.enrollment-card.transferred{background:#f5f5f5;border-left:3px solid #bdbdbd}.enrollment-card.transferred .student-name{color:#888}.enrollment-card.transferred .student-avatar{background:#e0e0e0;color:#888}.btn-recharge-mini:disabled{background:#e0e0e0;color:#999;cursor:not-allowed;opacity:.6}@media (max-width: 720px){.enrollment-page .page-title p{display:none}.enrollment-page .enrollment-summary{padding:.75rem 1rem}.enrollment-page .summary-row{flex-direction:column;align-items:stretch;gap:.75rem}.enrollment-page .summary-stats{gap:1rem;justify-content:flex-start}.enrollment-page .stat-label{display:none}.enrollment-page .stat-count{font-size:1rem;margin-left:.15rem}.enrollment-page .filter-section{gap:.375rem;flex-wrap:wrap}.enrollment-page .filter-btn{padding:.35rem .5rem;font-size:.7rem;flex-shrink:0;white-space:nowrap}.enrollment-page .search-input{flex:1 1 100%;min-width:100%;width:100%;font-size:.8rem;padding:.4rem .75rem .4rem 2rem;margin-top:.25rem}.enrollment-page .content-split{flex-wrap:wrap}.enrollment-page .class-list-panel,.enrollment-page .enrollment-list-panel,.enrollment-page .detail-panel{width:100%;min-width:100%;min-height:auto}.enrollment-page .page-header{margin-bottom:1rem}.enrollment-page .page-title h1{font-size:1.1rem}.enrollment-page .class-item{padding:.6rem .75rem}.enrollment-page .class-icon{width:28px;height:28px;font-size:.8rem}.enrollment-page .class-name{font-size:.85rem}.enrollment-page .class-meta{font-size:.7rem;flex-wrap:wrap;gap:.25rem .5rem}.enrollment-page .class-meta span:last-child{display:inline}.enrollment-page .enrollment-list-panel .panel-header{flex-wrap:wrap;gap:.5rem}.enrollment-page .panel-header-left{flex:1;min-width:0}.enrollment-page .panel-title{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.enrollment-page .class-status-badge{font-size:.65rem;padding:.15rem .35rem}.enrollment-page .btn-add-student{padding:.35rem .6rem;font-size:.7rem;flex-shrink:0}.enrollment-page .enrollment-card{padding:.75rem}.enrollment-page .card-header{flex-wrap:wrap}.enrollment-page .student-info{flex:1;min-width:0}.enrollment-page .student-avatar{width:36px;height:36px;font-size:.95rem}.enrollment-page .student-name{font-size:.9rem}.enrollment-page .student-enrollment-info{flex-direction:row;flex-wrap:wrap;gap:.5rem}.enrollment-page .enrollment-date{font-size:.7rem}.enrollment-page .recharge-controls{gap:.25rem;flex-shrink:0}.enrollment-page .recharge-count{font-size:.7rem}.enrollment-page .btn-recharge-mini{padding:.2rem .4rem;font-size:.65rem}.enrollment-page .session-bar{width:100%;justify-content:space-between}.enrollment-page .session-segment{flex:1;min-width:0;padding:5px 0;font-size:.8rem}.enrollment-page .session-segment i{font-size:.75rem}.enrollment-page .class-info-summary{padding:.4rem .75rem}.enrollment-page .class-info-row{gap:.5rem;margin-bottom:.35rem}.enrollment-page .class-info-row:last-child{margin-bottom:0}.enrollment-page .class-fee-type{font-size:.6rem;padding:.15rem .4rem}.enrollment-page .class-meta-item{font-size:.7rem}.enrollment-page .student-avatar,.enrollment-page .btn-text-full{display:none}.enrollment-page .btn-text-mobile{display:inline}}.btn-text-mobile{display:none}.date-input-sm{padding:.375rem .5rem;border:1px solid #ddd;border-radius:6px;font-size:.85rem;color:#333;background:#fff;cursor:pointer}.date-input-sm:focus{outline:none;border-color:#5bbfba;box-shadow:0 0 0 2px #5bbfba26}.payment-page{max-width:1400px}.payment-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.payment-page .page-title h1{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:.25rem}.payment-page .page-title p{color:#888;font-size:.9rem}.payment-page .payment-summary{background:var(--woneasy-bg-white);border-radius:var(--panel-radius);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--woneasy-border-light)}.payment-page .stats-filter-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.625rem;border-bottom:1px solid #f0f0f0}.payment-page .stats-filter-group{display:flex;align-items:center;gap:.5rem}.payment-page .stats-filter-group>i{color:#5bbfba;font-size:.9rem}.payment-page .stats-filter-select{padding:.35rem .625rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.8rem;color:#333;background:#f8f9fa;cursor:pointer;transition:all .2s;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;min-width:90px}.payment-page .stats-filter-select:focus{outline:none;border-color:#5bbfba;background:#fff;box-shadow:0 0 0 2px #5bbfba26}.payment-page .stats-filter-select:hover{border-color:#ccc;background:#f0f2f5}.payment-page .stats-filter-label{font-size:.75rem;color:#999;font-weight:500}.payment-page .summary-row{display:flex;align-items:center;gap:2rem}.payment-page .stat-item{display:flex;align-items:center;gap:.75rem}.payment-page .stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.payment-page .stat-icon.total{background:#5bbfba1a;color:#5bbfba}.payment-page .stat-icon.pending{background:#e85a5a1a;color:#e85a5a}.payment-page .stat-icon.paid{background:#4caf501a;color:#4caf50}.payment-page .stat-info{display:flex;flex-direction:column}.payment-page .stat-label{font-size:.8rem;color:#888}.payment-page .stat-value{font-size:1.1rem;font-weight:700;color:#333}.payment-page .stat-value.pending{color:#e85a5a}.payment-page .stat-value.paid{color:#4caf50}.payment-page .content-split{display:flex;gap:1rem;flex:1;min-height:0;align-items:stretch;height:calc(100vh - 200px);overflow:hidden;margin-bottom:1.5rem}.payment-page .student-list-panel{flex:0 0 280px;width:280px;display:flex;flex-direction:column}.payment-page .payment-history-panel{flex:1;min-width:280px;display:flex;flex-direction:column}.payment-page .payment-detail-panel{width:340px;flex-shrink:0;display:flex;flex-direction:column;min-height:645px;max-height:929px}.payment-page .panel{background:var(--woneasy-bg-white);border-radius:var(--panel-radius);box-shadow:var(--shadow-sm);border:1px solid var(--woneasy-border-light);display:flex;flex-direction:column;overflow:hidden;height:100%}.payment-page .panel-header{padding:1rem 1.25rem;background:#f5a26b33;font-weight:600;color:#333;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between;border-radius:var(--panel-radius) var(--panel-radius) 0 0}.payment-page .panel-header .count{font-weight:400;color:#888;font-size:.9rem}.payment-page .panel-header-left{display:flex;align-items:center;gap:.5rem}.payment-page .panel-title{font-weight:600}.payment-page .panel-content{flex:1;min-height:0;overflow-y:auto;padding:.5rem}.payment-page .student-list-panel .panel-content{padding:0;overflow-y:auto;scrollbar-width:none}.payment-page .student-list-panel .panel-content::-webkit-scrollbar{width:6px;background:transparent}.payment-page .student-list-panel .panel-content::-webkit-scrollbar-thumb{background:transparent;border-radius:3px;transition:background .2s}.payment-page .student-list-panel .panel-content:hover{scrollbar-width:thin}.payment-page .student-list-panel .panel-content:hover::-webkit-scrollbar-thumb{background:#0003}.payment-page .student-list-panel .panel-content:hover::-webkit-scrollbar-thumb:hover{background:#00000059}.payment-page .filter-row{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border-bottom:1px solid #f0f0f0}.payment-page .filter-row .search-input{flex:1;min-width:0;padding:.375rem .5rem;border:1px solid #e8e8e8;border-radius:6px;font-size:.75rem;background:#f5f7fa}.payment-page .filter-row .search-input:focus{outline:none;border-color:#5bbfba;background-color:#fff}.payment-page .filter-tab{padding:.375rem .75rem;border:none;background:#f5f7fa;border-radius:6px;font-size:.75rem;color:#666;cursor:pointer;transition:all .2s}.payment-page .filter-tab:hover{background:#eef1f4}.payment-page .filter-tab.active{background:#5bbfba;color:#fff}.payment-page .student-list{padding:0;display:block;text-align:left;max-height:none;overflow-y:visible}.payment-page .student-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;box-sizing:border-box;padding:.625rem .75rem;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:.25rem;border:1px solid transparent}.payment-page .student-item:hover{background:#f5f7fa}.payment-page .student-item.active{background:#5bbfba14;border-color:#5bbfba4d}.payment-page .student-item-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.payment-page .student-avatar{width:36px;height:36px;background:linear-gradient(135deg,#5bbfba,#4ab0ab);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.85rem;flex-shrink:0}.payment-page .student-info{flex:1;min-width:0}.payment-page .student-name{flex:1;font-weight:600;color:#333;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payment-page .student-meta{font-size:.75rem;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payment-page .student-item-footer{display:flex;align-items:center;justify-content:space-between;padding-left:calc(36px + .75rem)}.payment-page .due-date{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#888}.payment-page .due-date i{font-size:.7rem;color:#aaa}.payment-page .unpaid-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:#e85a5a1a;color:#e85a5a;border-radius:4px;font-size:.7rem;font-weight:600}.payment-page .paid-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:#4caf501a;color:#4caf50;border-radius:4px;font-size:.7rem;font-weight:600}.payment-page .payment-history-panel .panel-header.compact{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:nowrap;background:#f5a26b33;border-bottom:1px solid #f0f0f0;padding:.8rem 1rem}.payment-page .payment-history-panel .panel-header.compact .name{font-weight:600;font-size:1rem;color:#333}.payment-page .payment-history-panel .header-stats{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap;background:#fff;padding:.25rem .5rem;border-radius:6px;border:1px solid #e8e8e8}.payment-page .payment-history-panel .header-stats .stat-item{font-size:.75rem;color:#666;background:transparent;padding:0;border:none;white-space:nowrap}.payment-page .payment-history-panel .header-stats .stat-item em{font-style:normal;font-weight:600}.payment-page .payment-history-panel .header-stats .stat-item em.total{color:#333}.payment-page .payment-history-panel .header-stats .stat-item em.pending{color:#e85a5a}.payment-page .payment-history-panel .header-stats .stat-item em.paid{color:#4caf50}.payment-page .stats-bar{display:flex;gap:1rem;padding:.5rem .75rem;background:#fff;border-radius:8px}.payment-page .stats-bar-item{display:flex;align-items:center;gap:.5rem}.payment-page .stats-bar-label{font-size:.75rem;color:#666}.payment-page .stats-bar-value{font-size:.85rem;font-weight:600}.payment-page .stats-bar-value.total{color:#333}.payment-page .stats-bar-value.pending{color:#e85a5a}.payment-page .stats-bar-value.paid{color:#4caf50}.payment-page .payment-list{padding:1rem}.payment-page .payment-card{background:#f8f9fa;border-radius:12px;padding:1rem 1.25rem;margin-bottom:.75rem;transition:all .2s;border:1px solid transparent;cursor:pointer}.payment-page .payment-card:hover{background:#f0f2f5;border-color:#e0e0e0}.payment-page .payment-card.selected{border-color:#5bbfba;background:#5bbfba0d}.payment-page .payment-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.payment-page .payment-title{font-weight:600;color:#333;font-size:.95rem;margin-bottom:.25rem}.payment-page .payment-class{font-size:.8rem;color:#888}.payment-page .status-badge{padding:.25rem .625rem;border-radius:12px;font-size:.7rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.payment-page .status-badge.pending{background:#e85a5a1a;color:#e85a5a}.payment-page .status-badge.paid{background:#4caf501a;color:#4caf50}.payment-page .status-badge.partial{background:#ff98001a;color:#ff9800}.payment-page .status-badge.overdue{background:#9c27b01a;color:#9c27b0}.payment-page .status-badge.cancelled{background:#9e9e9e1a;color:#9e9e9e}.payment-page .status-badge.refunded{background:#2196f31a;color:#2196f3}.payment-page .payment-card-body{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding-top:.75rem;border-top:1px solid #e8e8e8}.payment-page .payment-info-item{display:flex;flex-direction:column;gap:.125rem}.payment-page .payment-info-label{font-size:.7rem;color:#999}.payment-page .payment-info-value{font-size:.85rem;color:#333;font-weight:500}.payment-page .payment-info-value.amount{color:#5bbfba;font-weight:600}.payment-page .payment-info-value.unpaid{color:#e85a5a}.payment-page .payment-card-footer{margin-top:.75rem;padding-top:.5rem;border-top:1px solid #e8e8e8;font-size:.75rem;color:#999}.payment-page .due-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500}.payment-page .due-badge.waiting{background:#4caf501a;color:#4caf50}.payment-page .due-badge.today{background:#ff98001a;color:#ff9800}.payment-page .due-badge.overdue{background:#f443361a;color:#f44336}.payment-page .payment-detail-panel .panel-content{padding:1.25rem}.payment-page .detail-section{margin-bottom:1.5rem}.payment-page .detail-section-title{font-size:.8rem;color:#888;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #f0f0f0}.payment-page .detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.payment-page .detail-label{font-size:.85rem;color:#666}.payment-page .detail-value{font-size:.85rem;color:#333;font-weight:500}.payment-page .detail-value.highlight{color:#5bbfba;font-weight:600;font-size:1rem}.payment-page .detail-value.discount{color:#e85a5a}.payment-page .memo-box{background:#f8f9fa;border-radius:8px;padding:.75rem;font-size:.85rem;color:#666;min-height:60px}.payment-page .action-buttons{display:flex;flex-direction:column;gap:.5rem;padding-top:1rem;border-top:1px solid #f0f0f0}.payment-page .btn-action{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}.payment-page .btn-action.primary{background:linear-gradient(135deg,#5bbfba,#4ab0ab);color:#fff}.payment-page .btn-action.primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5bbfba59}.payment-page .btn-action.secondary{background:#f5f7fa;color:#666;border:1px solid #e8e8e8}.payment-page .btn-action.secondary:hover{background:#eef1f4;border-color:#ddd}.payment-page .btn-action.danger{background:#e85a5a1a;color:#e85a5a}.payment-page .btn-action.danger:hover{background:#e85a5a33}.payment-page .btn-row{display:flex;gap:.5rem}.payment-page .btn-row .btn-action{flex:1}.payment-page .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:2rem;text-align:center;color:#999}.payment-page .empty-state i{font-size:3rem;margin-bottom:1rem;color:#ddd}.payment-page .empty-state p{font-size:.9rem}.payment-page .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.payment-page .modal-content{background:#fff;border-radius:16px;width:90%;max-width:400px;box-shadow:0 20px 50px #0003}.payment-page .modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between}.payment-page .modal-header h3{font-size:1.1rem;font-weight:600;margin:0}.payment-page .modal-close{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;line-height:1}.payment-page .modal-close:hover{color:#333}.payment-page .modal-body{padding:1.5rem}.payment-page .form-group{margin-bottom:1rem}.payment-page .form-group label{display:block;font-size:.85rem;color:#666;margin-bottom:.5rem;font-weight:500}.payment-page .form-group input,.payment-page .form-group select{width:100%;padding:.625rem .875rem;border:1px solid #e8e8e8;border-radius:8px;font-size:.9rem}.payment-page .form-group input:focus,.payment-page .form-group select:focus{outline:none;border-color:#5bbfba}.payment-page .modal-footer{padding:1rem 1.5rem;border-top:1px solid #f0f0f0;display:flex;gap:.75rem;justify-content:flex-end}.payment-page .btn-modal{padding:.625rem 1.25rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem}.payment-page .btn-modal.cancel{background:#f5f7fa;color:#666}.payment-page .btn-modal.confirm{background:linear-gradient(135deg,#5bbfba,#4ab0ab);color:#fff}.payment-page .conditional-fields{margin-top:.25rem;margin-bottom:1rem;padding:.875rem;border-radius:10px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.payment-page .conditional-fields.card-fields{background:#2196f30f;border:1px solid rgba(33,150,243,.15)}.payment-page .conditional-fields.cash-fields{background:#4caf500f;border:1px solid rgba(76,175,80,.15)}.payment-page .conditional-fields-header{font-size:.8rem;font-weight:600;color:#555;margin-bottom:.75rem;display:flex;align-items:center;gap:.35rem}.payment-page .conditional-fields.card-fields .conditional-fields-header{color:#1976d2}.payment-page .conditional-fields.cash-fields .conditional-fields-header{color:#388e3c}.payment-page .conditional-fields .form-group{margin-bottom:.75rem}.payment-page .conditional-fields .form-group:last-child{margin-bottom:0}.payment-page .checkbox-group{margin-bottom:.75rem}.payment-page .checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;color:#333}.payment-page .checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#4CAF50;cursor:pointer}.payment-page .conditional-fields-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;animation:slideDown .2s ease-out}.payment-page .conditional-fields-row .form-group{margin-bottom:0}.payment-page .detail-value.receipt-issued{color:#4caf50;font-weight:600;font-size:.8rem;background:#4caf501a;padding:.125rem .5rem;border-radius:4px}.payment-page .loading-spinner{display:flex;align-items:center;justify-content:center;padding:2rem;color:#888}@media (max-width: 1280px){.payment-page .content-split{grid-template-columns:220px 1fr 300px}}@media (max-width: 1400px){.payment-page .payment-history-panel .panel-header.compact{flex-wrap:nowrap;gap:.5rem;align-items:center;padding:.75rem 1rem}.payment-page .payment-history-panel .panel-header.compact .name{flex:0 0 auto;white-space:nowrap}.payment-page .payment-history-panel .header-stats{flex-wrap:nowrap;gap:.5rem;font-size:.75rem;margin-left:auto;overflow:hidden}.payment-page .payment-history-panel .header-stats .stat-item{max-width:none;flex:none;white-space:nowrap}.payment-page .payment-history-panel .header-stats .stat-item:first-child,.payment-page .payment-history-panel .header-stats .stat-item:nth-child(2){display:none}}@media (max-width: 1200px){.payment-page .payment-detail-panel{width:280px}.payment-page .student-list-panel{flex:0 0 240px;width:240px}.payment-page .student-list-panel .filter-row{flex-wrap:wrap;gap:.5rem}.payment-page .student-list-panel .filter-row .search-input{flex:0 0 100%;width:100%;order:-1}.payment-page .student-list-panel .filter-row .filter-tab{flex:1;padding:.4rem .5rem;font-size:.8rem;white-space:nowrap}.payment-page .payment-history-panel .panel-header.compact{flex-wrap:nowrap;gap:.5rem;align-items:center}.payment-page .payment-history-panel .panel-header.compact .name{flex:0 0 auto;font-size:1rem}.payment-page .payment-history-panel .header-stats{flex-wrap:nowrap;gap:.5rem;font-size:.75rem;margin-left:auto}.payment-page .payment-history-panel .header-stats .stat-item{max-width:none;flex:none}.payment-page .payment-history-panel .header-stats .stat-item:first-child,.payment-page .payment-history-panel .header-stats .stat-item:nth-child(2){display:none}.payment-page .payment-history-panel .payment-list{padding:.25rem}.payment-page .payment-history-panel .payment-list>div{padding:.75rem .5rem}.payment-page .content-split{height:auto;max-height:calc(100vh - 280px);overflow:visible}}@media (max-width: 991px){.payment-page .content-split{gap:.5rem}.payment-page .student-list-panel{flex:0 0 200px;width:200px}.payment-page .payment-detail-panel{width:240px}.payment-page .stat-label{font-size:.7rem}.payment-page .stat-value{font-size:.95rem}}@media (max-width: 991px) and (min-width: 721px){.payment-page .student-list-panel{flex:0 0 160px;width:160px}.payment-page .payment-detail-panel{width:200px;min-height:auto;max-height:none}.payment-page .payment-history-panel .panel-header.compact{flex-wrap:nowrap;gap:.5rem;align-items:center}.payment-page .payment-history-panel .panel-header.compact .name{flex:0 0 auto;font-size:.95rem}.payment-page .payment-history-panel .header-stats{flex-wrap:nowrap;gap:.5rem;font-size:.7rem;margin-left:auto}.payment-page .payment-history-panel .header-stats .stat-item{max-width:none;flex:none}.payment-page .student-list-panel .filter-row{flex-wrap:wrap;gap:.5rem}.payment-page .student-list-panel .filter-row .search-input{flex:0 0 100%;width:100%;order:-1}.payment-page .student-list-panel .filter-row .filter-tab{flex:1;padding:.35rem .5rem;font-size:.75rem;white-space:nowrap}.payment-page .payment-history-panel .header-stats .stat-item:first-child,.payment-page .payment-history-panel .header-stats .stat-item:nth-child(2){display:none}.payment-page .payment-history-panel .header-stats .stat-item:nth-child(3),.payment-page .payment-history-panel .header-stats .stat-item:nth-child(4){display:inline}.payment-page .payment-history-panel .payment-list{padding:.25rem}.payment-page .payment-history-panel .payment-list>div{padding:.75rem .5rem}.payment-page .payment-detail-panel .action-buttons{gap:.5rem}.payment-page .payment-detail-panel .btn-action{padding:.5rem;font-size:.7rem;white-space:nowrap}.payment-page .payment-detail-panel .btn-row{flex-direction:column;gap:.5rem}.payment-page .payment-detail-panel .btn-row .btn-action{flex:1}}@media (max-width: 720px){.payment-page .content-split{flex-wrap:wrap!important;height:auto!important;overflow:visible!important;flex-direction:column!important;max-height:none!important}.payment-page .student-list-panel,.payment-page .payment-history-panel,.payment-page .payment-detail-panel{width:100%!important;flex:0 0 100%!important;min-width:100%!important;min-height:auto!important;max-height:none!important}.payment-page .student-list-panel{max-height:260px!important;overflow-y:auto}.payment-page .payment-history-panel{min-height:auto;max-height:320px!important;overflow-y:auto}.payment-summary{padding:.5rem .75rem!important;margin-bottom:.5rem!important}.payment-page .stats-filter-row{margin-bottom:.5rem!important;padding-bottom:.375rem!important}.payment-page .stats-filter-select{font-size:.75rem!important;min-width:70px!important;padding:.25rem .4rem!important}.payment-page .stats-filter-label{font-size:.65rem!important}.payment-page .stats-filter-group>i{font-size:.75rem!important}.payment-summary .summary-row{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:.5rem!important;justify-content:space-between!important;align-items:center!important}.payment-summary .stat-item{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:.35rem!important;padding:.4rem .5rem!important;flex:1!important;max-width:none!important;background:transparent!important;border-radius:0!important}.payment-summary .stat-item:first-child{flex:1!important;width:auto!important}.payment-summary .stat-icon{width:22px!important;height:22px!important;font-size:.75rem!important;border-radius:6px!important}.payment-summary .stat-info{display:flex!important;flex-direction:row!important;align-items:center!important;gap:0!important}.payment-summary .stat-label{display:none!important}.payment-summary .stat-value{font-size:.8rem!important;font-weight:600!important}.payment-page .page-title p{display:none}.payment-page .page-title h1{font-size:1.1rem}.payment-page .payment-history-panel .panel-header.compact{flex-wrap:wrap!important;gap:.5rem!important;padding:.75rem 1rem!important;align-items:center!important}.payment-page .payment-history-panel .panel-header.compact .name{font-size:1rem!important;font-weight:600!important}.payment-page .payment-history-panel .header-stats{display:flex!important;flex-wrap:nowrap!important;gap:0!important;font-size:.7rem!important;margin-left:auto!important;padding:.2rem .4rem!important}.payment-page .payment-history-panel .header-stats .stat-item:first-child,.payment-page .payment-history-panel .header-stats .stat-item:nth-child(2){display:none!important}.payment-page .payment-history-panel .header-stats .stat-item:nth-child(3),.payment-page .payment-history-panel .header-stats .stat-item:nth-child(4){display:inline!important;white-space:nowrap!important;padding:0 .4rem!important;max-width:none!important;flex:none!important;min-width:auto!important}.payment-page .payment-history-panel .payment-list{padding:0!important}.payment-page .payment-history-panel .payment-list>div{padding:1rem .5rem!important}.payment-page .payment-item{padding:.75rem}.payment-page .payment-item-header{flex-wrap:wrap;gap:.25rem}.payment-page .payment-item-title{font-size:.85rem}.payment-page .payment-item-details{font-size:.75rem;gap:.5rem;flex-wrap:wrap}.payment-page .payment-detail-panel{display:flex!important;flex-direction:column!important;min-height:350px!important;height:auto!important;max-height:none!important;overflow:visible!important;margin-bottom:1rem!important;visibility:visible!important;opacity:1!important}.payment-page .payment-detail-panel.panel{height:auto!important;overflow:visible!important}.payment-page .content-split{margin-bottom:1rem;overflow:visible!important}}@media (max-width: 991px) and (orientation: landscape){.payment-page .content-split{height:auto!important;max-height:none!important;overflow:visible!important;margin-bottom:80px!important}.payment-page{padding-bottom:60px!important}}*{margin:0;padding:0;box-sizing:border-box}
