*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:#f3f4f6;color:#1f2937;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}.container{max-width:480px;margin:0 auto;padding:0 16px;width:100%}.card{background:#fff;border-radius:16px;padding:16px;margin-bottom:16px;box-shadow:0 1px 3px #0000000d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:12px;font-weight:600;font-size:16px;border:none;cursor:pointer;transition:all .2s;width:100%}.btn-primary{background:#8b5cf6;color:#fff}.btn-primary:hover{background:#7c3aed}.btn-primary:disabled{background:#c4b5fd;cursor:not-allowed}.btn-secondary{background:#ede9fe;color:#7c3aed}.btn-secondary:hover{background:#ddd6fe}.btn-outline{background:transparent;border:2px solid #E5E7EB;color:#6b7280}.btn-outline:hover{border-color:#8b5cf6;color:#8b5cf6}.btn-danger{background:transparent;border:1px solid #EF4444;color:#ef4444;padding:8px 12px;font-size:13px}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.input{width:100%;padding:14px 16px;border:1px solid #E5E7EB;border-radius:12px;font-size:16px;font-family:inherit;transition:border-color .2s}.input:focus{outline:none;border-color:#8b5cf6}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;display:flex;justify-content:space-around;padding:12px 0;padding-bottom:calc(20px + env(safe-area-inset-bottom));border-top:1px solid #E5E7EB;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:#9ca3af;text-decoration:none;font-size:12px;font-weight:500;padding:4px 12px;cursor:pointer;background:none;border:none}.nav-item.active{color:#8b5cf6}.nav-item svg{width:24px;height:24px}.page-content{flex:1;padding-bottom:80px}.loading{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{width:40px;height:40px;border:3px solid #EDE9FE;border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state svg{width:48px;height:48px;color:#d1d5db;margin-bottom:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-purple{background:#ede9fe;color:#7c3aed}.page-header{background:#fff;padding:16px;padding-top:calc(16px + env(safe-area-inset-top));border-bottom:1px solid #E5E7EB;position:sticky;top:0;z-index:50}.page-header h1{font-size:20px;font-weight:700;color:#1f2937}.section-title{font-size:13px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 4px}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pull-hint{text-align:center;padding:8px;color:#9ca3af;font-size:13px}.admin-top-header{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top));display:flex;justify-content:space-between;align-items:center}.admin-top-header h1{font-size:20px;font-weight:700}.admin-top-header .logout-btn{background:#fff3;border:none;color:#fff;padding:8px;border-radius:8px;cursor:pointer}.admin-top-header .header-actions{display:flex;gap:8px}.refresh-header-btn{background:#fff3;border:none;color:#fff;padding:8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.admin-nav{background:#fff}.admin-nav .nav-item.active{color:#8b5cf6}.admin-page{flex:1;padding:16px 16px 100px;overflow-y:auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.admin-header h1{font-size:24px;font-weight:700;color:#1f2937}.refresh-btn{background:#ede9fe;border:none;color:#8b5cf6;width:44px;height:44px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.refresh-btn:disabled{opacity:.5}.refresh-btn.small{width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}.helper-text{color:#6b7280;font-size:14px;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.stat-card{background:#fff;border-radius:16px;padding:16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:transform .2s;box-shadow:0 1px 3px #0000000d}.stat-card:active{transform:scale(.98)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon.purple{background:#ede9fe;color:#8b5cf6}.stat-icon.blue{background:#dbeafe;color:#3b82f6}.stat-icon.green{background:#d1fae5;color:#10b981}.stat-icon.orange{background:#fef3c7;color:#f59e0b}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:24px;font-weight:700;color:#1f2937}.stat-label{font-size:12px;color:#6b7280}.quick-actions{background:#fff;border-radius:16px;padding:16px}.quick-actions h2{font-size:16px;font-weight:600;margin-bottom:12px;color:#1f2937}.dashboard-page{padding-top:8px}.day-badge{display:inline-flex;align-items:center;gap:6px;background:#1f2937;color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:16px}.day-dot{color:#10b981;font-size:10px}.dashboard-header-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:16px;padding:16px;margin-bottom:16px}.logo-section{display:flex;align-items:center;gap:12px}.logo-circle{width:50px;height:50px;background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px}.logo-image{width:50px;height:50px;border-radius:12px;object-fit:cover}.logo-text h1{font-size:20px;font-weight:700;color:#1f2937;margin:0}.logo-text span{font-size:12px;color:#6b7280}.refresh-btn-header{background:#fee2e2;border:none;color:#ef4444;width:40px;height:40px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.welcome-banner{background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:16px;padding:20px;margin-bottom:16px;color:#fff}.welcome-banner h2{font-size:20px;font-weight:700;margin:0 0 4px}.welcome-banner span{font-size:14px;opacity:.9}.stats-grid-new{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.stat-card-new{background:#fff;border-radius:16px;padding:16px;cursor:pointer;border-left:4px solid transparent;transition:transform .2s}.stat-card-new:active{transform:scale(.98)}.stat-card-new.purple-border{border-left-color:#8b5cf6}.stat-card-new.blue-border{border-left-color:#3b82f6}.stat-card-new.green-border{border-left-color:#10b981}.stat-card-new.orange-border{border-left-color:#f59e0b}.stat-icon-new{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-icon-new.purple{background:#ede9fe;color:#8b5cf6}.stat-icon-new.blue{background:#dbeafe;color:#3b82f6}.stat-icon-new.green{background:#d1fae5;color:#10b981}.stat-icon-new.orange{background:#fef3c7;color:#f59e0b}.stat-number-new{font-size:32px;font-weight:700;color:#1f2937;line-height:1;margin-bottom:4px}.stat-label-new{font-size:13px;color:#6b7280}.quick-actions-card{background:#fff;border-radius:16px;padding:16px;margin-bottom:16px}.quick-actions-card h3{font-size:16px;font-weight:700;color:#1f2937;margin:0 0 16px}.quick-actions-row{display:flex;justify-content:space-between;gap:8px}.quick-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 4px;background:transparent;border:none;cursor:pointer}.quick-btn-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.quick-btn-icon.green{background:#d1fae5;color:#10b981}.quick-btn-icon.yellow{background:#fef3c7;color:#f59e0b}.quick-btn-icon.blue{background:#dbeafe;color:#3b82f6}.quick-btn-icon.purple{background:#ede9fe;color:#8b5cf6}.quick-btn span{font-size:11px;font-weight:600;color:#374151;text-align:center}.todays-bookings-card{display:flex;align-items:center;gap:12px;background:#dbeafe;border:none;border-radius:16px;padding:16px;width:100%;cursor:pointer;text-align:left}.bookings-icon{width:44px;height:44px;background:#3b82f6;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center}.bookings-info{flex:1}.bookings-info h4{font-size:15px;font-weight:700;color:#1e40af;margin:0 0 2px}.bookings-info span{font-size:12px;color:#3b82f6}.bookings-arrow{font-size:24px;color:#3b82f6;font-weight:300}.action-buttons{display:flex;flex-direction:column;gap:10px}.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:12px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.action-btn.primary{background:#8b5cf6;color:#fff}.action-btn.secondary{background:#ede9fe;color:#8b5cf6}.schedule-container{background:#fff;border-radius:16px;overflow:hidden;margin-bottom:16px}.schedule-header{display:grid;grid-template-columns:repeat(7,1fr);background:#8b5cf6;padding:12px 4px}.day-header{text-align:center;font-size:11px;font-weight:700;color:#fff}.schedule-grid{display:flex;flex-direction:column;padding:8px 4px;gap:4px;min-height:200px}.time-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.empty-cell{min-height:50px}.day-column{display:flex;flex-direction:column;gap:4px}.no-class{height:60px;display:flex;align-items:center;justify-content:center;color:#d1d5db;font-size:14px}.class-cell{border:none;border-radius:6px;padding:6px 4px;border-left:3px solid;min-height:50px;cursor:pointer;text-align:left;transition:transform .1s}.class-cell:active{transform:scale(.95)}.class-name{font-size:9px;font-weight:600;display:block;margin-bottom:2px;white-space:pre-line}.class-time{font-size:8px;opacity:.8}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:200}.modal-content{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #E5E7EB;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{font-size:18px;font-weight:600}.header-actions{display:flex;align-items:center;gap:8px}.close-btn{background:none;border:none;font-size:28px;color:#6b7280;cursor:pointer;line-height:1}.session-modal{padding-bottom:env(safe-area-inset-bottom)}.session-time{text-align:center;color:#6b7280;padding:8px 20px 0}.date-navigator{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px}.nav-btn{background:#ede9fe;border:none;color:#8b5cf6;width:40px;height:40px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.date-display{text-align:center}.date-main{display:block;font-size:16px;font-weight:600;color:#1f2937}.date-year{font-size:12px;color:#6b7280}.today-btn{display:block;margin:0 auto 16px;background:none;border:none;color:#8b5cf6;font-size:14px;font-weight:600;cursor:pointer}.session-actions{display:flex;gap:8px;padding:0 20px 16px}.session-actions .action-btn{flex:1;padding:12px;font-size:14px}.action-btn.booking{background:#ede9fe;color:#8b5cf6}.action-btn.checkin{background:#d1fae5;color:#10b981}.action-btn.refresh-small{flex:0;width:44px;background:#f3f4f6;color:#6b7280}.delete-class-btn{display:flex;align-items:center;justify-content:center;gap:8px;flex:1;padding:12px;background:#fee2e2;color:#dc2626;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer}.delete-class-btn.full-width{width:100%;margin-top:24px}.class-manage-buttons{display:flex;gap:10px;padding:16px 20px}.edit-class-btn{display:flex;align-items:center;justify-content:center;gap:8px;flex:1;padding:12px;background:#ede9fe;color:#8b5cf6;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer}.edit-class-modal{max-height:90vh}.edit-class-modal .modal-header{display:flex;justify-content:space-between;align-items:center}.cancel-link{background:none;border:none;color:#6b7280;font-size:16px;cursor:pointer}.save-link{background:none;border:none;color:#8b5cf6;font-size:16px;font-weight:600;cursor:pointer}.save-link:disabled{opacity:.5}.edit-form{padding:20px}.form-section{margin-bottom:24px}.form-section>label{display:block;font-size:14px;font-weight:700;color:#1f2937;margin-bottom:12px}.form-row{display:flex;gap:12px}.form-field{flex:1}.field-label{display:block;font-size:12px;color:#6b7280;margin-bottom:6px}.form-section input,.form-section select,.form-section textarea{width:100%;padding:14px;border:1px solid #E5E7EB;border-radius:12px;font-size:16px;margin-bottom:10px;background:#fff}.form-section input:focus,.form-section select:focus,.form-section textarea:focus{outline:none;border-color:#8b5cf6}.field-hint{display:block;font-size:12px;color:#9ca3af;margin-top:-6px}.loading-small{text-align:center;padding:40px;color:#6b7280}.attendance-section{padding:0 20px 20px}.section-title{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:12px}.section-title.booked{color:#8b5cf6}.section-title.checkedin{color:#10b981}.attendance-card{display:flex;align-items:center;gap:12px;background:#f9fafb;border-radius:12px;padding:12px;margin-bottom:8px}.attendance-card.booked{background:#ede9fe}.student-avatar{width:40px;height:40px;border-radius:50%;background:#8b5cf6;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.student-info{flex:1}.student-name{display:block;font-weight:600;color:#1f2937;font-size:14px}.student-meta{font-size:12px;color:#6b7280}.confirm-btn{background:#d1fae5;border:none;color:#10b981;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.remove-btn{background:#fee2e2;border:none;color:#ef4444;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.empty-text{text-align:center;color:#9ca3af;font-size:14px;padding:20px}.checkin-modal{max-height:80vh}.search-container{position:relative;padding:16px 20px}.search-container .search-icon{position:absolute;left:32px;top:50%;transform:translateY(-50%);color:#9ca3af}.search-container input{width:100%;padding:12px 12px 12px 44px;border:1px solid #E5E7EB;border-radius:12px;font-size:16px}.search-container input:focus{outline:none;border-color:#8b5cf6}.student-list{padding:0 20px;max-height:300px;overflow-y:auto}.student-select-card{display:flex;align-items:center;gap:12px;width:100%;background:#fff;border:2px solid #E5E7EB;border-radius:12px;padding:12px;margin-bottom:8px;cursor:pointer;text-align:left;transition:all .2s}.student-select-card:hover{border-color:#8b5cf6}.student-select-card.selected{border-color:#8b5cf6;background:#ede9fe}.check-icon{color:#8b5cf6}.submit-btn{display:block;width:calc(100% - 40px);margin:16px 20px 20px;padding:14px;background:#8b5cf6;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer}.submit-btn:disabled{background:#c4b5fd;cursor:not-allowed}.filter-toggle{display:flex;background:#e5e7eb;border-radius:10px;padding:4px;margin-bottom:16px}.filter-btn{flex:1;padding:10px;border:none;background:transparent;border-radius:8px;font-size:13px;font-weight:600;color:#6b7280;cursor:pointer}.filter-btn.active{background:#fff;color:#8b5cf6}.student-list-page{display:flex;flex-direction:column;gap:8px}.student-card{display:flex;align-items:center;gap:12px;width:100%;background:#fff;border:none;border-radius:16px;padding:16px;cursor:pointer;text-align:left;box-shadow:0 1px 3px #0000000d}.student-email{font-size:13px;color:#6b7280}.student-membership{display:flex;align-items:center;gap:8px;margin-top:4px}.membership-badge{background:#ede9fe;color:#7c3aed;font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px}.classes-remaining{font-size:12px;color:#6b7280}.classes-remaining.exhausted{color:#ef4444}.student-detail-modal{max-height:90vh}.student-detail-content{padding:20px}.profile-card{text-align:center;padding-bottom:20px;border-bottom:1px solid #E5E7EB;margin-bottom:20px}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin:0 auto 12px}.profile-card h3{font-size:20px;font-weight:700;margin-bottom:4px}.profile-email{color:#6b7280;font-size:14px;margin-bottom:12px}.status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:12px}.edit-student-btn{display:flex;align-items:center;gap:6px;background:#f3f4f6;border:none;color:#6b7280;padding:8px 16px;border-radius:8px;font-size:13px;cursor:pointer;margin-bottom:16px}.edit-student-btn:hover{background:#e5e7eb;color:#374151}.adjust-input-row{display:flex;align-items:center;gap:8px}.adjust-input-row input{flex:1;font-size:20px;font-weight:600}.adjust-btn-minus,.adjust-btn-plus{width:48px;height:48px;border-radius:12px;border:none;font-size:24px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.adjust-btn-minus{background:#fee2e2;color:#dc2626}.adjust-btn-plus{background:#d1fae5;color:#059669}.adjust-btn-minus:active,.adjust-btn-plus:active{transform:scale(.95)}.checkin-buttons{display:flex;flex-direction:column;gap:10px}.guest-btn{background:#f3f4f6;color:#6b7280;border:1px dashed #D1D5DB;padding:14px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer}.guest-btn:hover{background:#e5e7eb;color:#374151}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.expiring_soon{background:#fef3c7;color:#92400e}.status-badge.expired,.status-badge.exhausted{background:#fee2e2;color:#991b1b}.profile-actions{display:flex;gap:10px;justify-content:center}.profile-actions .action-btn{padding:12px 20px}.action-btn.purchase{background:#ede9fe;color:#8b5cf6}.action-btn.private{background:#fef3c7;color:#f59e0b}.action-btn.booking{background:#dbeafe;color:#3b82f6}.action-btn.adjust{background:#f3f4f6;color:#374151;width:100%}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:#8B5CF6}.checkbox-label span{font-size:15px;color:#374151}.modal-hint-info{text-align:center;color:#8b5cf6;font-size:14px;padding:0 20px 16px;font-weight:600}.submit-btn.adjust-btn{background:#6b7280}.submit-btn.private-btn{background:#f59e0b}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.stat-item{background:#f9fafb;border-radius:12px;padding:12px;text-align:center}.stat-item .stat-number{font-size:20px}.stat-item .stat-label{font-size:10px}.history-section{margin-bottom:20px}.history-section h4{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:12px}.history-section h4.upcoming-title{color:#8b5cf6}.attendance-scroll-container{max-height:300px;overflow-y:auto;padding-right:5px}.attendance-scroll-container::-webkit-scrollbar{width:6px}.attendance-scroll-container::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.attendance-scroll-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.view-all-btn{width:100%;padding:10px;margin-top:8px;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.view-all-btn:hover{background:#e5e7eb;color:#374151}.history-card{display:flex;align-items:center;gap:12px;padding:10px;background:#f9fafb;border-radius:10px;margin-bottom:6px}.history-card.upcoming{background:#ede9fe}.booking-actions{display:flex;gap:8px;flex-shrink:0}.checkin-booking-btn{width:28px;height:28px;border-radius:50%;background:#d1fae5;color:#10b981;border:none;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkin-booking-btn:active{background:#a7f3d0}.cancel-booking-btn{width:28px;height:28px;border-radius:50%;background:#fee2e2;color:#dc2626;border:none;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cancel-booking-btn:active{background:#fecaca}.history-icon{width:32px;height:32px;border-radius:8px;background:#d1fae5;color:#10b981;display:flex;align-items:center;justify-content:center;font-size:14px}.history-icon.upcoming-icon,.history-icon.payment{background:#ede9fe;color:#8b5cf6}.history-info{flex:1}.history-title{display:block;font-size:13px;font-weight:600;color:#1f2937}.history-date{font-size:11px;color:#6b7280}.small-modal{max-height:70vh;padding-bottom:env(safe-area-inset-bottom)}.modal-subtitle{text-align:center;color:#6b7280;padding:0 20px 8px}.modal-hint{text-align:center;color:#dc2626;font-size:13px;padding:0 20px 16px;font-weight:500}.discount-preview{display:block;color:#10b981;font-size:14px;font-weight:600;margin-top:4px}.form-group{padding:0 20px;margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-group select,.form-group input{width:100%;padding:12px;border:1px solid #E5E7EB;border-radius:10px;font-size:16px;background:#fff}.form-group select:focus,.form-group input:focus{outline:none;border-color:#8b5cf6}.date-picker-row{display:flex;align-items:center;gap:12px;background:#fff;padding:12px 16px;border-radius:12px;margin-bottom:12px}.date-picker-row svg{color:#8b5cf6}.date-input{flex:1;border:none;font-size:16px;font-family:inherit}.date-input:focus{outline:none}.today-link{background:none;border:none;color:#8b5cf6;font-weight:600;cursor:pointer}.date-label{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:16px}.period-navigator{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:12px;padding:12px;margin-bottom:12px}.nav-arrow{width:36px;height:36px;border-radius:50%;border:none;background:#f3f4f6;color:#374151;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.nav-arrow:hover{background:#e5e7eb}.period-display{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#374151}.attendance-group{background:#fff;border-radius:16px;padding:16px;margin-bottom:12px}.group-title{font-size:14px;font-weight:600;color:#8b5cf6;margin-bottom:12px}.summary-card{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:16px;padding:20px;display:flex;justify-content:space-between;align-items:center;color:#fff;margin-top:16px}.summary-label{font-size:14px;opacity:.9}.summary-number{font-size:32px;font-weight:700}.empty-state{background:#fff;border-radius:16px;padding:40px 20px;text-align:center}.payments-page .page-header{display:flex;justify-content:space-between;align-items:center;background:transparent;padding:0;border-bottom:none;margin-bottom:16px}.payments-page .page-header h1{font-size:24px;font-weight:700}.add-btn{width:48px;height:48px;border-radius:50%;background:#8b5cf6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.revenue-card{background:#fff;border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;margin-bottom:16px}.revenue-icon{width:56px;height:56px;border-radius:14px;background:#d1fae5;color:#10b981;display:flex;align-items:center;justify-content:center}.revenue-info{display:flex;flex-direction:column}.revenue-label{font-size:14px;color:#6b7280}.revenue-amount{font-size:28px;font-weight:700;color:#1f2937}.payments-quick-actions{display:flex;gap:12px;margin-bottom:20px}.pqa-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;background:#fff;border:none;border-radius:14px;padding:16px 8px;cursor:pointer}.pqa-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.pqa-icon.green{background:#d1fae5;color:#10b981}.pqa-icon.purple{background:#ede9fe;color:#8b5cf6}.pqa-icon.blue{background:#dbeafe;color:#3b82f6}.pqa-btn span{font-size:12px;font-weight:600;color:#374151}.payment-history-section h3{font-size:16px;font-weight:700;color:#1f2937;margin-bottom:12px}.payment-list{display:flex;flex-direction:column;gap:12px}.payment-card{background:#fff;border-radius:14px;padding:16px}.payment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.payment-header h4{font-size:16px;font-weight:600;color:#1f2937;margin:0}.payment-status{font-size:10px;font-weight:700;padding:4px 8px;border-radius:4px;text-transform:uppercase}.payment-status.completed{background:#d1fae5;color:#065f46}.payment-description{font-size:14px;color:#6b7280;margin:0 0 8px}.payment-meta{display:flex;gap:16px;margin-bottom:12px}.payment-date,.payment-method{display:flex;align-items:center;gap:6px;font-size:12px;color:#9ca3af}.payment-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #F3F4F6}.payment-amount{font-size:20px;font-weight:700;color:#10b981}.payment-amount.zero{color:#9ca3af}.delete-payment-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:8px}.reports-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;background:transparent;padding:0;border-bottom:none;margin-bottom:16px}.reports-page .page-header h1{font-size:24px;font-weight:700;margin-bottom:4px}.page-subtitle{font-size:14px;color:#6b7280;margin:0}.view-mode-tabs{display:flex;gap:8px;margin-bottom:12px;overflow-x:auto;padding-bottom:4px}.view-mode-tab{padding:10px 18px;border-radius:20px;border:none;background:#e5e7eb;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.view-mode-tab.active{background:#8b5cf6;color:#fff}.report-type-toggle{display:flex;gap:8px;margin-bottom:16px}.report-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:12px;border:2px solid #E5E7EB;background:#fff;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer}.report-type-btn.active{border-color:#8b5cf6;background:#ede9fe;color:#8b5cf6}.today-revenue-card{background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:16px;padding:24px;color:#fff;margin-bottom:16px}.today-revenue-card.attendance{background:linear-gradient(135deg,#10b981,#34d399)}.today-label{display:block;font-size:14px;opacity:.9;margin-bottom:8px}.today-amount{font-size:40px;font-weight:700}.month-comparison{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.month-card{background:#fff;border-radius:14px;padding:16px}.month-label{display:block;font-size:12px;color:#6b7280;margin-bottom:6px}.month-amount{font-size:22px;font-weight:700;color:#1f2937}.percent-change{display:flex;align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600}.percent-change.positive{color:#10b981}.percent-change.negative{color:#ef4444}.report-section{background:#fff;border-radius:14px;padding:16px;margin-bottom:12px}.report-section h3{font-size:16px;font-weight:700;color:#1f2937;margin:0 0 12px}.payment-method-list{display:flex;flex-direction:column;gap:10px}.payment-method-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #F3F4F6}.payment-method-row:last-child{border-bottom:none}.method-name{display:flex;align-items:center;gap:8px;font-size:14px;color:#374151;text-transform:capitalize}.method-amount{font-size:14px;font-weight:600;color:#1f2937}.recent-payments-list{display:flex;flex-direction:column;gap:10px}.recent-payment-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #F3F4F6}.recent-payment-row:last-child{border-bottom:none}.payment-info{display:flex;flex-direction:column}.payment-name{font-size:14px;font-weight:600;color:#1f2937}.payment-desc{font-size:12px;color:#6b7280}.payment-amt{font-size:14px;font-weight:600;color:#10b981}.attendance-class-list{display:flex;flex-direction:column;gap:10px}.attendance-class-row{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9fafb;border-radius:10px}.attendance-class-row .class-name{font-size:14px;font-weight:500;color:#374151}.attendance-class-row .class-count{width:32px;height:32px;border-radius:50%;background:#ede9fe;color:#8b5cf6;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.sales-count{display:block;font-size:14px;opacity:.8;margin-top:4px}.refresh-btn{background:#f3f4f6;border:none;padding:10px;border-radius:10px;cursor:pointer;color:#6b7280}.refresh-btn:hover{background:#e5e7eb}.report-section h3{display:flex;align-items:center;gap:8px}.package-type-list{display:flex;flex-direction:column;gap:8px}.package-type-row{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9fafb;border-radius:10px}.package-info{display:flex;flex-direction:column}.package-name{font-size:14px;font-weight:600;color:#374151}.package-count{font-size:12px;color:#6b7280}.package-amount{font-size:16px;font-weight:700;color:#10b981}.sales-list{display:flex;flex-direction:column;gap:0}.sale-row{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 0;border-bottom:1px solid #F3F4F6}.sale-row:last-child{border-bottom:none}.sale-info{display:flex;flex-direction:column;gap:2px}.sale-name{font-size:15px;font-weight:600;color:#1f2937}.sale-package{font-size:13px;color:#6b7280}.sale-date{font-size:11px;color:#9ca3af;margin-top:2px}.sale-amount{font-size:16px;font-weight:700;color:#10b981}.adjustments-section{background:#fafafa;border:1px dashed #D1D5DB}.adjustments-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;padding:0;cursor:pointer;font-size:14px;font-weight:600;color:#6b7280}.toggle-icon{font-size:18px;font-weight:400}.adjustments-list{margin-top:12px;padding-top:12px;border-top:1px solid #E5E7EB}.adjustment-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid #E5E7EB}.adjustment-row:last-child{border-bottom:none}.adjustment-info{display:flex;flex-direction:column;gap:2px}.adjustment-name{font-size:14px;font-weight:500;color:#6b7280}.adjustment-desc{font-size:12px;color:#9ca3af}.adjustment-date{font-size:11px;color:#9ca3af}.adjustment-amount{font-size:14px;color:#9ca3af}.admin-nav .nav-item{padding:4px 6px}.admin-nav .nav-item span{font-size:10px}.notification-container{position:relative}.notification-btn{background:#fff3;border:none;color:#fff;padding:8px;border-radius:8px;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.notification-dropdown{position:absolute;top:100%;left:50%;transform:translate(-70%);margin-top:8px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;width:320px;max-height:400px;overflow:hidden;z-index:1000}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid #E5E7EB}.notification-header h4{font-size:14px;font-weight:700;color:#1f2937;margin:0}.mark-read-btn{background:none;border:none;color:#8b5cf6;font-size:11px;font-weight:600;cursor:pointer}.notification-list{max-height:280px;overflow-y:auto}.no-notifications{text-align:center;padding:24px 14px;color:#9ca3af;font-size:13px}.notification-item{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid #F3F4F6;cursor:pointer;transition:background .2s}.notification-item:hover{background:#f9fafb}.notification-item:last-child{border-bottom:none}.notification-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-icon.booking{background:#dbeafe;color:#3b82f6}.notification-content{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.notification-title{font-size:13px;font-weight:600;color:#1f2937}.notification-message{font-size:12px;color:#6b7280;line-height:1.4}.notification-time{font-size:10px;color:#9ca3af;margin-top:2px}.conflict-checking{padding:10px;background:#f3f4f6;border-radius:8px;color:#6b7280;font-size:13px;text-align:center;margin-bottom:12px}.conflict-warning{padding:12px;background:#fef3c7;border:1px solid #F59E0B;border-radius:8px;color:#92400e;font-size:13px;margin-bottom:12px}.conflict-warning strong{display:block;margin-bottom:6px}.conflict-warning ul{margin:0;padding-left:20px}.conflict-warning li{margin-bottom:4px}.conflict-clear{padding:10px;background:#d1fae5;border:1px solid #10B981;border-radius:8px;color:#065f46;font-size:13px;text-align:center;margin-bottom:12px}.conflict-hint{text-align:center;color:#f59e0b;font-size:12px;margin-top:8px}.private-session-cell{background:linear-gradient(135deg,#f59e0b,#d97706)!important;border-left-color:#b45309!important;color:#fff!important}.private-session-cell .class-name{color:#fff!important}.private-session-cell .class-time{color:#ffffffe6!important}.private-sessions-section{margin-top:24px;padding:16px;background:#fef3c7;border-radius:12px;border:1px solid #F59E0B}.private-sessions-section h3{margin:0 0 12px;font-size:16px;color:#92400e;font-weight:600}.private-sessions-list{display:flex;flex-direction:column;gap:8px}.private-session-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000001a}.private-session-card:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.private-session-card .session-date{min-width:70px;font-size:12px;font-weight:600;color:#6b7280}.private-session-card .session-details{flex:1;display:flex;flex-direction:column}.private-session-card .session-student{font-size:14px;font-weight:600;color:#1f2937}.private-session-card .session-time-small{font-size:12px;color:#6b7280}.private-session-card .session-status{font-size:18px}.private-session-card .session-status.attended{color:#10b981}.private-session-card .session-status.booked{color:#f59e0b}.private-session-detail{padding:16px 0}.private-session-detail p{margin:8px 0;font-size:14px;color:#374151}.private-session-detail strong{color:#1f2937}.guest-history-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:15px;cursor:pointer;margin-bottom:16px;transition:all .2s}.guest-history-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.guest-history-modal{background:#fff;border-radius:24px;width:100%;max-width:500px;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease;margin-bottom:auto;margin-top:60px}.guest-history-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #E5E7EB;position:sticky;top:0;background:#fff;z-index:10}.guest-history-modal .modal-header h2{font-size:18px;font-weight:600;color:#1f2937}.guest-history-modal .modal-body{padding:16px}.guest-list{display:flex;flex-direction:column;gap:12px}.guest-card{background:#f9fafb;border-radius:12px;padding:14px;border:1px solid #E5E7EB}.guest-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.guest-info{display:flex;flex-direction:column;gap:2px}.guest-name{font-weight:600;font-size:15px;color:#1f2937}.guest-date{font-size:13px;color:#6b7280}.guest-amount{font-weight:700;font-size:16px;color:#10b981}.guest-details{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px dashed #E5E7EB}.guest-class{font-size:13px;color:#374151}.guest-referral{font-size:13px;color:#8b5cf6;font-weight:500}.guest-actions{display:flex;justify-content:flex-end}.create-account-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#ede9fe;color:#7c3aed;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.create-account-btn:hover{background:#ddd6fe}.create-account-form{display:flex;flex-direction:column;gap:10px;width:100%}.create-account-form input{padding:10px 14px;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;width:100%}.create-account-form input:focus{outline:none;border-color:#8b5cf6}.create-account-form .form-buttons{display:flex;gap:8px;justify-content:flex-end}.create-account-form .cancel-btn{padding:8px 14px;background:#f3f4f6;color:#6b7280;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer}.create-account-form .cancel-btn .guest-tabs{display:flex;border-bottom:1px solid #E5E7EB;padding:0 16px}.create-account-form .cancel-btn .guest-tab{flex:1;padding:12px 16px;background:none;border:none;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.create-account-form .cancel-btn .guest-tab.active{color:#8b5cf6;border-bottom-color:#8b5cf6}.create-account-form .cancel-btn .referral-stats{padding:8px 0}.create-account-form .cancel-btn .referral-summary{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.create-account-form .cancel-btn .referral-stat-box{background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:12px;padding:16px;text-align:center;color:#fff}.create-account-form .cancel-btn .referral-stat-box .stat-value{display:block;font-size:28px;font-weight:700;margin-bottom:4px}.create-account-form .cancel-btn .referral-stat-box .stat-label{font-size:12px;opacity:.9}.create-account-form .cancel-btn .referral-title{font-size:14px;font-weight:600;color:#374151;margin-bottom:12px;padding-left:4px}.create-account-form .cancel-btn .referrer-list{display:flex;flex-direction:column;gap:10px}.create-account-form .cancel-btn .referrer-card{display:flex;align-items:center;gap:12px;background:#f9fafb;border-radius:10px;padding:12px;border:1px solid #E5E7EB}.create-account-form .cancel-btn .referrer-rank{width:28px;height:28px;border-radius:50%;background:#8b5cf6;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.create-account-form .cancel-btn .referrer-card:nth-child(1) .referrer-rank{background:linear-gradient(135deg,#f59e0b,#d97706)}.create-account-form .cancel-btn .referrer-card:nth-child(2) .referrer-rank{background:linear-gradient(135deg,#9ca3af,#6b7280)}.create-account-form .cancel-btn .referrer-card:nth-child(3) .referrer-rank{background:linear-gradient(135deg,#d97706,#b45309)}.create-account-form .cancel-btn .referrer-info{flex:1}.create-account-form .cancel-btn .referrer-guests{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.create-account-form .cancel-btn .guest-class-tag{display:inline-block;padding:4px 8px;background:#f3f4f6;border-radius:6px;font-size:11px;color:#6b7280}.create-account-form .cancel-btn .referrer-name{display:block;font-weight:600;font-size:15px;color:#1f2937}.create-account-form .cancel-btn .referrer-stats{font-size:13px;color:#6b7280}.create-account-form .confirm-btn{padding:8px 14px;background:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}.create-account-form .confirm-btn:hover{background:#7c3aed}.referrer-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #E5E7EB;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;max-height:200px;overflow-y:auto;margin-top:4px}.referrer-option{display:block;width:100%;padding:12px 14px;text-align:left;background:none;border:none;border-bottom:1px solid #F3F4F6;cursor:pointer;font-size:14px;color:#1f2937}.referrer-option:hover{background:#f3f4f6}.referrer-option:last-child{border-bottom:none}.referrer-suggestions .no-results{padding:12px 14px;color:#9ca3af;font-size:13px;text-align:center}.selected-referrer{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;background:#ede9fe;border-radius:8px;font-size:13px;color:#6b7280}.selected-referrer strong{color:#7c3aed}.selected-referrer button{margin-left:auto;background:none;border:none;font-size:18px;color:#9ca3af;cursor:pointer;padding:0 4px}.cancel-class-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:#fee2e2;color:#dc2626;border:1px solid #FECACA;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;margin-bottom:12px;transition:all .2s}.cancel-class-btn:hover{background:#fecaca}.cancel-class-btn:disabled{opacity:.6;cursor:not-allowed}.restore-class-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:#dcfce7;color:#16a34a;border:1px solid #BBF7D0;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;margin-bottom:12px;transition:all .2s}.restore-class-btn:hover{background:#bbf7d0}.class-canceled-banner{display:flex;align-items:center;justify-content:center;gap:10px;background:#dc2626;color:#fff;padding:12px 16px;border-radius:10px;font-weight:700;font-size:15px;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.class-canceled-banner .card.canceled-class{position:relative;border:1px solid #FECACA;background:#fef2f2}.class-canceled-banner .canceled-badge{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:4px;background:#dc2626;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.5px}.session-actions button:disabled{opacity:.4;cursor:not-allowed}.selected-referrer button:hover{color:#6b7280}.small-modal .form-group{position:relative}.needs-attention-card{background:#fff;border-radius:16px;padding:16px;margin-top:16px;border:1px solid #FEE2E2}.needs-attention-header{display:flex;align-items:center;gap:10px;color:#dc2626;margin-bottom:16px}.needs-attention-header h3{font-size:16px;font-weight:600;margin:0}.attention-section{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #F3F4F6}.attention-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.attention-section h4{font-size:13px;font-weight:600;color:#6b7280;margin-bottom:8px}.attention-name{font-size:14px;font-weight:500;color:#1f2937}.attention-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:12px}.attention-badge.red{background:#fee2e2;color:#dc2626}.attention-badge.orange{background:#fef3c7;color:#d97706}.attention-badge.yellow{background:#fef9c3;color:#ca8a04}.history-card.canceled{background:#fef2f2;border-color:#fecaca}.history-card.canceled .history-icon{background:#fee2e2;color:#dc2626}.canceled-text{text-decoration:line-through;color:#9ca3af}.canceled-badge{display:inline-block;margin-left:8px;padding:2px 6px;background:#dc2626;color:#fff;font-size:10px;font-weight:600;border-radius:4px}.more-link{display:block;font-size:12px;color:#8b5cf6;text-align:center;padding:4px;cursor:pointer}.attention-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f9fafb;border-radius:8px;margin-bottom:6px;gap:8px}.attention-content{display:flex;justify-content:space-between;align-items:center;flex:1;cursor:pointer;transition:opacity .2s}.attention-content:hover{opacity:.8}.dismiss-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:none;background:#e5e7eb;color:#6b7280;cursor:pointer;transition:all .2s;flex-shrink:0}.dismiss-btn:hover{background:#fee2e2;color:#dc2626}.dismiss-btn:disabled{opacity:.5;cursor:not-allowed}
