.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;padding:12px}.modal-content{background-color:#fff!important;padding:20px;border-radius:8px;width:80%;max-width:800px;max-height:90vh;overflow-y:auto;overflow-x:hidden;position:relative;border:1px solid #ccc}.modal-close{position:absolute;top:10px;right:10px;border:none;background:none;font-size:1.5rem;cursor:pointer}.modal-table-container{max-height:70vh;overflow-y:auto;overflow-x:auto;margin-top:15px;border-radius:8px;border:1px solid var(--border-color)}@media(max-width:768px){.modal-content{width:calc(100vw - 24px);max-width:calc(100vw - 24px);padding:16px;max-height:92vh}}.notification{position:fixed;bottom:20px;right:20px;background-color:#4bb543;color:#fff;padding:15px 20px;border-radius:5px;z-index:10000;box-shadow:0 4px 8px #0003;font-size:1rem}.stat-card-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:0 1px 3px #0000000d}.stat-card-icon{border-radius:8px;padding:12px;display:flex;align-items:center;justify-content:center}.stat-card-icon svg{color:currentColor}.stat-card-content{display:flex;flex-direction:column}.stat-card-title{font-size:.875rem;font-weight:500;color:#64748b;text-transform:uppercase}.stat-card-value{font-size:2.25rem;font-weight:700;color:#1e293b;line-height:1.2}.stat-card-container.stat-card-compact{padding:1.1rem 1.2rem;gap:.8rem}.stat-card-container.stat-card-compact .stat-card-icon{padding:9px}.stat-card-container.stat-card-compact .stat-card-icon svg{width:20px;height:20px}.stat-card-container.stat-card-compact .stat-card-title{font-size:.8rem}.stat-card-container.stat-card-compact .stat-card-value{font-size:1.75rem}.stat-card-trend{display:flex;align-items:center;gap:4px;font-size:.875rem;margin-top:4px}.trend-up{color:#16a34a}.trend-down{color:#dc2626}.subtext{color:#64748b}.bg-yellow-100{background-color:#fef9c3}.text-yellow-600{color:#ca8a04}@media(max-width:768px){.stat-card-container{padding:.875rem;gap:.625rem;border-radius:10px}.stat-card-icon{padding:8px;border-radius:6px}.stat-card-icon svg{width:18px;height:18px}.stat-card-title{font-size:.72rem;letter-spacing:.02em}.stat-card-value{font-size:1.5rem;line-height:1.15}.stat-card-container.stat-card-compact{padding:.8rem;gap:.55rem}.stat-card-container.stat-card-compact .stat-card-icon{padding:7px}.stat-card-container.stat-card-compact .stat-card-icon svg{width:16px;height:16px}.stat-card-container.stat-card-compact .stat-card-title{font-size:.68rem}.stat-card-container.stat-card-compact .stat-card-value{font-size:1.3rem}.stat-card-trend{font-size:.75rem;margin-top:2px;flex-wrap:wrap}}.filter-controls{display:flex;gap:15px;align-items:flex-end}.filter-group label{margin-bottom:5px;font-size:.9rem;color:#666}.filter-group select,.filter-group input{padding:8px 12px;border:1px solid var(--border-color);border-radius:5px;font-size:1rem}.stat-cards-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:24px;margin-bottom:30px}@media(max-width:768px){.stat-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:20px}}@media(max-width:520px){.stat-cards-grid{grid-template-columns:1fr}}@media(max-width:768px){.mobile-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}}@media(max-width:420px){.mobile-kpi-grid{grid-template-columns:1fr}}@media(min-width:768px){.stat-cards-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.stat-cards-grid{grid-template-columns:repeat(4,1fr)}}.breakdown-grid{display:grid;grid-template-columns:1fr;gap:30px}@media(min-width:768px){.breakdown-grid{grid-template-columns:1fr 1fr}}.overview-summary-dual-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:stretch;margin-bottom:24px}@media(min-width:1024px){.overview-summary-dual-grid{grid-template-columns:1fr 1fr;align-items:start}}.overview-summary-card{display:flex;flex-direction:column;height:100%;overflow:hidden}.overview-summary-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin:auto -20px -20px;padding:12px 18px;background-color:#f4f7fb;border-top:1px solid #e7edf6}.overview-summary-footer-label{color:#64748b;font-size:.875rem}.overview-summary-footer-value{font-weight:700;font-size:1.125rem}.overview-summary-footer-value-danger{color:#ef4444}.overview-summary-footer-value-info{color:#2563eb}.overview-card-tag{display:inline-flex;align-items:center;margin-left:10px;padding:6px 10px;border-radius:6px;background-color:#f1f5f9;color:#64748b;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;vertical-align:middle}.overview-paused-alert{margin-bottom:20px;display:flex;flex-direction:column;gap:10px;background-color:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:14px;padding:14px 16px}.overview-warning-alert{margin-bottom:20px;display:flex;flex-direction:column;gap:10px;border-radius:14px;padding:14px 16px}.overview-warning-alert-amber{background-color:#fff7ed;color:#c2410c;border:1px solid #fdba74}.overview-warning-alert-yellow{background-color:#fefce8;color:#854d0e;border:1px solid #fef08a}.overview-warning-alert-header{display:flex;align-items:center;gap:10px;cursor:pointer;justify-content:space-between}.overview-warning-alert-title{display:flex;align-items:center;gap:10px;min-width:0;font-weight:600}.overview-warning-list{display:flex;flex-direction:column;gap:8px;padding-top:4px}.overview-warning-link{text-decoration:none}.overview-warning-card{display:grid;grid-template-columns:86px minmax(170px,1.1fr) minmax(170px,1fr) 20px minmax(190px,1fr) auto;align-items:center;gap:14px;border-radius:12px;padding:14px 16px;transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease}.overview-warning-card-amber{background-color:#fff;border:1px solid #fed7aa;color:#9a3412}.overview-warning-card-yellow{background-color:#fff;border:1px solid #fde68a;color:#854d0e}.overview-warning-link:hover .overview-warning-card-amber{background-color:#fffaf5;border-color:#fdba74;box-shadow:0 10px 24px #c2410c1f}.overview-warning-link:hover .overview-warning-card-yellow{background-color:#fffef2;border-color:#facc15;box-shadow:0 10px 24px #a162071f}.overview-warning-code{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:6px 10px;border-radius:8px;font-weight:700;font-size:.95rem}.overview-warning-code-amber{background-color:#ffedd5;color:#c2410c}.overview-warning-code-yellow{background-color:#fef3c7;color:#a16207}.overview-warning-subject,.overview-warning-meta{display:inline-flex;align-items:center;gap:8px;min-width:0;color:#334155}.overview-warning-subject,.overview-warning-meta{justify-self:stretch}.overview-warning-subject span,.overview-warning-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-warning-text-block{display:flex;flex-direction:column;min-width:0}.overview-warning-text-block>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-warning-subline{margin-top:2px;color:#64748b;font-size:.82rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-warning-separator{color:#cbd5e1;font-weight:700}.overview-warning-action{justify-self:end;color:#2563eb;font-size:.9rem;font-weight:700;opacity:0;transform:translate(-6px);transition:opacity .16s ease,transform .16s ease;white-space:nowrap}.overview-warning-link:hover .overview-warning-action,.overview-warning-link:focus-visible .overview-warning-action{opacity:1;transform:translate(0)}.overview-paused-alert-header{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.overview-paused-alert-title{display:flex;align-items:center;gap:10px;min-width:0;font-weight:600}.overview-paused-alert-controls{display:inline-flex;align-items:center;gap:12px;flex-shrink:0}.overview-paused-alert-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:999px;background-color:#3b82f61f;color:#1d4ed8;font-weight:700;font-size:.92rem}.overview-warning-alert-count-amber{background-color:#fb923c2e;color:#c2410c}.overview-warning-alert-count-yellow{background-color:#facc1538;color:#a16207}.overview-paused-class-list{display:flex;flex-direction:column;gap:8px;padding-top:4px}.overview-paused-class-link{text-decoration:none}.overview-paused-class-card{display:grid;grid-template-columns:86px minmax(170px,1.1fr) minmax(170px,1fr) 20px minmax(190px,1fr) auto;align-items:center;gap:14px;border:1px solid #dbeafe;border-radius:12px;background-color:#fff;padding:14px 16px;color:#1e3a8a;transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease}.overview-paused-class-link:hover .overview-paused-class-card{background-color:#f8fbff;border-color:#bfdbfe;box-shadow:0 10px 24px #2563eb1f}.overview-paused-class-action{justify-self:end;color:#2563eb;font-size:.9rem;font-weight:700;opacity:0;transform:translate(-6px);transition:opacity .16s ease,transform .16s ease;white-space:nowrap}.overview-paused-class-link:hover .overview-paused-class-action,.overview-paused-class-link:focus-visible .overview-paused-class-action{opacity:1;transform:translate(0)}.overview-paused-class-code{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:6px 10px;border-radius:8px;background-color:#dbeafe;color:#1d4ed8;font-weight:700;font-size:.95rem}.overview-paused-class-subject,.overview-paused-class-meta{display:inline-flex;align-items:center;gap:8px;color:#334155;min-width:0}.overview-paused-class-subject span,.overview-paused-class-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-paused-class-separator{color:#cbd5e1;font-weight:700}@media(max-width:768px){.overview-summary-footer{margin:auto -20px -20px;padding:12px 14px}.overview-summary-footer-label{font-size:.82rem}.overview-summary-footer-value{font-size:1rem}.overview-card-tag{margin-left:8px;padding:5px 8px;font-size:.68rem}.overview-paused-alert,.overview-warning-alert{padding:12px 14px;border-radius:12px}.overview-paused-alert-header,.overview-warning-alert-header{align-items:flex-start}.overview-paused-alert-title,.overview-warning-alert-title{font-size:.94rem;line-height:1.45}.overview-paused-class-card{grid-template-columns:1fr;gap:10px;padding:12px 14px}.overview-paused-class-separator{display:none}.overview-paused-class-action{justify-self:start;opacity:1;transform:none}.overview-warning-card{grid-template-columns:1fr;gap:10px;padding:12px 14px}.overview-warning-separator{display:none}.overview-warning-action{justify-self:start;opacity:1;transform:none}}.breakdown-card{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px;overflow-x:auto}.profile-chip-link{margin-top:6px;display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;border:1px solid #e2e8f0;background-color:#fff;color:#4f46e5;font-size:.78rem;font-weight:600;text-decoration:none;transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease}.profile-chip-link:hover{background-color:#eef2ff;border-color:#c7d2fe}.profile-chip-link:focus-visible{outline:none;box-shadow:0 0 0 2px #c7d2fe}.page-header{background-color:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:35;padding:16px 32px;display:flex;flex-direction:row;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;box-shadow:0 1px #0f172a0f}@media(min-width:1280px){.page-header{flex-direction:row;align-items:center}}@media(max-width:768px){.page-header{padding:16px;flex-direction:column;align-items:flex-start}.page-title{font-size:1.1rem;line-height:1.25}.page-description{font-size:.82rem;line-height:1.35}}.page-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.page-description{font-size:.875rem;color:#64748b;margin:0}.details-page-header-inner{width:100%}.details-page-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.details-page-title-group{display:flex;flex:1;min-width:0;flex-direction:column;gap:10px}.details-page-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}@media(max-width:768px){.details-page-header>div:first-child{padding-left:0}.details-page-breadcrumb{padding-left:48px;margin-bottom:10px!important;font-size:.88rem!important;line-height:1.3}.details-page-toolbar{display:grid!important;grid-template-columns:auto minmax(0,1fr);align-items:start!important;gap:10px 12px!important}.details-page-back{grid-column:1;grid-row:1 / span 2;align-self:start;margin-top:2px}.details-page-title-group{grid-column:2;grid-row:1 / span 2;min-width:0;gap:12px}.details-page-title-group>div:first-child{align-items:flex-start}.details-page-actions{width:100%}.details-page-actions .btn{width:fit-content;max-width:100%}}.page-content{padding:30px}@media(max-width:768px){.filter-bar{width:100%;gap:10px;padding:6px}.filter-select,.dropdown-trigger{min-height:40px;font-size:.9rem}.page-content{padding:16px}}.filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;background-color:#f8fafc;padding:8px;border-radius:12px;border:1px solid #f1f5f9;flex-basis:100%}.filter-icon-wrapper{display:flex;align-items:center;padding:0 8px;color:#94a3b8}.filter-select{background-color:#fff;border:1px solid #e2e8f0;font-size:.875rem;border-radius:8px;padding:8px 12px;outline:none;color:#334155;font-weight:500;height:38px}.filter-select:focus{box-shadow:0 0 0 2px #6366f1;border-color:#6366f1}.date-inputs{display:flex;align-items:center;gap:8px;animation:fadeIn .2s ease-in-out;flex-wrap:wrap}@keyframes fadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.divider{height:24px;width:1px;background-color:#cbd5e1;margin:0 4px;display:none}@media(min-width:768px){.divider{display:block}}.dropdown-trigger{background-color:#fff;border:1px solid #e2e8f0;font-size:.875rem;border-radius:8px;padding:0 12px;height:38px;outline:none;color:#334155;min-width:160px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background-color .2s}.dropdown-trigger:hover{background-color:#f8fafc}.dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;width:256px;background-color:#fff;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #f1f5f9;padding:8px 0;z-index:50;animation:zoomIn .2s ease-out}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.dropdown-scroll-area{max-height:300px;overflow-y:auto}.dropdown-item{padding:8px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background-color .15s}.dropdown-item:hover{background-color:#f1f5f9}.dropdown-item span{font-size:.875rem;color:#334155}.dropdown-item span.selected{font-weight:500;color:#4f46e5}.dropdown-overlay{position:fixed;inset:0;z-index:40}.dropdown-divider{height:1px;background-color:#f1f5f9;margin:4px 8px}.modal-header-custom{background-color:#f8f9fa;padding:20px 25px;border-top-left-radius:8px;border-top-right-radius:8px;margin:-20px -20px 20px;border-bottom:1px solid #e0e0e0}@media(max-width:768px){.modal-header-custom{margin:-16px -16px 16px;padding:14px 16px}}.modal-title-custom{font-size:1.25rem;font-weight:600;color:#343a40;margin-bottom:5px}.modal-description-custom{font-size:.875rem;color:#6c757d;margin:0}.btn-outline{background-color:#fff;color:#6c757d;border:1px solid #ced4da}.btn-outline:hover{background-color:#e2e6ea;border-color:#dae0e5;color:#6c757d}.btn-primary-custom{background-color:#6366f1;color:#fff}.btn-primary-custom:hover{background-color:#4f46e5}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:9999px;font-size:.85rem;font-weight:500;white-space:nowrap}.badge-scheduled{background-color:#eff6ff;color:#2563eb;border:1px solid #dbeafe}.badge-proposed{background-color:#f8fafc;color:#475569;border:1px solid #cbd5e1}.badge-completed,.badge-done,.badge-active{background-color:#f0fdf4;color:#16a34a;border:1px solid #dcfce7}.badge-paused{background-color:#fffbeb;color:#d97706;border:1px solid #fde68a}.badge-cancelled{background-color:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.badge-no_show{background-color:#fff7ed;color:#c2410c;border:1px solid #fdba74}.badge-inactive{background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca}.badge-paid{background-color:#f0fdf4;color:#16a34a}.badge-unpaid-student{background-color:#fff7ed;color:#ea580c}.badge-unpaid-tutor{background-color:#fef2f2;color:#dc2626}.badge-complimentary{background-color:#ecfeff;color:#0f766e;border:1px solid #a5f3fc}.badge-na{background-color:#f8fafc;color:#94a3b8}.badge-draft{background-color:#eff6ff;color:#2563eb;border:1px solid #dbeafe}.badge-issued,.badge-partially_paid{background-color:#fff7ed;color:#ea580c;border:1px solid #fed7aa}.badge-void{background-color:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.student-class-link{display:block;text-decoration:none}.entity-stats-summary{border:1px solid #d9e2ee;border-radius:16px;background:#fff;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:24px;max-width:1320px;margin-left:auto;margin-right:auto}.entity-stats-summary-left{display:flex;align-items:center;gap:16px;min-width:250px}.entity-stats-summary-icon{width:56px;height:56px;border-radius:14px;background:#e9eef8;color:#4f46e5;display:inline-flex;align-items:center;justify-content:center}.entity-stats-summary-total{min-width:0}.entity-stats-summary-label{text-transform:uppercase;letter-spacing:.04em;color:#5f7ca4;font-size:.9rem;font-weight:700;line-height:1.1}.entity-stats-summary-value{margin-top:6px;color:#0f172a;font-size:2.1rem;line-height:1;font-weight:700}.entity-stats-summary-right{flex:1 1 auto;min-width:280px}.entity-stats-summary-breakdown{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.entity-stats-summary-item{display:inline-flex;flex-direction:column;gap:4px;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.entity-stats-summary-item strong{font-size:2rem;color:#0f172a;line-height:1;text-transform:none;letter-spacing:0}.entity-stats-summary-item.active{color:#059669}.entity-stats-summary-item.inactive{color:#ef4444;text-align:right}.entity-stats-summary-item.paused{color:#ca8a04;text-align:center}.entity-stats-summary-item.upcoming{color:#0284c7;text-align:right}.entity-stats-summary-item.active span:before,.entity-stats-summary-item.inactive span:after{content:"";width:9px;height:9px;border-radius:999px;display:inline-block;vertical-align:middle}.entity-stats-summary-item.active span:before{margin-right:6px;background:#10b981}.entity-stats-summary-item.inactive span:after{margin-left:6px;background:#fb7185}.entity-stats-summary-item.paused span:before{content:"";width:9px;height:9px;border-radius:999px;display:inline-block;vertical-align:middle;margin-right:6px;background:#f59e0b}.entity-stats-summary-item.upcoming span:before{content:"";width:9px;height:9px;border-radius:999px;display:inline-block;vertical-align:middle;margin-right:6px;background:#0ea5e9}.entity-stats-summary-bar{margin-top:14px;width:100%;height:12px;border-radius:999px;overflow:hidden;background:#eef2f7;display:flex}.entity-stats-summary-bar-active{background:#10b981}.entity-stats-summary-bar-inactive{background:#fb7185}.entity-stats-summary-bar-paused{background:#f59e0b}.entity-stats-summary-bar-upcoming{background:#0ea5e9}.overview-session-summary .entity-stats-summary-item{text-align:left}.overview-session-summary .entity-stats-summary-item.upcoming{text-align:right}.overview-session-summary{max-width:none}@media(max-width:768px){.entity-stats-summary{padding:14px;flex-direction:column;align-items:stretch;gap:14px}.entity-stats-summary-left{min-width:0}.entity-stats-summary-icon{width:48px;height:48px;border-radius:12px}.entity-stats-summary-label{font-size:.8rem}.entity-stats-summary-value{font-size:1.7rem}.entity-stats-summary-right{min-width:0}.entity-stats-summary-item{font-size:.82rem}.entity-stats-summary-item strong{font-size:1.5rem}}.student-class-card{border:1px solid #e2e8f0;border-radius:10px;background-color:#fff;padding:14px 14px 12px;transition:background-color .16s ease,border-color .16s ease}.student-class-link:hover .student-class-card{background-color:#f8fafc;border-color:#dbe3ee}.student-goal-card{border-color:#dbe4f0}.student-goal-card-completed{background-color:#f0fdf4;border-color:#bbf7d0}.student-class-link:hover .student-goal-card{background-color:#f8fafc;border-color:#dbe3ee;box-shadow:0 10px 22px #0f172a1f}.student-class-link:hover .student-goal-card-completed{background-color:#dcfce7;border-color:#86efac}.mobile-card.mobile-session-card{border-radius:16px;padding:14px 14px 0;border:1px solid #dbe4f0;box-shadow:0 6px 16px #0f172a0f;overflow:hidden}.mobile-session-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.mobile-session-card-title{font-size:1.18rem;line-height:1.2;font-weight:700;color:#0f172a}.mobile-session-card-subject{display:inline-flex;align-items:center;gap:6px;margin-top:6px;color:#64748b;font-size:.92rem}.mobile-session-card-datetime{display:flex;align-items:center;gap:18px;padding:12px 0;margin-top:12px;border-top:1px solid #eef2f7;border-bottom:1px solid #eef2f7;flex-wrap:wrap}.mobile-session-card-datetime-item{display:inline-flex;align-items:center;gap:7px;color:#475569;font-weight:600}.mobile-session-card-duration{color:#94a3b8;font-size:.84rem;font-weight:500}.mobile-session-card-people{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px 0}.mobile-session-card-person-column{min-width:0}.mobile-session-card-person-column:first-child{padding-right:12px;border-right:1px solid #eef2f7}.mobile-session-card-person-column:last-child{padding-left:4px}.mobile-session-card-person-label{color:#94a3b8;font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}.mobile-session-card-person{display:flex;align-items:center;gap:8px;color:#334155;min-width:0;font-weight:700;width:100%}.mobile-session-card-person-tutor{color:#334155}.mobile-session-card-avatar{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;flex-shrink:0}.mobile-session-card-avatar-image{width:28px;height:28px;border-radius:999px;object-fit:cover;border:1px solid #dbe4f0;flex-shrink:0}.mobile-session-card-avatar-student{background:#e0e7ff;color:#4338ca}.mobile-session-card-avatar-tutor{background:#ffedd5;color:#c2410c}.mobile-session-card-person-name{min-width:0;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.25}.mobile-session-card-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding-top:12px}.mobile-session-card-payments{display:flex;flex-direction:column;gap:4px}.mobile-session-card-payment-row{display:grid;grid-template-columns:58px auto;align-items:center;gap:8px}.mobile-session-card-payment-label{color:#94a3b8;font-weight:600;text-align:left}.mobile-session-card-payment-row .badge{justify-self:start}.mobile-session-card-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.mobile-session-card-actions-bar{margin:12px -14px 0;padding:12px 14px 0;border-top:1px solid #eef2f7;background:#f8fafc;display:flex;justify-content:flex-end;min-height:52px}@media(max-width:420px){.mobile-session-card-person-column:first-child{padding-right:0;border-right:1px solid #eef2f7;padding-bottom:0;border-bottom:none}.mobile-session-card-person-column:last-child{padding-left:4px;padding-top:0}.mobile-session-card-footer{flex-direction:column;align-items:stretch}.mobile-session-card-actions{justify-content:flex-end}.mobile-session-card-actions-bar{margin:12px -14px 0}}.class-goal-card{border:1px solid #dbe4f0;background-color:#fff;transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease}.class-goal-card-completed{background-color:#f0fdf4;border-color:#bbf7d0}.class-goal-card:hover{background-color:#f8fafc;border-color:#dbe3ee;box-shadow:0 10px 22px #0f172a1f}.class-goal-card-completed:hover{background-color:#dcfce7;border-color:#86efac}.entity-student-card{transition:box-shadow .16s ease,transform .16s ease}.entity-student-card:hover{box-shadow:0 10px 22px #0f172a1f}.entity-class-card{transition:box-shadow .16s ease,transform .16s ease}.entity-class-card:hover{box-shadow:0 10px 22px #0f172a1f}.student-session-panel{margin-bottom:20px;padding:0;overflow:hidden}.student-session-panel-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #e2e8f0}.student-session-panel-link{display:inline-flex;align-items:center;justify-content:center;color:#94a3b8;width:24px;height:24px;border-radius:999px;text-decoration:none;transition:background-color .16s ease,color .16s ease}.student-session-panel-link:hover{background-color:#f1f5f9;color:#64748b}.student-session-row{display:flex;align-items:center;gap:14px;padding:14px 20px;text-decoration:none;border-bottom:1px solid #e2e8f0;transition:background-color .16s ease}.student-session-row:last-child{border-bottom:none}.student-session-row:hover{background-color:#f8fafc}.student-session-date-badge{width:48px;min-width:48px;height:48px;border-radius:10px;border:1px solid #dbe4f0;background-color:#eef2ff;color:#4338ca;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}.student-session-date-badge .month{font-size:.72rem;font-weight:700;letter-spacing:.03em}.student-session-date-badge .day{margin-top:3px;font-size:1.25rem;font-weight:700}.student-session-content{min-width:0}.student-session-title{font-size:1.03rem;font-weight:700;color:#0f172a}.student-session-meta{margin-top:6px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:#64748b;font-size:.92rem}.student-session-meta .item{display:inline-flex;align-items:center;gap:5px}.breakdown-person-cell{display:inline-flex;align-items:center;gap:10px;min-width:0}.breakdown-person-link{color:inherit;text-decoration:none}.breakdown-person-link:hover .breakdown-person-name{text-decoration:underline}.breakdown-person-avatar,.breakdown-person-avatar-fallback{width:30px;height:30px;border-radius:999px;flex-shrink:0;border:1px solid #dbe3ef}.breakdown-person-avatar{object-fit:cover}.breakdown-person-avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700}.breakdown-person-avatar-fallback:before{content:attr(data-initial)}.breakdown-person-name{color:#0f172a;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.metric-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:3px 10px;font-size:.82rem;font-weight:700;border:1px solid transparent;white-space:nowrap}.metric-badge-income{background-color:#e0f2fe;color:#0369a1;border-color:#bae6fd}.metric-badge-cost{background-color:#fff1f2;color:#be123c;border-color:#fecdd3}.metric-badge-profit{background-color:#dcfce7;color:#15803d;border-color:#bbf7d0}.metric-badge-danger{background-color:#fee2e2;color:#b91c1c;border-color:#fecaca}.metric-badge-neutral{background-color:#f1f5f9;color:#475569;border-color:#e2e8f0}.metric-badge-amber{background-color:#fff7ed;color:#c2410c;border-color:#fed7aa}.metric-badge-info{background-color:#eff6ff;color:#2563eb;border-color:#bfdbfe}.student-detail-count-badge{min-width:26px;height:26px;border-radius:999px;background-color:#e2e8f0;color:#475569;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;padding:0 8px}.student-goal-filter-toggle{display:inline-flex;align-items:center;padding:3px;border:1px solid #dbe4f0;border-radius:999px;background-color:#f8fafc}.student-goal-filter-btn{border:none;background:transparent;color:#64748b;padding:5px 10px;border-radius:999px;font-size:.78rem;font-weight:700;cursor:pointer;transition:background-color .16s ease,color .16s ease}.student-goal-filter-btn.active{background-color:#eef2ff;color:#4338ca}.student-goal-filter-btn:hover{color:#334155}.table-no-header tbody tr:first-child td{border-top:none}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px 16px;background:radial-gradient(circle at 18% 14%,#bfdbfe,#bfdbfe00 44%),radial-gradient(circle at 84% 8%,#c7d2fe,#c7d2fe00 48%),linear-gradient(165deg,#eff6ff,#f8fafc 48%,#fff)}.login-box{background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:34px 32px;border-radius:20px;border:1px solid rgba(148,163,184,.25);box-shadow:0 22px 55px #0f172a24;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:18px}.login-logo{display:block;margin:0 auto 12px;width:164px;height:auto}.login-box h2{margin:0 0 6px;border-bottom:none;color:#0f172a;font-size:1.68rem;letter-spacing:-.02em}.login-subtitle{margin:0;color:#64748b;font-size:.94rem}.login-error{color:var(--danger-color);margin-bottom:14px;font-size:.9rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:9px 10px}.login-form .form-group{margin-bottom:14px}.login-form .form-group label{text-align:left;margin-bottom:6px;font-size:.84rem;font-weight:600;color:#334155}.login-form .form-group input{border-radius:12px;border:1px solid #cbd5e1;padding:11px 12px;font-size:.96rem;background:#fff}.login-form .form-group input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f12e}.login-btn{width:100%;margin-top:8px;justify-content:center;min-height:44px;border-radius:12px;font-weight:600}.login-footnote{margin:14px 0 0;text-align:center;font-size:.78rem;color:#94a3b8}@media(max-width:768px){.login-container{align-items:stretch;padding:max(18px,env(safe-area-inset-top,0px)) 14px max(18px,env(safe-area-inset-bottom,0px));background:radial-gradient(circle at 18% 8%,#bfdbfe,#bfdbfe00 42%),radial-gradient(circle at 92% 0%,#c7d2fe,#c7d2fe00 46%),linear-gradient(170deg,#eff6ff,#fff 72%)}.login-box{max-width:100%;margin:auto 0;padding:20px 14px 14px;border-radius:16px;border:1px solid rgba(148,163,184,.28);box-shadow:0 16px 34px #0f172a1f}.login-box h2{font-size:1.34rem;margin-bottom:4px}.login-logo{width:140px;margin-bottom:8px}.login-subtitle{font-size:.86rem}.login-form .form-group{margin-bottom:10px}.login-form .form-group label{margin-bottom:5px;font-size:.8rem}.login-form .form-group input{padding:10px 11px;font-size:.92rem}.login-btn{margin-top:6px}.login-footnote{margin-top:12px;font-size:.75rem}}.financial-card-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;padding:1.5rem;overflow:hidden;position:relative;box-shadow:0 1px 3px #0000000d}.card-header-section{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.icon-wrapper{padding:.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.icon-wrapper .icon-style{width:1.5rem;height:1.5rem}.growth-tag{font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:9999px}.card-title{font-size:.875rem;font-weight:500;color:#64748b;margin-bottom:.25rem}.card-value{font-size:1.875rem;font-weight:700;color:#1e293b;margin-top:.25rem}.progress-bar-background{width:100%;background-color:#f1f5f9;height:.375rem;margin-top:1.5rem;border-radius:9999px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:9999px}.bg-emerald-50{background-color:#ecfdf5}.text-emerald-700{color:#047857}.bg-emerald-500{background-color:#10b981}.bg-red-50{background-color:#fef2f2}.text-red-700{color:#b91c1c}.bg-red-500{background-color:#ef4444}.bg-indigo-100{background-color:#e0e7ff}.text-indigo-600{color:#4f46e5}.bg-green-100{background-color:#d1fae5}.text-green-600{color:#059669}.bg-red-100{background-color:#fee2e2}.text-red-600{color:#ef4444}.bg-blue-100{background-color:#dbeafe}.text-blue-600{color:#2563eb}.bg-sky-100{background-color:#e0f2fe}.text-sky-600{color:#0284c7}.bg-amber-100{background-color:#ffedd5}.text-amber-600{color:#f97316}.bg-emerald-100{background-color:#d1fae5}.text-emerald-600{color:#059669}@media(max-width:768px){.financial-card-container{padding:.95rem;border-radius:10px}.card-header-section{margin-bottom:.625rem}.icon-wrapper{padding:.5rem;border-radius:.4rem}.icon-wrapper .icon-style{width:1.125rem;height:1.125rem}.growth-tag{font-size:.67rem;padding:.18rem .42rem}.card-title{font-size:.78rem;margin-bottom:.1rem}.card-value{font-size:1.35rem;margin-top:.1rem}.progress-bar-background{margin-top:.75rem;height:.3rem}}.user-guide-page{--guide-bg: linear-gradient(180deg, #f8fbff 0%, #fdfefe 100%);--guide-card-bg: rgba(255, 255, 255, .94);--guide-card-border: rgba(199, 210, 254, .52);--guide-copy: #49607f;--guide-heading: #173156;--guide-pill-bg: #eef2ff;--guide-pill-text: #8a98b6;--guide-shadow: 0 18px 40px rgba(148, 163, 184, .08);background:var(--guide-bg);min-height:100%}.user-guide-content{display:flex;flex-direction:column;gap:0}.user-guide-card{display:grid;grid-template-columns:62px minmax(0,1fr);gap:18px;align-items:flex-start;padding:28px 30px;border-radius:20px;background:var(--guide-card-bg);border:1px solid var(--guide-card-border);box-shadow:var(--guide-shadow)}.user-guide-icon{width:62px;height:62px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent}.user-guide-card-body{min-width:0}.user-guide-card-heading{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}.user-guide-step-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:10px;background:var(--guide-pill-bg);color:var(--guide-pill-text);font-size:.86rem;font-weight:700;line-height:1}.user-guide-card h3{margin:0;color:var(--guide-heading);font-size:2rem;line-height:1.15;letter-spacing:-.03em;font-weight:800}.user-guide-copy{display:flex;flex-direction:column;gap:14px}.user-guide-copy p{margin:0;color:var(--guide-copy);font-size:1.12rem;line-height:1.7;max-width:72ch}.user-guide-card--indigo{--guide-card-border: rgba(191, 219, 254, .78)}.user-guide-card--mint{--guide-card-border: rgba(187, 247, 208, .84)}.user-guide-card--sky{--guide-card-border: rgba(186, 230, 253, .88)}.user-guide-card--amber{--guide-card-border: rgba(253, 230, 138, .82)}.user-guide-card--rose{--guide-card-border: rgba(251, 207, 232, .78)}.user-guide-card--violet{--guide-card-border: rgba(221, 214, 254, .82)}.user-guide-card--teal{--guide-card-border: rgba(153, 246, 228, .82)}.user-guide-card--peach{--guide-card-border: rgba(254, 215, 170, .84)}.user-guide-card--blue{--guide-card-border: rgba(191, 219, 254, .82)}.user-guide-card--slate{--guide-card-border: rgba(203, 213, 225, .88)}.user-guide-icon--indigo{background:linear-gradient(180deg,#eef2ff,#e6ecff);color:#4f46e5;border-color:#c7d2fee0}.user-guide-icon--mint{background:linear-gradient(180deg,#ecfdf5,#ddfbef);color:#059669;border-color:#a7f3d0e6}.user-guide-icon--sky{background:linear-gradient(180deg,#ecfeff,#dbf7fb);color:#0891b2;border-color:#a5f3fceb}.user-guide-icon--amber{background:linear-gradient(180deg,#fffbeb,#fef3c7);color:#d97706;border-color:#fde68aeb}.user-guide-icon--rose{background:linear-gradient(180deg,#fff1f2,#ffe4e6);color:#e11d48;border-color:#fecdd3f0}.user-guide-icon--violet{background:linear-gradient(180deg,#f5f3ff,#ede9fe);color:#7c3aed;border-color:#ddd6fef0}.user-guide-icon--teal{background:linear-gradient(180deg,#f0fdfa,#ccfbf1);color:#0f766e;border-color:#99f6e4f0}.user-guide-icon--peach{background:linear-gradient(180deg,#fff7ed,#ffedd5);color:#ea580c;border-color:#fed7aaf0}.user-guide-icon--blue{background:linear-gradient(180deg,#eff6ff,#dbeafe);color:#2563eb;border-color:#bfdbfef0}.user-guide-icon--slate{background:linear-gradient(180deg,#f8fafc,#e2e8f0);color:#475569;border-color:#cbd5e1f0}@media(max-width:900px){.user-guide-card{padding:22px 22px 24px;grid-template-columns:54px minmax(0,1fr);gap:16px}.user-guide-icon{width:54px;height:54px;border-radius:16px}.user-guide-card h3{font-size:1.5rem}.user-guide-copy p{font-size:1rem;line-height:1.65}}@media(max-width:640px){.user-guide-card{grid-template-columns:1fr;gap:14px;padding:20px 18px 22px;border-radius:18px}.user-guide-icon{width:52px;height:52px}.user-guide-card-heading{gap:10px;margin-bottom:12px}.user-guide-card h3{font-size:1.3rem}.user-guide-copy{gap:12px}.user-guide-copy p{font-size:.97rem;line-height:1.6}}.sidebar{width:240px;background-color:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;padding:24px 0;position:fixed;top:0;left:0;height:100vh;z-index:50;transition:transform .3s ease-in-out}.sidebar-header{display:flex;align-items:center;padding:0 16px;margin-bottom:16px;gap:12px;justify-content:center;position:relative}.close-sidebar-btn{display:none;background:none;border:none;cursor:pointer;color:#64748b;padding:4px;position:absolute;right:16px}.brand-logo{max-width:160px;height:auto;max-height:40px;object-fit:contain}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #00000026}.close-sidebar-btn{display:block}}.sidebar-nav{flex:1;padding:0 16px;margin-top:16px;overflow-y:auto}.sidebar-nav ul{list-style:none;padding:0;margin:0}.nav-item{margin-bottom:8px}.nav-item a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;text-decoration:none;color:#475569;font-size:1rem;font-weight:500}.nav-item a:hover{background-color:#f1f5f9;color:#1e293b}.nav-item.active a{background-color:#e0e7ff;color:#4f46e5}.nav-item-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;cursor:pointer;color:#475569;font-weight:500;transition:background-color .2s}.nav-item-header:hover{background-color:#f1f5f9;color:#1e293b}.nav-item-content{display:flex;align-items:center;gap:12px}.sub-menu{list-style:none;padding-left:32px;margin:4px 0 12px}.sub-nav-item{margin-bottom:4px}.sub-nav-item a{display:block;padding:8px 12px;border-radius:6px;text-decoration:none;color:#64748b;font-size:.9rem;font-weight:500;transition:all .2s}.sub-nav-item a:hover{background-color:#f8fafc;color:#4f46e5}.sub-nav-item.active a{color:#4f46e5;background-color:#f1f5f9}.sidebar-footer{padding:16px;border-top:1px solid #f1f5f9;background-color:#fff}.user-profile{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;transition:background-color .2s}.user-profile-link:hover .user-profile{background-color:#f1f5f9}.user-avatar{width:40px;height:40px;border-radius:9999px;background-color:#e2e8f0;display:flex;align-items:center;justify-content:center;color:#475569;font-weight:700;font-size:.875rem}.user-name{font-size:.875rem;font-weight:500;color:#1e293b;margin:0}.logout-button{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:none;border:none;color:#475569;font-size:1rem;font-weight:500;text-align:left;cursor:pointer;border-radius:8px;transition:background-color .2s,color .2s}.logout-button:hover{background-color:#f1f5f9;color:#1e293b}.login-link{display:block;text-align:center;padding:10px 0;color:#4f46e5;text-decoration:none;font-weight:500}.version-info{font-size:.7rem;color:#94a3b8;text-align:center;margin-top:12px;font-family:monospace}:root{--primary-color: #4f46e5;--primary-light-color: #e0e7ff;--secondary-color: #e2e8f0;--text-color: #1e293b;--light-text-color: #94a3b8;--border-color: #e2e8f0;--background-color: #f8fafc;--card-background-color: #ffffff;--danger-color: #ef4444;--success-color: #22c55e;--mobile-breakpoint: 768px;--mobile-space-xs: 8px;--mobile-space-sm: 12px;--mobile-space-md: 16px;--mobile-space-lg: 20px;--mobile-card-radius: 12px;--mobile-sheet-radius: 16px;--mobile-touch-target: 44px;--mobile-title-size: 1.05rem;--mobile-body-size: .92rem}*,*:before,*:after{box-sizing:border-box}html,body{width:100%;max-width:100%;overflow-x:hidden}#root{width:100%;max-width:100%}body{margin:0;font-family:Inter,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-color);line-height:1.5}.app-container{display:flex;position:relative;width:100%;max-width:100%}.main-content{--page-header-height: 0px;flex-grow:1;padding:0;margin-left:240px;background-color:var(--background-color);height:100vh;transition:margin-left .3s ease;max-width:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.main-content.no-sidebar{margin-left:0!important}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:45;background-color:#fff;border:1px solid var(--border-color);border-radius:8px;padding:8px;cursor:pointer;box-shadow:0 2px 4px #0000001a;color:var(--text-color)}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:40;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.env-badge{position:fixed;right:16px;bottom:16px;z-index:95;padding:6px 10px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.04em;border:1px solid transparent;pointer-events:none}.env-badge-dev{background-color:#fff7ed;color:#c2410c;border-color:#fdba74}@media(max-width:768px){.main-content{margin-left:0;width:100%}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.sidebar-overlay{display:block}.page-header{padding:16px!important;flex-direction:column;align-items:flex-start}.page-header>div:first-child{padding-left:48px}.form-grid{grid-template-columns:1fr;gap:12px}}h2{color:var(--text-color);font-size:1.875rem;font-weight:700;margin-bottom:24px}h3{color:var(--text-color);font-size:1.5rem;font-weight:600;margin-bottom:20px}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.btn{padding:10px 18px;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease-in-out;display:inline-flex;align-items:center;gap:8px}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#4338ca}.btn-secondary{background-color:#64748b;color:#fff}.btn-secondary:hover{background-color:#475569}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-light{background-color:#f1f5f9;color:var(--text-color);border:1px solid var(--border-color)}.btn-light:hover{background-color:#e2e8f0}.btn-icon{background:none;border:none;cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#64748b;transition:background-color .2s,color .2s}.btn-icon:hover{background-color:#e2e8f0;color:var(--text-color)}.btn-icon-danger:hover{background-color:#fee2e2;color:#dc2626}.btn-icon-success:hover{background-color:#dcfce7;color:#16a34a}.btn-icon-view:hover{background-color:#dbeafe;color:#2563eb}.btn-icon-edit:hover{background-color:#fef3c7;color:#d97706}.btn-icon-history:hover{background-color:#e0e7ff;color:#4f46e5}.btn-icon-copy:hover{background-color:#ccfbf1;color:#0f766e}.btn-icon-download:hover{background-color:#e0f2fe;color:#0369a1}.btn-icon-more:hover{background-color:#e2e8f0;color:#334155}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.form-group{display:flex;flex-direction:column;margin-bottom:15px}.form-group label{margin-bottom:8px;font-weight:500;color:#334155;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;color:var(--text-color);background-color:var(--card-background-color);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e533}.table{width:100%;border-collapse:separate;border-spacing:0;margin-top:20px;background-color:var(--card-background-color);box-shadow:0 1px 3px #0000001a;border-radius:8px;overflow:visible}.table th,.table td{padding:8px 20px;text-align:left;border-bottom:1px solid var(--border-color)}.col-date{min-width:130px}.col-start-time{min-width:180px}.col-timepoint{min-width:170px}.table th{background-color:var(--primary-light-color);color:var(--primary-color);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.table.sticky-table thead th{position:sticky;top:var(--page-header-height);z-index:16;background-color:var(--primary-light-color);box-shadow:0 -2px 0 var(--background-color),inset 0 -1px 0 var(--border-color)}.invoice-list-card{overflow:visible}.table.sessions-sticky-table thead th{top:calc(var(--page-header-height) + 2px);border-top:0}.table.sessions-sticky-table thead th:first-child{border-top-left-radius:8px}.table.sessions-sticky-table thead th:last-child{border-top-right-radius:8px}.table.invoice-sticky-table thead th{top:calc(var(--page-header-height) + 2px);border-top:0}.table th:first-child{border-top-left-radius:8px}.table th:last-child{border-top-right-radius:8px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background-color:#f5f5f5}@media(max-width:768px){.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:20px;border-radius:8px;max-width:100vw}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background-color:var(--card-background-color);padding:20px;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:15px}.stat-card .label{font-size:.9rem;color:#64748b;font-weight:500}.stat-card .value{font-size:1.875rem;font-weight:700;color:var(--text-color)}.stat-card .icon{font-size:2rem;padding:12px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:var(--primary-light-color);color:var(--primary-color)}.stat-card.total .icon{background-color:#e0e7ff;color:#4338ca}.stat-card.active .icon{background-color:#d1fae5;color:#059669}.stat-card.inactive .icon{background-color:#fee2e2;color:#ef4444}.actions-cell{align-items:center;gap:8px}.mobile-card-list{display:grid;gap:10px;margin-top:12px}.mobile-card{border:1px solid #e2e8f0;border-radius:var(--mobile-card-radius);background:#fff;padding:var(--mobile-space-sm)}.mobile-card-title{font-weight:700;color:#0f172a;margin-bottom:8px;line-height:1.3}.mobile-card-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-top:6px}.mobile-card-row span{color:#64748b;font-size:.82rem;line-height:1.3}.mobile-card-row strong{color:#0f172a;font-size:.88rem;font-weight:600;line-height:1.35;text-align:right}.mobile-empty{color:#94a3b8;margin:8px 0 0}.mobile-filter-trigger{display:inline-flex;align-items:center;gap:8px}.mobile-sheet-overlay{position:fixed;inset:0;background:#0f172a59;z-index:75}.mobile-filter-sheet{position:fixed;inset:0;background:#fff;border-radius:0;box-shadow:0 -6px 20px #0f172a2e;z-index:80;transform:translateY(101%);transition:transform .2s ease;max-height:100vh;display:flex;flex-direction:column}.mobile-filter-sheet.open{transform:translateY(0)}.mobile-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:var(--mobile-space-sm) var(--mobile-space-md);border-bottom:1px solid #e2e8f0}.mobile-sheet-body{padding:var(--mobile-space-sm) var(--mobile-space-md);overflow-y:auto}.mobile-filter-sheet-body .filter-bar{border:none;background:transparent;padding:0;gap:10px}.mobile-sheet-sticky-footer{padding:var(--mobile-space-sm) var(--mobile-space-md) calc(var(--mobile-space-sm) + env(safe-area-inset-bottom,0px));border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;background:#fff}.mobile-action-sheet{position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top-left-radius:var(--mobile-sheet-radius);border-top-right-radius:var(--mobile-sheet-radius);box-shadow:0 -6px 20px #0f172a2e;max-height:70vh;display:flex;flex-direction:column}.mobile-action-sheet-item{width:100%;border:1px solid #e2e8f0;border-radius:10px;background:#fff;padding:12px;font-size:var(--mobile-body-size);display:inline-flex;align-items:center;gap:8px;min-height:var(--mobile-touch-target);color:#0f172a}.mobile-action-sheet-item.danger{color:#b91c1c;border-color:#fecaca;background:#fef2f2}.mobile-form-sheet{position:fixed;inset:0;z-index:80;background:#fff;display:flex;flex-direction:column}.mobile-sheet-title{margin:0;font-size:var(--mobile-title-size);line-height:1.2}.mobile-sheet-description{margin:2px 0 0;color:#64748b;font-size:.82rem}.mobile-sticky-cta{position:fixed;right:16px;bottom:16px;z-index:60;box-shadow:0 8px 20px #0f172a40;border-radius:999px}.alert.alert-danger{background-color:#fee2e2;color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #fca5a5}.dropdown-container{position:relative}.actions-dropdown{position:absolute;right:0;top:100%;background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 6px #0000001a;z-index:1000;display:flex;flex-direction:column;min-width:120px}.actions-dropdown.open-upward{top:auto;bottom:100%}.actions-dropdown button{background:none;border:none;padding:10px 15px;text-align:left;width:100%;cursor:pointer;color:var(--text-color);font-size:.9rem}.actions-dropdown button:hover{background-color:var(--background-color)}.modal-buttons{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.modal-buttons .btn{min-width:100px}.session-editor-modal .session-add-slot-btn{border-radius:8px}.class-editor-modal{min-width:0}@media(max-width:768px){.session-editor-modal .modal-header-custom{margin:-16px -16px 12px;padding:14px 16px}.session-editor-modal .modal-title-custom{font-size:1.05rem;margin-bottom:2px}.session-editor-modal .modal-description-custom{font-size:.8rem}.session-editor-modal .session-editor-top-grid{grid-template-columns:1fr!important;gap:12px!important}.session-editor-modal .time-slots-container{max-height:42vh;overflow-y:auto;padding-right:2px;margin-bottom:12px!important}.session-editor-modal .time-slot-row{grid-template-columns:1fr!important;gap:10px!important;padding:12px!important}.session-editor-modal .session-add-slot-btn{width:100%;justify-content:center;border:1px dashed #c7d2fe;background-color:#eef2ff!important;padding:10px 12px!important;margin-top:4px}.session-editor-modal .modal-buttons{position:sticky;bottom:-16px;margin:14px -16px -16px!important;padding:12px 16px calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid #e2e8f0;background:#fff}.session-editor-modal .modal-buttons .btn{flex:1;min-width:0;justify-content:center}.class-editor-modal .modal-header-custom{margin:-16px -16px 12px;padding:12px 16px}.class-editor-modal .modal-title-custom{font-size:1.05rem;margin-bottom:2px}.class-editor-modal .modal-description-custom{font-size:.8rem}.class-editor-modal .form-group{margin-bottom:10px}.class-editor-modal .form-group label{margin-bottom:4px;font-size:.78rem}.class-editor-modal .form-group input,.class-editor-modal .form-group select{padding:8px 10px;font-size:.92rem}.class-editor-modal .modal-buttons{position:sticky;bottom:-16px;margin:8px -16px -16px!important;padding:10px 16px calc(10px + env(safe-area-inset-bottom,0px));border-top:1px solid #e2e8f0;background:#fff}.class-editor-modal .modal-buttons .btn{flex:1;min-width:0;justify-content:center}}.form-group textarea{min-height:80px;resize:vertical}.filter-controls{display:flex;gap:15px;align-items:flex-end;margin-bottom:30px}.filter-group{display:flex;flex-direction:column}.filter-group label{margin-bottom:8px;font-weight:500;color:#334155;font-size:.875rem}.filter-group select,.filter-group input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;color:var(--text-color);background-color:var(--card-background-color);transition:border-color .2s,box-shadow .2s}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e533}@media(max-width:768px){.has-mobile-cta{padding-bottom:96px}.btn,.dropdown-trigger,.mobile-filter-trigger{min-height:var(--mobile-touch-target)}.btn{font-size:.92rem}.table th,.table td{padding:10px 12px}.mobile-primary-cta{min-height:var(--mobile-touch-target)}.mobile-primary-cta.mobile-sticky-cta,.mobile-primary-cta{position:fixed;right:16px;bottom:16px;z-index:60;box-shadow:0 8px 20px #0f172a40;border-radius:999px}.btn-icon{min-width:var(--mobile-touch-target);min-height:var(--mobile-touch-target)}.mobile-filter-sheet-body .filter-icon-wrapper,.mobile-filter-sheet-body .divider{display:none}.mobile-filter-sheet-body .dropdown-container{width:100%}.mobile-filter-sheet-body .dropdown-trigger{width:100%;min-width:0}.mobile-filter-sheet-body .dropdown-overlay{display:none}.mobile-filter-sheet-body .dropdown-menu{position:static;width:100%;margin-top:8px;box-shadow:none;border:1px solid #e2e8f0}.mobile-filter-sheet-body .dropdown-scroll-area{max-height:38vh}}.overview-header h2{margin-bottom:0}.app-loading-screen{min-height:100vh;display:grid;place-items:center;background:var(--background-color)}.app-loading-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 18px;color:#334155;font-weight:600}.page-skeleton{display:flex;flex-direction:column;gap:16px}.page-skeleton-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.page-skeleton-card,.page-skeleton-row{position:relative;overflow:hidden;background:#e2e8f0;border-radius:10px}.page-skeleton-card{height:84px}.page-skeleton-table{display:flex;flex-direction:column;gap:8px}.page-skeleton-row{height:42px}.page-skeleton-card:after,.page-skeleton-row:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:page-skeleton-shimmer 1.2s infinite}@keyframes page-skeleton-shimmer{to{transform:translate(100%)}}@media(max-width:768px){.page-skeleton-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
