body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.login-content{display:flex;max-width:500px;position:relative;width:100%;z-index:1}.login-left{align-items:center;display:flex;flex:1 1;justify-content:center;padding:0}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1e293b66;border:1px solid #94a3b833;border-radius:16px;box-shadow:0 20px 40px #0000004d;padding:40px;transition:all .3s ease;width:100%}.login-card:hover{background:#1e293b80;border-color:#94a3b84d}.login-header{align-items:center;display:flex;flex-direction:column;gap:15px;margin-bottom:30px;text-align:center}.login-logo{animation:fadeInScale .6s ease-out;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));height:140px;object-fit:contain;width:140px}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.login-header h1{color:#e2e8f0;font-size:28px;font-weight:600;letter-spacing:1px;margin:0}.login-header p{color:#94a3b8;font-size:15px;font-style:italic;margin:0}.login-form{margin-bottom:30px}.form-group{margin-right:20px}.form-group label{color:#fff!important;font-size:15px;margin-bottom:5px;text-shadow:0 1px 3px #00000080}.form-group input{background:#fffffff2;border:1px solid #94a3b84d;border-radius:8px;box-sizing:border-box;color:#1e293b;font-size:15px;font-weight:500;padding:12px;transition:all .3s ease}.form-group input::placeholder{color:#94a3b8}.form-group input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;margin-bottom:20px;padding:10px;text-align:center}.login-btn{background:#475569;border:none;border-radius:8px;box-shadow:0 2px 8px #0003;color:#f1f5f9;cursor:pointer;font-size:15px;font-weight:600;padding:13px;transition:all .3s ease;width:100%}.login-btn:hover:not(:disabled){background:#334155;box-shadow:0 4px 12px #0000004d}.login-btn:disabled{cursor:not-allowed;opacity:.6}.demo-section{border-top:1px solid #94a3b833;padding-top:20px}.demo-section h3{color:#94a3b8;font-size:13px;letter-spacing:1px;margin:0 0 15px;text-align:center;text-transform:uppercase}.demo-buttons{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.demo-btn{background:#1e293b66;border:1px solid #94a3b84d;border-radius:8px;color:#cbd5e1;cursor:pointer;font-size:14px;font-weight:500;padding:11px;transition:all .3s ease}.demo-btn.teacher{border-color:#64748b66}.demo-btn.teacher:hover:not(:disabled){background:#33415599;border-color:#64748b99}.demo-btn.parent{border-color:#64748b66}.demo-btn.parent:hover:not(:disabled){background:#33415599;border-color:#64748b99}.demo-btn:disabled{cursor:not-allowed;opacity:.6}@keyframes twinkle{0%{opacity:.3}to{opacity:1}}@keyframes rotate{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}@media (max-width:768px){.login-content{max-width:100%}.login-card{padding:30px 20px}.login-header h1{font-size:24px}.demo-buttons{grid-template-columns:1fr}}.animated-background{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);height:100%;left:0;position:fixed;top:0;width:100%;z-index:0}.change-password-modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.change-password-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0006;max-height:90vh;max-width:550px;overflow-y:auto;width:100%}.modal-header{background:linear-gradient(135deg,#4a655a,#3d5449);border-radius:16px 16px 0 0;color:#fff;padding:24px 32px}.modal-header h2{align-items:center;display:flex;flex-wrap:wrap;font-size:1.5rem;font-weight:600;gap:10px;margin:0 0 8px}.required-badge{background:#ff5722;border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.required-message{font-size:.9rem;line-height:1.5;margin:8px 0 0;opacity:.95}.change-password-form{padding:32px}.error-banner{background:#ffebee;border-left:4px solid #f44336;border-radius:8px;color:#c62828;font-size:.9rem;font-weight:500;margin-bottom:20px;padding:12px 16px}.form-group{margin-bottom:24px}.form-group label{color:#333}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{background:#f8f6f3;border:2px solid #e0ddd8;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:.95rem;padding:12px 45px 12px 16px;transition:all .3s ease;width:100%}.password-input-wrapper input:focus{background:#fff;border-color:#4a655a;box-shadow:0 0 0 3px #4a655a1a;outline:none}.password-input-wrapper input.error{background:#ffebee;border-color:#f44336}.toggle-password{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:4px 8px;position:absolute;right:12px;transition:transform .2s ease}.toggle-password:hover{transform:scale(1.1)}.toggle-password:disabled{cursor:not-allowed;opacity:.5}.error-text{color:#f44336}.error-text,.success-text{display:block;font-weight:500;margin-top:6px}.success-text{color:#4caf50;font-size:.85rem}.password-strength{align-items:center;display:flex;gap:12px;margin-top:12px}.strength-bar{display:flex;flex:1 1;gap:4px;height:6px}.strength-segment{background:#e0e0e0;border-radius:3px;flex:1 1;transition:background-color .3s ease}.strength-text{font-size:.85rem;font-weight:600;min-width:60px}.password-requirements{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;margin-top:12px;padding:12px 16px}.requirements-title{color:#666;font-size:.85rem;font-weight:600;margin:0 0 8px}.password-requirements ul{list-style:none;margin:0;padding:0}.password-requirements li{color:#666;font-size:.85rem;margin:4px 0;transition:color .3s ease}.password-requirements li.valid{color:#4caf50;font-weight:500}.form-actions{border-top:2px solid #e0ddd8;margin-top:32px;padding-top:24px}.btn-submit{background:linear-gradient(135deg,#4a655a,#3d5449);border-radius:10px;box-shadow:0 4px 12px #4a655a4d;font-size:1rem;font-weight:600;padding:14px 24px;width:100%}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #4a655a66;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:600px){.change-password-modal{margin:10px;max-width:95%}.modal-header{padding:20px 24px}.modal-header h2{font-size:1.3rem}.change-password-form{padding:24px 20px}.form-group{margin-bottom:20px}}.change-password-modal::-webkit-scrollbar{width:8px}.change-password-modal::-webkit-scrollbar-track{background:#f1f1f1;border-radius:0 16px 16px 0}.change-password-modal::-webkit-scrollbar-thumb{background:#4a655a;border-radius:10px}.change-password-modal::-webkit-scrollbar-thumb:hover{background:#3d5449}.user-menu{display:inline-block;position:relative;z-index:9000}.user-menu-trigger{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;transition:all .3s ease;width:40px}.user-menu-trigger:hover{background:#ffffff1a;transform:scale(1.05)}.user-menu-trigger:active{transform:scale(.95)}.hamburger{position:relative}.hamburger,.hamburger:after,.hamburger:before{background-color:#fff;display:block;height:2px;transition:all .3s ease;width:24px}.hamburger:after,.hamburger:before{content:"";position:absolute}.hamburger:before{top:-8px}.hamburger:after{top:8px}.user-menu-trigger:hover .hamburger,.user-menu-trigger:hover .hamburger:after,.user-menu-trigger:hover .hamburger:before{background-color:#fff}.user-menu-dropdown{animation:dropdownFadeIn .2s ease-out;background:#f8f6f3;border:2px solid #4a7c59;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:280px;z-index:10000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu-header{align-items:center;background:linear-gradient(135deg,#2d5016,#4a7c59);color:#fff;display:flex;gap:16px;padding:20px}.user-avatar-large{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.user-initial-large{color:#fff;font-size:18px;font-weight:700}.user-details h3{color:#fff;font-size:16px;font-weight:600;margin:0 0 4px}.user-details p{color:#fffc;font-size:14px;margin:0 0 8px}.user-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px}.menu-divider{background:#a69080;border:none;height:1px;margin:0}.user-menu-footer,.user-menu-items{padding:8px 0}.menu-item{align-items:center;background:none;border:none;color:#2d5016;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:14px 20px;text-align:left;transition:all .2s ease;width:100%}.menu-item:hover{background:#e8e6e1;color:#2d5016}.menu-item-icon{align-items:center;display:flex;font-size:18px;justify-content:center;width:24px}.menu-icon,.menu-item-icon{flex-shrink:0;text-align:center}.menu-icon{font-size:16px;width:20px}.logout-item{color:#8b4513}.logout-item:hover{background:#f0ede8;color:#8b4513}@media (max-width:768px){.user-menu-trigger{min-width:140px;padding:6px 10px}.user-name{font-size:13px}.user-role{font-size:11px}.user-menu-dropdown{right:-10px;width:260px}.user-menu-header{padding:16px}.user-avatar-large{height:40px;width:40px}.user-initial-large{font-size:16px}.user-details h3{font-size:14px}.user-details p{font-size:13px}}@media (prefers-color-scheme:dark){.user-menu-trigger{background:#0003;border-color:#ffffff1a}.user-menu-trigger:hover{background:#0000004d;border-color:#fff3}.user-name{color:#fff}.user-menu-dropdown{background:#1a202c;border-color:#2d3748}.menu-item{color:#f8f6f3}.menu-item:hover{color:#fff}.menu-divider,.menu-item:hover{background:#2d3748}}.user-menu-trigger{transform-origin:center}.user-menu-trigger:active{transform:translateY(-1px) scale(.98)}.menu-item{transform-origin:left center}.menu-item:active{transform:scale(.98)}.user-info-view{animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.user-info-header{align-items:center;color:#fff;display:flex;gap:16px;padding:16px 20px;position:relative}.back-btn{background:#fff3;border-radius:50%;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.back-btn:hover{background:#ffffff4d;transform:translateX(-2px)}.user-info-header h3{font-size:18px;font-weight:600;margin:0}.user-info-content{padding:20px}.user-info-section{border-bottom:1px solid #a69080;margin-bottom:24px;padding-bottom:20px;text-align:center}.info-avatar{align-items:center;background:linear-gradient(135deg,#2d5016,#4a7c59);border:3px solid #f8f6f3;border-radius:50%;box-shadow:0 4px 12px #0000001a;display:flex;height:64px;justify-content:center;margin:0 auto 12px;width:64px}.info-initial{color:#fff;font-size:24px;font-weight:700}.user-info-section h4{color:#1a202c;font-size:20px;font-weight:600;margin:0 0 8px}.info-role{background:#e8e6e1;border-radius:16px;color:#2d5016;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px}.user-details-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.detail-item{background:#f8f6f3;gap:12px;padding:12px;transition:all .2s ease}.detail-item:hover{background:#e8e6e1;transform:translateY(-1px)}.detail-icon{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-shrink:0;font-size:18px;height:32px;justify-content:center;width:32px}.detail-content{flex:1 1;min-width:0}.detail-content label{color:#8d7b68;display:block;font-size:12px;font-weight:600;letter-spacing:.05em;margin-bottom:2px;text-transform:uppercase}.detail-content span{color:#1e293b;display:block;font-size:14px;font-weight:500;word-break:break-word}.info-actions{border-top:1px solid #a69080;padding-top:16px}.edit-btn{align-items:center;background:linear-gradient(135deg,#2d5016,#4a7c59);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:all .2s ease;width:100%}.edit-btn:hover{box-shadow:0 8px 16px #667eea4d;transform:translateY(-2px)}.edit-btn:active{transform:translateY(0)}@media (max-width:768px){.user-info-content{padding:16px}.user-info-header{padding:12px 16px}.info-avatar{height:56px;width:56px}.info-initial{font-size:20px}.user-info-section h4{font-size:18px}.detail-item{padding:10px}.detail-icon{font-size:16px;height:28px;width:28px}}.student-notifications{padding:24px}.notifications-title{color:#202124;font-size:1.5rem;font-weight:500;margin-bottom:20px}.notifications-loading{color:#5f6368;padding:40px;text-align:center}.no-notifications{padding:60px 20px;text-align:center}.no-notifications-icon{font-size:4rem;margin-bottom:16px}.no-notifications p{color:#5f6368;font-size:1.1rem}.notifications-list{display:flex;flex-direction:column;gap:16px}.notification-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:box-shadow .2s ease}.notification-card:hover{box-shadow:0 2px 8px #0000001a}.notification-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:16px 20px;transition:background .2s ease}.notification-header:hover{background:#f8f9fa}.notification-main{flex:1 1}.notification-subject{color:#202124;font-size:1rem;font-weight:600;margin-bottom:8px}.notification-meta{align-items:center;display:flex;font-size:.875rem;gap:16px}.notification-date{color:#5f6368}.notification-status{display:flex;gap:12px}.status-success{color:#137333;font-weight:500}.status-failed{color:#c5221f;font-weight:500}.expand-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#5f6368;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;padding:8px;transition:background .2s ease;width:32px}.expand-btn:hover{background:#0000000d}.notification-body{animation:expandDown .2s ease-out;border-top:1px solid #e0e0e0;padding:0 20px 20px}@keyframes expandDown{0%{max-height:0;opacity:0}to{max-height:1000px;opacity:1}}.notification-recipients{margin-bottom:20px}.notification-recipients strong{color:#202124;display:block;font-size:.9rem;margin-bottom:8px}.notification-recipients ul{list-style:none;margin:0;padding:0}.notification-recipients li{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;font-size:.875rem;gap:8px;margin-bottom:4px;padding:6px 12px}.notification-recipients li.recipient-sent{background:#e6f4ea;color:#137333}.notification-recipients li.recipient-failed{background:#fce8e6;color:#c5221f}.recipient-email{color:#5f6368;font-size:.8rem;margin-left:4px}.notification-message{margin-top:16px}.notification-message strong{color:#202124;display:block;font-size:.9rem;margin-bottom:8px}.notification-message pre{word-wrap:break-word;background:#f8f9fa;border-radius:6px;color:#202124;font-family:inherit;font-size:.875rem;line-height:1.6;margin:0;padding:12px;white-space:pre-wrap}@media (max-width:768px){.student-notifications{padding:16px}.notification-header{padding:12px 16px}.notification-meta{align-items:flex-start;flex-direction:column;gap:4px}.notification-body{padding:0 16px 16px}}.student-comments-container{margin:0 auto;max-width:900px;padding:1.5rem}.comments-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.comments-header h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.add-comment-btn{background:#475569;border:none;border-radius:8px;box-shadow:0 2px 8px #4755694d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.add-comment-btn:hover{background:#334155;box-shadow:0 4px 12px #47556966;transform:translateY(-1px)}.comment-form{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 12px #0000001a;margin-bottom:2rem;padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{font-size:.95rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;font-family:inherit;font-size:.95rem;transition:all .3s ease}.form-group textarea{min-height:100px}.sentiment-buttons{display:flex;gap:1rem}.sentiment-btn{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:.75rem 1rem;transition:all .3s ease}.sentiment-btn.positive.active,.sentiment-btn.positive:hover{background:#d1fae5;border-color:#10b981;color:#065f46}.sentiment-btn.neutral.active,.sentiment-btn.neutral:hover{background:#f3f4f6;border-color:#6b7280;color:#374151}.sentiment-btn.negative.active,.sentiment-btn.negative:hover{background:#fee2e2;border-color:#ef4444;color:#991b1b}.form-actions{margin-top:1.5rem}.btn-cancel,.btn-submit{font-size:.95rem;padding:.75rem 1.5rem}.btn-cancel{background:#f1f5f9;color:#475569}.btn-cancel:hover{background:#e2e8f0}.comments-list{display:flex;flex-direction:column;gap:1.5rem}.no-comments{background:#fff;border:2px dashed #d1d5db;border-radius:12px;padding:4rem 2rem;text-align:center}.no-comments-icon{font-size:4rem;margin-bottom:1rem}.no-comments p{color:#6b7280;font-size:1.1rem;margin:0 0 .5rem}.no-comments small{color:#9ca3af;font-size:.9rem}.comment-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;transition:all .3s ease}.comment-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.comment-header{justify-content:space-between;margin-bottom:1rem}.comment-header,.comment-meta{align-items:center;display:flex}.comment-meta{flex-wrap:wrap;gap:.75rem}.comment-type-badge{color:#fff}.comment-type-badge,.sentiment-badge{border-radius:6px;font-size:.85rem;font-weight:600;padding:.35rem .75rem}.sentiment-badge{background:#f3f4f6}.comment-actions{display:flex;gap:.5rem}.action-btn{background:#0000;font-size:1.2rem;padding:.35rem .5rem}.action-btn.edit:hover{background:#dbeafe}.comment-content{background:#f8fafc;border-left:3px solid #475569;border-radius:8px;color:#1e293b;font-size:1rem;line-height:1.6;margin-bottom:1rem;overflow-wrap:break-word;padding:1rem;white-space:pre-line}.comment-footer{color:#6b7280;display:flex;flex-wrap:wrap;font-size:.85rem;gap:1rem}.comment-author,.comment-date,.session-date{align-items:center;display:flex;gap:.35rem}.comments-loading{padding:3rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-top-color:#475569;height:40px;margin:0 auto 1rem;width:40px}@media (max-width:768px){.student-comments-container{padding:1rem}.comments-header{align-items:flex-start;gap:1rem}.comment-footer,.comments-header,.sentiment-buttons{flex-direction:column}.comment-footer{gap:.5rem}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}.student-detail-page{background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh;padding:0}.page-header{background:#fff;box-shadow:0 2px 8px #0000000d;padding:1rem 2rem;position:relative;z-index:1}.back-btn{background:#475569;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem}.back-btn:hover{background:#334155;transform:translateX(-4px)}.student-profile-header{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;margin:1.5rem 2rem;overflow:hidden}.header-top{gap:2rem;justify-content:space-between;padding:2rem}.header-top,.profile-left{align-items:flex-start;display:flex}.profile-left{flex:1 1;gap:1.5rem}.profile-avatar{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 8px 24px #3b82f64d;flex-shrink:0;height:120px;width:120px}.profile-avatar img{height:100%;object-fit:cover;width:100%}.avatar-fallback{align-items:center;background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff;display:flex;font-size:3rem;font-weight:700;height:100%;justify-content:center;width:100%}.profile-info{flex:1 1;text-align:left}.profile-name{color:#1e293b;font-size:2rem;font-weight:700;margin:0 0 1rem;text-align:left}.profile-details{align-items:flex-start;display:flex;flex-direction:column;gap:.5rem}.profile-details p{color:#475569;font-size:.95rem;line-height:1.6;margin:0;text-align:left}.profile-details strong{color:#1e293b;font-weight:600;margin-right:.5rem}.profile-stats{display:flex;flex-shrink:0;gap:1rem}.stat-box{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:12px;min-width:120px;padding:1.25rem 1.75rem;text-align:center}.stat-value{color:#3b82f6;font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:#64748b;font-size:.85rem}.student-nav-tabs{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:0;margin:0;overflow-x:auto;padding:0}.tab-btn{flex-shrink:0;padding:1rem 2rem;position:relative;white-space:nowrap}.tab-btn:hover{background:#fff;color:#3b82f6}.tab-btn.active{border-bottom-color:#3b82f6;color:#3b82f6}.student-content{min-height:400px;padding:1rem}.tab-content{border-radius:16px;box-shadow:0 4px 12px #00000014;padding:2rem}.tab-content h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.loading-state{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.spinner{animation:spin .8s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:50px;width:50px}.no-data{color:#64748b;padding:3rem 2rem;text-align:center}.no-data-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.attendance-list{gap:1rem}.attendance-card{align-items:center;background:#f8fafc;border-left:4px solid #0000;display:flex;gap:1.5rem;padding:1.25rem}.attendance-card:hover{box-shadow:0 4px 12px #00000014;transform:translateX(4px)}.attendance-card.present{background:#f0fdf4;border-left-color:#10b981}.attendance-card.absent{background:#fef2f2;border-left-color:#ef4444}.attendance-date{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d;flex-direction:column;justify-content:center;min-width:70px;padding:.75rem}.date-day{color:#1e293b;font-size:1.75rem;font-weight:700;line-height:1}.date-month{color:#64748b;font-size:.8rem;font-weight:600;margin-top:.25rem;text-transform:uppercase}.attendance-info{display:flex;flex-direction:column;gap:.5rem}.session-title{text-transform:capitalize}.session-meta{color:#64748b;display:flex;font-size:.9rem;gap:1.5rem}.session-notes{font-size:.85rem;font-style:italic;margin-top:.25rem}.attendance-badge{flex-shrink:0}.badge-absent,.badge-present{border-radius:8px;display:inline-block;font-size:.85rem;font-weight:600;padding:.5rem 1rem}.badge-present{background:#d1fae5;color:#065f46}.badge-absent{background:#fee2e2;color:#991b1b}.progress-bar{background:#e0ddd8;border-radius:6px;height:12px;overflow:hidden;width:100%}.progress-fill{height:100%;transition:width .5s ease}.progress-text{color:#5d4e37;font-weight:600;text-align:center}.attendance-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:30px}.attendance-section h2{color:#5d4e37;font-size:24px;margin:0 0 20px}.no-attendance{color:#8d7b68}.no-attendance-icon{font-size:64px;margin-bottom:20px}.no-attendance h3{color:#5d4e37;font-size:24px;margin:0 0 10px}.attendance-list{flex-direction:column;gap:15px}.attendance-item{grid-gap:20px;align-items:center;border:2px solid #e0ddd8;border-radius:12px;display:grid;gap:20px;grid-template-columns:auto 1fr auto;padding:20px;transition:all .3s ease}.attendance-item:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-2px)}.attendance-item.present{background:#4a655a0d;border-color:#4a655a33}.attendance-item.absent{background:#ef44440d;border-color:#ef444433}.attendance-date{gap:15px}.attendance-date,.date-badge{align-items:center;display:flex}.date-badge{background:#4a655a;border-radius:8px;color:#fff;flex-direction:column;min-width:50px;padding:8px 12px}.date-badge .day{font-size:18px;font-weight:700;line-height:1}.date-badge .month{font-size:12px;margin-top:2px;text-transform:uppercase}.weekday{font-size:16px;font-weight:600}.full-date{color:#8d7b68;font-size:14px}.attendance-details{display:flex;flex-direction:column;gap:8px}.session-info{color:#8d7b68;font-size:14px;gap:15px}.session-notes,.student-notes{color:#5d4e37;font-size:14px;line-height:1.4}.session-notes strong,.student-notes strong{color:#8d7b68}.attendance-status{display:flex;justify-content:center}.status-badge{align-items:center;display:flex;font-size:14px;gap:8px;padding:8px 16px}.status-badge.present{background:#4a655a1a;border:2px solid #4a655a;color:#4a655a}.status-badge.absent{background:#ef44441a;border:2px solid #ef4444;color:#ef4444}.status-icon{font-size:16px}@media (max-width:1024px){.header-top{flex-direction:column}.profile-stats{justify-content:center;width:100%}}@media (max-width:768px){.page-header,.student-content,.student-profile-header{margin:1rem}.header-top{padding:1.5rem 1rem}.profile-left{align-items:center;flex-direction:column;text-align:center}.profile-avatar{height:100px;width:100px}.profile-name{font-size:1.5rem}.tab-btn{font-size:.85rem;padding:.75rem 1rem}.attendance-card{flex-direction:column;text-align:center}.session-meta{justify-content:center}.stat-box{min-width:100px;padding:1rem 1.25rem}.stat-value{font-size:1.5rem}}.create-student-form-container{margin:0 auto;max-width:800px;width:100%}.create-student-form{display:flex;flex-direction:column;gap:2rem}.form-section{background:#fff!important;border:1px solid #ddd!important;border-radius:8px;padding:1.5rem}.form-section h3{border-bottom:2px solid #ddd!important;color:#333!important;font-size:1.2rem;margin:0 0 1.5rem;padding-bottom:.5rem}.form-row{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1rem}.form-group label{font-size:1rem;text-shadow:none}.create-student-form .form-group label,.form-group label,.form-section .form-group label,label[for]{color:#000!important;font-weight:700}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:1rem;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#8d7b68;box-shadow:0 0 0 2px #8d7b671a}.form-group input.error,.form-group select.error{border-color:#dc3545}.form-group textarea{color:#333;min-height:80px;resize:vertical}.error-text{color:#dc3545;font-size:.85rem;margin-top:-.25rem}.checkbox-group{margin-bottom:1.5rem}.checkbox-group label{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:.5rem}.checkbox-group input[type=checkbox]{cursor:pointer;height:20px;width:20px}.form-actions{border-top:1px solid #dee2e6;gap:1rem;padding-top:1rem}.btn-cancel,.btn-submit{border:none;border-radius:4px;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover:not(:disabled){background:#5a6268}.btn-submit{background:#3788d8}.btn-submit:hover:not(:disabled){background:#2c6db5;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.btn-cancel:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.6}.hourly-rate-selector{align-items:center;display:flex;gap:.5rem}.rate-select{background:#fff;border:1px solid #ced4da;border-radius:4px;cursor:pointer;flex:1 1;font-size:1rem;padding:.75rem;transition:border-color .2s}.rate-select:focus{border-color:#3788d8;box-shadow:0 0 0 3px #3788d81a;outline:none}.custom-rate-input{animation:slideIn .3s ease;background:#fff3cd;border:2px solid #ffc107;border-radius:4px;color:#856404;flex:1 1;font-size:1rem;font-weight:600;padding:.75rem}.custom-rate-input:focus{border-color:#ff9800;box-shadow:0 0 0 3px #ffc10733;outline:none}.info-box{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-left:4px solid #4a655a;border-radius:8px;margin-top:1rem;padding:1rem 1.5rem}.info-box p{color:#2e7d32;font-size:.9rem;line-height:1.5;margin:.5rem 0}.info-box strong{color:#1b5e20;font-weight:600}@media (max-width:768px){.form-row{grid-template-columns:1fr}.form-section{padding:1rem}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}.hourly-rate-selector{flex-direction:column}.custom-rate-input,.rate-select{width:100%}}.students-tab{margin:0 auto;max-width:1400px;padding:2rem}.tab-header{margin-bottom:2rem;min-height:60px;position:relative;z-index:1}.tab-header h2{color:#1e293b;font-size:1.75rem;font-weight:600}.header-actions .add-btn{background:#4a655a;border:none;border-radius:8px;box-shadow:0 2px 8px #4a655a4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.header-actions .add-btn:hover{background:#3d5449;box-shadow:0 4px 12px #4a655a66;transform:translateY(-1px)}.students-list,.students-tab .students-list,div.students-list{grid-gap:2.5rem!important;grid-row-gap:2.5rem!important;grid-column-gap:2.5rem!important;column-gap:2.5rem!important;display:grid!important;gap:2.5rem!important;grid-template-columns:repeat(auto-fit,minmax(280px,280px))!important;justify-content:start!important;margin:0!important;padding:0!important;row-gap:2.5rem!important;width:100%!important}.no-students-message{background:#fff;border:2px dashed #d1d5db;border-radius:12px;grid-column:1/-1;padding:4rem 2rem;text-align:center}.no-students-message p{color:#6b7280;font-size:1.1rem;margin:0}.students-list .student-item,.students-tab .students-list .student-item,div.student-item{background:#fff!important;border:1px solid #e5e7eb!important;border-radius:16px;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;flex-direction:column;height:120px!important;max-height:120px!important;max-width:280px!important;min-height:120px!important;min-width:280px!important;overflow:hidden;position:relative;transition:all .3s ease;width:280px!important}.students-list .student-item:hover,.students-tab .students-list .student-item:hover,div.student-item:hover{background:#f8fafc!important;box-shadow:0 4px 12px #00000026;transform:scale(1.02)}.student-actions-icons{align-items:center;display:flex;flex-shrink:0;gap:.4rem;position:absolute;right:.5rem;top:.5rem}.student-item .student-content,.students-list .student-item .student-content,.students-tab .students-list .student-item .student-content,div.student-content{align-items:flex-start;box-sizing:border-box;display:flex!important;flex:1 1;gap:1rem;height:auto!important;min-height:80px!important;opacity:1!important;overflow:visible!important;padding:1rem 4rem 1rem 1rem;visibility:visible!important;width:100%!important}.student-content *{display:inherit!important;opacity:1!important;visibility:visible!important}.student-avatar-section,.student-content .student-avatar-section,.student-item .student-avatar-section{align-items:flex-start!important;display:flex!important;flex-direction:column!important;flex-shrink:0!important;gap:.3rem!important;min-width:60px!important;opacity:1!important;overflow:visible!important;visibility:visible!important}.student-avatar-circle{background:linear-gradient(135deg,#60a5fa,#3b82f6)!important;border-radius:50%!important;box-shadow:0 4px 12px #3b82f64d!important;display:block!important;flex-shrink:0!important;height:60px!important;opacity:1!important;overflow:hidden!important;position:relative!important;visibility:visible!important;width:60px!important}.student-avatar-circle img{display:block!important;object-fit:cover!important}.student-avatar-circle img,.student-avatar-fallback{height:100%!important;opacity:1!important;visibility:visible!important;width:100%!important}.student-avatar-fallback{align-items:center!important;background:linear-gradient(135deg,#60a5fa,#3b82f6)!important;color:#fff!important;display:flex!important;font-size:1.75rem!important;font-weight:700!important;justify-content:center!important}.student-level-badge{align-self:flex-start!important;background:#f3f4f6!important;border-radius:4px!important;color:#374151!important;display:inline-block!important;font-size:.65rem!important;font-weight:600!important;max-width:60px!important;opacity:1!important;overflow:hidden!important;padding:.15rem .3rem!important;text-align:center!important;text-overflow:ellipsis!important;visibility:visible!important;white-space:nowrap!important}.student-content .student-main-info,.student-item .student-main-info,.student-main-info{align-items:flex-start!important;display:flex!important;flex:1 1!important;flex-direction:column!important;gap:.35rem!important;justify-content:center!important;min-width:0!important;opacity:1!important;overflow:visible!important;visibility:visible!important}.student-content .student-name-display,.student-item .student-name-display,.students-list .student-item .student-name-display,.students-tab .students-list .student-item .student-name-display,h3.student-name-display{color:#111827!important;display:block!important;font-size:1rem!important;font-weight:700!important;line-height:1.2!important;margin:0!important;max-width:100%!important;opacity:1!important;overflow:hidden!important;text-align:left!important;text-overflow:ellipsis!important;visibility:visible!important;white-space:nowrap!important;width:100%!important}.student-contact-info{align-items:flex-start!important;flex-direction:column!important;gap:.3rem!important}.contact-item,.student-contact-info{display:flex!important;opacity:1!important;visibility:visible!important;width:100%!important}.contact-item{align-items:center!important;gap:.5rem!important}.contact-label{color:#111827!important;flex-shrink:0!important;font-size:.9rem!important}.contact-label,.contact-value{display:inline!important;opacity:1!important;visibility:visible!important}.contact-value{color:#4b5563!important;font-size:.8rem!important;font-weight:500!important;line-height:1.3!important;max-width:100%!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.student-email-text,.student-item .student-email-text,.student-item .student-phone-text,.student-phone-text,.students-tab .student-email-text,.students-tab .student-phone-text{color:#4b5563!important;font-size:.8rem!important;font-weight:500;line-height:1.3;max-width:100%;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.action-icon-btn{align-items:center;background:#fffc;border:none;border-radius:8px;box-shadow:0 2px 6px #0000001a;cursor:pointer;display:flex;height:32px;justify-content:center;padding:6px;transition:all .2s ease;width:32px}.action-icon-btn img{height:100%;object-fit:contain;width:100%}.action-icon-btn.edit:hover{background:#dbeafe;box-shadow:0 4px 12px #3b82f64d;transform:scale(1.05)}.action-icon-btn.delete:hover{background:#fee2e2;box-shadow:0 4px 12px #ef44444d;transform:scale(1.05)}.modal-overlay{background:#0f172a80;padding:1rem}.modal{padding:2rem}.modal h3{color:#1e293b;margin:0 0 1.5rem}.modal form{gap:1rem}.modal input,.modal select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:.95rem;padding:.75rem;transition:all .3s ease}.modal input:focus,.modal select:focus{border-color:#64748b;box-shadow:0 0 0 3px #64748b1a;outline:none}.modal-buttons{gap:1rem;margin-top:1rem}.modal-buttons button{border-radius:8px;padding:.75rem}.modal-buttons button[type=button]{background:#f1f5f9;color:#475569}.modal-buttons button[type=button]:hover{background:#e2e8f0}.modal-buttons button[type=submit]{background:#475569}.modal-buttons button[type=submit]:hover{background:#334155}@media (max-width:1200px){.students-list,.students-tab .students-list,div.students-list{gap:1.5rem!important;grid-template-columns:repeat(auto-fit,minmax(260px,260px))!important}}@media (max-width:900px){.students-list,.students-tab .students-list,div.students-list{gap:1.5rem!important;grid-template-columns:repeat(auto-fit,minmax(240px,240px))!important}}@media (max-width:768px){.students-list,.students-tab .students-list,div.students-list{gap:1.2rem!important;grid-template-columns:repeat(auto-fit,minmax(220px,220px))!important}.tab-header{align-items:flex-start;flex-direction:column;gap:1rem}.student-item{height:auto;min-height:140px;padding:1rem}.student-content{align-items:flex-start;flex-direction:row;padding-right:4rem;padding-top:0;text-align:left}.student-avatar-section{margin:0}.student-contact-info,.student-main-info{align-items:flex-start}.student-actions-icons{right:.5rem;top:.5rem}.form-row{grid-template-columns:1fr}}@media (max-width:480px){.students-list,.students-tab .students-list,div.students-list{gap:1rem!important;grid-template-columns:repeat(auto-fit,minmax(160px,160px))!important}.student-avatar-circle{height:50px;width:50px}.student-avatar-fallback{font-size:1.4rem}.student-name-display{font-size:.9rem}.contact-value,.student-email-text,.student-phone-text{font-size:.75rem}.action-icon-btn{height:28px;width:28px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.student-item{animation:fadeInUp .3s ease-out}.classes-tab,.payments-management,.sessions-management-new,.students-tab{margin:0 auto;max-width:1400px;padding:2rem}.classes-tab .tab-header,.payments-management .payments-header,.sessions-management-new .management-header,.students-tab .tab-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem;min-height:60px;padding:0;position:relative;z-index:1}.classes-tab .tab-header h2,.payments-management .payments-header h2,.sessions-management-new .management-header h2,.students-tab .tab-header h2{color:#1e293b;font-size:1.75rem;font-weight:600;line-height:1.2;margin:0}.add-btn,.btn-add,.btn-generate,.btn-generate-custom,.header-actions .add-btn{background:#4a655a!important;border:none!important;border-radius:8px!important;box-shadow:0 2px 8px #4a655a4d!important;color:#fff!important;cursor:pointer!important;font-size:.95rem!important;font-weight:500!important;line-height:1.5!important;padding:.75rem 1.5rem!important;transition:all .3s ease!important;white-space:nowrap!important}.add-btn:hover,.btn-add:hover,.btn-generate-custom:hover,.btn-generate:hover,.header-actions .add-btn:hover{background:#3d5449!important;box-shadow:0 4px 12px #4a655a66!important;transform:translateY(-1px)!important}.student-box-header.clickable{border-radius:8px;cursor:pointer;margin:-8px -8px 7px;padding:8px;transition:all .3s ease}.student-box-header.clickable:hover{background:#8d7b681a;transform:scale(1.02)}.student-name h3{color:#5d4e37}.student-status.active{background:#d4edda;color:#155724}.student-status.inactive{background:#f8d7da;color:#721c24}.detail-item{margin-bottom:8px}.action-btn{font-size:12px}.edit-btn{background:#e3f2fd;color:#1976d2}.edit-btn:hover{background:#bbdefb}.delete-btn{background:#ffebee;color:#d32f2f}.session-actions{border-top:1px solid #f0f0f0;margin-top:15px;padding-top:15px}.delete-btn:hover{background:#ffcdd2}.sessions-container{grid-gap:24px;gap:24px;padding:4px}.session-box:hover{box-shadow:0 6px 18px #0000001f}.session-info h3{color:#333;font-size:20px;font-weight:600;text-align:left}.detail-item{background:#f8f9fa;border:1px solid #e9ecef;min-width:80px}.detail-label{font-size:11px;margin-bottom:2px}.session-status.completed{background:#d4edda;color:#155724}.calendar-container{background:#f8f6f3;border-radius:12px;margin-top:20px;padding:20px}.calendar-header{margin-bottom:20px}.calendar-header h3{color:#5d4e37;font-size:24px}.nav-btn{background:#8d7b68;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 15px;transition:background .2s ease}.nav-btn:hover{background:#7a6a57}.calendar-grid{background:#fff;box-shadow:0 2px 8px #8d7b681a}.calendar-day-names{background:#8d7b68;display:grid;grid-template-columns:repeat(7,1fr)}.day-name{color:#fff;font-size:14px;padding:12px;text-align:center}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{border:1px solid #e0ddd8;cursor:pointer;min-height:100px;padding:8px;transition:background .2s ease}.calendar-day:hover{background:#f5f5f5}.calendar-day.other-month{background:#fafafa;color:#ccc}.calendar-day.today{background:#fff3cd;border:2px solid #8d7b68}.day-number{font-weight:600;margin-bottom:4px}.day-events{display:flex;flex-direction:column;gap:2px}.event-indicator{align-items:center;background:#e3f2fd;border-radius:4px;color:#1976d2;display:flex;font-size:10px;gap:4px;overflow:hidden;padding:2px 6px;text-overflow:ellipsis;white-space:nowrap}.event-indicator.session{background:#e8f5e8;color:#2e7d32}.event-indicator.completed{background:#d4edda;color:#155724}.event-indicator.planned{background:#fff3cd;color:#856404}.event-icon{font-size:8px}.more-events{color:#666;font-size:10px;margin-top:2px;text-align:center}.selected-date-details{background:#fff;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;margin-top:20px;padding:20px}.selected-date-details h3{color:#5d4e37;margin:0 0 15px}.events-list{display:flex;flex-direction:column;gap:10px}.event-detail{background:#f8f6f3;border-left:4px solid #8d7b68;border-radius:8px;display:flex;gap:15px;padding:12px}.event-time{color:#8d7b68;font-weight:600;min-width:60px}.event-content{flex:1 1}.event-content h4{color:#5d4e37;margin:0 0 4px}.event-content p{color:#666;font-size:14px;margin:2px 0}.status-badge{border-radius:12px;font-size:10px;padding:2px 6px}.no-events{color:#666;font-style:italic;padding:20px;text-align:center}.close-details{background:#8d7b68;border:none;border-radius:6px;color:#fff;cursor:pointer;float:right;margin-top:15px;padding:8px 15px}.calendar-summary{background:#fff;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;margin-top:20px;padding:20px}.calendar-summary h3{color:#5d4e37;margin:0 0 15px}.summary-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-item{align-items:center;background:#f8f6f3;border-radius:8px;display:flex;gap:12px;padding:15px}.stat-icon{font-size:24px}.stat-content{display:flex;flex-direction:column}.stat-number{color:#8d7b68;font-size:24px}.stat-label{color:#666;font-size:12px}.payments-summary{margin-bottom:30px}.summary-cards{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.summary-card{border-radius:12px;box-shadow:0 2px 8px #8d7b681a;gap:15px}.card-icon,.summary-card{align-items:center;display:flex}.card-icon{background:linear-gradient(135deg,#8d7b68,#a69080);border-radius:50%;font-size:32px;height:60px;justify-content:center;width:60px}.card-content h3{color:#5d4e37;font-size:16px;margin:0 0 8px}.amount{color:#333;font-size:24px;font-weight:700}.amount.paid{color:#2e7d32}.amount.pending{color:#f57c00}.payments-table{background:#fff;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;margin-bottom:30px;overflow:hidden}.table-header{background:#8d7b68;color:#fff;font-size:14px;font-weight:600}.table-header,.table-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1.5fr 1fr;padding:15px}.table-row{align-items:center;border-bottom:1px solid #e0ddd8}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8f6f3}.student-name{color:#5d4e37}.sessions-count{text-align:center}.paid-amount,.remaining-amount,.total-amount{font-weight:600;text-align:right}.remaining-amount.unpaid{color:#d32f2f}.remaining-amount.paid{color:#2e7d32}.last-payment{font-size:14px}.last-payment,.payment-status{text-align:center}.payments-history{background:#fff;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;padding:20px}.payments-history h3{color:#5d4e37;margin:0 0 20px}.payments-list{gap:12px}.payment-item{background:#f8f6f3;border-left:4px solid #8d7b68;border-radius:8px;gap:15px;padding:15px}.payment-icon,.payment-item{align-items:center;display:flex}.payment-icon{background:linear-gradient(135deg,#8d7b68,#a69080);border-radius:50%;font-size:24px;height:50px;justify-content:center;width:50px}.payment-info{flex:1 1}.payment-info h4{color:#5d4e37;margin:0 0 4px}.payment-date{color:#666;font-size:14px;margin-bottom:2px}.payment-notes{color:#666;font-size:12px;font-style:italic}.payment-amount{color:#2e7d32}.payment-status{font-size:20px}.view-mode-buttons{background:#e0ddd8;border-radius:6px;display:flex;gap:5px;padding:4px}.view-mode-buttons button{background:#0000;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:12px;font-weight:500;padding:8px 12px;transition:all .2s ease}.view-mode-buttons button.active{background:#8d7b68;color:#fff}.view-mode-buttons button:hover:not(.active){background:#f0f0f0}.payment-modal{max-width:600px;width:90%}.payment-modal .form-row{margin-bottom:15px}.payment-modal label{color:#5d4e37;display:block;font-weight:500;margin-bottom:5px}.payment-modal input,.payment-modal select,.payment-modal textarea{border:1px solid #e0ddd8;border-radius:6px;font-size:14px;padding:10px;width:100%}.payment-modal textarea{min-height:80px;resize:vertical}.groups-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,320px));justify-content:start;margin-top:1rem;width:100%}.group-item{background:#d1d5db;border-radius:16px;cursor:pointer;display:flex;flex-direction:column;height:140px;padding:1rem 1.25rem;position:relative;transition:all .3s ease}.group-item:hover{background:#c4c8cf;transform:scale(1.02)}.group-actions-icons{align-items:center;display:flex;flex-shrink:0;gap:.4rem;position:absolute;right:.5rem;top:.5rem}.group-content{flex:1 1;gap:1rem;overflow:hidden;padding-right:5rem;width:100%}.group-content,.group-icon-section{align-items:flex-start;display:flex}.group-icon-section{flex-direction:column;flex-shrink:0;gap:.4rem;min-width:70px}.group-icon-circle{align-items:center;background:linear-gradient(135deg,#456055,#456055);border-radius:50%;box-shadow:0 4px 12px #3b82f64d;display:flex;height:70px;justify-content:center;overflow:hidden;position:relative;width:70px}.group-icon-circle img{height:60%;object-fit:contain;width:60%}.group-level-badge{align-self:flex-start;background:#f3f4f6;border-radius:6px;color:#374151;font-size:.7rem;font-weight:600;max-width:70px;overflow:hidden;padding:.2rem .4rem;text-align:left;text-overflow:ellipsis;white-space:nowrap}.group-main-info{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:.35rem;justify-content:center;min-width:0;overflow:hidden}.group-name-display{color:#111827;font-size:1.1rem;font-weight:700;line-height:1.2;margin:0;max-width:100%;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%}.group-contact-info{align-items:flex-start;display:flex;flex-direction:column;gap:.2rem;width:100%}.group-description-text,.group-info-text{color:#4b5563;font-size:.8rem;font-weight:500;line-height:1.3;max-width:100%;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.group-description-text{color:#6b7280;font-style:italic}.group-item .action-icon-btn{align-items:center;background:#fffc;border:none;border-radius:8px;box-shadow:0 2px 6px #0000001a;cursor:pointer;display:flex;height:32px;justify-content:center;padding:6px;transition:all .2s ease;width:32px}.group-item .action-icon-btn img{height:100%;object-fit:contain;width:100%}.group-item .action-icon-btn.edit:hover{background:#dbeafe;box-shadow:0 4px 12px #3b82f64d;transform:scale(1.05)}.group-item .action-icon-btn.delete:hover{background:#fee2e2;box-shadow:0 4px 12px #ef44444d;transform:scale(1.05)}@media (max-width:768px){.classes-container,.groups-list,.sessions-container,.students-container{grid-template-columns:1fr}.group-item{height:auto;min-height:140px}.group-content{align-items:flex-start;flex-direction:row;padding-right:4rem;padding-top:0;text-align:left}.group-icon-section{margin:0}.group-contact-info,.group-main-info{align-items:flex-start}.summary-cards,.table-header,.table-row{grid-template-columns:1fr}.table-header,.table-row{gap:5px}.calendar-days{grid-template-columns:repeat(7,1fr)}.calendar-day{font-size:12px;min-height:80px}.summary-stats{grid-template-columns:1fr}}.students-selection{margin:20px 0}.students-selection h4{border-bottom:2px solid #4a655a;margin-bottom:15px;padding-bottom:8px}.students-filters{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.search-input{background:#f8f6f3;border-radius:8px;flex:2 1;font-size:14px;padding:10px 15px;transition:border-color .3s ease}.search-input:focus{background:#fff;border-color:#4a655a;outline:none}.level-filter{background:#f8f6f3;border:2px solid #e0ddd8;border-radius:8px;flex:1 1;font-size:14px;min-width:150px;padding:10px 15px;transition:border-color .3s ease}.level-filter:focus{background:#fff;border-color:#4a655a;outline:none}.students-checkboxes{background:#f8f6f3;border:1px solid #e0ddd8;border-radius:8px;max-height:300px;padding:15px}.checkbox-label{border-radius:6px;margin:5px 0;padding:8px 10px}.checkbox-label:hover{background-color:#4a655a1a}.checkbox-label input[type=checkbox]{accent-color:#4a655a;margin-right:12px;transform:scale(1.2)}.student-info{justify-content:space-between;width:100%}.student-level{background:#e0ddd8;border-radius:12px;color:#8d7b68;font-size:12px;font-weight:600;margin-left:10px;padding:2px 8px}.no-students{color:#8d7b68;font-style:italic;margin:0;padding:20px}.students-count{background:#4a655a1a;border-left:3px solid #4a655a;border-radius:6px;color:#8d7b68;font-size:14px;margin-bottom:10px;padding:8px 12px}.selected-count{color:#4a655a;font-weight:600}.sessions-tabs{display:flex;gap:10px;margin-bottom:20px}.tab-btn{background:#f8f6f3;border:2px solid #e0ddd8;border-radius:8px;padding:10px 20px}.tab-btn:hover{color:#4a655a}.tab-btn.active,.tab-btn:hover{border-color:#4a655a}.fixed-session{border-left:4px solid #4a655a}.session-schedule{color:#4a655a;font-weight:600;margin-top:5px}.session-status.active{background:#4a655a1a;color:#4a655a}.session-status.active,.session-status.inactive{border-radius:12px;font-size:12px;font-weight:600;padding:2px 8px}.session-status.inactive{background:#8d7b681a;color:#8d7b68}.group-members .detail-value{display:block;margin-top:5px}.members-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:5px}.member-tag{background:#4a655a;border-radius:12px;color:#fff;font-size:12px;font-weight:500;padding:3px 8px;white-space:nowrap}.price-selector-container{margin-bottom:15px}.price-selector-container label{display:block;font-size:14px;margin-bottom:8px}.price-selector{gap:10px}.price-select{background:#fff;border:1px solid #e0ddd8;border-radius:6px;cursor:pointer;font-size:14px;padding:10px;transition:border-color .2s}.price-select:focus{border-color:#8d7b68;box-shadow:0 0 0 3px #8d7b681a;outline:none}.custom-price-input{background:#fff3cd;border:2px solid #ffc107;border-radius:6px;color:#856404;font-size:14px;font-weight:600;padding:10px}.custom-price-input:focus{border-color:#ff9800;box-shadow:0 0 0 3px #ffc10733;outline:none}.level-info{background:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:14px;margin-bottom:10px;padding:8px 12px}@media (max-width:768px){.students-filters{flex-direction:column}.level-filter,.search-input{flex:none;width:100%}.price-selector{flex-direction:column}.custom-price-input,.price-select{width:100%}}.history-panel,.inbox-panel{background:#f8f6f3;border:1px solid #e0ddd8;border-radius:12px;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.panel-header-right{background:linear-gradient(135deg,#8d7b68,#a69080);border-bottom:1px solid #e0ddd8;color:#fff;padding:15px 20px}.panel-header-right h3{font-size:1.1rem;font-weight:600}.close-panel{background:none;color:#fff;font-size:1.5rem;height:30px;padding:0;transition:background-color .2s ease;width:30px}.close-panel:hover{background-color:#fff3}.panel-content-scroll{flex:1 1;overflow-y:auto;padding:15px}.notifications-management{min-height:600px}@media (max-width:1200px){.notifications-management{flex-direction:column;gap:15px}.history-panel,.inbox-panel{max-height:400px}.compose-area,.history-panel,.inbox-panel{max-width:none!important;min-width:auto!important}}.notifications-management-wrapper{height:100%;max-width:100%}.notifications-tabs{background:#f8f6f3;border-bottom:1px solid #e0ddd8;margin-bottom:0}.tab-btn{color:#666;font-size:1rem}.tab-btn:hover{background:#8d7b681a;color:#8d7b68}.tab-btn.active{background:#fff;border-bottom-color:#8d7b68;color:#8d7b68}.tab-content{background:#fff;min-height:600px;padding:0}@media (max-width:768px){.tab-btn{font-size:.9rem;padding:10px 12px}.tab-content{min-height:500px}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{animation:slideUp .3s ease;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:700px;width:100%}.modal h3{background:linear-gradient(135deg,#4a655a,#3d5449);border-radius:16px 16px 0 0;color:#fff;font-size:1.5rem;font-weight:600;margin:0;padding:24px 32px}.modal form{gap:20px;padding:32px}.modal input[type=number],.modal input[type=text],.modal select,.modal textarea{background:#f8f6f3;border:2px solid #e0ddd8;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:.95rem;padding:12px 16px;transition:all .3s ease;width:100%}.modal input[type=number]:focus,.modal input[type=text]:focus,.modal select:focus,.modal textarea:focus{background:#fff;border-color:#4a655a;box-shadow:0 0 0 3px #4a655a1a;outline:none}.modal textarea{font-family:inherit}.price-selector-container{display:flex;flex-direction:column;gap:10px}.price-selector-container label{color:#5d4e37;font-size:.9rem;font-weight:600}.price-selector{align-items:center;display:flex;gap:12px}.price-select{flex:1 1}.custom-price-input{animation:slideIn .3s ease;flex:1 1}.students-selection{background:#f8f6f3;border:2px solid #e0ddd8;border-radius:12px;padding:20px}.students-selection h4{align-items:center;color:#4a655a;display:flex;font-size:1.1rem;gap:8px;margin:0 0 12px}.level-info{background:#4a655a26;border-left:4px solid #4a655a;border-radius:8px;color:#4a655a;font-size:.9rem;font-weight:500;margin-bottom:16px;padding:10px 16px}.modal-buttons{border-top:2px solid #e0ddd8;margin-top:10px}.modal-buttons button{border:none;border-radius:10px;flex:1 1;font-size:.95rem;font-weight:600;padding:14px 24px;transition:all .3s ease}.modal-buttons button[type=button]{background:#e0ddd8;color:#5d4e37}.modal-buttons button[type=button]:hover{background:#cbd5e0;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.modal-buttons button[type=submit]{background:linear-gradient(135deg,#4a655a,#3d5449);box-shadow:0 4px 12px #4a655a4d}.modal-buttons button[type=submit]:hover{box-shadow:0 6px 20px #4a655a66;transform:translateY(-2px)}.modal-content{border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:700px;width:100%}.modal-content h3{background:linear-gradient(135deg,#4a655a,#3d5449);border-radius:16px 16px 0 0;color:#fff;font-size:1.5rem;font-weight:600;margin:0;padding:24px 32px}@media (max-width:768px){.modal,.modal-content{margin:10px;max-width:95%}.modal form{padding:20px}.modal-buttons,.price-selector{flex-direction:column}}.sessions-management-new{margin:0 auto;max-width:1400px;padding:2rem}.management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem;min-height:60px;position:relative;z-index:1}.management-header h2{color:#1e293b;font-size:1.75rem;font-weight:600;margin:0}.header-controls{align-items:center;display:flex;gap:1rem}.view-tabs{background:#f1f5f9;border-radius:8px;display:flex;padding:4px}.tab-btn{background:none;color:#64748b;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.tab-btn.active{box-shadow:0 2px 4px #0000001a}.tab-btn:hover:not(.active){background:#e2e8f0;color:#334155}.modal-header{border-bottom:1px solid #e0e0e0;padding:24px}.modal-header h3{color:#202124;font-size:1.5rem}.modal-close{color:#5f6368;font-size:28px;transition:background .2s ease}.modal-close:hover{background:#f1f3f4}.session-form{padding:24px}.form-row{margin-bottom:20px}.form-row label{color:#202124;font-size:14px;font-weight:500;margin-bottom:8px}.form-row input,.form-row select,.form-row textarea{border:1px solid #dadce0;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:#1a73e8;outline:none}.form-row textarea{resize:vertical}.checkbox-row{background:#e8f0fe;border:2px solid #1a73e8;border-radius:8px;padding:12px 16px}.checkbox-label{color:#1a73e8;font-weight:500;gap:10px}.checkbox-label input[type=checkbox]{height:20px;width:20px}.checkbox-label span{font-size:15px}.radio-group{display:flex;gap:16px}.radio-label{align-items:center;border:1px solid #dadce0;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .2s ease}.radio-label:hover{background:#f8f9fa;border-color:#1a73e8}.radio-label input[type=radio]{cursor:pointer;height:18px;width:18px}.radio-label span{font-size:14px}.form-actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.btn-cancel,.btn-submit{font-size:.875rem;padding:.625rem 1.5rem;transition:all .3s ease}.btn-submit{border-radius:8px;cursor:pointer;font-weight:500}.sessions-list>h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.sessions-section h4{align-items:center;color:#475569;display:flex;font-size:1.25rem;font-weight:600;gap:8px;margin-bottom:1rem}.sessions-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,320px));justify-content:start}.session-card{background:#d1d5db;border-radius:16px;display:flex;flex-direction:column;height:180px;padding:1rem;position:relative;transition:all .3s ease}.session-card:hover{background:#c4c8cf;transform:scale(1.02)}.session-card.fixed{border-left:4px solid #475569}.session-card.occasional{border-left:4px solid #64748b}.day-group{margin-bottom:2.5rem}.day-divider{align-items:center;border-bottom:2px solid #cbd5e1;display:flex;gap:.5rem;margin:1.5rem 0 1rem;padding-bottom:.5rem}.day-label{color:#1e293b;font-size:1rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.day-count{color:#64748b;font-size:.9rem;font-weight:500}.session-badge-inline{border-radius:8px;flex-shrink:0;font-size:.75rem;font-weight:600;letter-spacing:.3px;margin-left:auto;padding:.25rem .625rem}.session-badge-inline.fixed{background:#475569;color:#fff}.session-badge{border-radius:8px;font-size:.7rem;font-weight:600;letter-spacing:.3px;padding:.25rem .75rem;position:absolute;right:.75rem;top:.75rem}.session-badge.occasional{background:#64748b;color:#fff}.session-header{flex:0 0 auto;gap:.75rem;margin-bottom:.75rem}.session-type{font-size:1.5rem}.session-title{flex:1 1;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-details{display:flex;flex:1 1;margin-bottom:.75rem;overflow-y:auto}.detail-row{border-bottom:1px solid #0000001a;display:flex;font-size:.875rem;justify-content:space-between;padding:.5rem 0}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#475569;font-weight:500}.detail-row .time-value{color:#1e293b;font-size:.95rem;font-weight:700}.detail-row .price{color:#475569;font-size:1rem;font-weight:600}.session-notes{background:#0000000d;color:#475569;flex:0 0 auto;font-size:.8rem;line-height:1.4;margin-bottom:.75rem;padding:.625rem .75rem}.btn-attendance{background:#4a655a}.btn-attendance:hover{background:#3a4f42}.session-actions{gap:.5rem;margin-top:auto}.btn-attendance{align-items:center;background:#456055;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:.625rem;transition:all .3s ease}.btn-attendance:hover{background:#1f2a24;transform:translateY(-1px)}.btn-history{align-items:center;background:#6b7280;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:.625rem;transition:all .3s ease}.btn-history:hover{background:#4b5563;transform:translateY(-1px)}.btn-delete{align-items:center;background:#8d7b67;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:.625rem;transition:all .3s ease}.btn-delete:hover{background:#53483b;transform:translateY(-1px)}.no-sessions{background:#fff;border:2px dashed #dadce0;border-radius:12px;padding:60px 20px;text-align:center}.no-sessions p{color:#5f6368;font-size:1.2rem;margin-bottom:20px}@media (max-width:768px){.sessions-management-new{padding:20px 16px}.management-header{align-items:flex-start;flex-direction:column;gap:16px}.sessions-grid{grid-template-columns:1fr}.modal-content{max-height:95vh;width:95%}.radio-group{flex-direction:column}}.calendar-view{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;padding:1.5rem}.calendar-header{align-items:center;border-bottom:2px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.calendar-header h3{color:#1e293b;font-size:1.3rem;font-weight:600;margin:0}.calendar-nav-right{display:flex;gap:.5rem}.btn-current,.btn-nav{background:#4a655a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.btn-current:hover,.btn-nav:hover{background:#3a4f42;transform:translateY(-1px)}.btn-current{background:#8d7b68}.btn-current:hover{background:#7a6a57}.calendar-grid{grid-gap:1px;background:#e2e8f0;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);min-height:500px;overflow:hidden}.calendar-day{background:#fff;display:flex;flex-direction:column;padding:0}.calendar-day.today{background:#fef3e2}.day-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.75rem;text-align:center}.calendar-day.today .day-header{background:#4a655a;color:#fff}.day-name{display:block;font-size:.875rem}.day-date{display:block;font-size:1.25rem;font-weight:700;margin-top:2px}.day-sessions{display:flex;flex:1 1;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;padding:.5rem}.no-sessions-day{color:#94a3b8;font-size:.8rem;font-style:italic;padding:1rem .5rem;text-align:center}.calendar-session{background:#f8fafc;border-left:3px solid #4a655a;border-radius:6px;cursor:pointer;font-size:.8rem;padding:.5rem;transition:all .3s ease}.calendar-session:hover{background:#f1f5f9;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.calendar-session.occasional{background:#fefbf7;border-left-color:#8d7b68}.calendar-session.occasional:hover{background:#fdf8f1}.session-time{color:#4a655a;font-size:.75rem;font-weight:700;margin-bottom:2px}.calendar-session.occasional .session-time{color:#8d7b68}.session-title{align-items:center;color:#1e293b;display:flex;font-size:.75rem;font-weight:600;gap:.25rem;line-height:1.2}.session-duration{color:#64748b;font-size:.7rem;margin-top:2px}.session-actions-mini{display:flex;justify-content:flex-end}.btn-attendance-mini{background:none;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;padding:2px 4px;transition:background .3s ease}.btn-attendance-mini:hover{background:#4a655a1a}@media (max-width:1024px){.calendar-grid{min-height:400px}.day-sessions{max-height:300px}}@media (max-width:768px){.calendar-header{align-items:stretch;flex-direction:column;gap:1rem}.calendar-nav-right{justify-content:center}.btn-current,.btn-nav{font-size:.8rem;padding:.4rem .8rem}.calendar-grid{grid-template-columns:1fr;min-height:auto}.calendar-day{border-radius:8px;margin-bottom:1rem;overflow:hidden}.day-sessions{max-height:none}}.payments-management{background-color:#f8f6f3;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.payments-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem;min-height:60px;position:relative;z-index:1}.payments-header h2{color:#5d4e37;font-size:1.75rem;font-weight:600;margin:0}.payments-loading{color:#8d7b68;font-size:1.125rem;padding:3rem;text-align:center}.payments-filters{align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem}.filter-group{display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-width:200px}.filter-group label{color:#475569;font-size:.875rem;font-weight:500}.filter-group select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;cursor:pointer;font-size:.9375rem;padding:.625rem}.btn-reset{background:#e2e8f0;border:none;border-radius:8px;color:#475569;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;transition:all .3s ease;white-space:nowrap}.btn-reset:hover{background:#cbd5e1}.btn-add{background:#4a655a;border:none;border-radius:8px;box-shadow:0 2px 8px #4a655a4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.btn-add:hover{background:#3d5449;box-shadow:0 4px 12px #4a655a66;transform:translateY(-1px)}.header-actions{gap:1rem}.btn-generate,.btn-generate-custom{background:#4a655a;border:none;border-radius:8px;box-shadow:0 2px 8px #4a655a4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.btn-generate-custom:hover,.btn-generate:hover{background:#3d5449;box-shadow:0 4px 12px #4a655a66;transform:translateY(-1px)}.payments-list{margin-top:2rem}.no-payments{background:#f1f5f9;border:2px dashed #cbd5e1;border-radius:12px;color:#64748b;font-size:1rem;padding:3rem 1.25rem;text-align:center}.payments-grid{grid-gap:1.25rem;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(300px,350px));justify-content:start}.payment-card{background:#d1d5db;border-radius:16px;display:flex;flex-direction:column;gap:1rem;padding:1.25rem;position:relative;transition:all .3s ease}.payment-card:hover{background:#c4c8cf;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.payment-card.status-paid{border-left:4px solid #10b981}.payment-card.status-partial{border-left:4px solid #f59e0b}.payment-card.status-unpaid{border-left:4px solid #6b7280}.payment-card.status-overdue{border-left:4px solid #ef4444}.payment-header{align-items:flex-start;gap:.75rem}.payment-student{align-items:center;display:flex;flex:1 1;gap:.75rem}.student-avatar{background:#fff;flex-shrink:0;height:48px;overflow:hidden;width:48px}.student-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:#475569;color:#fff;display:flex;font-size:1.25rem;font-weight:600;height:100%;justify-content:center;width:100%}.student-name{color:#1e293b;font-size:1rem;font-weight:600}.payment-month{color:#64748b;font-size:.875rem}.payment-status{border-radius:8px;color:#fff;flex-shrink:0;font-size:.8rem;font-weight:600;padding:.375rem .75rem;white-space:nowrap}.payment-amounts{background:#ffffff80;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.amount-row{align-items:center;display:flex;font-size:.9375rem;justify-content:space-between}.amount-row .label{color:#475569;font-weight:500}.amount-row .amount{color:#1e293b;font-weight:700}.amount-row .amount.total{color:#475569;font-size:1rem}.amount-row .amount.paid{color:#10b981}.amount-row .amount.remaining{color:#ef4444;font-size:1.0625rem}.payment-info{color:#64748b;font-size:.8125rem;font-style:italic}.payment-actions{display:flex;flex-wrap:wrap;gap:.5rem}.btn-history,.btn-pay{background:#475569;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:.8125rem;font-weight:500;padding:.625rem .75rem;transition:all .3s ease;white-space:nowrap}.btn-history:hover,.btn-pay:hover{background:#334155;transform:translateY(-1px)}.btn-history{background:#64748b}.btn-history:hover{background:#475569}.btn-delete-small{background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.8125rem;padding:.625rem .75rem;transition:all .3s ease}.btn-delete-small:hover{background:#dc2626;transform:translateY(-1px)}.modal-overlay{animation:fadeIn .2s ease}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.modal-content.modal-large{max-width:800px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#1e293b;font-size:1.375rem;font-weight:600;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:1.75rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.modal-close:hover{background:#f1f5f9;color:#1e293b}.modal-body,.modal-footer{padding:1.5rem}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end}.form-group{margin-bottom:1.25rem}.form-group label{color:#475569;font-size:.875rem;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-size:.9375rem;padding:.625rem;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#475569;box-shadow:0 0 0 3px #4755691a;outline:none}.form-row{grid-gap:1rem;gap:1rem}.btn-cancel,.btn-submit{border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1.5rem;transition:all .3s ease}.btn-cancel{background:#fff;border:1px solid #cbd5e1;color:#64748b}.btn-cancel:hover{background:#f8fafc;border-color:#94a3b8}.btn-submit{background:#475569;border:none;box-shadow:0 2px 8px #4755694d;color:#fff}.btn-submit:hover{background:#334155;box-shadow:0 4px 12px #47556966;transform:translateY(-1px)}.payment-summary{background:#f8fafc;border-left:4px solid #475569;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.payment-summary p{color:#475569;margin:.5rem 0}.payment-summary strong{color:#1e293b}.history-header{margin-bottom:1.5rem}.history-header h4{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0 0 .75rem}.history-summary{color:#64748b;display:flex;flex-wrap:wrap;font-size:.9375rem;gap:1.5rem}.history-list{gap:1rem}.history-item{background:#f8fafc;border-radius:8px;padding:1rem;position:relative}.history-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.payment-date{color:#1e293b;font-size:.9375rem;font-weight:600}.payment-amount{color:#10b981;font-size:1.125rem}.history-item-details{color:#64748b;display:flex;flex-wrap:wrap;font-size:.875rem;gap:1rem;margin-bottom:.5rem}.history-item-notes{background:#fff;border-radius:4px;color:#475569;font-size:.875rem;font-style:italic;margin-top:.5rem;padding:.5rem}.btn-delete-history{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.8125rem;margin-top:.75rem;padding:.5rem .75rem;transition:all .3s ease}.btn-delete-history:hover{background:#dc2626;transform:translateY(-1px)}.no-history{color:#94a3b8;font-style:italic;padding:2rem}@media (max-width:768px){.payments-filters{flex-direction:column}.filter-group{min-width:100%}.form-row,.payments-grid{grid-template-columns:1fr}.modal-content{width:95%}}.generate-form{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.generate-form .form-group:last-child{grid-column:1/-1}.generate-info{background:#f0f9ff;border:1px solid #7dd3fc;border-radius:8px;margin-top:1rem;padding:1rem}.generate-info p{color:#0c4a6e;font-size:.9rem;margin:.5rem 0}@media (max-width:600px){.generate-form{grid-template-columns:1fr}.header-actions{flex-direction:column}}.emails-management{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.emails-header{margin-bottom:30px}.emails-header h1{color:#456055;font-size:28px;margin-bottom:20px}.email-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.stat-card{border:3px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .2s}.stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.stat-card.unread{border-color:#3b82f6}.stat-card.high-priority{border-color:#ef4444}.stat-card.today{border-color:#10b981}.stat-number{color:#456055;margin-bottom:8px}.stat-label{color:#8d7b67;font-size:14px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.email-filters{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.filter-select,.search-input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;padding:12px 16px;transition:all .2s}.search-input{flex:1 1;min-width:200px}.filter-select:focus,.search-input:focus{border-color:#456055;box-shadow:0 0 0 3px #4560551a;outline:none}.emails-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.email-item{border-bottom:1px solid #f3f4f6;cursor:pointer;padding:20px;position:relative;transition:all .2s}.email-item:last-child{border-bottom:none}.email-item:hover{background:#f8fafc}.email-item.unread{background:linear-gradient(90deg,#f0f9ff,#fff);border-left:4px solid #3b82f6}.email-item.unread:before{background:#3b82f6;border-radius:50%;content:"";height:8px;left:12px;position:absolute;top:24px;width:8px}.email-header{align-items:center;display:flex;gap:16px;margin-bottom:8px}.email-from{flex-shrink:0;min-width:200px}.email-from strong{color:#111827;font-size:14px;font-weight:500}.email-subject-line{align-items:center;display:flex;flex:1 1;min-width:0}.subject-text{color:#456055;font-weight:600;white-space:nowrap}.preview-separator{color:#8d7b67;margin:0 4px}.email-preview-inline{color:#6b7280;flex:1 1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.email-context{margin-bottom:8px;margin-left:216px}.related-info{background:#f3f4f6;border-radius:4px;color:#8d7b67;display:inline-block;font-size:12px;padding:2px 8px}.email-meta{align-items:center;display:flex;flex-shrink:0;gap:12px}.priority{font-size:16px}.date{color:#8d7b67;font-size:14px;font-weight:500;min-width:60px;text-align:right}.email-tags{display:flex;flex-wrap:wrap;gap:8px;margin-left:216px;margin-top:4px}.tag{border-radius:12px;color:#fff;font-size:11px;font-weight:500;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.email-actions{display:flex;gap:8px;opacity:0;transition:opacity .2s}.email-item:hover .email-actions{opacity:1}.action-btn{background:#f3f4f6;padding:8px 12px;transition:all .2s}.action-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.action-btn.delete:hover{background:#fee2e2;color:#dc2626}.pagination{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;justify-content:center;margin-top:24px;padding:20px}.pagination button{background:#456055;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:12px 20px;transition:all .2s}.pagination button:hover:not(:disabled){background:#374b42;transform:translateY(-1px)}.pagination button:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed;transform:none}.loading,.no-emails{color:#8d7b67;font-size:16px;padding:60px 20px;text-align:center}.modal-overlay{background:#0009;padding:20px}.email-detail-modal,.reply-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:80vh;max-width:700px;overflow-y:auto;width:100%}.email-detail-header h3,.reply-modal h3{border-bottom:1px solid #f3f4f6;color:#456055;margin:0;padding:20px}.email-detail-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:20px}.email-detail-header button{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:20px;padding:8px}.email-detail-header button:hover{background:#f3f4f6}.form-group{padding:0 20px 20px}.form-group label{color:#374151;margin-bottom:8px}.form-group input,.form-group textarea{border:2px solid #e5e7eb;border-radius:8px;resize:vertical;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#456055;box-shadow:0 0 0 3px #4560551a}.email-detail-actions,.modal-actions{border-top:1px solid #f3f4f6;display:flex;gap:12px;justify-content:flex-end;padding:20px}.btn-cancel{background:#f3f4f6;border:none;border-radius:8px;color:#374151;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s}.btn-cancel:hover{background:#e5e7eb}.btn-reply,.btn-send{background:#456055;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s}.btn-reply:hover,.btn-send:hover{background:#374b42;transform:translateY(-1px)}.btn-read{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s}.btn-read:hover{background:#2563eb;transform:translateY(-1px)}.email-detail-content{padding:20px}.email-detail-meta{background:#f8fafc;border-radius:8px;margin-bottom:20px;padding:16px}.email-detail-meta p{color:#374151;font-size:14px;margin:0 0 8px}.email-detail-meta p:last-child{margin-bottom:0}.email-detail-body{color:#374151;line-height:1.6}.email-detail-body pre{font-family:inherit;margin:0;white-space:pre-wrap}@media (max-width:768px){.emails-management{padding:15px}.email-stats{grid-template-columns:repeat(2,1fr)}.email-filters{flex-direction:column}.filter-select,.search-input{min-width:auto;width:100%}.email-item{padding:16px}.email-header{flex-direction:column;gap:8px}.email-meta{align-self:flex-start}.email-actions{margin-top:12px;opacity:1}.modal-overlay{padding:10px}.email-detail-modal,.reply-modal{max-height:90vh}}.notifications-management-wrapper{background:#f5f5f5;height:calc(100vh - 200px);overflow:hidden}.notifications-tabs{background:#fff;border-bottom:2px solid #e0e0e0;display:flex;gap:0;padding:0 20px}.tab-btn{border-bottom:3px solid #0000;color:#5f6368;font-size:15px;margin-bottom:-2px;padding:16px 24px;transition:all .2s ease}.tab-btn:hover{background:#00000005;color:#202124}.tab-btn.active{border-bottom-color:#1a73e8;color:#1a73e8}.notifications-management{background:#f5f5f5;display:flex;height:calc(100vh - 200px);overflow:hidden;position:relative;z-index:1}.sidebar{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto;padding:20px 12px;width:260px}.compose-btn{align-items:center;background:#c2e7ff;border:none;border-radius:16px;box-shadow:0 1px 3px #0000001f;color:#001d35;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;margin-bottom:20px;padding:14px 24px;transition:all .2s ease}.compose-btn:hover{background:#a8d7f7;box-shadow:0 2px 8px #00000026}.history-btn{align-items:center;background:#fff;border:2px solid #1a73e8;border-radius:16px;color:#1a73e8;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;justify-content:center;margin-bottom:20px;padding:12px 24px;transition:all .2s ease}.history-btn:hover{background:#e8f0fe}.emails-btn{align-items:center;background:#4285f4;border:1px solid #4285f4;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:8px;justify-content:center;margin:5px 0;padding:12px;transition:all .2s ease;width:100%}.emails-btn:hover{background:#3367d6}.sidebar-section{margin-bottom:25px}.sidebar-section h3{color:#5f6368;font-size:13px;font-weight:500;margin-bottom:8px;padding-left:12px}.sidebar-option{align-items:center;background:#0000;border:none;border-radius:0 20px 20px 0;color:#202124;cursor:pointer;display:flex;font-size:14px;gap:16px;margin-bottom:2px;padding:10px 16px;text-align:left;transition:background .2s ease;width:100%}.sidebar-option:hover{background:#f1f3f4}.sidebar-option.active{background:#d3e3fd;color:#001d35;font-weight:500}.sidebar-option .icon{font-size:18px}.templates-section{border-top:1px solid #e0e0e0;padding-top:15px}.template-btn{align-items:center;background:#0000;border:1px solid #e0e0e0;border-radius:8px;color:#202124;cursor:pointer;display:flex;font-size:13px;gap:10px;margin-bottom:8px;padding:8px 12px;text-align:left;transition:all .2s ease;width:100%}.template-btn:hover{background:#f8f9fa;border-color:#d0d0d0}.compose-area{background:#fff;box-shadow:0 1px 2px #0000001a;flex:1 1;flex-direction:column;overflow:hidden}.compose-area,.compose-header{display:flex;position:relative;z-index:1}.compose-header{align-items:center;border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:20px 24px}.compose-header h2{color:#202124;font-size:20px;font-weight:400;margin:0}.header-actions{z-index:1}.success-badge{background:#e6f4ea;border-radius:20px;color:#137333;font-size:13px;font-weight:500;padding:8px 16px}.btn-send-primary{background:#1a73e8;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-send-primary:hover:not(:disabled){background:#1557b0;box-shadow:0 1px 3px #0003}.btn-send-primary:disabled{background:#f1f3f4;color:#9aa0a6;cursor:not-allowed}.compose-form{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.field-row{align-items:flex-start;border-bottom:1px solid #e0e0e0;display:flex;padding:12px 24px}.field-label{color:#5f6368;flex-shrink:0;font-size:14px;padding-top:8px;width:80px}.field-content{flex:1 1;position:relative}.recipients-input-area{align-items:center;display:flex;flex-wrap:wrap;gap:6px;min-height:36px;padding:4px 0}.recipient-bubble{align-items:center;background:#e8f0fe;border-radius:16px;color:#1967d2;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:4px 8px}.remove-bubble{align-items:center;background:#0000;border:none;border-radius:50%;color:#1967d2;cursor:pointer;display:flex;font-size:16px;height:16px;justify-content:center;padding:0;transition:background .2s ease;width:16px}.remove-bubble:hover{background:#1967d21a}.inline-search{border:none;color:#202124;flex:1 1;font-size:14px;min-width:200px;outline:none;padding:6px}.inline-search::placeholder{color:#9aa0a6}.search-dropdown{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #00000026;left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.search-result{align-items:center;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .2s ease}.search-result:hover{background:#f1f3f4}.result-icon{font-size:20px}.result-info{flex:1 1}.result-name{color:#202124;font-size:14px;font-weight:500;margin-bottom:2px}.result-email{color:#5f6368;font-size:12px}.no-results{color:#5f6368;font-size:13px;padding:16px}.subject-field{border:none;color:#202124;font-size:14px;outline:none;padding:6px;width:100%}.subject-field::placeholder{color:#9aa0a6}.field-separator{background:#e0e0e0;height:1px}.message-area{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:16px 24px}.message-field{border:none;color:#202124;flex:1 1;font-family:Arial,sans-serif;font-size:14px;line-height:1.6;outline:none;resize:none;width:100%}.message-field::placeholder{color:#9aa0a6}.groups-panel{background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;width:320px}.panel-header-right{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.panel-header-right h3{color:#202124;font-size:16px;font-weight:500;margin:0}.close-panel{align-items:center;background:#0000;border:none;border-radius:50%;color:#5f6368;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:background .2s ease;width:32px}.close-panel:hover{background:#f1f3f4}.groups-list-scroll{flex:1 1;overflow-y:auto;padding:12px}.group-card{align-items:center;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:12px;margin-bottom:10px;padding:12px;transition:all .2s ease}.group-card:hover{background:#f8f9fa;border-color:#d0d0d0}.group-card.selected{background:#e8f0fe;border-color:#1a73e8}.group-checkbox-icon{align-items:center;color:#1a73e8;display:flex;font-size:16px;font-weight:700;height:20px;justify-content:center;width:20px}.group-details{flex:1 1}.group-name-text{color:#202124;font-size:14px;font-weight:500;margin-bottom:4px}.group-count-text{color:#5f6368;font-size:12px}.groups-list-scroll::-webkit-scrollbar,.message-area::-webkit-scrollbar,.search-dropdown::-webkit-scrollbar,.sidebar::-webkit-scrollbar{height:8px;width:8px}.groups-list-scroll::-webkit-scrollbar-track,.message-area::-webkit-scrollbar-track,.search-dropdown::-webkit-scrollbar-track,.sidebar::-webkit-scrollbar-track{background:#0000}.groups-list-scroll::-webkit-scrollbar-thumb,.message-area::-webkit-scrollbar-thumb,.search-dropdown::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb{background:#dadce0;border-radius:10px}.groups-list-scroll::-webkit-scrollbar-thumb:hover,.message-area::-webkit-scrollbar-thumb:hover,.search-dropdown::-webkit-scrollbar-thumb:hover,.sidebar::-webkit-scrollbar-thumb:hover{background:#bdc1c6}@media (max-width:1024px){.sidebar{width:200px}.groups-panel{width:280px}}@media (max-width:768px){.notifications-management{flex-direction:column}.sidebar{border-bottom:1px solid #e0e0e0;border-right:none;max-height:200px;width:100%}.groups-panel{display:none}}.student-search{max-width:400px;position:relative;width:100%}.search-input-container{align-items:center;display:flex;position:relative}.search-input{background:#fff;border:2px solid #e0ddd8;border-radius:25px;font-size:16px;outline:none;padding:12px 16px 12px 45px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#8d7b68;box-shadow:0 0 0 3px #8d7b681a}.search-input::placeholder{color:#8d7b68;opacity:.7}.search-icon{color:#8d7b68;font-size:16px;left:15px;pointer-events:none;position:absolute}.search-results{background:#fff;border:2px solid #e0ddd8;border-radius:0 0 12px 12px;border-top:none;box-shadow:0 4px 12px #0000001a;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.search-result-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#8d7b680d;transform:translateX(2px)}.student-avatar-small{align-items:center;background:linear-gradient(135deg,#8d7b68,#a69080);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:40px;justify-content:center;width:40px}.student-info-search{flex:1 1;min-width:0}.student-name-search{color:#5d4e37;font-size:16px;font-weight:600;margin-bottom:2px}.student-details-search{color:#8d7b68;font-size:14px;opacity:.8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-results{color:#8d7b68;font-style:italic;padding:20px 16px;text-align:center}.search-results{animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.student-search{max-width:100%}.search-input{font-size:16px}.search-results{max-height:250px}.search-result-item{padding:15px 12px}.student-avatar-small{font-size:12px;height:35px;width:35px}.student-name-search{font-size:15px}.student-details-search{font-size:13px}}.session-tabs-nav{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:0;margin-bottom:20px;padding:4px}.tab-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#8d7b68;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.tab-btn:hover{background:#f0ebe6;color:#5d4e37}.tab-btn.active{background:#4a655a;color:#fff;font-weight:600}.attendance-tab-content,.history-tab-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.attendance-content h3{color:#4a655a;font-size:18px;margin-bottom:20px}.new-session-form{background:#f8f6f3;border-radius:8px;margin-bottom:20px;padding:20px}.new-session-form h4{color:#4a655a;margin-bottom:16px}.form-row{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px}.form-group{flex:1 1;min-width:200px}.form-group label{display:block;font-weight:500;margin-bottom:4px}.form-group input{border:1px solid #d4c9c1;border-radius:6px;font-size:14px;padding:8px 12px;width:100%}.form-group input:focus{border-color:#4a655a;box-shadow:0 0 0 2px #4a655a1a;outline:none}.participants-list{background:#fff;border:1px solid #d4c9c1;border-radius:6px;margin:16px 0;padding:12px}.participants-list h5{color:#4a655a;margin:0 0 8px}.btn-create-session{background:#4a655a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:background .2s}.btn-create-session:hover{background:#3e5449}.session-history-page{background:#f8f6f3;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.back-btn{align-items:center;background:#525f71;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:10px;padding:10px 30px;transition:all .3s ease}.back-btn:hover{transform:translateY(-2px)}.add-session-btn{align-items:center;background:#4a655a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.add-session-btn:hover{background:#3a5148;transform:translateY(-2px)}.session-info h1{color:#5d4e37;font-size:24px;margin:0 0 8px}.session-details{color:#8d7b68;font-size:16px;margin:0}.history-content{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:30px}.no-history{color:#8d7b68}.no-history-icon{font-size:64px;margin-bottom:20px}.no-history h3{color:#5d4e37;font-size:24px}.no-history p{font-size:16px}.sessions-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.history-session-card{background:#f8f6f3;border:2px solid #e0ddd8;border-radius:12px;padding:20px;transition:all .3s ease}.history-session-card:hover{border-color:#4a655a;box-shadow:0 8px 20px #0000001a;transform:translateY(-3px)}.session-date{align-items:center;border-bottom:1px solid #e0ddd8;display:flex;gap:15px;margin-bottom:15px;padding-bottom:15px}.date-info .day{font-size:18px;font-weight:700;line-height:1}.date-info .month{font-size:12px;margin-top:2px;text-transform:uppercase}.session-meta{flex:1 1}.session-number{background:#8d7b68;border-radius:12px;color:#fff;display:block;font-size:12px;font-weight:600;margin-bottom:4px;padding:3px 8px;width:-webkit-fit-content;width:fit-content}.weekday{color:#5d4e37;font-size:14px;font-weight:500;text-transform:capitalize}.session-stats{margin-bottom:15px}.individual-stats .status{align-items:center;border-radius:20px;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:6px 12px}.status.present{background:#4a655a1a;color:#4a655a}.status.absent{background:#ef44441a;color:#ef4444}.group-stats{display:flex;flex-direction:column;gap:8px}.attendance-summary{align-items:baseline;color:#5d4e37;font-weight:600;gap:4px}.present-count{color:#4a655a}.total-count{color:#8d7b68;font-size:16px}.label{color:#8d7b68;font-weight:500}.attendance-bar{background:#e0ddd8;border-radius:3px;height:6px;overflow:hidden;width:100%}.attendance-fill{background:linear-gradient(90deg,#4a655a,#5a7865);height:100%;transition:width .3s ease}.session-actions{justify-content:center}.attendance-btn{align-items:center;background:#4a655a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.attendance-btn:hover{background:#3a5148;transform:translateY(-2px)}.add-session-modal{max-height:80vh;max-width:600px}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.form-group label{color:#5d4e37;font-size:14px;font-weight:600}.form-group input,.form-group textarea{border:2px solid #e0ddd8;border-radius:6px;font-size:14px;padding:12px;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:#4a655a;outline:none}.students-attendance-list{background:#f8f6f3;border-radius:6px;display:flex;flex-direction:column;gap:10px;max-height:200px;overflow-y:auto;padding:10px}.attendance-modal{max-height:80vh;max-width:600px}.modal-header .session-date-info{font-size:14px;margin:8px 0 0}.attendance-list{overflow-y:auto;padding:20px 0}.student-attendance-item{align-items:center;background:#f8f6f3;border:1px solid #e0ddd8;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px}.student-info{align-items:center;display:flex;gap:12px}.student-avatar{background:linear-gradient(135deg,#8d7b68,#a69080);font-size:14px;height:40px;width:40px}.student-name .name{color:#5d4e37;font-weight:600}.attendance-toggle{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.attendance-toggle.present{background:#4a655a1a;border:2px solid #4a655a;color:#4a655a}.attendance-toggle.absent{background:#ef44441a;border:2px solid #ef4444;color:#ef4444}.attendance-toggle:hover{transform:scale(1.05)}.modal-buttons{border-top:1px solid #e0ddd8;gap:12px;padding-top:20px}.close-btn{background:#8d7b68}.close-btn,.save-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.save-btn{background:#4a655a}.close-btn:hover,.save-btn:hover{transform:translateY(-2px)}@media (max-width:768px){.session-history-page{padding:10px}.history-header{align-items:flex-start;flex-direction:column;gap:15px}.sessions-grid{grid-template-columns:1fr}.attendance-modal{margin:10px;max-width:calc(100vw - 20px)}}.attendance-sheet-simple{background:#f9fafb;margin:0 auto;max-width:800px}.attendance-header{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;gap:20px;margin-bottom:30px;padding:20px}.btn-back{background:#456055}.session-info{margin-bottom:4px}.session-info,.session-info h2{display:flex;justify-content:center}.session-details span{font-size:15px;padding:4px 12px}.session-details .detail-name{background:#456055;color:#fff;font-weight:600}.attendance-summary{background:#fff;box-shadow:0 2px 8px #0000001a;margin-bottom:2px;padding:20px}.attendance-summary,.summary-stats{display:flex;justify-content:center}.summary-stats{align-items:center;font-size:18px;font-weight:600;gap:8px}.present-count{font-size:24px}.separator{font-size:20px}.total-count{font-size:24px}.label{font-size:16px;margin-left:8px}.simple-attendance-list{background:#fff;box-shadow:0 2px 8px #0000001a;margin-bottom:2px}.simple-student-row{border-bottom:1px solid #f3f4f6;padding:12px 0}.simple-student-row:last-child{border-bottom:none}.checkbox-container{align-items:center;cursor:pointer;display:flex;font-size:16px;gap:12px;-webkit-user-select:none;user-select:none}.checkbox-container input[type=checkbox]{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.checkmark{background-color:#e5e7eb;border:2px solid #d1d5db;border-radius:4px;flex-shrink:0;height:20px;margin-left:8px;position:relative;transition:all .2s;width:20px}.checkbox-container:hover input~.checkmark{background-color:#f3f4f6}.checkbox-container input:checked~.checkmark{background-color:#456055;border-color:#456055}.checkmark:after{content:"";display:none;position:absolute}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{border:solid #fff;border-width:0 2px 2px 0;height:10px;left:6px;top:2px;transform:rotate(45deg);width:6px}.no-students{align-items:center;color:#8d7b67;display:flex;flex-direction:column;font-size:16px;gap:16px;padding:40px}.no-students img{opacity:.6}.attendance-actions{background:#fff;box-shadow:0 2px 8px #0000001a;padding:20px}.attendance-actions,.btn-save{display:flex;justify-content:center}.btn-save{align-items:center;background:#456055;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;gap:8px;min-width:140px;padding:14px 28px;transition:all .2s}.btn-save:hover:not(:disabled){background:#1f2a24;transform:translateY(-1px)}.btn-save:disabled{background:#e5e7eb;color:#8d7b67;cursor:not-allowed;transform:none}@media (max-width:768px){.attendance-sheet-simple{padding:1px}.attendance-header{flex-direction:column;gap:15px;text-align:center}.btn-back{align-self:flex-start}.simple-student-row{padding:16px 0}.student-name{font-size:18px}}.attendance-history{background:#f9fafb;margin:0 auto;max-width:1000px;min-height:100vh;padding:20px}.history-header{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;gap:20px;margin-bottom:30px;padding:20px}.btn-back,.history-header{align-items:center;display:flex}.btn-back{background:#8d7b67;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;gap:8px;min-width:100px;padding:12px 20px;transition:all .2s}.btn-back:hover{background:#53483b;transform:translateY(-1px)}.session-info{flex:1 1}.session-info h2{color:#456055;font-size:24px;font-weight:700;margin:0 0 8px}.loading{color:#8d7b67;height:60vh}.history-list{display:flex;flex-direction:column;gap:20px}.no-history{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:60px 20px;text-align:center}.no-history img{margin-bottom:20px;opacity:.6}.no-history h3{color:#456055;font-size:20px;margin:0 0 10px}.no-history p{color:#8d7b67;margin:0}.item-header{border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between}.date-info{display:flex;flex-direction:row;gap:4px}.date-main{color:#111827;font-size:16px;font-weight:600}.time{font-size:14px}.attendance-stats{align-items:center;display:flex;font-weight:600;gap:8px}.present-count{color:#456055;font-size:18px}.separator{color:#8d7b67;font-size:16px}.total-count{color:#8d7b67;font-size:18px}.label{color:#111827;font-size:14px;margin-left:4px}.percentage{background:#456055;border-radius:6px;color:#fff;font-size:12px;font-weight:700;margin-left:8px;padding:4px 8px}.students-list{display:flex;flex-wrap:wrap;gap:8px}.student-item{align-items:center;border:1px solid #e5e7eb;border-radius:8px;display:inline-flex;justify-content:center;width:-webkit-fit-content;width:fit-content}.student-item.present{background:#4560550d;border-color:#456055}.student-item.absent{background:#8d7b670d;border-color:#8d7b67}.student-name{color:#111827;font-weight:500}.status{font-size:14px;font-weight:600}.status.present{color:#456055}.status.absent{color:#8d7b67}@media (max-width:768px){.attendance-history{padding:15px}.history-header{flex-direction:column;gap:15px;text-align:center}.btn-back{align-self:flex-start}.item-header{gap:12px}.item-header,.student-item{flex-direction:column;text-align:center}}.teacher-dashboard{background-color:#fff;min-height:100vh}.header-logo{align-items:center;display:flex}.dashboard-logo{filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));height:50px;margin-bottom:10px;object-fit:contain;transition:transform .3s ease;width:50px}.dashboard-logo:hover{transform:scale(1.05)}.header-actions{align-items:flex-end;gap:20px;position:relative;z-index:3}.nav-button{background-color:initial;border:none;border-bottom:3px solid #0000;border-radius:0;border-right:1px solid #ffffff4d;color:#fff;font-size:14px;font-weight:500;margin-bottom:-3px;padding:12px 24px;position:relative;text-shadow:0 1px 2px #0000004d}.nav-button:last-child{border-right:none}.nav-button:hover{background-color:#ffffff1a;border-bottom-color:#ffffff80;box-shadow:none;color:#fff;transform:none}.nav-button.active{background-color:#ffffff26;border-bottom-color:#fff;font-weight:600}.nav-button.back-to-dashboard{background-color:#fffffff2;border-color:#ffffffe6;color:#8d7b68;font-weight:600}.nav-button.back-to-dashboard:hover{background-color:#fff;border-color:#fff;color:#5d4e37}.loading{align-items:center;color:#8d7b68;display:flex;height:100vh;justify-content:center}.students-container{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.student-box{background:#f8f6f3;border:1px solid #e0ddd8;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;padding:20px}.student-box:hover{box-shadow:0 4px 16px #8d7b6826;transform:translateY(-2px)}.student-box-header{background:#4a655a;border-radius:8px;color:#fff;margin-bottom:15px;padding:15px}.student-avatar{font-size:16px}.student-name{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;justify-content:center}.student-name h3{margin:0 0 5px;text-align:center}.student-status{border-radius:12px;font-weight:600;padding:4px 8px;text-transform:uppercase}.student-status.active{background:#fff3;border:1px solid #ffffff4d;color:#fff}.student-status.inactive{background:#ffffff1a;border:1px solid #fff3;color:#ffcccb}.student-details{margin-bottom:15px}.detail-item{background:#ffffff80;border-radius:8px;margin-bottom:12px;padding:8px 12px}.detail-label{color:#666;font-weight:500}.detail-value{color:#333;font-weight:600}.student-actions{border-radius:8px}.action-btn{font-size:14px;height:40px;justify-content:center;min-width:100px;padding:12px 20px;transition:all .2s ease}.action-btn.edit-btn{background:#4a655a!important;border-radius:6px!important;color:#fff!important}.action-btn.edit-btn:hover{background:#3d5449!important}.action-btn.delete-btn{background:#dc3545!important;border-radius:6px!important;color:#fff!important}.action-btn.delete-btn:hover{background:#c82333!important}.classes-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.class-box{background:#f8f6f3;border:1px solid #e0ddd8;border-radius:12px;box-shadow:0 2px 8px #8d7b681a;padding:20px;transition:all .3s ease}.class-box:hover{box-shadow:0 4px 16px #8d7b6826;transform:translateY(-2px)}.class-box-header{justify-content:space-between;margin-bottom:15px}.class-box-header,.class-name{align-items:center;display:flex}.class-name{gap:10px}.class-icon{align-items:center;background:linear-gradient(135deg,#8d7b68,#a69080);border-radius:8px;display:flex;font-size:18px;height:40px;justify-content:center;width:40px}.class-name h3{color:#5d4e37;font-size:18px;margin:0}.class-students-list{margin-bottom:15px}.class-students-list h4{color:#666;font-size:14px;font-weight:500;margin:0 0 8px}.students-chips{display:flex;flex-wrap:wrap;gap:6px}.student-chip{background:#e8f4f8;border-radius:12px;color:#2c5282;font-size:12px;font-weight:500;padding:4px 8px}.sessions-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.session-box{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014;padding:20px;transition:transform .2s ease,box-shadow .2s ease}.session-box:hover{box-shadow:0 4px 16px #8d7b6826;transform:translateY(-2px)}.session-box-header{align-items:center;display:flex;gap:15px;margin-bottom:15px}.session-type-icon{align-items:center;background:linear-gradient(135deg,#8d7b68,#a69080);border-radius:8px;display:flex;font-size:18px;height:40px;justify-content:center;width:40px}.session-info h3{color:#5d4e37;font-size:16px;margin:0}.session-details{margin-bottom:15px}.session-status{font-weight:600;padding:4px 8px;text-transform:uppercase}.session-status.completed{background:#e8f5e8;color:#4a655a}.session-status.planned{background:#fff3cd;color:#856404}.session-status.cancelled{background:#f8d7da;color:#721c24}.session-notes{background:#fffbf0;border-left:4px solid #8d7b68;border-radius:8px;margin-bottom:15px;padding:12px}.session-notes h4{color:#5d4e37;font-size:14px;margin:0 0 8px}.session-notes p{font-style:italic}.session-actions{display:flex;gap:10px;justify-content:flex-end}.sessions-selection{border:1px solid #e0ddd8;border-radius:8px;margin-bottom:10px;max-height:200px;overflow-y:auto;padding:10px}.session-checkbox{align-items:center;border-radius:4px;display:flex;gap:8px;padding:8px;transition:background .2s ease}.session-checkbox:hover{background:#f5f5f5}.session-checkbox input[type=checkbox]{margin:0}.session-checkbox label{color:#333;cursor:pointer;font-size:14px}.selected-total{background:#f8f6f3;border-radius:4px;color:#8d7b68;font-weight:700;margin-top:8px;padding:8px;text-align:right}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-number{font-size:36px}.recent-activity{padding:20px}.activity-list{gap:10px}.activity-item{background:#f8f9fa;border-radius:5px;padding:10px}.tab-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.tab-header h2{color:#333;margin:0}.add-btn{background:#456055;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:12px 20px;transition:background .3s ease}.add-btn:hover{background:#6b6258}.header-actions{align-items:center;display:flex;gap:12px}.add-btn.primary{align-items:center;background:linear-gradient(135deg,#334156 0 100%);border:2px solid #0000;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.add-btn.primary:hover{box-shadow:0 4px 16px #667eea66;transform:translateY(-2px)}.add-btn.secondary{align-items:center;background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease}.add-btn.secondary:hover{background:#667eea;box-shadow:0 2px 8px #667eea33;color:#fff;transform:translateY(-1px)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9000}.modal{background:#fff;border-radius:10px;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.modal h3{color:#333;margin:0 0 20px}.modal form{display:flex;flex-direction:column;gap:15px}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.modal input,.modal select,.modal textarea{border:2px solid #ddd;border-radius:5px;font-size:16px;padding:12px}.modal input:focus,.modal select:focus,.modal textarea:focus{border-color:#667eea;outline:none}.modal textarea{min-height:80px;resize:vertical}.modal-buttons{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.modal-buttons button{border-radius:5px;cursor:pointer;font-weight:500;padding:10px 20px}.modal-buttons button[type=button]{background:#a69080;border:none;color:#fff}.modal-buttons button[type=submit]{background:#8d7b68;border:none;color:#fff}.modal .form-group{display:flex;flex-direction:column;gap:8px}.modal .form-group label{color:#5d4e37;font-size:14px;font-weight:600;margin:0}.modal .form-row-compact{grid-gap:15px;align-items:end;display:grid;gap:15px;grid-template-columns:1fr 1fr}.modal .form-row-triple{grid-gap:12px;align-items:end;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.modal .form-group-inline{align-items:center;display:flex;flex-direction:row;gap:12px}.modal .form-group-inline label{margin:0;min-width:120px}.modal .form-group-inline select{flex:1 1;max-width:200px}.session-box.clickable{cursor:pointer;transition:all .3s ease}.session-box.clickable:hover{border-color:#4a655a;box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.click-hint{color:#8d7b68;font-size:12px;font-style:italic;margin-top:5px}.students-container{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.student-box{background:#fff;border:2px solid #0000;border-radius:15px;box-shadow:0 8px 25px #0000001a;overflow:hidden;transition:all .3s ease}.student-box:hover{border-color:#4a655a;box-shadow:0 15px 35px #00000026;transform:translateY(-5px)}.student-box-header{align-items:center;background:linear-gradient(135deg,#3d5449,#4a655a);display:flex;gap:15px;padding:20px}.student-avatar{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;font-size:18px;font-weight:700;height:50px;justify-content:center;width:50px}.student-name h3{color:#fff;font-size:18px;font-weight:600;margin:0}.student-status{border-radius:15px;display:inline-block;font-size:12px;font-weight:500;margin-top:5px;padding:4px 12px}.student-status.active{background:#4caf5033;border:1px solid #4caf504d;color:#4caf50}.student-status.inactive{background:#f4433633;border:1px solid #f443364d;color:#f44336}.student-details{padding:20px}.detail-item{align-items:center;border-bottom:1px solid #f0f0f0;justify-content:space-between;padding:12px 0}.detail-item:last-child{border-bottom:none}.detail-label{color:#2d5016;font-size:14px}.detail-value{color:#666;font-size:14px}.student-actions{background:#fff;display:flex;gap:10px;justify-content:flex-end}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:5px;padding:8px 16px;transition:all .3s ease}.action-btn.edit-btn{background:#4a655a;color:#fff}.action-btn.edit-btn:hover{background:#2d5016;transform:translateY(-2px)}.action-btn.delete-btn{background:#dc3545;color:#fff}.action-btn.delete-btn:hover{background:#c82333;transform:translateY(-2px)}.status{border-radius:15px;display:inline-block;font-size:12px;font-weight:500;margin-top:10px;padding:5px 10px}.status.active{background:#e8e6e3;color:#6b6258}.status.inactive{background:#f0ede8;color:#a69080}.session-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.session-header h3{color:#333;margin:0}.session-details p{color:#666;margin:5px 0}.payment-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.payment-card.paid{border-left-color:#4caf50}.payment-card.pending{border-left-color:#ff9800}.payment-header h3{color:#333;margin:0}.mark-paid-btn{background:#8d7b68;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;margin-top:10px;padding:8px 16px}.mark-paid-btn:hover{background:#6b6258}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:15px;padding:15px;text-align:center}.header-nav{flex-wrap:wrap;gap:10px;justify-content:center}.nav-button{font-size:13px;padding:8px 16px}.header-actions{align-items:center;flex-direction:column;gap:15px;width:100%}.header-actions .student-search{max-width:100%;width:100%}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.students-container{gap:15px;grid-template-columns:1fr}.student-box-header,.student-details{padding:15px}.student-actions{flex-direction:column;padding:12px 15px}.action-btn{justify-content:center}.form-row{grid-template-columns:1fr}.tab-header{align-items:stretch;flex-direction:column;gap:15px}.payment-header,.session-header{align-items:flex-start;flex-direction:column;gap:5px}}.subject-display{background-color:#e8e6e3;border:2px solid #8d7b68;border-radius:8px;margin:10px 0;padding:15px;text-align:center}.subject-display label{color:#6b6258;font-size:16px;margin:0}.subject-display strong{color:#1b5e20;font-size:18px}.classes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px}.class-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px;transition:transform .2s ease}.class-card:hover{transform:translateY(-2px)}.class-card h3{color:#333;font-size:18px;margin:0 0 15px}.class-students{background-color:#f9f9f9;border-radius:5px;margin:15px 0;padding:10px}.class-students ul{margin:5px 0 0;padding-left:20px}.class-students li{margin:3px 0}.students-selection{margin:15px 0}.students-checkboxes{grid-gap:10px;background-color:#f9f9f9;border:1px solid #ddd;border-radius:5px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:10px;max-height:200px;overflow-y:auto;padding:10px}.checkbox-label{align-items:center;border-radius:3px;cursor:pointer;display:flex;gap:8px;padding:5px;transition:background-color .2s ease}.checkbox-label:hover{background-color:#f3f0ec}.checkbox-label input[type=checkbox]{cursor:pointer}.calendar-tab{padding:20px}.calendar-legend{background-color:#f9f9f9;border-radius:5px;display:flex;gap:20px;margin-bottom:15px;padding:10px}.legend-item{align-items:center;display:flex;gap:8px}.legend-color{border-radius:3px;height:16px;width:16px}.legend-individual{background-color:#8d7b68}.legend-class{background-color:#a69080}.legend-scheduled{background-color:#c4b5a0}.form-row{margin-bottom:15px}.form-row label{color:#333;display:block;font-weight:600;margin-bottom:5px}.session-card h3{align-items:center;display:flex;gap:8px}.student-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.student-header h3{margin:0}.delete-btn{background:#f44;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;transition:all .3s ease}.delete-btn:hover{background:#c00;transform:scale(1.1)}.delete-btn:active{transform:scale(.95)}.profile-selector{align-items:center;animation:fadeIn .5s ease-in;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.profile-selector-container{max-width:1200px;position:relative;text-align:center;width:100%;z-index:1}.profile-title{color:#e2e8f0;font-size:2.5rem;font-weight:500;letter-spacing:.5px;margin-bottom:3rem}.profiles-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(150px,200px));justify-content:center;margin-bottom:2rem;padding:2rem}.profile-card{cursor:pointer;position:relative;transition:all .3s ease}.profile-card:hover{transform:scale(1.1)}.profile-card:hover .profile-avatar{border:3px solid #94a3b8;box-shadow:0 8px 20px #94a3b84d}.profile-avatar{align-items:center;background:linear-gradient(135deg,#475569,#334155);border:2px solid #94a3b84d;border-radius:12px;box-shadow:0 4px 16px #0000004d;display:flex;height:180px;justify-content:center;margin:0 auto 1rem;overflow:hidden;position:relative;transition:all .3s ease;width:180px}.profile-avatar:before{background:linear-gradient(135deg,#ffffff1a,#fff0 50%,#0000001a);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.profile-initials{color:#fff;font-size:4rem;font-weight:700;position:relative;text-shadow:2px 2px 8px #0006;z-index:1}.profile-avatar-emoji{filter:drop-shadow(2px 2px 8px rgba(0,0,0,.3));font-size:5rem;position:relative;z-index:1}.profile-avatar-image{background-color:initial!important;overflow:hidden}.profile-name{color:#010204;font-size:1.3rem;font-weight:600;margin-bottom:.5rem;margin-top:1rem;transition:color .3s ease}.profile-card:hover .profile-name{color:#fff;font-weight:700;transform:translateY(-2px)}.profile-level{color:#94a3b8;font-size:1rem;font-style:italic;margin:0;text-shadow:0 1px 2px #00000080}.profile-subtitle{color:grey;font-size:1.1rem;line-height:1.6;margin-top:3rem}@media (max-width:768px){.profile-title{font-size:2.5rem;margin-bottom:2rem}.profiles-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(120px,150px));padding:1rem}.profile-avatar{height:140px;width:140px}.profile-initials{font-size:3rem}.profile-avatar-emoji{font-size:4rem}.profile-name{font-size:1.2rem}.profile-level{font-size:.9rem}.profile-subtitle{font-size:1rem;margin-top:2rem}}@media (max-width:480px){.profile-selector{padding:1rem}.profile-title{font-size:2rem;margin-bottom:1.5rem}.profiles-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(100px,120px))}.profile-avatar{height:110px;width:110px}.profile-initials{font-size:2.5rem}.profile-avatar-emoji{font-size:3rem}.profile-name{font-size:1rem}.profile-subtitle{font-size:.9rem}}.profile-card{animation:slideIn .5s ease-out;animation-fill-mode:both}.profile-card:first-child{animation-delay:.1s}.profile-card:nth-child(2){animation-delay:.2s}.profile-card:nth-child(3){animation-delay:.3s}.profile-card:nth-child(4){animation-delay:.4s}.profile-card:nth-child(5){animation-delay:.5s}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.parent-dashboard{background-color:#fff;min-height:100vh}.dashboard-header{align-items:flex-end;background:url(/static/media/physics-banner.003a74fb8bf64aa70c66.png) bottom;background-repeat:no-repeat;background-size:cover;box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;justify-content:space-between;min-height:80px;padding:15px 20px 0;position:relative}.dashboard-header .user-menu{position:absolute;right:20px;top:15px;z-index:100}.header-nav{align-items:flex-end;align-self:flex-end;border-bottom:3px solid #ffffff4d;display:flex;gap:0;position:relative;z-index:3}.header-nav-btn{background-color:initial;border:none;border-bottom:3px solid #0000;border-radius:0;border-right:1px solid #ffffff4d;color:#fff;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-3px;padding:12px 24px;position:relative;text-decoration:none;text-shadow:0 1px 2px #0000004d;transition:all .3s ease}.header-nav-btn:last-child{border-right:none}.header-nav-btn:hover{background-color:#ffffff1a;border-bottom-color:#ffffff80;box-shadow:none;color:#fff;transform:none}.header-nav-btn.active{background-color:#ffffff26;border-bottom-color:#fff;color:#fff;font-weight:700}.change-profile-btn{background-color:#e50914e6;border:none!important;border-right:1px solid #ffffff4d!important;color:#fff!important;font-weight:600;margin-left:20px;padding:12px 24px}.change-profile-btn:hover{background-color:#e50914;box-shadow:0 2px 8px #e5091466;transform:none}.nav-button{background-color:#456055e6;cursor:pointer;font-size:15px;font-weight:600;padding:15px;text-decoration:none;text-shadow:none;transition:all .3s ease}.nav-button:hover{background-color:#fff;border-color:#fff;box-shadow:0 4px 8px #0003;color:#8d7b68;transform:translateY(-2px)}.nav-button.active{background-color:#8d7b68;border-color:#8d7b68;color:#fff;font-weight:700}.dashboard-header:before{background:#0003;border-radius:inherit;bottom:0;content:"";left:0;position:absolute;right:0;top:0}.header-left h1{font-size:28px;font-weight:600;margin:0 0 5px}.header-left p{font-size:14px;margin:0;opacity:.9}.loading{font-size:18px;padding:50px;text-align:center}.no-students{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin:20px;padding:50px 20px;text-align:center}.no-students h2{color:#333;margin-bottom:15px}.no-students p{color:#666;font-size:16px}.student-selector{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin:20px;padding:20px}.student-selector h3{color:#333;margin:0 0 15px}.student-buttons{display:flex;flex-wrap:wrap;gap:10px}.student-btn{background:#fff;border:2px solid #8d7b68;border-radius:25px;color:#8d7b68;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.student-btn:hover{background:#f3f0ec}.student-btn.active{background:#8d7b68;color:#fff}.dashboard-content{padding:20px}.student-header-simple{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px;text-align:center}.student-header-simple h2{color:#333;font-size:24px;font-weight:600;margin:0}.student-info{margin-bottom:30px}.student-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:25px}.student-card h2{color:#333;font-size:24px;margin:0 0 15px}.student-details{grid-gap:8px;display:grid;gap:8px}.student-details p{color:#666;font-size:16px;margin:0}.stats-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px;text-align:center}.stat-card h3{color:#666;font-size:16px;margin:0 0 10px}.stat-number{color:#333;font-size:32px;font-weight:700}.stat-info{color:#999;font-size:14px;font-style:italic;margin-top:10px}.stat-card-next-session{text-align:left}.next-session-compact{display:flex;flex-direction:column;gap:12px;margin-top:10px}.day-and-date{align-items:center;display:flex;gap:10px}.day-and-date .day-name{background:linear-gradient(135deg,#4a655a,#3d5449);border-radius:6px;color:#fff;font-size:14px;font-weight:600;padding:6px 12px}.day-and-date .date-time{color:#666;font-size:14px;font-weight:500}.session-subject{align-items:center;display:flex;flex-wrap:wrap;font-size:15px;font-weight:600;gap:8px}.group-badge{background:#e3f2fd;border-radius:12px;color:#1976d2;font-size:12px;font-weight:500;padding:4px 10px}.dashboard-sections{display:flex;flex-direction:column;gap:30px;margin-top:30px}.payments-section{border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:25px}.payments-section h3,.sessions-section h3{color:#333;font-size:20px;margin:0 0 20px}.empty-state{color:#999;font-style:italic;padding:30px;text-align:center}.payments-list{display:flex;flex-direction:column;gap:15px;overflow-y:auto}.session-card{border:1px solid #e0e0e0;border-radius:8px;padding:15px;transition:box-shadow .3s ease}.session-card:hover{box-shadow:0 2px 8px #0000001a}.session-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.session-subject{color:#333;font-size:16px;font-weight:700}.session-date{color:#666}.session-duration,.session-price{color:#666;font-size:14px}.session-status{border-radius:12px;font-size:12px;font-weight:500;padding:3px 8px}.session-status.completed{background:#e8e6e3;color:#6b6258}.session-status.scheduled{background:#f0ede8;color:#8d7b68}.session-notes{background:#f8f9fa;border-radius:5px;margin-top:10px;padding:10px}.session-notes strong{color:#333;display:block;margin-bottom:5px}.session-notes p{color:#666;line-height:1.4;margin:0}.payment-card{border:1px solid #e0e0e0;border-left:4px solid;border-radius:8px;padding:15px;transition:box-shadow .3s ease}.payment-card:hover{box-shadow:0 2px 8px #0000001a}.payment-card.paid{background:#f3f0ec;border-left-color:#6b6258}.payment-card.pending{background:#f8f6f3;border-left-color:#a69080}.payment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.payment-amount{color:#333;font-size:18px;font-weight:700}.payment-status{border-radius:15px;font-size:12px;font-weight:500;padding:5px 10px}.payment-status.paid{background:#e8e6e3;color:#6b6258}.payment-status.pending{background:#f0ede8;color:#8d7b68}.payment-details p{color:#666;margin:5px 0}.payment-actions{margin-top:10px}.payment-reminder{background:#e3f2fd;border-left:3px solid #2196f3;border-radius:5px;color:#1976d2;padding:8px 12px}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:15px;text-align:center}.student-buttons{justify-content:center}.dashboard-sections{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.payment-header,.session-header{align-items:flex-start;flex-direction:column;gap:5px}.payments-list,.sessions-list{max-height:none}}@media (max-width:480px){.dashboard-content{padding:10px}.payments-section,.sessions-section,.student-card{padding:15px}.stats-row{grid-template-columns:1fr}}.overview-tab{padding:20px 0}.info-message{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:4px solid #4a655a;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin:20px 0;padding:20px 25px}.info-message p{color:#495057;font-size:15px;line-height:1.6;margin:8px 0}.info-message p:first-child{color:#4a655a;font-size:16px;font-weight:600}.recent-activity{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-top:30px;padding:25px}.recent-activity h2{color:#333;font-size:20px;margin:0 0 20px}.activity-list{display:flex;flex-direction:column;gap:15px}.activity-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:10px 0}.activity-item:last-child{border-bottom:none}.activity-date{color:#666;font-size:14px}.payments-tab,.sessions-tab{padding:20px 0}.payments-tab .payments-section,.sessions-tab .sessions-section{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin:0;padding:25px}.messages-tab{padding:20px 0}.dashboard-section{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:25px}.dashboard-section h2{color:#333;font-size:20px;margin:0 0 20px}.messages-list{display:flex;flex-direction:column;gap:15px}.message-card{background:#fff;border-left:4px solid #0000;border-radius:10px;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;gap:15px;padding:20px;pointer-events:auto;position:relative;text-align:left;transition:all .3s ease;-webkit-user-select:none;user-select:none}.message-card:hover{border-left-color:#456055;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.message-card.unread{background:linear-gradient(90deg,#4560550d,#fff);border-left-color:#456055}.message-card.positive-card{background:linear-gradient(90deg,#22c55e0d,#fff);border-left-color:#22c55e}.message-card.negative-card{background:linear-gradient(90deg,#ef44440d,#fff);border-left-color:#ef4444}.message-info{flex:1 1;pointer-events:none}.message-header{align-items:center;display:flex;gap:10px;margin-bottom:8px}.message-header h4{color:#333;font-size:16px;font-weight:600;margin:0}.unread-indicator{animation:pulse 2s ease-in-out infinite;color:#456055;font-size:18px;line-height:1;margin-left:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.unread-dot{background:#456055;border-radius:50%;flex-shrink:0;height:10px;width:10px}.message-preview{color:#666;font-size:14px;line-height:1.4;margin:5px 0}.session-date{color:#456055;font-size:13px;font-weight:500;margin:5px 0 0}.message-detail{animation:fadeIn .3s ease;text-align:left}.back-button{align-items:center;background:none;border:none;color:#456055;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:5px;margin-bottom:15px;padding:8px 12px;transition:all .2s ease}.back-button:hover{background:#4560551a;border-radius:5px}.message-card-detail{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px}.message-header-detail{border-bottom:2px solid #f0f0f0;display:flex;gap:20px;margin-bottom:25px;padding-bottom:20px}.message-header-detail h3{color:#333;font-size:22px;margin:0 0 8px}.message-sender{color:#666;font-size:14px;font-weight:500;margin:5px 0}.message-date{color:#999;font-size:13px;margin:5px 0 0}.message-content{background:#f9f9f9;border-radius:8px;line-height:1.6;padding:20px}.message-content p{word-wrap:break-word;color:#333;font-size:15px;margin:0;white-space:pre-wrap}.teacher-avatar{border:2px solid #456055;border-radius:50%;flex-shrink:0;height:50px;object-fit:cover;pointer-events:none;width:50px}.teacher-avatar-large{border:3px solid #456055;border-radius:50%;flex-shrink:0;height:70px;object-fit:cover;width:70px}.message-type{color:#456055;font-size:13px;font-weight:600;margin:5px 0}.notification-badge{background:#e50914;border-radius:10px;color:#fff;display:inline-block;font-size:11px;font-weight:700;margin-left:8px;min-width:18px;padding:2px 6px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.next-session-card{background:linear-gradient(135deg,#456055,#5a7a6b);border-radius:16px;box-shadow:0 4px 12px #0000001a;color:#fff;margin-bottom:24px;padding:24px}.next-session-card h2{font-size:22px;font-weight:600;margin:0 0 20px}.next-session-content{align-items:center;display:flex;gap:24px}.next-session-date{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:12px;min-width:160px;padding:20px;text-align:center}.day-name{font-size:18px;font-weight:600;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.date-number{font-size:28px;font-weight:700;margin-bottom:8px}.session-time{font-size:16px;opacity:.9}.next-session-details{flex:1 1}.next-session-details h4{font-size:20px;font-weight:600;margin:0 0 12px}.next-session-details p{font-size:15px;margin:6px 0;opacity:.9}.enrolled-sessions{margin-bottom:24px}.enrolled-sessions h2{color:#333;font-size:20px;font-weight:600;margin:0 0 16px}.enrolled-sessions-list{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.enrolled-session-card{background:#fff;border:2px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:16px;padding:16px;transition:all .3s ease}.enrolled-session-card:hover{border-color:#456055;box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.enrolled-session-day{align-items:center;display:flex;flex-direction:column;gap:8px}.day-badge{background:#456055;border-radius:8px;color:#fff;font-size:13px;font-weight:600;min-width:70px;padding:8px 12px;text-align:center}.session-time-small{color:#666;font-size:14px;font-weight:600}.enrolled-session-info{flex:1 1}.enrolled-session-info h4{color:#333;font-size:16px;font-weight:600;margin:0 0 8px}.enrolled-session-info p{color:#666;font-size:14px;margin:4px 0}.session-duration{font-weight:500}.session-class{color:#456055;font-style:italic}.fixed-sessions-section{margin-bottom:32px}.fixed-sessions-section h3{color:#333;font-size:22px;font-weight:600;margin:0 0 20px}.fixed-sessions-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:32px}.fixed-session-card{background:#fff;border:2px solid #f0f0f0;border-radius:12px;box-shadow:0 2px 12px #0000001a;overflow:hidden;transition:all .3s ease}.fixed-session-card:hover{border-color:#456055;box-shadow:0 6px 20px #00000026;transform:translateY(-4px)}.fixed-session-header{background:linear-gradient(135deg,#456055,#5a7a6b);color:#fff;padding:20px;text-align:center}.day-badge-large{font-size:18px;font-weight:700;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}.session-time-large{font-size:24px;font-weight:700}.fixed-session-body{padding:20px}.fixed-session-body h4{color:#333;font-size:18px;font-weight:600;margin:0 0 16px}.fixed-session-details p{color:#666;display:flex;font-size:14px;justify-content:space-between;margin:8px 0}.fixed-session-details strong{color:#456055;font-weight:600}.next-occurrence{border-top:1px solid #e0e0e0;color:#456055!important;display:block!important;margin-top:16px!important;padding-top:16px}.payments-tab{display:flex;flex-direction:column;gap:32px}.payments-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px}.payments-section h3{color:#333;font-size:22px;font-weight:600;margin:0 0 20px}.empty-state-positive{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-radius:12px;padding:40px 20px;text-align:center}.empty-state-positive p:first-child{color:#2e7d32;font-size:20px;font-weight:600;margin:0 0 8px}.empty-subtitle{color:#558b2f;font-size:15px;margin:0}.payments-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.payment-card-new{background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 12px #0000001a;overflow:hidden;transition:all .3s ease}.payment-card-new.pending{border-color:#ffa726}.payment-card-new.urgent{border-color:#ff9800;box-shadow:0 4px 16px #ff980033}.payment-card-new.overdue{border-color:#ef5350;box-shadow:0 4px 16px #ef535033}.payment-card-new:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-4px)}.payment-card-header{align-items:center;background:linear-gradient(135deg,#456055,#5a7a6b);display:flex;justify-content:space-between;padding:20px}.payment-card-new.urgent .payment-card-header{background:linear-gradient(135deg,#ff9800,#fb8c00)}.payment-card-new.overdue .payment-card-header{background:linear-gradient(135deg,#ef5350,#e53935)}.payment-amount-large{color:#fff;font-size:32px;font-weight:700}.payment-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff4d;border-radius:20px;color:#fff;font-size:13px;font-weight:600;padding:6px 12px}.payment-card-body{padding:20px}.payment-info-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:12px 0}.payment-info-row:last-child{border-bottom:none}.payment-info-row.alert{background:#ffebee;border-bottom:none;margin:0 -20px;padding:12px 20px}.payment-label{color:#666;font-size:14px;font-weight:500}.payment-value{color:#333;font-size:15px;font-weight:600}.payment-info-row.alert .payment-value{color:#c62828}.payment-card-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:16px 20px}.payment-reminder{color:#666;font-size:14px;margin:0;text-align:center}.payment-history-list{display:flex;flex-direction:column;gap:12px}.payment-history-card{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:10px;display:flex;justify-content:space-between;padding:16px 20px;transition:all .3s ease}.payment-history-card:hover{background:#fff;box-shadow:0 2px 8px #00000014;transform:translateX(4px)}.payment-history-left{align-items:center;display:flex;flex:1 1;gap:16px}.payment-checkmark{align-items:center;background:linear-gradient(135deg,#66bb6a,#4caf50);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:40px;justify-content:center;width:40px}.payment-history-info{display:flex;flex-direction:column;gap:4px}.payment-history-amount{color:#333;font-size:20px;font-weight:700}.payment-month-badge{color:#456055;font-size:14px;font-weight:500}.payment-history-dates{display:flex;flex-direction:column;font-size:13px;gap:2px}.paid-date{color:#4caf50;font-weight:600}.due-date-small{color:#999}.payment-method{align-items:center;color:#666;display:flex;font-size:13px;gap:6px;margin-top:4px}.method-icon{font-size:16px}.method-name{font-weight:500}.payment-status-badge{border-radius:20px;flex-shrink:0;font-size:13px;font-weight:600;padding:8px 16px}.payment-status-badge.paid{background:#e8f5e9;color:#2e7d32}.payments-summary{background:linear-gradient(135deg,#f5f5f5,#fff);border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:24px}.payments-summary h3{color:#333;font-size:20px;font-weight:600;margin:0 0 20px}.summary-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-card{background:#fff;border:2px solid #0000;border-radius:10px;box-shadow:0 2px 8px #00000014;padding:20px;text-align:center;transition:all .3s ease}.summary-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.summary-card.total{border-color:#4caf50}.summary-card.total .summary-value{color:#4caf50}.summary-card.pending{border-color:#ff9800}.summary-card.pending .summary-value{color:#ff9800}.summary-card.count{border-color:#456055}.summary-card.count .summary-value{color:#456055}.summary-label{color:#666;font-size:13px;font-weight:500;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.summary-value{font-size:28px;font-weight:700}@media (max-width:768px){.payments-grid,.summary-cards{grid-template-columns:1fr}.payment-history-card{align-items:flex-start;flex-direction:column;gap:12px}.payment-status-badge{align-self:flex-end}}.attendance-tab{height:auto;padding:20px 0}.attendance-tab h2{color:#1a1a1a;font-size:28px;font-weight:700;margin-bottom:30px}.no-attendance{background:#f8f9fa;border-radius:12px;color:#6c757d;padding:60px 20px;text-align:center}.no-attendance p{font-size:16px;margin:0}.attendance-list{align-items:flex-start;display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;height:auto;justify-content:center}.attendance-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:20px;transition:all .3s ease}.attendance-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.attendance-card.present{background:linear-gradient(90deg,#f0fdf4 0,#fff);border-left:5px solid #10b981;min-width:400px}.attendance-card.absent{background:linear-gradient(90deg,#fef2f2 0,#fff);border-left:5px solid #ef4444;min-width:400px}.attendance-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;gap:16px;margin-bottom:16px;padding-bottom:16px}.attendance-status-icon{flex-shrink:0;font-size:32px}.attendance-info{flex:1 1}.attendance-info h3{color:#1a1a1a;font-size:20px;font-weight:600;margin:0 0 6px}.session-date{color:#6c757d;font-size:14px;margin:0;text-transform:capitalize}.status-badge{border-radius:20px;font-size:13px;font-weight:600;letter-spacing:.5px;padding:6px 16px;text-transform:uppercase}.present-badge{background:#d1fae5;color:#065f46}.absent-badge{background:#fee2e2;color:#991b1b}.attendance-details{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{color:#6c757d;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#1a1a1a;font-size:15px;font-weight:500}.detail-value.status-completed{color:#10b981}.detail-value.status-scheduled{color:#f59e0b}.detail-value.status-cancelled{color:#ef4444}.session-homework,.session-topic{background:#f8f9fa;border-radius:8px;font-size:14px;line-height:1.6;margin-bottom:12px;padding:12px 16px}.session-homework strong,.session-topic strong{color:#495057;display:block;margin-bottom:4px}.session-topic{border-left:3px solid #3b82f6}.session-homework{border-left:3px solid #8b5cf6}.attendance-timestamp{border-top:1px solid #e9ecef;color:#6c757d;font-size:12px;font-style:italic;margin-top:12px;padding-top:12px}@media (max-width:768px){.attendance-tab{padding:20px}.attendance-tab h2{font-size:24px}.attendance-header{flex-wrap:wrap}.attendance-details{grid-template-columns:1fr}.status-badge{text-align:center;width:100%}}.App{text-align:center}.loading-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 2s linear infinite;font-size:48px;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-screen p{font-size:18px;margin:0}.error-screen{align-items:center;background-color:#f5f5f5;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.error-screen h2{color:#f44336;margin-bottom:10px}.error-screen p{color:#666;margin:0}
/*# sourceMappingURL=main.ecdf6438.css.map*/