:root{--blue:#3b82f6;--indigo:#6366f1;--lavender:#a78bfa;--sage:#8da399;--terracotta:#c96a49;--linen:#f3ede6;--butter:#ffd66b;--gold:#d4a017;--coral:#f97316;--charcoal:#1e293b;--primary:#3b82f6;--secondary:#6366f1;--accent:#f97316;--background-light:#f8fafc;--background-card:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--border:#e2e8f0;--shadow:#00000014;--shadow-hover:#00000026;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f8fafc;background-color:var(--background-light);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}body,p{color:#1e293b;color:var(--text-primary);font-size:15px;line-height:1.6}p{margin-bottom:12px}.text-sm,small{font-size:13px;line-height:1.5}.text-lg{font-size:17px;line-height:1.6}.text-xs{font-size:12px;line-height:1.4}small{font-size:13px;line-height:1.5}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.gap-2{gap:16px}.gap-3{gap:24px}.mb-3{margin-bottom:24px}.mt-3{margin-top:24px}.w-100{width:100%}.global-loading{color:#64748b;color:var(--text-secondary);font-size:18px;padding:40px;text-align:center}.global-spinner{animation:spin 1s linear infinite;border:4px solid #0b69ff1a;border-radius:50%;border-top-color:#3b82f6;border-top:4px solid var(--primary);height:40px;margin:0 auto 20px;width:40px}@media (max-width:768px){p{font-size:14px}}@media (max-width:480px){p{font-size:13px}}.auth-layout{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;position:relative;width:100vw}.auth-layout__main{align-items:center;display:flex;flex:1 1;justify-content:center;margin-top:55px;padding:20px;position:relative;z-index:10}.auth-layout__content{background:#fffffffa;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000004d;box-sizing:border-box;max-width:500px;padding:40px;position:relative;width:100%;z-index:20}.auth-layout__header{margin-bottom:32px;text-align:center}.auth-layout__title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 8px}.auth-layout__subtitle{color:var(--text-secondary);font-size:15px;margin:0}.auth-layout__form{display:flex;flex-direction:column;gap:20px}.auth-layout__form-group{display:flex;flex-direction:column;gap:8px}.auth-layout__form-label{color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:4px}.auth-layout__form-control{background-color:var(--background-card);border:1px solid var(--border);border-radius:8px;box-sizing:border-box;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.auth-layout__form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.auth-layout__form-control::placeholder{color:var(--text-secondary)}.auth-layout__btn{align-items:center;background-color:var(--primary);border:none;border-radius:8px;box-shadow:0 1px 3px var(--shadow);color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:500;gap:8px;height:44px;justify-content:center;line-height:1.2;min-height:44px;padding:12px 20px;transition:all .2s ease}.auth-layout__btn:hover{background-color:#2563eb;box-shadow:0 4px 8px var(--shadow-hover);transform:translateY(-1px)}.auth-layout__btn:focus{outline:2px solid var(--blue);outline-offset:2px}.auth-layout__footer{color:var(--text-secondary);font-size:14px;margin-top:24px;text-align:center}.auth-layout__link{color:var(--primary);font-weight:500;text-decoration:none}.auth-layout__link:hover{text-decoration:underline}.login-tabs{background:var(--background-card);border:1px solid var(--border);border-radius:12px;display:flex;gap:4px;margin-bottom:24px;padding:4px}.login-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s ease}.login-tab.active{background:var(--primary);color:#fff}.login-tab:hover:not(.active){background:var(--background-light);color:var(--text-primary)}.tab-icon{font-size:16px}.language-selector-bottom{display:flex;gap:8px;justify-content:center}.lang-btn{background:var(--background-card);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.lang-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.lang-btn:hover{border-color:var(--primary);color:var(--text-primary)}.alert{margin-bottom:16px}@media (max-width:768px){.auth-layout__content{margin:20px;padding:32px}.auth-layout__title{font-size:24px}}@media (max-width:480px){.auth-layout__content{margin:16px;padding:24px}.auth-layout__title{font-size:22px}.auth-layout__subtitle{font-size:14px}}.admin-dashboard__container{box-sizing:border-box;margin:0;max-width:100%;padding:0 0 0 20px;width:100%}.admin-dashboard__stats-grid{grid-gap:24px;box-sizing:border-box;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px;width:100%}.admin-dashboard__stat-card{align-items:center;background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 15px var(--shadow);box-sizing:border-box;display:flex;gap:14px;max-width:100%;min-height:120px;padding:12px 16px;transition:all .3s ease;width:100%}.admin-dashboard__stat-card:hover{box-shadow:0 8px 20px var(--shadow-hover);transform:translateY(-3px)}.admin-dashboard__stat-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:20px;height:42px;justify-content:center;width:42px}.admin-dashboard__stat-info h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2;margin:0 0 2px}.admin-dashboard__stat-info p{color:var(--text-secondary);font-size:.875rem;line-height:1.2;margin:0}.admin-dashboard__quick-actions-grid{grid-gap:20px;box-sizing:border-box;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px;width:100%}.admin-dashboard__quick-action-btn{align-items:center;background:#f8fafc;border:2px solid var(--border);border-radius:16px;box-sizing:border-box;color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;font-size:1rem;font-weight:500;gap:12px;padding:25px 20px;transition:all .2s ease;width:100%}.admin-dashboard__quick-action-btn:hover{background:var(--background-card);border-color:var(--primary);box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.admin-dashboard__action-icon{font-size:2rem}.admin-dashboard__action-text{text-align:center}.admin-dashboard__welcome-grid{grid-gap:25px;box-sizing:border-box;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px;width:100%}.admin-dashboard__welcome-item{background:#f8fafc;border:1px solid var(--border);border-radius:12px;box-sizing:border-box;padding:20px;width:100%}.admin-dashboard__welcome-item h3{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:0 0 12px}.admin-dashboard__welcome-item p{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0}@media (max-width:768px){.stats-grid{gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-card{padding:20px}.stat-info h3{font-size:1.7rem}.quick-actions-grid{gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.quick-action-btn{padding:20px 15px}.welcome-grid{grid-template-columns:1fr}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;padding:18px;text-align:center}.stat-icon{font-size:24px;height:50px;width:50px}.stat-info h3{font-size:1.5rem}.quick-actions-grid{grid-template-columns:1fr}.quick-action-btn{font-size:.9rem;padding:18px 12px}}@media (min-width:1920px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));max-width:1600px}.quick-actions-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));max-width:1600px}.welcome-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));max-width:1600px}}.students-container{box-sizing:border-box;margin:0;max-width:100%;padding:0;width:100%}.students-stats-row{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:30px}.stat-box{border-radius:16px;box-shadow:0 4px 12px var(--shadow);flex:1 1;flex-direction:column;gap:8px;min-width:150px;transition:transform .2s ease}.stat-box:hover{transform:translateY(-3px)}.stat-label{font-size:.9rem}.stat-count{color:var(--primary);font-size:1.8rem;font-weight:700}.stat-box.active .stat-count{color:#10b981}.stat-box.inactive .stat-count{color:#f59e0b}.stat-box.graduated .stat-count{color:#3b82f6}.search-filters{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);box-sizing:border-box;margin-bottom:30px;padding:25px;width:100%}.search-filters h2{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0 0 20px}.filters{display:flex;flex-wrap:wrap;gap:20px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:var(--text-primary);font-size:.95rem;font-weight:500}.filter-input{background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .2s ease;width:100%}.filter-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0b69ff1a;outline:none}.action-buttons{display:flex;flex-wrap:wrap;gap:15px}.results-info{background:#f8fafc;border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);font-weight:500;margin-bottom:20px;padding:12px 20px}.student-table-photo{border:2px solid var(--lavender);border-radius:50%;height:40px;object-fit:cover;width:40px}.student-table-photo-placeholder{align-items:center;background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:700;height:40px;justify-content:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:40px}.action-buttons-table{display:flex;flex-wrap:wrap;gap:6px}.action-buttons-table .btn{border-radius:6px;font-size:12px;max-width:80px;min-width:70px;padding:6px 12px}.students-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.student-card,.students-grid{box-sizing:border-box;width:100%}.student-card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);display:flex;flex-direction:column;gap:20px;max-width:100%;padding:25px;transition:all .3s ease}.student-card:hover{box-shadow:0 8px 20px var(--shadow-hover);transform:translateY(-3px)}.student-header{gap:20px}.student-photo{border:3px solid var(--lavender);border-radius:50%;box-shadow:0 4px 8px #0000001a;height:50px;object-fit:cover;width:50px}.student-photo-placeholder{background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);border-radius:50%;font-weight:700;height:50px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:50px}.student-basic-info h3{color:var(--text-primary);font-size:1.3rem;font-weight:600;margin:0 0 8px}.student-id{font-size:.95rem;margin:0}.student-details{display:flex;flex-direction:column;gap:15px}.detail-row{border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:10px 0}.detail-label{font-size:.95rem;font-weight:500}.detail-value{font-size:.95rem;max-width:60%;text-align:right}.student-actions{display:flex;gap:12px;margin-top:10px}.student-actions .btn{border-radius:10px;flex:1 1;font-size:.9rem;padding:10px 16px}.pagination{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:40px}.pagination button{background:var(--background-card);border:1px solid var(--border);border-radius:10px;box-sizing:border-box;cursor:pointer;font-weight:500;padding:10px 18px;transition:all .2s ease}.pagination button.active,.pagination button:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.no-students{padding:60px 20px}.loading,.no-students,.students__loading{font-size:1.2rem;grid-column:1/-1}.students__loading{color:var(--text-secondary);padding:60px 20px;text-align:center}.spinner{margin:0 auto 20px}.students__spinner{animation:spin 1s linear infinite;border:4px solid #0b69ff1a;border-radius:50%;border-top:4px solid var(--primary);height:50px;margin:0 auto 20px;width:50px}@media (max-width:768px){.filters,.students-grid{grid-template-columns:1fr}.student-card{padding:20px}.student-header{gap:15px}.student-photo{height:60px;width:60px}.student-basic-info h3{font-size:1.2rem}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}.student-actions{flex-direction:column}.pagination{margin-top:30px}.pagination button{font-size:.9rem;padding:8px 14px}.table{font-size:14px}.student-table-photo,.student-table-photo-placeholder{font-size:14px;height:35px;width:35px}.students-stats-row{gap:12px}.stat-box{min-width:120px;padding:15px}.stat-count{font-size:1.5rem}.action-buttons-table{flex-direction:column;gap:4px}.action-buttons-table .btn{font-size:11px;min-width:50px;padding:4px 8px}}@media (max-width:480px){.search-filters{padding:20px}.filters{gap:15px}.filter-input{font-size:.95rem;padding:10px 14px}.student-card{padding:18px}.student-photo{height:55px;width:55px}.detail-row{padding:8px 0}.student-actions{gap:10px}.student-actions .btn{font-size:.85rem;padding:8px 14px}.students-stats-row{gap:8px}.stat-box{min-width:calc(50% - 8px);padding:12px}.stat-count{font-size:1.3rem}.table td,.table th{padding:8px 6px}.student-table-photo,.student-table-photo-placeholder{font-size:12px;height:30px;width:30px}}.view-student-container{box-sizing:border-box;margin:0;max-width:100%;padding:20px;width:100%}.student-header{align-items:center;background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);border-radius:16px;box-shadow:0 10px 20px #0000001a;box-sizing:border-box;color:#fff;display:flex;justify-content:space-between;margin-bottom:15px;padding:25px;width:100%}.student-basic-info{align-items:center;display:flex;gap:25px}.view-student-container .student-photo{border:4px solid #ffffff4d;border-radius:25px;box-shadow:0 5px 15px #0003;height:150px;object-fit:cover;width:150px}.student-text-info h1{color:#fff;font-size:2.2rem;font-weight:700;margin:0 0 12px}.student-id{color:#ffffffe6;font-size:1.2rem;font-weight:500;margin:5px 0}.header-controls{display:flex;flex-direction:column;gap:15px}.language-selector{display:flex;gap:12px}.language-selector .btn{border-radius:12px;font-size:.95rem;padding:10px 18px}.stats-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:15px}.stat-card,.stats-grid{box-sizing:border-box;width:100%}.stat-card{background:var(--background-card);border-left:4px solid var(--blue);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 15px var(--shadow);max-width:100%;padding:18px;transition:all .3s ease}.stat-card:hover{box-shadow:0 8px 20px var(--shadow-hover);transform:translateY(-3px)}.stat-card h3{color:var(--blue);font-size:1.1rem;font-weight:600;margin:0 0 12px}.stat-card p{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:0}.card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 15px var(--shadow);box-sizing:border-box;margin-bottom:15px;max-width:100%;padding:25px;transition:all .3s ease;width:100%}.card:hover{box-shadow:0 8px 20px var(--shadow-hover);transform:translateY(-2px)}.card h2{align-items:center;color:var(--text-primary);display:flex;font-size:1.4rem;font-weight:700;gap:12px;margin:0 0 15px}.student-details-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));width:100%}.student-info-container{display:flex;flex-direction:column;gap:0;width:100%}.info-section{border-bottom:1px solid #e2e8f0;padding:20px 0}.info-section:last-child{border-bottom:none;padding-bottom:0}.info-section:first-child{padding-top:0}.section-title{border-bottom:2px solid #f0f4f8;font-size:.95rem;letter-spacing:.5px;margin:0 0 16px;padding-bottom:10px;text-transform:uppercase}.info-grid{grid-gap:16px 32px;gap:16px 32px;grid-template-columns:1fr 1fr;width:100%}.info-row{grid-gap:24px;align-items:flex-start;display:grid;gap:24px;grid-template-columns:200px 1fr;padding:8px 0}.info-label{color:#64748b;font-size:.9rem;font-weight:500;letter-spacing:.3px}.info-value{color:var(--text-primary);font-size:.95rem;word-break:break-word}@media (max-width:768px){.info-grid{gap:16px;grid-template-columns:1fr}.info-row{gap:16px;grid-template-columns:140px 1fr}}@media (max-width:480px){.info-row{gap:6px;grid-template-columns:1fr}.info-label{color:#94a3b8;font-size:.85rem}.info-value{font-size:.9rem}}.badge{font-size:.95rem;font-weight:600;letter-spacing:.5px;padding:8px 16px;text-transform:uppercase}.badge-primary{background-color:#0b69ff26;color:var(--primary)}.badge-success{background-color:#10b98126;color:var(--success)}.badge-warning{background-color:#f59e0b26;color:var(--warning)}.badge-danger{background-color:#ef444426;color:var(--danger)}.badge-info{background-color:#3b82f626;color:var(--info)}.feedback-list{display:flex;flex-direction:column;gap:16px;width:100%}.feedback-filters{align-items:flex-end;background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.filter-item{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:180px}.filter-label{color:var(--text-primary);font-size:.85rem;font-weight:600;margin-bottom:0}.filter-input,.filter-select{background:var(--background);border:1px solid var(--border);border-radius:8px;box-sizing:border-box;color:var(--text-primary);font-size:14px;height:44px;outline:none;padding:0 12px;transition:all .2s}.filter-input:focus,.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.filter-reset-btn{background:var(--secondary);border:none;border-radius:8px;box-sizing:border-box;color:#fff;cursor:pointer;font-size:14px;font-weight:500;height:44px;padding:0 20px;transition:all .2s;white-space:nowrap}.filter-reset-btn:hover{background:#545b62;transform:translateY(-1px)}.feedback-item{background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000f;box-sizing:border-box;max-width:100%;padding:20px;transition:all .3s ease;width:100%}.feedback-item:hover{box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.feedback-header{align-items:flex-start;padding-bottom:20px}.feedback-course h3{color:var(--text-primary);font-size:1.3rem;font-weight:600;margin:0 0 8px}.feedback-course p{color:var(--text-secondary);font-size:1rem;margin:0}.feedback-grade{text-align:right}.grade-badge{background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);border-radius:20px;box-shadow:0 4px 10px #0b69ff33;color:#fff;display:inline-block;font-size:1.2rem;font-weight:600;margin-bottom:8px;padding:8px 16px}.percentage{color:var(--text-secondary);display:block;font-size:1rem;font-weight:500}.feedback-details{margin-bottom:20px}.detail-row{align-items:center;border-bottom:none;display:grid;grid-template-columns:40% 60%;margin-bottom:6px;padding:6px 0}.detail-row:last-child{border-bottom:none;margin-bottom:0}.detail-label{color:var(--text-primary);font-size:.9rem;font-weight:600;padding-right:12px}.detail-value{text-align:left;word-break:break-word}.detail-value,.feedback-footer{color:var(--text-secondary);font-size:.9rem}.feedback-footer{text-align:right}.table-responsive{box-sizing:border-box;overflow-x:auto;width:100%}.table{background:var(--background-card);border-radius:12px;box-shadow:0 2px 8px var(--shadow);box-sizing:border-box;margin-bottom:20px;overflow:hidden}.table td,.table th{border:1px solid var(--border);padding:16px;text-align:left}.table th{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:var(--text-primary);font-size:.85rem;letter-spacing:.5px;text-transform:uppercase}.table tr:nth-child(2n){background-color:#f8fafc}.table tr:hover{background-color:#f1f5f9}.eligibility-card .eligibility-status{align-items:flex-start;display:flex;flex-direction:column;gap:20px}.eligibility-reason{background:#f8fafc;border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);margin:0;padding:20px}.payment-section{margin-bottom:35px;width:100%}.payment-section h3{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:1.3rem;margin:0 0 20px;padding-bottom:12px}.no-data{font-size:1.1rem;font-style:italic;margin:0;padding:40px}.btn{border-radius:12px;box-shadow:0 2px 5px var(--shadow);display:inline-block;font-size:1rem;padding:12px 24px;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);box-shadow:0 4px 12px #0b69ff33}.btn-primary:hover{background:linear-gradient(135deg,#0952cc,#2d22b5);box-shadow:0 6px 15px #0b69ff4d}.btn-secondary{background-color:#64748b}.btn-secondary:hover{background-color:#475569;box-shadow:0 4px 10px #64748b33;transform:translateY(-1px)}.alert{border-radius:16px;box-sizing:border-box;margin-bottom:25px;padding:20px}.alert-error{background-color:#fee2e2;border-color:#fecaca;color:#991b1b}.alert-success{background-color:#dcfce7;border-color:#bbf7d0;color:#166534}.loading,.view-student__loading{align-items:center;display:flex;flex-direction:column;font-size:1.3rem;gap:20px;padding:50px}.view-student__loading{color:var(--text-secondary);text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #0b69ff1a;border-top:4px solid var(--primary);height:50px;width:50px}.parent-view .student-header{background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%)}.parent-view .card{border-left:4px solid var(--blue)}@media (max-width:768px){.student-header{gap:25px;padding:25px}.student-basic-info,.student-header{flex-direction:column;text-align:center}.header-controls{width:100%}.language-selector{justify-content:center}.stats-grid{grid-template-columns:1fr}.feedback-header{align-items:flex-start;flex-direction:column;gap:15px;text-align:left}.feedback-grade{text-align:left}.parent-details{grid-template-columns:1fr}.table td,.table th{font-size:.9rem;padding:12px 10px}.btn{font-size:.95rem;padding:10px 20px}.detail-row{flex-direction:column;gap:8px}.detail-value{max-width:100%;text-align:left}.card{padding:25px}.card h2{font-size:1.4rem}}@media (max-width:480px){.student-header{padding:20px}.student-photo{height:90px;width:90px}.student-text-info h1{font-size:1.8rem}.card,.feedback-item,.stat-card{padding:20px}}.add-student-container{margin:0 auto;max-width:1200px;padding:20px}.form-section{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);margin-bottom:30px;padding:25px}.form-section h2{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0 0 20px;padding-bottom:15px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.95rem}.form-input{background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0b69ff1a;outline:none}.form-input:disabled{background:var(--background-disabled);cursor:not-allowed}.form-hint{color:var(--text-secondary);font-size:.85rem;margin-top:5px}.form-actions{border-top:1px solid var(--border);gap:15px;margin-top:30px;padding-top:20px}.subject-checkboxes{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:10px}.subject-checkbox{align-items:center;display:flex;gap:8px}.subject-checkbox input{height:18px;width:18px}.image-upload-wrapper{display:flex;flex-direction:column;gap:15px}.image-preview-container{align-items:center;background:#0b69ff0d;border:2px dashed var(--border);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:20px}.image-preview{border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:200px;max-width:200px;object-fit:cover}@media (max-width:768px){.add-student-container{padding:15px}.form-row{gap:15px;grid-template-columns:1fr}.form-section{padding:20px}.form-section h2{font-size:1.3rem}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}@media (max-width:480px){.add-student-container{padding:12px}.form-section{padding:18px}.form-input{font-size:.95rem;padding:10px 14px}.subject-checkboxes{grid-template-columns:1fr}}.teachers-container{padding:20px}.teachers-header{margin-bottom:20px}.teachers-table{background:#fff;border-collapse:collapse;border-radius:5px;box-shadow:0 2px 4px #0000001a;overflow:hidden;width:100%}.teachers-table td,.teachers-table th{border-bottom:1px solid #dee2e6;font-size:.9rem;padding:8px 12px;text-align:left}.teachers-table th{background-color:#e9ecef;font-weight:600}.teachers-table tr:hover{background-color:#f8f9fa}.teacher-photo{border-radius:50%;height:40px;object-fit:cover;width:40px}.role-badge{font-size:.8rem}.status-active{background-color:#28a745;color:#fff}.status-inactive{background-color:#6c757d;color:#fff}.status-on-leave{background-color:#ffc107;color:#000}.photo-upload{align-items:center;display:flex;gap:15px}.current-photo{border-radius:50%;height:80px;object-fit:cover;width:80px}.upload-controls{flex:1 1}.file-input{margin-bottom:10px}.view-teacher-container{padding:20px}.view-teacher-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.teacher-profile-card{margin-bottom:30px}.teacher-profile-header{align-items:center;display:flex;gap:20px;margin-bottom:20px}.teacher-avatar{border:3px solid #007bff;border-radius:50%;height:100px;object-fit:cover;width:100px}.teacher-initials{align-items:center;background-color:#007bff;border-radius:50%;color:#fff;display:flex;font-size:40px;font-weight:700;height:100px;justify-content:center;width:100px}.teacher-info{flex:1 1}.teacher-name{margin:0}.teacher-id{color:#007bff;font-size:18px;font-weight:700;margin:5px 0}.teacher-details-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-top:20px}.detail-item strong{margin-right:5px}.badge-role,.badge-status{margin-left:10px}.permissions-section{border-top:1px solid #ddd;margin-top:25px;padding-top:20px}.permissions-section h3{margin-bottom:15px}.permissions-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.permission-item{align-items:center;display:flex;gap:10px}.section-title{margin:30px 0 15px}.attendance-card,.schedule-card{margin-bottom:30px}.empty-message{color:#666;padding:20px;text-align:center}.table-container{overflow-x:auto}.status-badge{border-radius:15px;font-size:.8rem;font-weight:700;padding:5px 10px}.status-success{background-color:#28a745;color:#fff}.status-danger{background-color:#dc3545;color:#fff}.status-warning{background-color:#ffc107;color:#000}.status-info{background-color:#17a2b8;color:#fff}.container{padding:20px}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;overflow:hidden}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e0e0e0;color:#fff;padding:20px}.card-header h2{font-size:1.3rem;font-weight:600;margin:0}.card-body{padding:25px}.table{border-collapse:collapse;margin:0}.table thead tr{background:#f5f5f5;border-bottom:2px solid #e0e0e0}.table th{color:#333;font-size:.95rem;font-weight:600;padding:15px;text-align:left}.table td{border-bottom:1px solid #f0f0f0;color:#555;padding:15px}.table tbody tr:hover{background:#fafafa}.btn{font-size:.95rem;font-weight:500;gap:8px;padding:10px 16px}.btn-primary{background:#667eea}.btn-primary:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover{background:#da190b}.btn-sm{padding:8px 12px}.badge,.btn-sm{font-size:.85rem}.badge{border-radius:20px;display:inline-block;font-weight:500;padding:6px 12px}.badge-info{background:#e3f2fd;color:#1976d2}.alert{font-weight:500;padding:15px 20px}.alert-error{background:#ffebee;border-left:4px solid #c62828;color:#c62828}.alert-success{background:#e8f5e9;border-left:4px solid #2e7d32;color:#2e7d32}.modal{border-radius:12px;box-shadow:0 8px 32px #0003;max-width:700px;padding:30px}.modal h2{font-size:1.3rem;margin-bottom:25px}.form-group label{color:#333}.form-group input,.form-group select,.form-group textarea{border-radius:8px;font-family:inherit;font-size:1rem;padding:12px 16px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{min-height:80px;resize:vertical}.loading{color:#666;padding:40px 20px}.timetable-container{padding:20px}.timetable-header{color:#333;margin-bottom:30px}.timetable-filter-select{background-color:#fff;border:2px solid #e0e6ed;border-radius:8px;color:#3e4b5b;cursor:pointer;font-size:14px;height:45px;max-width:400px;padding:0 15px;transition:all .2s}.timetable-filter-select:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a;outline:none}.timetable-filter-select:hover{border-color:#cbd5e0}.loading-message{color:#666}.alert{border-radius:5px;padding:15px}.alert-info{border:1px solid #bee5eb}.exams-page-container{box-sizing:border-box;margin:0;max-width:100%;padding:0;width:100%}.exams-page-header{margin-bottom:30px}.exams-page-header-content{align-items:center;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between}.exams-page-title-section{flex:1 1;min-width:200px}.exams-page-title{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 8px}.exams-page-subtitle{color:var(--text-secondary);font-size:.95rem;margin:0}.exams-page-actions{display:flex;flex-wrap:wrap;gap:12px}.exams-page-actions .btn svg{margin-right:6px;vertical-align:middle}.exams-content-section{margin-bottom:30px}.exams-loading-state{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:60px 20px;text-align:center}.exams-loading-state .students__spinner{margin:0 auto 20px}.exams-loading-text{color:var(--text-secondary);font-size:1.1rem;margin:0}.exams-empty-state{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:80px 40px;text-align:center}.exams-empty-state-content{margin:0 auto;max-width:400px}.exams-empty-icon{font-size:3rem;margin-bottom:20px}.exams-empty-title{color:var(--text-primary);font-size:1.3rem;font-weight:600;margin:0 0 12px}.exams-empty-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin:0 0 30px}.exams-empty-state .btn svg{margin-right:6px;vertical-align:middle}.exams-table-card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);overflow:hidden}.exams-table-wrapper{overflow-x:auto}.exams-table{border-collapse:collapse;margin:0;width:100%}.exams-table thead{background:#3b82f60d}.exams-table th{border-bottom:2px solid var(--border);border-right:1px solid var(--border);color:var(--text-primary);font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.exams-table th:last-child{border-right:none}.exams-table td{border-bottom:1px solid var(--border);border-right:1px solid var(--border);color:var(--text-secondary);font-size:14px;padding:14px 16px;vertical-align:middle}.exams-table td:last-child{border-right:none}.exams-table tbody tr:hover{background:#3b82f605}.exams-table tbody tr:last-child td{border-bottom:none}.exams-table-exam-name{color:var(--text-primary)!important;font-weight:500}.exams-table-marks{font-weight:500}.exams-table-center{text-align:center}.exams-table-actions{display:flex;flex-wrap:wrap;gap:6px}.exams-table-actions .btn svg{margin-right:4px;vertical-align:middle}@media (max-width:768px){.exams-page-header-content{align-items:stretch;flex-direction:column}.exams-page-actions{justify-content:stretch}.exams-page-actions .btn{flex:1 1}.exams-empty-state{padding:60px 20px}.exams-table{font-size:13px}.exams-table td,.exams-table th{padding:10px 12px}.exams-table-actions{flex-direction:column}.exams-table-actions .btn{width:100%}}@media (max-width:480px){.exams-page-title{font-size:1.5rem}.exams-table td,.exams-table th{font-size:12px;padding:8px 10px}}.exam-results-container{padding:20px}.exam-results-header{margin-bottom:20px}.exam-results-table{border-collapse:collapse;margin-top:15px;width:100%}.exam-results-table td,.exam-results-table th{border:1px solid #dee2e6;padding:12px;text-align:left}.exam-results-table th{background-color:#e9ecef;font-weight:700}.feedback-page{margin:0 auto;max-width:1400px;padding:24px}.page-header{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:32px}.page-header h1{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 8px}.subtitle{color:var(--text-secondary);font-size:15px;margin:0}.section{margin-bottom:40px}.section-header{margin-bottom:20px}.section-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:22px;font-weight:600;margin:0 0 6px}.section-header h2 svg{margin-right:8px;vertical-align:middle}.section-subtitle{color:var(--text-secondary);font-size:14px;margin:0}.section-subtitle.help-text{margin-top:8px}.feedback-toolbar{align-items:center;background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:20px;justify-content:space-between;margin-bottom:24px;padding:16px 24px}.view-mode-buttons{background:var(--background);border:1px solid var(--border);border-radius:10px;display:flex;padding:4px}.view-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px;transition:all .2s}.view-btn.active{background:var(--background-card);box-shadow:0 2px 6px #0000001a;color:var(--primary)}.teacher-filter{align-items:center;display:flex;gap:12px}.teacher-filter label{font-weight:600;white-space:nowrap}.filter-select,.teacher-filter label{color:var(--text-primary);font-size:14px}.filter-select{background:var(--background);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-weight:500;min-width:200px;outline:none;padding:8px 16px;transition:all .2s}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.classes-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.class-card{background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:24px;transition:all .3s ease}.class-card:hover{box-shadow:0 4px 16px #0000001a}.class-header{align-items:center;border-bottom:2px solid var(--border);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.class-header h3{color:var(--primary);font-size:18px;font-weight:600;margin:0}.class-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 4px #667eea4d;font-size:13px;padding:6px 12px}.class-info{margin-bottom:16px}.class-info p{color:var(--text-secondary);font-size:14px;margin:8px 0}.students-list h4{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 12px}.student-items{display:flex;flex-direction:column;gap:8px}.student-item{align-items:center;background:var(--background);border:1px solid var(--border);border-radius:8px;display:flex;justify-content:space-between;padding:10px 12px;transition:all .2s}.student-item button{flex-shrink:0}.feedback-action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:6px 15px;transition:all .2s;white-space:nowrap}.feedback-btn-add{background:#3b82f6;color:#fff}.feedback-btn-add:hover{background:#2563eb}.feedback-btn-done{background:#10b981;color:#fff;cursor:default}.feedback-btn-done:disabled{opacity:1}.student-item:hover{background:#3b82f608;border-color:var(--primary)}.student-info{align-items:center;display:flex;gap:8px}.student-photo,.student-photo-placeholder{border-radius:50%;flex-shrink:0;height:50px;object-fit:cover;width:50px}.student-photo-placeholder{align-items:center;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;font-size:20px;font-weight:600;justify-content:center}.student-info div{display:flex;flex-direction:column}.student-info strong{color:var(--text-primary);font-size:14px;font-weight:600}.student-id{font-size:12px}.no-students,.student-id{color:var(--text-secondary)}.no-students{font-size:14px;padding:16px}.feedback-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:28px}.feedback-stats .stat-card{background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.feedback-stats .stat-card h3{align-items:center;color:var(--text-primary);display:flex;font-size:16px;font-weight:600;gap:8px;margin:0 0 16px}.feedback-stats .stat-card h3 svg{font-size:20px}.stat-breakdown{display:flex;flex-direction:column;gap:10px}.stat-item{align-items:center;background:#3b82f608;border-radius:8px;display:flex;justify-content:space-between;padding:8px 12px;transition:all .2s}.stat-item:hover{background:#3b82f614;transform:translateX(4px)}.stat-label{align-items:center;display:flex;font-size:14px;font-weight:500;gap:6px}.stat-label svg,.stat-value{font-size:16px}.stat-value{color:var(--primary)}.feedback-table-container{background:var(--background-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.feedback-table{border-collapse:collapse;width:100%}.feedback-table thead{background:#3b82f60d}.feedback-table th{border-bottom:2px solid var(--border);color:var(--text-primary);font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.feedback-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:14px;padding:14px 16px}.feedback-table tbody tr:hover{background:#3b82f605}.student-cell{display:flex;flex-direction:column}.student-cell strong{color:var(--text-primary);font-weight:600}.student-id-small{color:var(--text-secondary);font-size:12px}.status-badge{font-size:12px;padding:4px 10px;text-transform:capitalize}.score-badge{border-radius:12px;display:inline-block;font-size:13px;font-weight:700;padding:6px 12px}.score-excellent{background:#10b98126;color:#059669}.score-good{background:#3b82f626;color:#2563eb}.score-fair{background:#f59e0b26;color:#d97706}.score-poor{background:#ef444426;color:#dc2626}.status-completed,.status-excellent{background:#10b9811a;color:#10b981}.status-incomplete{background:#ef44441a;color:#ef4444}.status-not-assigned{background:#6b72801a;color:#6b7280}.status-active,.status-good{background:#3b82f61a;color:#3b82f6}.status-moderate,.status-satisfactory{background:#f59e0b1a;color:#f59e0b}.status-needs-improvement,.status-passive{background:#ef44441a;color:#ef4444}.status-absent{background:#0000001a;color:#000}.notes-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exam-day-row{background-color:#3b82f60d}.exam-badge{background:linear-gradient(135deg,#3b82f6,#2563eb)!important;box-shadow:0 2px 4px #2563eb4d;color:#fff!important;font-weight:800!important}.exam-label{color:var(--primary);font-weight:700;margin-right:4px}.exam-toggle-container{background:#3b82f614;border:1px solid #3b82f633;border-radius:10px;margin-bottom:20px!important;padding:12px 16px}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;gap:10px;margin-bottom:0!important}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-text{color:var(--primary);font-size:15px;font-weight:700}.exam-score-input{background:#10b9810d;border:2px dashed #10b981;border-radius:12px;margin-bottom:24px;padding:20px}.exam-range{background:linear-gradient(90deg,#ef4444 0,#f59e0b 50%,#10b981)!important}.modal-overlay{padding:20px}.modal-content{background:var(--background-card);border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%}.modal-header{padding:24px 28px}.modal-header h2{color:var(--text-primary);font-size:20px;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;transition:all .2s;width:32px}.close-btn:hover{background:#ef44441a;color:#ef4444}.modal-body{padding:28px}.feedback-info{background:#3b82f60d;border-left:4px solid var(--primary);border-radius:8px;margin-bottom:24px;padding:16px}.feedback-info p{color:var(--text-secondary);font-size:14px;margin:6px 0}.feedback-info strong{color:var(--text-primary);font-weight:600}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:20px}.form-group label{font-size:14px}.form-range,.form-select,.form-textarea{background:var(--background);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;padding:12px 14px;transition:all .2s;width:100%}.form-range{-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,#ef4444 0,#f59e0b 50%,#10b981);border-radius:4px;height:8px;outline:none;padding:0}.form-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--primary);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0003;cursor:pointer;height:20px;width:20px}.form-range::-moz-range-thumb{background:var(--primary);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0003;cursor:pointer;height:20px;width:20px}.range-labels{color:var(--text-secondary);display:flex;font-size:12px;justify-content:space-between;margin-top:4px;padding:0 2px}.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-textarea{min-height:80px;resize:vertical}.modal-footer{gap:12px;padding-top:20px}.alert{padding:14px 16px}.alert-error{background:#ef44441a;border-color:#ef44444d;color:#dc2626}.alert-success{background:#10b9811a;border-color:#10b9814d;color:#059669}.alert-info{background:#3b82f61a;border-color:#3b82f64d;color:#2563eb}.btn{border-radius:8px;transition:all .2s}.btn-sm{border-radius:6px!important;font-size:11px!important;gap:4px!important;padding:4px 8px!important}.btn-primary{background:var(--primary)}.btn-primary:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-secondary{background:var(--text-secondary)}.btn-secondary:hover{background:#4b5563}.btn-success{background:#10b981;color:#fff;cursor:default}.btn-success:hover{transform:none}.btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.classes-grid{gap:16px;grid-template-columns:1fr;padding:0 8px}.class-card{margin:0;max-width:100%;padding:16px;width:100%}.form-grid{grid-template-columns:1fr}.feedback-table-container{overflow-x:auto}.feedback-table{min-width:800px}}@media (max-width:480px){.classes-grid{gap:12px;grid-template-columns:1fr;padding:0}.class-card{box-sizing:border-box;margin:0 12px;max-width:100%;padding:16px;width:calc(100% - 24px)}.class-header{align-items:flex-start;flex-direction:column;gap:8px}.class-badge{align-self:flex-start}}.modal-overlay{z-index:9999!important}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;padding:24px;position:relative;width:90%;z-index:10000!important}.modal h2{color:#333;margin-bottom:20px;margin-top:0}.info-card{background:#f8f9fa;border-radius:4px;margin-bottom:20px;padding:16px}.info-row{display:flex;flex-wrap:wrap;gap:16px}.info-item{flex:1 1;min-width:150px}.info-item label{color:#555;display:block;font-weight:600;margin-bottom:4px}.info-item span{color:#333;display:block}.expected-amount{color:#007bff;font-weight:700}.form-group{margin-bottom:20px}.form-group label{color:#555;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:16px;padding:10px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.payment-info{background:#e9f7fe;border:1px solid #bee5eb;border-radius:4px;font-size:14px;margin-bottom:15px;padding:12px}.payment-info strong{color:#0c5460}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn{border-radius:4px;font-size:16px;padding:10px 20px;transition:background-color .2s}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-primary{background:#007bff}.btn-primary:hover{background:#0069d9}.alert{padding:12px}.alert-error{background:#f8d7da}.alert-success{background:#d4edda}:root{--bg-page:#f5f7fb;--bg-card:#fff;--border-soft:#e6e9f0;--text-main:#1f2937;--text-muted:#6b7280;--primary:#2563eb;--primary-hover:#1d4ed8;--success:#16a34a;--success-soft:#dcfce7;--danger:#dc2626;--danger-soft:#fee2e2;--shadow-sm:0 2px 6px #0000000d;--shadow-md:0 6px 18px #00000014;--radius-sm:6px;--radius-md:10px;--radius-lg:14px}.payments-page-container{box-sizing:border-box;margin:0;max-width:100%;padding:0;width:100%}.payments-page-header{margin-bottom:30px}.payments-page-header-content{align-items:center;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between}.payments-page-title-section{flex:1 1;min-width:200px}.payments-page-title{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.payments-page-actions{display:flex;flex-wrap:wrap;gap:12px}.payments-page-actions .btn{border-radius:8px;cursor:pointer;font-weight:500;height:44px;padding:0 16px}.payments-loading-state{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:60px 20px;text-align:center}.payments-loading-state .students__spinner{margin:0 auto 20px}.payments-loading-text{color:var(--text-secondary);font-size:1.1rem;margin:0}.payments-error-state{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:40px;text-align:center}.payments-error-state .btn{border-radius:8px;cursor:pointer;font-weight:500;height:44px;margin-top:20px;padding:0 16px}.payments-container{background:#f5f7fb;background:var(--bg-page);margin-top:1.5rem;padding-bottom:2rem}.payments-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.payments-header h1{color:#1f2937;color:var(--text-main);font-size:1.6rem;font-weight:700;margin:0}.payments-header .btn{background:#2563eb;background:var(--primary);border:none;border-radius:6px;border-radius:var(--radius-sm);font-weight:600;padding:8px 16px}.payments-header .btn:hover{background:#1d4ed8;background:var(--primary-hover)}.payments-filter-container{background:#fff;background:var(--bg-card);border:1px solid #e6e9f0;border:1px solid var(--border-soft);border-radius:12px;box-shadow:0 2px 6px #0000000d;box-shadow:var(--shadow-sm);margin-bottom:24px;padding:20px}.payments-filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.payments-filter-field{display:flex;flex:1 1 200px;flex-direction:column;gap:6px;min-width:180px}.payments-filter-search{flex:1 1 400px;min-width:250px}.payments-filter-month,.payments-filter-reset-container,.payments-filter-year{flex:0 0 120px;min-width:120px}.payments-filter-label{color:#6b7280;color:var(--text-muted);font-size:.85rem;font-weight:500}.payments-filter-input,.payments-filter-select{background:#fff;background:var(--bg-card);border:1px solid #e6e9f0;border:1px solid var(--border-soft);border-radius:8px;box-sizing:border-box;font-size:14px;height:44px;padding:0 12px;transition:border .2s ease,box-shadow .2s ease;width:100%}.payments-filter-input:focus,.payments-filter-select:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f;outline:none}.payments-filter-reset{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;height:44px;padding:0 20px;transition:background .2s ease,transform .15s ease}.payments-filter-reset:hover{background:#1d4ed8;transform:translateY(-1px)}.payments-filter-reset:active{transform:scale(.97)}@media (max-width:768px){.payments-filter-row{align-items:stretch;flex-direction:column}.payments-filter-field{max-width:100%;width:100%}.payments-filter-reset{width:100%}}.payments-table-card{background:#fff;background:var(--bg-card);border:1px solid #e6e9f0;border:1px solid var(--border-soft);border-radius:16px;box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-md);overflow:hidden}.payments-table-wrapper{overflow-x:auto}.payments-table{border-collapse:collapse;width:100%}.payments-table thead{background:#3b82f60d}.payments-table th{border-bottom:2px solid #e6e9f0;border-bottom:2px solid var(--border-soft);color:var(--text-primary);font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.payments-table td{border-bottom:1px solid #e6e9f0;border-bottom:1px solid var(--border-soft);color:#1f2937;color:var(--text-main);font-size:.9rem;padding:14px 16px;vertical-align:middle}.payments-table tbody tr{transition:background .2s ease}.payments-table tbody tr:hover{background:#3b82f605}.payments-table tbody tr:last-child td{border-bottom:none}.payments-table td.student-id{color:#374151;font-weight:700}.payments-table td.student-name{font-weight:600}.payments-table td.text-center{font-weight:600;text-align:center}.no-students{color:#6b7280;color:var(--text-muted);padding:48px;text-align:center}.paid-row td.text-center{color:#16a34a;color:var(--success)}.unpaid-row td.text-center{color:#dc2626;color:var(--danger)}.course-pills-container{display:flex;flex-wrap:wrap;gap:8px}.course-pill{align-items:center;border:none;border-radius:8px;box-shadow:0 2px 6px #0000000d;box-shadow:var(--shadow-sm);cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:6px;height:44px;padding:0 16px;transition:all .2s ease}.course-pill.unpaid{background:#fee2e2;background:var(--danger-soft);color:#dc2626;color:var(--danger)}.course-pill.paid{background:#dcfce7;background:var(--success-soft);color:#16a34a;color:var(--success)}.course-pill:hover{box-shadow:0 6px 18px #00000014;box-shadow:var(--shadow-md);transform:translateY(-1px)}.course-pill .subject-name{font-weight:700}.course-pill .status-label{font-size:.75rem;opacity:.8}.alert{border-radius:6px;border-radius:var(--radius-sm)}.alert-success{background:var(--success-soft);color:var(--success)}.alert-danger{background:var(--danger-soft);color:var(--danger)}.alert-info{background:#e0f2fe;border:1px solid #bae6fd;color:#0369a1}.settings-container{padding:20px}.settings-card,.settings-header{margin-bottom:20px}.settings-card{border:1px solid #dee2e6;border-radius:5px}.settings-card-header{background-color:#f8f9fa;border-bottom:1px solid #dee2e6;padding:15px 20px}.settings-card-body{padding:20px}.staff-table{border-collapse:collapse;margin-bottom:10px;margin-top:30px;width:100%}.staff-table td,.staff-table th{border:1px solid #dee2e6;padding:10px 12px;text-align:left;vertical-align:middle}.staff-table td:last-child{border-bottom:1px solid #dee2e6}.staff-table td.action-buttons{display:table-cell;vertical-align:middle}.staff-table td.action-buttons button{margin-right:6px}.staff-table th{background-color:#e9ecef;font-weight:700;white-space:nowrap}.staff-table td:first-child,.staff-table th:first-child{text-align:center;width:60px}.staff-table td:nth-child(2),.staff-table th:nth-child(2){width:18%}.staff-table td:nth-child(3),.staff-table th:nth-child(3){width:22%}.staff-table td:nth-child(4),.staff-table th:nth-child(4){width:12%}.staff-table td:nth-child(5),.staff-table th:nth-child(5){width:18%}.staff-table td:last-child,.staff-table th:last-child{white-space:nowrap;width:auto}.permission-toggle{align-items:center;display:flex}.permission-toggle input[type=checkbox]{margin-right:8px}.role-badge{border-radius:15px;font-size:12px;font-weight:700;padding:5px 10px;text-transform:capitalize}.role-admin{background-color:#dc3545;color:#fff}.role-teacher{background-color:#007bff;color:#fff}.role-sales{background-color:#28a745;color:#fff}.role-manager{background-color:#ffc107;color:#000}.role-founder{background-color:#6f42c1;color:#fff}.btn-warning{background-color:#ff9800;border:1px solid #ff9800;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:6px 12px;transition:all .3s ease}.btn-warning:hover{background-color:#f57c00;border-color:#f57c00;box-shadow:0 2px 4px #ff98004d;transform:translateY(-1px)}.btn-warning:active{box-shadow:none;transform:translateY(0)}.modal-content{position:relative}.checkbox-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.checkbox-item{align-items:center;display:flex}.checkbox-item input[type=checkbox]{margin-right:8px}.permission-section{background-color:#f8f9fa;border-radius:5px;margin-bottom:20px;padding:15px}.permission-section h4{margin-bottom:15px;margin-top:0}.attendance-container{padding:20px}.attendance-header,.filters-section{margin-bottom:20px}.filters-section{background:#f8f9fa;border-radius:5px;padding:20px}.filter-row{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.filter-group{flex:1 1;min-width:200px}.filter-label{display:block;font-weight:500;margin-bottom:5px}.filter-input,.filter-select{border:1px solid #ced4da;border-radius:4px;padding:8px 12px;width:100%}.attendance-table{background:#fff;border-radius:5px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.attendance-table td,.attendance-table th{border-bottom:1px solid #dee2e6;padding:12px 15px}.attendance-table th{background-color:#e9ecef;font-weight:600}.attendance-table tr:hover{background-color:#f8f9fa}.status-present{background-color:#d4edda;color:#155724}.status-absent,.status-present{border-radius:15px;font-size:.8rem;font-weight:700;padding:5px 10px}.status-absent{background-color:#f8d7da;color:#721c24}.status-late{background-color:#fff3cd;border-radius:15px;color:#856404;font-size:.8rem;font-weight:700;padding:5px 10px}.student-attendance-container{padding:20px}.student-attendance-header{margin-bottom:20px}.student-attendance-table{border-collapse:collapse;margin-top:15px;width:100%}.student-attendance-table td,.student-attendance-table th{border:1px solid #dee2e6;padding:12px;text-align:left}.student-attendance-table th{background-color:#e9ecef;font-weight:700}.staff-earnings__container{margin:0 auto;max-width:1400px;padding:24px}.staff-earnings__header{margin-bottom:32px}.staff-earnings__title{color:#1a1a1a;font-size:32px;font-weight:700;margin:0 0 8px}.staff-earnings__subtitle{color:#666;font-size:16px;margin:0}.staff-earnings__loading{color:#666;font-size:18px;padding:48px;text-align:center}.staff-earnings__summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.staff-earnings__summary-card{background:#fff;border-left:4px solid #ddd;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px;transition:transform .2s,box-shadow .2s}.staff-earnings__summary-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.staff-earnings__summary-card--primary{border-left-color:#007bff}.staff-earnings__summary-card--success{border-left-color:#28a745}.staff-earnings__summary-card--warning{border-left-color:orange}.staff-earnings__summary-card--info{border-left-color:#17a2b8}.staff-earnings__summary-label{color:#666;font-size:14px;font-weight:500;margin-bottom:8px}.staff-earnings__summary-value{color:#1a1a1a;font-size:28px;font-weight:700;margin-bottom:4px}.staff-earnings__summary-note{color:#999;font-size:12px}.staff-earnings__filters{align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.staff-earnings__filter-group{display:flex;flex-direction:column;gap:8px}.staff-earnings__filter-group label{color:#555;font-size:14px;font-weight:500}.staff-earnings__filter-input,.staff-earnings__filter-select{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;min-width:150px;padding:10px 14px;transition:border-color .2s}.staff-earnings__filter-input:focus,.staff-earnings__filter-select:focus{border-color:#007bff;outline:none}.staff-earnings__filter-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .2s}.staff-earnings__filter-btn:hover{background:#0056b3}.staff-earnings__table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px;overflow:hidden}.staff-earnings__table{border-collapse:collapse;width:100%}.staff-earnings__table thead{background:#f8f9fa}.staff-earnings__table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:14px;font-weight:600;padding:16px;text-align:left}.staff-earnings__table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;padding:16px}.staff-earnings__table tbody tr:hover{background:#f8f9fa}.staff-earnings__table tbody tr:last-child td{border-bottom:none}.staff-earnings__status-badge{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.staff-earnings__type{align-items:center;background:#f0f0f0;border-radius:8px;color:#555;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:4px 10px}.staff-earnings__amount--positive{color:#28a745;font-weight:600}.staff-earnings__amount--negative{color:#dc3545;font-weight:600}.staff-earnings__pending-text{color:#999;font-style:italic}.staff-earnings__empty{color:#999;padding:64px 24px;text-align:center}.staff-earnings__empty p{font-size:18px;margin-bottom:8px}.staff-earnings__empty small{color:#bbb;font-size:14px}.staff-earnings__info-box{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:8px;margin-top:24px;padding:20px 24px}.staff-earnings__info-box h3{color:#1565c0;font-size:16px;font-weight:600;margin:0 0 12px}.staff-earnings__info-box ul{list-style:disc;margin:0;padding-left:20px}.staff-earnings__info-box li{color:#424242;font-size:14px;line-height:1.5;margin-bottom:8px}.staff-earnings__info-box li:last-child{margin-bottom:0}.staff-earnings__info-box strong{color:#1565c0;font-weight:600}@media (max-width:768px){.staff-earnings__container{padding:16px}.staff-earnings__summary{grid-template-columns:1fr}.staff-earnings__filters{align-items:stretch;flex-direction:column}.staff-earnings__filter-group,.staff-earnings__filter-input,.staff-earnings__filter-select{width:100%}.staff-earnings__table-container{overflow-x:auto}.staff-earnings__table{min-width:800px}}.scheduler-container{padding:20px}.filter-section{background-color:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:20px;padding:20px}.scheduler-filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-top:12px}.scheduler-filter-field{display:flex;flex:1 1 300px;flex-direction:column;gap:6px;min-width:250px}.scheduler-filter-field:last-child{flex:0 0 120px;min-width:120px}.scheduler-filter-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.scheduler-filter-select{background:var(--background-card);border:1px solid var(--border);border-radius:8px;box-sizing:border-box;font-size:14px;height:44px;padding:0 12px;transition:border .2s ease,box-shadow .2s ease;width:100%}.scheduler-filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f;outline:none}.scheduler-filter-reset{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;height:44px;padding:0 20px;transition:background .2s ease,transform .15s ease;width:100%}.scheduler-filter-reset:hover{background:#1d4ed8;transform:translateY(-1px)}.scheduler-filter-reset:active{transform:scale(.97)}.schedule-list-card{margin-bottom:20px}.schedule-table{border-collapse:collapse;width:100%}.schedule-table td,.schedule-table th{border:1px solid #dee2e6;padding:10px 12px;text-align:left;vertical-align:middle}.schedule-table td:last-child{border-bottom:1px solid #dee2e6}.schedule-table td.action-buttons{display:table-cell;vertical-align:middle}.schedule-table td.action-buttons button{margin-right:6px}.schedule-table th{background-color:#e9ecef;font-weight:700}.action-buttons button{margin-right:5px}.modal-overlay{background-color:#00000080}.modal-content{border-radius:8px;max-width:600px}.modal-header{border-bottom:1px solid #dee2e6;padding:15px 20px}.modal-title{font-size:18px;font-weight:700;margin:0}.modal-footer{border-top:1px solid #dee2e6}.form-group{margin-bottom:15px}.form-label{display:block;font-weight:500;margin-bottom:5px}.form-control{border-radius:4px;font-size:14px;padding:8px 12px}.days-checkbox-group{display:flex;flex-wrap:wrap;gap:10px}.loading-message{color:#6c757d;padding:20px;text-align:center}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:15px;padding:10px}.success-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724;margin-bottom:15px;padding:10px}.text-muted{color:#6c757d}.mt-2{margin-top:.5rem}.branches-container{margin:0 auto;max-width:1400px;padding:20px}.branches-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.branches-header h1{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.branches-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.branch-card{background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000d;transition:transform .2s ease,box-shadow .2s ease}.branch-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.branch-card.inactive{background:#f8f9fa;opacity:.6}.branch-card-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px}.branch-card-header h3{color:var(--text-primary);font-size:1.25rem;margin:0}.status-badge{border-radius:12px;font-size:.75rem;font-weight:600;padding:4px 12px;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.inactive{background:#fee2e2;color:#dc2626}.branch-card-body{padding:20px}.branch-card-body p{color:var(--text-secondary);font-size:.9rem;margin:8px 0}.branch-card-body strong{color:var(--text-primary)}.branch-card-actions{border-top:1px solid var(--border);display:flex;gap:8px;padding:15px 20px}.branch-card-actions button{border:1px solid #0000;border-radius:6px;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:8px 12px;transition:all .2s ease}.branch-card-actions .btn-primary{background:#2563eb;border-color:#2563eb;color:#fff}.branch-card-actions .btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8}.branch-card-actions .btn-warning{background:#f59e0b;border-color:#f59e0b;color:#fff}.branch-card-actions .btn-warning:hover{background:#d97706;border-color:#d97706}.branch-card-actions .btn-success{background:#10b981;border-color:#10b981;color:#fff}.branch-card-actions .btn-success:hover{background:#059669;border-color:#059669}.branch-card-actions .btn-danger{background:#ef4444;border-color:#ef4444;color:#fff}.branch-card-actions .btn-danger:hover{background:#dc2626;border-color:#dc2626}.loading{color:var(--text-secondary);font-size:1.1rem;padding:60px 20px;text-align:center}.alert{border-radius:8px;font-size:.9rem;padding:12px 16px}.alert-success{background:#dcfce7;border:1px solid #bbf7d0;color:#16a34a}.alert-danger{background:#fee2e2;border:1px solid #fecaca;color:#dc2626}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px}.modal-header h5{font-size:1.25rem;font-weight:600;margin:0}.modal-close-button{background:none;border:none;color:#6c757d;cursor:pointer;font-size:24px}.modal-body{padding:20px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.form-control{border:1px solid var(--border);border-radius:8px;box-sizing:border-box;font-size:.9rem;padding:10px 12px}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.modal-footer{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.notification-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.notification-modal-content{animation:modalAppear .3s ease-out;background-color:#fff;border-radius:16px;box-shadow:0 10px 25px #0003;max-width:400px;padding:32px;text-align:center;width:100%}@keyframes modalAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.notification-modal-icon{display:flex;justify-content:center;margin-bottom:20px}.notification-modal-title{color:#1f2937;font-size:24px;font-weight:700;margin-bottom:12px}.notification-modal-text{color:#4b5563;font-size:15px;line-height:1.5;margin-bottom:24px}.notification-modal-features{background-color:#f3f4f6;border-radius:12px;margin-bottom:28px;padding:16px;text-align:left}.feature-item{align-items:center;color:#374151;display:flex;font-size:14px;gap:10px;margin-bottom:8px}.feature-item:last-child{margin-bottom:0}.feature-check{color:#10b981;flex-shrink:0}.notification-modal-actions{display:flex;flex-direction:column;gap:10px}.btn-full{border-radius:8px;font-weight:600;padding:12px;width:100%}.btn-text{background:none;border:none;color:#6b7280;cursor:pointer}.btn-text:hover{color:#374151;text-decoration:underline}.notification-modal-error{color:#ef4444;font-size:13px;margin-bottom:16px}.student-dashboard{display:flex;flex-direction:column;gap:28px;padding:24px}.dashboard-welcome{background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:18px;color:#fff;padding:28px 32px}.welcome-title{font-size:28px;font-weight:700;margin:0 0 6px}.welcome-subtitle{font-size:14px;opacity:.9}.stats-grid{grid-gap:22px;display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.stat-card{align-items:stretch;background:#fff;border:1px solid #eef0f4;border-radius:18px;display:flex;gap:18px;min-height:200px;padding:22px;transition:transform .25s ease,box-shadow .25s ease}.stat-card:hover{box-shadow:0 14px 30px #00000014;transform:translateY(-4px)}.stat-icon{align-items:center;border-radius:14px;display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.sd-attendance-card .stat-icon{background:#10b98126;color:#10b981}.sd-exams-card .stat-icon{background:#3b82f626;color:#3b82f6}.sd-payments-card .stat-icon{background:#f59e0b26;color:#f59e0b}.stat-content{display:flex;flex:1 1;flex-direction:column;justify-content:space-between}.stat-title{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}.stat-value{color:#111827;font-size:34px;font-weight:700;margin:6px 0}.stat-details{display:flex;font-size:14px;gap:14px}.stat-detail-item.present{color:#10b981}.stat-detail-item.absent{color:#ef4444}.stat-description{color:#6b7280;font-size:14px;margin-bottom:12px}.stat-action-btn{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;font-size:14px;margin-top:auto;padding:8px 14px;transition:all .2s ease}.stat-action-btn:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.dashboard-alerts .alert{background:#fff7ed;border:1px solid #fed7aa;border-radius:14px;color:#9a3412;display:flex;gap:12px;padding:16px 18px}.alert-content{font-size:14px;line-height:1.6}.student-info-section{background:#fff;border:1px solid #eef0f4;border-radius:18px;padding:26px}.section-title{margin-bottom:20px}.info-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.info-item{display:flex;flex-direction:column;gap:6px}.info-label{color:#6b7280;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#111827;font-size:15px;font-weight:500}.status-badge{border-radius:999px;display:inline-block;font-size:13px;padding:6px 14px}.status-badge.active{background:#10b98126;color:#10b981}.charts-section,.subject-charts-section{display:flex;flex-direction:column;gap:26px}.chart-card,.subject-chart-card{background:#fff;border:1px solid #eef0f4;border-radius:18px;padding:26px;transition:transform .25s ease,box-shadow .25s ease}.chart-card:hover,.subject-chart-card:hover{box-shadow:0 14px 30px #00000014;transform:translateY(-4px)}.chart-title{font-size:20px;font-weight:600}.chart-subtitle{color:#6b7280;font-size:14px}.chart-container{height:350px;width:100%}.subject-charts-grid{grid-gap:22px;display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(480px,1fr))}.subject-chart-title{font-size:18px;margin-bottom:14px}@media (max-width:768px){.student-dashboard{padding:16px}.welcome-title{font-size:24px}.chart-container{height:300px}.subject-charts-grid{grid-template-columns:1fr}}@media (max-width:480px){.dashboard-welcome{padding:20px}.stat-value{font-size:28px}.chart-container{height:260px}}.section-title{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 20px}.no-data{color:var(--text-secondary);padding:60px 20px;text-align:center}.no-data svg{color:var(--border);margin-bottom:16px}.no-data p{color:var(--text-secondary);font-size:15px;margin:0}.attendance-stats,.payment-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-box{align-items:center;background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px var(--shadow);display:flex;gap:16px;padding:20px;transition:all .2s ease}.stat-box:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-2px)}.stat-box svg{flex-shrink:0}.stat-info{flex:1 1}.stat-number{color:var(--text-primary);font-size:28px;font-weight:700;line-height:1;margin-bottom:4px}.stat-label{color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.present-box svg{color:var(--success)}.absent-box svg{color:var(--danger)}.late-box svg{color:var(--warning)}.paid-box svg{color:var(--success)}.pending-box svg{color:var(--warning)}.overdue-box svg{color:var(--danger)}.percentage-box{align-items:center;flex-direction:column;text-align:center}.percentage-circle{align-items:center;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:50%;box-shadow:0 4px 12px #3b82f64d;color:#fff;display:flex;font-size:20px;font-weight:700;height:72px;justify-content:center;margin-bottom:8px;width:72px}.attendance-records{margin-top:30px}.records-list{grid-gap:12px;display:grid;gap:12px}.attendance-record-card{grid-gap:16px;align-items:center;background:var(--background-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px var(--shadow);display:grid;gap:16px;grid-template-columns:1fr auto;padding:20px;transition:all .2s ease}.attendance-record-card:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-1px)}.record-date{color:var(--text-primary);font-size:15px;font-weight:600;grid-column:1/-1}.record-subject{color:var(--text-secondary);font-size:14px}.record-status{border-radius:20px;font-size:13px;font-weight:600;letter-spacing:.3px;padding:6px 12px;text-align:center}.record-status.status-present{background:#10b98126;color:var(--success)}.record-status.status-absent{background:#ef444426;color:var(--danger)}.record-status.status-late{background:#f59e0b26;color:var(--warning)}.feedback-list{grid-gap:20px;display:grid;gap:20px}.feedback-card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:24px;transition:all .3s ease}.feedback-card:hover{box-shadow:0 6px 16px var(--shadow-hover);transform:translateY(-2px)}.feedback-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.feedback-subject{color:var(--text-primary);font-size:18px;font-weight:600}.feedback-date{color:var(--text-secondary);font-size:13px}.feedback-body{grid-gap:16px;display:grid;gap:16px}.feedback-comment,.feedback-performance{grid-gap:10px;display:grid;gap:10px}.feedback-comment .label,.feedback-performance .label{color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.rating{display:flex;gap:6px}.rating svg{color:var(--border);height:20px;width:20px}.rating svg.filled{color:var(--warning)}.feedback-comment p{color:var(--text-primary);font-size:15px;line-height:1.6;margin:0}.feedback-teacher{color:var(--primary);font-size:14px;font-style:italic;margin-top:12px;text-align:right}.exam-score-item{align-items:center;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;display:flex;grid-column:1/-1;justify-content:space-between;padding:12px}.exam-score-item .label{color:#0369a1;font-size:16px;font-weight:700}.exam-score-item .score-value{color:#0369a1;font-size:20px;font-weight:800}.tabs{border-bottom:2px solid var(--border);display:flex;gap:0;margin-bottom:24px}.tab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:15px;font-weight:600;margin-bottom:-2px;padding:14px 20px;transition:all .2s}.tab-btn:hover{background:#3b82f60d;color:var(--primary)}.tab-btn.active{border-bottom-color:var(--primary);color:var(--primary)}.exams-list,.results-list{grid-gap:20px;display:grid;gap:20px}.exam-card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);display:flex;gap:20px;padding:24px;transition:all .3s ease}.exam-card:hover{box-shadow:0 6px 16px var(--shadow-hover);transform:translateY(-2px)}.exam-icon{align-items:center;background:#3b82f61a;border-radius:12px;color:var(--primary);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.exam-details{flex:1 1}.exam-name{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 12px}.exam-info{grid-gap:6px;display:grid;gap:6px;margin-bottom:12px}.exam-info span{color:var(--text-secondary);font-size:14px}.exam-marks{color:var(--primary);font-size:14px;font-weight:600}.result-card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:24px;transition:all .3s ease}.result-card:hover{box-shadow:0 6px 16px var(--shadow-hover);transform:translateY(-2px)}.result-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.result-status{border-radius:20px;font-size:13px;font-weight:700;letter-spacing:.5px;padding:8px 16px}.result-status.pass{background:#10b98126;color:var(--success)}.result-status.fail{background:#ef444426;color:var(--danger)}.result-body{grid-gap:14px;display:grid;gap:14px}.result-item{display:flex;font-size:15px;justify-content:space-between}.result-item span{color:var(--text-secondary);font-weight:500}.result-item strong{color:var(--text-primary);font-weight:600}.grade{color:var(--primary)!important;font-size:18px!important;font-weight:700!important}.payment-cards{grid-gap:20px;display:grid;gap:20px}.payment-card{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);padding:24px;transition:all .3s ease}.payment-card:hover{box-shadow:0 6px 16px var(--shadow-hover);transform:translateY(-2px)}.payment-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.payment-type{color:var(--text-primary);font-size:16px;font-weight:600}.payment-status{border-radius:20px;font-size:13px;font-weight:600;letter-spacing:.3px;padding:6px 12px}.payment-status.status-paid{background:#10b98126;color:var(--success)}.payment-status.status-pending{background:#f59e0b26;color:var(--warning)}.payment-status.status-overdue{background:#ef444426;color:var(--danger)}.payment-amount{color:var(--primary);font-size:32px;font-weight:700;line-height:1;margin-bottom:16px}.payment-details{grid-gap:10px;display:grid;gap:10px}.payment-detail-item{display:flex;font-size:14px;justify-content:space-between}.payment-detail-item span{color:var(--text-secondary);font-weight:500}.payment-detail-item strong{color:var(--text-primary);font-weight:600}@media (max-width:768px){.attendance-stats,.payment-stats{gap:12px;grid-template-columns:repeat(2,1fr)}.exams-list,.feedback-list,.results-list{gap:16px}.tabs{gap:0}.tab-btn{font-size:14px;padding:12px 16px}.stat-box{padding:16px}.stat-number{font-size:24px}.exam-card,.feedback-card,.payment-card,.result-card{padding:20px}}@media (max-width:480px){.attendance-stats,.payment-stats{grid-template-columns:1fr}.stat-box{padding:14px}.percentage-circle{font-size:18px;height:64px;width:64px}.feedback-header,.payment-header{align-items:flex-start;flex-direction:column;gap:8px}.exam-card{flex-direction:column}.exam-icon{height:48px;width:48px}}.student-timetable-grid{grid-gap:20px;display:grid;gap:20px}.student-day-schedule{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.student-day-schedule h2{border-bottom:2px solid #e5e7eb;color:#2563eb;font-size:18px;font-weight:700;margin-bottom:15px;padding-bottom:10px}.student-day-classes{grid-gap:12px;display:grid;gap:12px}.student-class-card{background:#f8fafc;border-left:4px solid #2563eb;border-radius:8px;padding:15px}.student-class-card-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:8px}.student-class-card-info h3{color:#1e293b;font-size:16px;font-weight:600;margin-bottom:4px}.student-class-card-info p{color:#64748b;font-size:13px;margin:0}.student-class-card-time{align-items:center;background:#e0f2fe;border-radius:6px;color:#0369a1;display:flex;font-size:14px;font-weight:600;gap:6px;padding:6px 12px;white-space:nowrap}.student-class-card-details{color:#64748b;display:flex;flex-wrap:wrap;font-size:13px;gap:15px;margin-top:10px}.student-class-card-details div span{font-weight:600}@media (max-width:768px){.student-timetable-grid{gap:16px}.student-day-schedule{padding:16px}.student-day-schedule h2{font-size:16px;margin-bottom:12px}.student-day-classes{gap:10px}.student-class-card{padding:12px}.student-class-card-header{align-items:flex-start;flex-direction:column;gap:8px}.student-class-card-info h3{font-size:15px}.student-class-card-info p{font-size:12px}.student-class-card-time{font-size:13px;padding:5px 10px}.student-class-card-details{flex-direction:column;font-size:12px;gap:6px;margin-top:8px}}@media (max-width:480px){.student-timetable-grid{gap:12px}.student-day-schedule{padding:14px}.student-day-schedule h2{font-size:15px;margin-bottom:10px;padding-bottom:8px}.student-day-classes{gap:8px}.student-class-card{padding:10px}.student-class-card-info h3{font-size:14px}.student-class-card-time{font-size:12px;padding:4px 8px}}.teacher-timetable-container{padding:20px}.teacher-selector-card{background-color:#fff;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 4px 15px #00000014;margin-bottom:25px;overflow:hidden}.teacher-selector-header{background-color:#f8fbff;border-bottom:1px solid #eef2f7;padding:15px 20px}.teacher-selector-header h3{align-items:center;color:#2c3e50;display:flex;font-size:1.1rem;gap:10px;margin:0}.teacher-selector-body{padding:20px}.teacher-filter-buttons{display:flex;flex-wrap:wrap;gap:10px}.teacher-filter-buttons .btn{border-radius:8px;font-size:14px;padding:8px 16px;transition:all .2s}.btn-primary{background-color:#2196f3;border-color:#2196f3;color:#fff}.btn-outline-primary{background:#fff;border-color:#2196f3;color:#2196f3}.btn-outline-primary:hover{background-color:#2196f3;color:#fff}.timetable-view{margin-top:20px}.weekly-timetable{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto;padding:20px}.timetable-grid{grid-gap:0;border:1px solid #e0e0e0;border-radius:8px;display:grid;gap:0;grid-template-columns:80px repeat(7,1fr);min-width:900px;overflow:hidden}.time-column{background:#f5f5f5;border-right:2px solid #e0e0e0}.day-header,.time-header{background:#2196f3;border-bottom:2px solid #1976d2;color:#fff;font-size:14px;font-weight:700;padding:12px;text-align:center}.time-slot{align-items:center;border-bottom:1px solid #e0e0e0;color:#666;display:flex;font-size:12px;justify-content:center;padding:8px;text-align:center}.day-column{border-right:1px solid #e0e0e0;position:relative}.day-column:last-child{border-right:none}.day-schedule{background:#fff;position:relative}.grid-line{border-bottom:1px solid #f0f0f0;left:0;pointer-events:none;position:absolute;right:0}.grid-line:nth-child(2n){background-color:#fafafa}.no-classes{color:#999;font-size:13px;font-style:italic;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.class-block{border-radius:4px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:12px;left:4px;overflow:hidden;padding:8px;position:absolute;right:4px;transition:transform .2s,box-shadow .2s}.class-block:hover{box-shadow:0 4px 8px #0000004d;transform:translateY(-2px);z-index:10}.class-name{font-size:13px;font-weight:700;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-time{font-size:11px;margin-bottom:2px;opacity:.9}.class-room{font-size:11px;opacity:.85}.timetable-table{border-collapse:collapse;margin-top:15px;width:100%}.timetable-table td,.timetable-table th{border:1px solid #dee2e6;padding:8px;text-align:left}.timetable-table th{background-color:#e9ecef;font-weight:700}.mobile-tablet-only{display:none}.desktop-only{display:block}.today-timetable{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.today-header{border-bottom:2px solid #e0e0e0;margin-bottom:24px;padding-bottom:16px;text-align:center}.today-header h3{color:#2196f3;font-size:24px;margin:0 0 8px}.today-date{color:#666;font-size:14px;margin:0}.no-classes-today{color:#999;padding:60px 20px;text-align:center}.no-classes-icon{font-size:64px;margin-bottom:16px}.no-classes-today h4{color:#666;font-size:20px;margin:0 0 8px}.no-classes-today p{font-size:14px;margin:0}.today-classes-list{display:flex;flex-direction:column;gap:16px}.class-card{background:#fff;border-left:4px solid #2196f3;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:16px;transition:transform .2s,box-shadow .2s}.class-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.class-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.class-subject{color:#333;font-size:18px;font-weight:700}.class-badge{border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.class-card-body{display:flex;flex-direction:column;gap:8px}.class-room-info,.class-time-info{align-items:center;color:#666;display:flex;font-size:14px;gap:8px}.room-icon,.time-icon{font-size:18px}@media (max-width:1024px){.desktop-only{display:none}.mobile-tablet-only{display:block}}@media (max-width:768px){.teacher-timetable-container,.today-timetable{padding:16px}.today-header h3{font-size:20px}.class-card{padding:12px}.class-subject{font-size:16px}.class-room-info,.class-time-info{font-size:13px}.timetable-grid{grid-template-columns:60px repeat(7,minmax(100px,1fr))}.day-header,.time-header{font-size:12px;padding:8px}.class-block{font-size:10px;padding:6px}}.attendance-table{border-collapse:collapse;margin-top:15px;width:100%}.attendance-table td,.attendance-table th{border:1px solid #ddd;padding:12px;text-align:left}.attendance-table th{background-color:#f5f5f5;font-weight:700}.status-btn{border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;padding:6px 12px;text-transform:capitalize}.status-btn:hover{background-color:#f9f9f9}.alert{border-radius:4px;font-size:14px;margin-bottom:20px;padding:12px 15px}.alert-success{border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.admin-earnings__container{margin:0 auto;max-width:1400px;padding:24px}.admin-earnings__header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:32px}.admin-earnings__title{color:#1a1a1a;font-size:32px;font-weight:700;margin:0 0 8px}.admin-earnings__subtitle{color:#666;font-size:16px;margin:0}.admin-earnings__actions{display:flex;flex-wrap:wrap;gap:12px}.admin-earnings__action-btn{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.admin-earnings__action-btn--bonus{background:#28a745}.admin-earnings__action-btn--bonus:hover{background:#218838}.admin-earnings__action-btn--penalty{background:#dc3545}.admin-earnings__action-btn--penalty:hover{background:#c82333}.admin-earnings__action-btn--adjustment{background:#ffc107;color:#000}.admin-earnings__action-btn--adjustment:hover{background:#e0a800}.admin-earnings__tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:8px;margin-bottom:24px}.admin-earnings__tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.admin-earnings__tab:hover{color:#007bff}.admin-earnings__tab--active{border-bottom-color:#007bff;color:#007bff}.admin-earnings__table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.admin-earnings__table{border-collapse:collapse;width:100%}.admin-earnings__table thead{background:#f8f9fa}.admin-earnings__table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:14px;font-weight:600;padding:16px;text-align:left}.admin-earnings__table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;padding:16px}.admin-earnings__table tbody tr:hover{background:#f8f9fa}.admin-earnings__amount{color:#28a745;font-weight:600}.admin-earnings__amount--negative{color:#dc3545}.admin-earnings__approve-btn{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background .2s}.admin-earnings__approve-btn:hover{background:#218838}.admin-earnings__status-badge{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.admin-earnings__empty,.admin-earnings__loading{color:#666;font-size:18px;padding:48px;text-align:center}.admin-earnings__access-denied{padding:64px 24px;text-align:center}.admin-earnings__access-denied h2{color:#dc3545;font-size:24px;margin-bottom:12px}.admin-earnings__modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.admin-earnings__modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:500px;width:100%}.admin-earnings__modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:24px}.admin-earnings__modal-header h2{font-size:20px;font-weight:700;margin:0}.admin-earnings__modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:32px;line-height:1;padding:0}.admin-earnings__modal-close:hover{color:#333}.admin-earnings__modal-body{padding:24px}.admin-earnings__form-group{margin-bottom:20px}.admin-earnings__form-group label{color:#555;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.admin-earnings__form-group input,.admin-earnings__form-group select,.admin-earnings__form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:10px 14px;transition:border-color .2s;width:100%}.admin-earnings__form-group input:focus,.admin-earnings__form-group select:focus,.admin-earnings__form-group textarea:focus{border-color:#007bff;outline:none}.admin-earnings__form-group small{color:#999;display:block;font-size:12px;margin-top:4px}.admin-earnings__modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.admin-earnings__btn-secondary{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.admin-earnings__btn-secondary:hover{background:#5a6268}.admin-earnings__btn-primary{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.admin-earnings__btn-primary:hover{background:#0056b3}@media (max-width:768px){.admin-earnings__container{padding:16px}.admin-earnings__header{flex-direction:column}.admin-earnings__actions{width:100%}.admin-earnings__action-btn{flex:1 1}.admin-earnings__table-container{overflow-x:auto}.admin-earnings__table{min-width:800px}}.payout-panel__container{margin:0 auto;max-width:1400px;padding:24px}.payout-panel__header{margin-bottom:32px}.payout-panel__title{color:#1a1a1a;font-size:32px;font-weight:700;margin:0 0 8px}.payout-panel__subtitle{color:#666;font-size:16px;margin:0}.payout-panel__tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:8px;margin-bottom:24px}.payout-panel__tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.payout-panel__tab:hover{color:#007bff}.payout-panel__tab--active{border-bottom-color:#007bff;color:#007bff}.payout-panel__card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:24px}.payout-panel__card h3{color:#1a1a1a;font-size:18px;font-weight:600;margin:0 0 16px}.payout-panel__card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.payout-panel__card-header h3{margin:0}.payout-panel__select{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;padding:12px 16px;transition:border-color .2s;width:100%}.payout-panel__select:focus{border-color:#007bff;outline:none}.payout-panel__form-group{margin-bottom:16px}.payout-panel__form-group:last-child{margin-bottom:0}.payout-panel__form-group label{color:#555;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.payout-panel__form-group input,.payout-panel__form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:10px 14px;transition:border-color .2s;width:100%}.payout-panel__form-group input:focus,.payout-panel__form-group textarea:focus{border-color:#007bff;outline:none}.payout-panel__bank-details{border-top:1px solid #e0e0e0;margin-top:16px;padding-top:16px}.payout-panel__select-all-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background .2s}.payout-panel__select-all-btn:hover{background:#0056b3}.payout-panel__earnings-list{border:1px solid #e0e0e0;border-radius:8px;max-height:400px;overflow-y:auto}.payout-panel__earning-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .2s}.payout-panel__earning-item:hover{background:#f8f9fa}.payout-panel__earning-item:last-child{border-bottom:none}.payout-panel__earning-item input[type=checkbox]{cursor:pointer;height:18px;width:18px}.payout-panel__earning-info{align-items:center;display:flex;flex:1 1;gap:12px}.payout-panel__earning-date{color:#666;font-size:13px;min-width:90px}.payout-panel__earning-type{background:#e3f2fd;border-radius:6px;color:#1976d2;font-size:13px;font-weight:500;padding:4px 10px}.payout-panel__earning-desc{color:#555;flex:1 1;font-size:13px}.payout-panel__earning-amount{color:#28a745;font-size:15px;font-weight:700;min-width:120px;text-align:right}.payout-panel__preview{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-top:20px;padding:24px}.payout-panel__preview h3{color:#fff;font-size:20px;margin:0 0 20px}.payout-panel__preview-row{align-items:center;border-bottom:1px solid #fff3;display:flex;justify-content:space-between;padding:12px 0}.payout-panel__preview-row:last-of-type{border-bottom:none;margin-bottom:20px}.payout-panel__preview-row span{font-size:15px;opacity:.9}.payout-panel__preview-row strong{font-size:16px;font-weight:600}.payout-panel__preview-amount{font-size:24px!important;font-weight:700!important}.payout-panel__submit-btn{background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-size:16px;font-weight:700;padding:14px;transition:all .2s;width:100%}.payout-panel__submit-btn:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.payout-panel__table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.payout-panel__table{border-collapse:collapse;width:100%}.payout-panel__table thead{background:#f8f9fa}.payout-panel__table th{border-bottom:2px solid #e0e0e0;color:#555;font-size:14px;font-weight:600;padding:16px;text-align:left}.payout-panel__table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;padding:16px}.payout-panel__table tbody tr:hover{background:#f8f9fa}.payout-panel__payout-id{color:#666;font-family:monospace;font-size:13px}.payout-panel__amount{color:#28a745;font-weight:700}.payout-panel__status-badge{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.payout-panel__action-btns{display:flex;gap:8px}.payout-panel__action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s;width:32px}.payout-panel__action-btn--complete{background:#28a745;color:#fff}.payout-panel__action-btn--complete:hover{background:#218838}.payout-panel__action-btn--cancel{background:#dc3545;color:#fff}.payout-panel__action-btn--cancel:hover{background:#c82333}.payout-panel__completed-text{color:#28a745;font-size:13px;font-weight:600}.payout-panel__cancelled-text{color:#6c757d;font-size:13px;font-style:italic}.payout-panel__empty,.payout-panel__loading{color:#666;font-size:16px;padding:48px;text-align:center}.payout-panel__access-denied{padding:64px 24px;text-align:center}.payout-panel__access-denied h2{color:#dc3545;font-size:24px;margin-bottom:12px}@media (max-width:768px){.payout-panel__container{padding:16px}.payout-panel__card-header{align-items:flex-start;flex-direction:column;gap:12px}.payout-panel__select-all-btn{width:100%}.payout-panel__earning-info{align-items:flex-start;flex-direction:column;gap:4px}.payout-panel__earning-amount{text-align:left}.payout-panel__table-container{overflow-x:auto}.payout-panel__table{min-width:800px}}.not-found{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:20px}.not-found h1{color:#dc3545;font-size:2.5rem;margin-bottom:1rem}.not-found p{color:#6c757d;font-size:1.2rem;text-align:center}.user-avatar{align-items:center;background-color:#f0f0f0;border-radius:50%;display:inline-flex;flex-shrink:0;justify-content:center;overflow:hidden;position:relative}.user-avatar .avatar-image{display:block;height:100%;object-fit:cover;width:100%}.user-avatar .person-icon{display:block}.user-avatar{transition:all .2s ease}.user-avatar:hover{transform:scale(1.05)}.navbar{background:linear-gradient(135deg,var(--charcoal) 0,#1a1d24 100%);box-shadow:0 4px 12px #00000026;color:#fff;height:80px;left:0;position:fixed;right:0;top:0;z-index:999}.navbar,.navbar-content{align-items:center;display:flex;padding:0}.navbar-content{justify-content:space-between;margin:0;max-width:100%;width:100%}.navbar-brand{align-items:center;color:#fff;display:flex;font-size:1.6rem;font-weight:700;gap:10px;letter-spacing:-.5px;padding-left:20px;text-decoration:none}.navbar-brand:hover{color:var(--lavender)}.navbar-right{align-items:center;display:flex;gap:24px;padding-right:10px}.user-dropdown{display:inline-block;position:relative}.user-info-dropdown{align-items:center;border-radius:12px;cursor:pointer;display:flex;gap:10px;padding:8px 12px;transition:all .2s ease}.user-info-dropdown:hover{background-color:#ffffff1a}.user-avatar,.user-avatar-placeholder{border:2px solid var(--lavender);border-radius:50%;height:36px;object-fit:cover;width:36px}.user-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);color:#fff;display:flex;font-size:16px;font-weight:600;justify-content:center}.user-name{color:#fff;font-size:1rem;font-weight:500;margin-right:5px}.dropdown-menu{animation:dropdownAppear .3s cubic-bezier(.23,1,.32,1);background:#fff;border:none;border-radius:16px;box-shadow:0 20px 60px #00000040;margin-top:12px;overflow:hidden;position:absolute;right:0;top:100%;width:260px;z-index:1000}@keyframes dropdownAppear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-user-info{align-items:center;background:linear-gradient(135deg,#0b69ff14,#6f42c10f);border-bottom:none;display:flex;flex-direction:column;gap:8px;padding:20px 18px;text-align:center}.dropdown-user-avatar,.dropdown-user-avatar-placeholder{border:3px solid var(--lavender);border-radius:50%;height:70px;margin-bottom:6px;margin-right:0;object-fit:cover;width:70px}.dropdown-user-avatar-placeholder{align-items:center;background:linear-gradient(135deg,var(--blue) 0,var(--indigo) 100%);color:#fff;display:flex;font-size:24px;font-weight:600;justify-content:center}.dropdown-user-details{flex:1 1}.dropdown-user-name{color:var(--text-primary);font-size:1rem;font-weight:700;margin-bottom:2px}.dropdown-user-id{color:var(--text-secondary);font-size:.8rem;margin-bottom:6px}.dropdown-user-role{background-color:#0b69ff1a;border-radius:16px;color:var(--primary);display:inline-block;font-size:.75rem;font-weight:500;margin-top:2px;padding:3px 10px;text-transform:capitalize}.dropdown-divider{background:linear-gradient(90deg,#0000,#00000014 50%,#0000);height:1px;margin:0}.dropdown-language-selector{display:flex;gap:6px;justify-content:center;padding:10px 12px}.dropdown-lang-btn{background:#0000;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s ease}.dropdown-lang-btn:hover{background:#f1f5f9;border-color:var(--primary);color:var(--primary)}.dropdown-lang-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.dropdown-logout-button{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;justify-content:center;margin:0 auto;padding:8px 20px;text-align:center;transition:all .2s;width:auto}.dropdown-logout-button:hover{background-color:#fee;border-radius:8px;color:#d32f2f}.branch-dropdown{display:inline-block;position:relative}.branch-selector-button{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.branch-selector-button:hover{background:#ffffff26;border-color:#ffffff4d}.branch-icon{font-size:1.2rem}.branch-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.branch-arrow{font-size:.7rem;opacity:.8}.branch-dropdown-menu{animation:dropdownAppear .3s cubic-bezier(.23,1,.32,1);background:#fff;border-radius:12px;box-shadow:0 20px 60px #00000040;margin-top:12px;max-height:400px;max-width:320px;min-width:280px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.branch-option{align-items:center;border-left:3px solid #0000;cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:all .2s ease}.branch-option:hover{background:#f8f9fa;border-left-color:var(--primary)}.branch-option.active{background:linear-gradient(90deg,#0b69ff1a,#6f42c10d);border-left-color:var(--primary)}.branch-option-icon{flex-shrink:0;font-size:1.5rem}.branch-option-name{color:var(--text-primary);font-size:.95rem;font-weight:600;margin-bottom:2px}.branch-option-desc{color:var(--text-secondary);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.branch-divider{background:linear-gradient(90deg,#0000,#00000014 50%,#0000);height:1px;margin:4px 0}.dropdown-staff-alert{background:linear-gradient(135deg,#10b9811a,#0596690d);border-radius:8px;margin:10px 10px 0;padding:12px}@media (max-width:768px){.navbar{height:65px;padding:0 16px}.navbar-brand{font-size:1.3rem}.user-name{font-size:.9rem}.dropdown-menu{width:280px}.dropdown-user-info{padding:20px}.dropdown-user-avatar,.dropdown-user-avatar-placeholder{height:56px;width:56px}.dropdown-user-name{font-size:1.1rem}}@media (max-width:480px){.navbar-content{padding:0 16px}.navbar-right{gap:16px}.user-info-dropdown{padding:6px 10px}.user-avatar,.user-avatar-placeholder{font-size:16px;height:32px;width:32px}.user-name{display:none}.dropdown-menu{right:10px;width:260px}}.sidebar{background:linear-gradient(135deg,var(--charcoal) 0,#1a1d24 100%);bottom:0;box-shadow:4px 0 15px #0000001a;box-sizing:border-box;color:#fff;left:0;overflow-y:auto;padding:24px 0;position:fixed;top:70px;transition:all .3s ease;width:270px;z-index:99}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-menu{list-style:none;margin:0;padding:0}.sidebar-menu li{margin-bottom:4px}.sidebar-menu li a{align-items:center;border-left:4px solid #0000;color:#ffffffb3;display:flex;font-size:15px;font-weight:500;gap:14px;padding:14px 24px;text-decoration:none;transition:all .2s ease}.sidebar-menu li a .icon{font-size:20px;text-align:center;width:24px}.sidebar-menu li a:hover{background-color:#ffffff14;color:#fff;padding-left:28px}.sidebar-menu li.active a{background-color:#0b69ff26;border-left:4px solid var(--blue);color:var(--lavender);font-weight:600}.sidebar-menu li a:hover .icon{color:var(--lavender)}.sidebar-divider{background:#ffffff1a;height:1px;margin:20px 24px}.sidebar-header{color:var(--lavender);font-size:14px;font-weight:600;letter-spacing:1px;padding:0 24px 16px;text-transform:uppercase}.sidebar-menu li.group-header{margin-bottom:8px}.group-toggle{align-items:center;background:none;border:none;border-left:4px solid #0000;color:#ffffffb3;cursor:pointer;display:flex;font-family:inherit;font-size:15px;font-weight:500;gap:14px;padding:14px 24px;text-decoration:none;transition:all .2s ease;width:100%}.group-toggle .icon{flex-shrink:0;font-size:20px;text-align:center;width:24px}.group-toggle .chevron{align-items:center;display:flex;font-size:12px;margin-left:auto;transition:transform .2s ease}.group-toggle .chevron.open{transform:rotate(90deg)}.group-toggle:hover{background-color:#ffffff14;color:#fff;padding-left:28px}.group-toggle:hover .icon{color:var(--lavender)}.group-menu{background-color:#0003;border-left:2px solid var(--blue);list-style:none;margin:0;padding:0}.group-menu li{margin:0}.group-menu li a{color:#fff9;font-size:14px;font-weight:400;padding:12px 24px 12px 48px}.group-menu li a:hover{background-color:#ffffff0f;color:#ffffffe6;padding-left:52px}.group-menu li.active a{background-color:#0b69ff1a;border-left:4px solid var(--blue);color:var(--lavender);font-weight:500}@media (max-width:1024px){.sidebar{top:75px;transform:translateX(-100%);transition:transform .3s ease;width:240px;z-index:100}.sidebar.open{box-shadow:4px 0 15px #0000004d;transform:translateX(0)}.sidebar-menu li a{font-size:14px;padding:12px 20px}.sidebar-menu li a:hover{padding-left:24px}}@media (max-width:480px){.sidebar{top:70px;width:220px}.sidebar-menu li a{font-size:13px;padding:10px 16px}.sidebar-menu li a .icon{font-size:18px;width:20px}}.admin-layout{display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100vw}.admin-layout__main{display:flex;flex:1 1;margin-top:55px}.admin-layout__content-area{background:linear-gradient(135deg,#f8fafc,#f1f5f9);box-sizing:border-box;flex:1 1;margin-left:290px;margin-right:30px;margin-top:70px;max-width:1600px;min-height:calc(100vh - 80px);overflow-x:hidden;width:calc(100% - 290px)}.admin-layout__content-area h1,.admin-layout__content-area h2,.admin-layout__content-area h3{color:var(--text-primary);font-weight:600}.admin-layout__content-area h1{font-size:28px;margin-bottom:24px}.admin-layout__content-area h2{font-size:24px;margin-bottom:20px}.admin-layout__content-area h3{font-size:20px;margin-bottom:16px}.admin-layout__page-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.admin-layout__page-title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0}.admin-layout__page-actions{display:flex;gap:12px}.admin-layout__content-area>*{box-sizing:border-box;max-width:100%;padding-right:15px}.admin-layout__menu-toggle{align-items:center;background:#2d3748;border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;cursor:pointer;display:none;flex-direction:column;gap:5px;height:44px;justify-content:center;left:20px;position:fixed;top:75px;transition:transform .3s ease,left .3s ease;width:44px;z-index:999}@media (max-width:1024px){.admin-layout__menu-toggle{display:flex!important}}.admin-layout__main:has(.sidebar.open) .admin-layout__menu-toggle{left:260px}.admin-layout__menu-toggle:hover{background:#1a202c;transform:scale(1.05)}.admin-layout__menu-toggle:active{transform:scale(.95)}.admin-layout__hamburger-line{background:#fff;border-radius:2px;height:2px;transition:all .3s ease;width:20px}.admin-layout__sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;left:0;opacity:0;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;z-index:98}.admin-layout__sidebar-overlay.show{opacity:1;pointer-events:all;visibility:visible}@media (max-width:1024px){.admin-layout__main{flex-direction:column}.admin-layout__content-area{margin-left:0;margin-top:75px;max-width:100%;padding:20px;width:100%}.admin-layout__page-header{align-items:flex-start;flex-direction:column;gap:16px}.admin-layout__page-actions{justify-content:stretch;width:100%}.admin-layout__page-actions .btn{flex:1 1}.admin-layout__page-title{font-size:24px}}@media (max-width:480px){.admin-layout__content-area{margin-top:70px;padding:16px;width:100%}.admin-layout__page-title{font-size:20px}}@media (min-width:1920px){.admin-layout__content-area{margin-left:auto;margin-right:auto;max-width:1600px}}.student-sidebar{background:linear-gradient(135deg,var(--charcoal) 0,#1a1d24 100%);bottom:0;box-shadow:4px 0 15px #0000001a;box-sizing:border-box;color:#fff;left:0;overflow-y:auto;padding:24px 0;position:fixed;top:70px;transition:all .3s ease;width:270px;z-index:99}.student-sidebar::-webkit-scrollbar{width:6px}.student-sidebar::-webkit-scrollbar-track{background:#ffffff0d}.student-sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.student-sidebar-nav{padding:0 20px}.student-menu{list-style:none;margin:0;padding:0}.student-menu-item{margin-bottom:4px}.student-menu-link{align-items:center;border-left:4px solid #0000;border-radius:8px;color:#ffffffb3;display:flex;font-size:15px;font-weight:500;gap:14px;padding:14px 20px;text-decoration:none;transition:all .2s ease}.student-menu-link:hover{background:#ffffff14;border-left-color:#ffffff4d;color:#fffffff2;padding-left:24px}.student-menu-link.active{background:#0b69ff26;border-left-color:var(--blue);color:var(--lavender);font-weight:600}.student-menu-link.active .student-menu-icon{color:var(--lavender)}.student-menu-icon{align-items:center;color:inherit;display:flex;justify-content:center;min-width:20px;transition:all .2s ease}.student-menu-label{flex:1 1}@media (max-width:1024px){.student-sidebar{top:70px;transform:translateX(-100%);transition:transform .3s ease;width:240px;z-index:100}.student-sidebar.open{box-shadow:4px 0 15px #0000004d;transform:translateX(0)}.student-menu-link{font-size:14px;padding:10px 14px}.student-menu-link:hover{padding-left:18px}}@media (max-width:480px){.student-sidebar{width:220px}.student-menu-link{font-size:13px;padding:9px 12px}.student-menu-icon{font-size:18px}}.student-layout{background:var(--background-light);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100vw}.student-layout__container{display:flex;flex:1 1;margin-top:55px}.student-layout__main-content{background:linear-gradient(135deg,#f8fafc,#f1f5f9);box-sizing:border-box;flex:1 1;margin:70px 50px 50px 310px;max-width:1600px;min-height:calc(100vh - 80px);overflow-x:hidden;position:relative;width:calc(100% - 290px)}.student-layout__content-wrapper,.student-layout__content-wrapper>*{box-sizing:border-box;max-width:100%}.student-layout__menu-toggle{align-items:center;background:#2d3748;border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;cursor:pointer;display:none;flex-direction:column;gap:5px;height:44px;justify-content:center;left:20px;position:fixed;top:75px;transition:transform .3s ease,left .3s ease;width:44px;z-index:999}@media (max-width:1024px){.student-layout__menu-toggle{display:flex!important}}.student-layout__container:has(.student-sidebar.open) .student-layout__menu-toggle{left:260px}.student-layout__menu-toggle:hover{background:#1a202c;transform:scale(1.05)}.student-layout__menu-toggle:active{transform:scale(.95)}.student-layout__hamburger-line{background:#fff;border-radius:2px;height:2px;transition:all .3s ease;width:20px}.student-layout__sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;left:0;opacity:0;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;z-index:98}.student-layout__sidebar-overlay.show{opacity:1;pointer-events:all;visibility:visible}.student-page{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);margin-bottom:24px;padding:24px;transition:all .3s ease}.student-page-header{border-bottom:1px solid var(--border);margin-bottom:30px;padding-bottom:20px}.student-page-title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 8px}.student-page-subtitle{color:var(--text-secondary);font-size:15px;font-weight:400;margin:0}@media (max-width:768px){.student-layout__container{flex-direction:column}.student-layout__main-content{margin-left:0;margin-right:0;margin-top:65px;max-width:100%;padding:20px;width:100%}.student-layout__content-wrapper{width:100%}.student-page{border-radius:12px;margin-bottom:16px;padding:18px}.student-page-title{font-size:22px}.student-page-subtitle{font-size:13px}}@media (max-width:480px){.student-layout__main-content{margin-top:60px;padding:12px}.student-page{margin-bottom:12px;padding:14px}.student-page-title{font-size:20px;margin-bottom:6px}.student-page-subtitle{font-size:12px}.student-layout__menu-toggle{height:40px;left:15px;top:70px;width:40px}.student-layout__hamburger-line{width:18px}}@media (min-width:1920px){.student-layout__main-content{margin-left:auto;margin-right:auto;max-width:1600px}}.parent-layout{background:var(--background-light);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100vw}.parent-layout__container{display:flex;flex:1 1;margin-top:55px}.parent-layout__main-content{background:linear-gradient(135deg,#f8fafc,#f1f5f9);box-sizing:border-box;flex:1 1;margin:70px 50px 50px 310px;max-width:1600px;min-height:calc(100vh - 80px);overflow-x:hidden;position:relative;width:calc(100% - 290px)}.parent-layout__content-wrapper,.parent-layout__content-wrapper>*{box-sizing:border-box;max-width:100%}.parent-layout__menu-toggle{align-items:center;background:var(--charcoal);border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;cursor:pointer;display:none;flex-direction:column;gap:5px;height:44px;justify-content:center;left:20px;position:fixed;top:20px;transition:all .3s ease;width:44px;z-index:99}.parent-layout__menu-toggle:hover{background:#2d3748;box-shadow:0 4px 12px #0003}.parent-layout__menu-toggle:active{transform:scale(.95)}.parent-layout__hamburger-line{background:#fff;border-radius:2px;height:2px;transition:all .3s ease;width:20px}.parent-layout__sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:99}.parent-layout__page{background:var(--background-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 12px var(--shadow);margin-bottom:24px;padding:24px;transition:all .3s ease}.parent-layout__page-header{border-bottom:1px solid var(--border);margin-bottom:30px;padding-bottom:20px}.parent-layout__page-title{color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 8px}.parent-layout__page-subtitle{color:var(--text-secondary);font-size:15px;font-weight:400;margin:0}@media (max-width:768px){.parent-layout__container{flex-direction:column}.parent-layout__main-content{margin-left:0;margin-right:0;margin-top:65px;max-width:100%;padding:20px;width:100%}.parent-layout__content-wrapper{width:100%}.parent-layout__menu-toggle{display:flex}.parent-layout__sidebar-overlay{display:block}.parent-layout__page{border-radius:12px;padding:20px}.parent-layout__page-title{font-size:24px}.parent-layout__page-subtitle{font-size:14px}}@media (max-width:480px){.parent-layout__main-content,.parent-layout__page{padding:16px}.parent-layout__page-title{font-size:22px}.parent-layout__page-subtitle{font-size:13px}}@media (min-width:1920px){.parent-layout__main-content{margin-left:auto;margin-right:auto;max-width:1600px}}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;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.d-flex{display:flex}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.align-center{align-items:center}.container{margin:0 auto;max-width:1200px;padding:0 15px;width:100%}.btn{--btn-height:40px;--btn-padding-x:18px;--round:0.75rem;align-items:center;border:none;border-radius:var(--round);color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;height:var(--btn-height);justify-content:center;letter-spacing:.05em;line-height:1;outline:none;overflow:hidden;padding:0 var(--btn-padding-x);position:relative;text-align:center;text-decoration:none;transition:all .3s ease}.btn:active{transform:scale(.95)}.btn-primary{background:radial-gradient(65.28% 65.28% at 50% 100%,#3b82f6cc 0,#3b82f600 100%),linear-gradient(0deg,#3b82f6,#3b82f6);box-shadow:0 4px 12px #3b82f64d}.btn-primary:hover{box-shadow:0 6px 20px #3b82f680;transform:translateY(-2px)}.btn-primary:active{box-shadow:inset 0 0 15px #0003}.btn-secondary{background:radial-gradient(65.28% 65.28% at 50% 100%,#6c757dcc 0,#6c757d00 100%),linear-gradient(0deg,#6c757d,#6c757d);box-shadow:0 4px 12px #6c757d4d}.btn-secondary:hover{box-shadow:0 6px 20px #6c757d80;transform:translateY(-2px)}.btn-secondary:active{box-shadow:inset 0 0 15px #0003}.btn-success{background:radial-gradient(65.28% 65.28% at 50% 100%,#10b981cc 0,#10b98100 100%),linear-gradient(0deg,#10b981,#10b981);box-shadow:0 4px 12px #10b9814d}.btn-success:hover{box-shadow:0 6px 20px #10b98180;transform:translateY(-2px)}.btn-success:active{box-shadow:inset 0 0 15px #0003}.btn-danger{background:radial-gradient(65.28% 65.28% at 50% 100%,#ef4444cc 0,#ef444400 100%),linear-gradient(0deg,#ef4444,#ef4444);box-shadow:0 4px 12px #ef44444d}.btn-danger:hover{box-shadow:0 6px 20px #ef444480;transform:translateY(-2px)}.btn-danger:active{box-shadow:inset 0 0 15px #0003}.btn-sm{--btn-height:32px;--btn-padding-x:14px;font-size:12px}.btn-lg{--btn-height:48px;--btn-padding-x:24px;font-size:16px}.form-group{margin-bottom:1rem}.form-control{background-clip:padding-box;border:1px solid #ced4da;border-radius:.25rem;display:block;font-size:1rem;line-height:1.5;padding:.375rem .75rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}.form-control,.form-control:focus{background-color:#fff;color:#495057}.form-control:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:0}.table{background-color:initial;margin-bottom:1rem;max-width:100%;width:100%}.table td,.table th{border-top:1px solid #dee2e6;padding:.75rem;vertical-align:top}.table thead th{border-bottom:2px solid #dee2e6;vertical-align:bottom}.table tbody+tbody{border-top:2px solid #dee2e6}.card{word-wrap:break-word;background-clip:initial;background-color:#fff;border:1px solid rgba(0,0,0,.125);border-radius:.25rem;display:flex;flex-direction:column;min-width:0;position:relative}.card-body{flex:1 1 auto;min-height:1px;padding:1.25rem}.spinner{animation:spin 2s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin:20px auto;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.alert{border:1px solid #0000;border-radius:.25rem;margin-bottom:1rem;padding:.75rem 1.25rem}.alert-success{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.alert-danger{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.alert-warning{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.alert-info{background-color:#d1ecf1;border-color:#bee5eb;color:#0c5460}@media (max-width:768px){.container{padding:0 10px}.d-flex{flex-direction:column}}
/*# sourceMappingURL=main.5a20a608.css.map*/