*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}#root{min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:400px}.login-card h1{text-align:center;color:#333;margin-bottom:30px;font-size:28px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;border-left:4px solid #c33}.layout{display:flex;min-height:100vh;background:#f5f5f5}.sidebar{width:300px;background:linear-gradient(180deg,#fff,#f8f9fa);border-right:2px solid #e9ecef;padding:0;display:flex;flex-direction:column;box-shadow:2px 0 12px #0000000a}.sidebar-header{padding:32px 24px 24px;border-bottom:2px solid #e9ecef}.logo-section{display:flex;align-items:center;gap:16px}.logo-icon-desktop{font-size:36px;line-height:1}.logo-title{font-size:22px;font-weight:700;color:#1a252f;margin:0;line-height:1.2}.user-section-desktop{margin-top:auto;padding:24px;border-top:2px solid #e9ecef;background:linear-gradient(180deg,#667eea08,#667eea14)}.user-card-desktop{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border-radius:14px;margin-bottom:16px;box-shadow:0 2px 8px #0000000f;border:2px solid #e9ecef}.user-avatar-desktop{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;box-shadow:0 4px 12px #667eea4d;flex-shrink:0}.user-info-desktop{flex:1;min-width:0}.user-name-desktop{display:block;font-size:16px;font-weight:700;color:#1a252f;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.logout-btn-desktop{width:100%;padding:14px 20px;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 12px #e74c3c33}.logout-btn-desktop:hover{transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c59}.logout-icon{font-size:20px}.main-content{flex:1;padding:40px;background:#f5f7fa;overflow-y:auto;overflow-x:hidden}.dashboard-header{margin-bottom:35px;padding:28px 32px;background:linear-gradient(135deg,#667eea14,#764ba214);border-radius:16px;border-left:5px solid #667eea;box-shadow:0 2px 12px #0000000a}.dashboard-header h1{font-size:36px;color:#1a252f;margin-bottom:10px;font-weight:700;display:flex;align-items:center;gap:12px}.dashboard-header p{color:#6c757d;font-size:16px;margin:0}.search-bar{margin-bottom:30px}.search-input{width:100%;max-width:500px;padding:14px 20px;border:2px solid #ddd;border-radius:12px;font-size:16px;transition:border-color .3s,box-shadow .3s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;margin-bottom:30px}@media (max-width: 768px){.student-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:15px}}.student-button{background:#fff;border:3px solid transparent;border-radius:16px;padding:20px;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #0000001a;text-align:center}.student-button:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.student-button.gray{border-color:#bbb;background:#f9f9f9}.student-button.blue{border-color:#3498db;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.student-button.green{border-color:#27ae60;background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.student-photo{width:80px;height:80px;border-radius:50%;margin:0 auto 12px;background:#ddd;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#666}.student-name{font-weight:600;font-size:16px;color:#333;margin-bottom:4px}.student-class{font-size:14px;color:#666}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #00000040}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{font-size:24px;color:#333}.modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:#999;line-height:1;padding:0;width:32px;height:32px}.modal-close:hover{color:#333}.modal-body{margin-bottom:20px}.student-info{text-align:center;margin-bottom:30px}.student-info .student-photo{width:100px;height:100px;font-size:40px}.student-info h3{margin-top:16px;font-size:22px;color:#333}.student-info p{color:#666;margin-top:4px}.payment-options{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.payment-option{padding:20px;border:2px solid #ddd;border-radius:12px;cursor:pointer;transition:all .3s;text-align:center}.payment-option:hover{border-color:#667eea;background:#f8f9ff}.payment-option.selected{border-color:#667eea;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.payment-option .type{font-weight:600;font-size:18px;color:#333;margin-bottom:4px}.payment-option .amount{font-size:16px;color:#667eea;font-weight:600}.custom-days-input{margin-top:12px}.custom-days-input label{display:block;margin-bottom:8px;color:#555;font-weight:500}.custom-days-input input{width:100%;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:16px}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.btn-success{width:100%;padding:14px;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;margin-top:12px;transition:transform .2s,box-shadow .2s}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #27ae604d}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:300px;gap:20px}.spinner{width:60px;height:60px;border:5px solid rgba(102,126,234,.1);border-top:5px solid #667eea;border-right:5px solid #764ba2;border-radius:50%;animation:spin 1s cubic-bezier(.68,-.55,.27,1.55) infinite;box-shadow:0 4px 12px #667eea33}.loading-container:after{content:"Loading...";font-size:16px;font-weight:600;color:#6c757d;animation:pulse 1.5s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;background:#fff;padding:8px;border-radius:14px;box-shadow:0 2px 12px #0000000f}.tab{padding:14px 24px;background:transparent;border:none;border-radius:10px;cursor:pointer;font-size:15px;font-weight:600;color:#6c757d;transition:all .3s ease;white-space:nowrap;position:relative}.tab:hover{color:#495057;background:#667eea14;transform:translateY(-1px)}.tab.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}@media (max-width: 768px){.tabs{gap:6px;padding:6px}.tab{padding:12px 16px;font-size:14px}}.modal-content{background:#fff;border-radius:16px;padding:30px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.table-container:not(.contacts-section .table-container){background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;overflow-x:auto;margin-bottom:24px;border:1px solid rgba(102,126,234,.1)}table{width:100%;border-collapse:collapse}th{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:18px 16px;text-align:left;font-weight:700;font-size:13px;color:#495057;border-bottom:2px solid #dee2e6;text-transform:uppercase;letter-spacing:.5px}td{padding:16px;border-bottom:1px solid #f0f2f5;color:#495057;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover{background:linear-gradient(90deg,#667eea0a,#fff0);transition:background .2s ease}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;padding:32px;border-radius:16px;box-shadow:0 4px 20px #00000014;transition:all .4s ease;border:2px solid transparent;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.stat-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #00000026;border-color:#667eea33}.stat-card:hover:before{transform:scaleX(1)}.stat-card h3{font-size:12px;color:#6c757d;margin-bottom:16px;text-transform:uppercase;letter-spacing:1px;font-weight:700}.stat-card .value{font-size:42px;font-weight:800;color:#1a252f;margin-bottom:8px;line-height:1}.stat-card p{font-size:14px;color:#6c757d;margin:0}.stat-card.primary .value{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card.success .value{background:linear-gradient(135deg,#27ae60,#2ecc71);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card.warning .value{background:linear-gradient(135deg,#f39c12,#f1c40f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card.danger .value{background:linear-gradient(135deg,#e74c3c,#c0392b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contacts-container{display:flex;flex-direction:column;gap:30px}.action-buttons-section{display:flex;gap:16px;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:10px;padding:14px 28px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #00000014}.action-btn .btn-icon{font-size:20px}.add-student-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.add-student-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #667eea66}.add-teacher-btn{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.add-teacher-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #f093fb66}.form-container{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 16px #00000014;border-left:4px solid #667eea}.contacts-section{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 16px #00000014}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid #f0f2f5}.section-title h2{font-size:24px;color:#1a252f;margin:0 0 6px;font-weight:700}.section-subtitle{color:#6c757d;font-size:14px;margin:0}.export-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #27ae6033}.export-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #27ae604d}.attendance-legend{display:flex;gap:24px;padding:16px 20px;background:#f8f9fa;border-radius:12px;margin-bottom:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:#495057}.legend-color{width:24px;height:24px;border-radius:6px;box-shadow:0 2px 4px #0000001a}.legend-color.present{background:linear-gradient(135deg,#27ae60,#2ecc71)}.legend-color.not-marked{background:linear-gradient(135deg,#f39c12,#f1c40f)}.legend-color.absent{background:linear-gradient(135deg,#e74c3c,#c0392b)}.search-actions-wrapper{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.search-box{flex:1;min-width:300px;position:relative}.search-input-field{width:100%;padding:14px 45px 14px 16px;border:2px solid #e0e0e0;border-radius:12px;font-size:16px;transition:all .3s ease;background:#fff}.search-input-field:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.clear-search-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#e0e0e0;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:#666;transition:all .2s ease}.clear-search-btn:hover{background:#c0392b;color:#fff}.sms-actions{display:flex;gap:12px;flex-wrap:wrap}.sms-btn{display:flex;align-items:center;gap:8px;padding:14px 24px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #0000001a}.sms-btn span{font-size:18px}.sms-btn.sms-all{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.sms-btn.sms-all:hover{transform:translateY(-2px);box-shadow:0 6px 16px #27ae604d}.sms-btn.sms-absent{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.sms-btn.sms-absent:hover{transform:translateY(-2px);box-shadow:0 6px 16px #e74c3c4d}.row-present{background:linear-gradient(90deg,#e8f5e9,#fff)!important}.row-absent{background:linear-gradient(90deg,#ffebee,#fff)!important}.row-not-marked{background:linear-gradient(90deg,#fff3e0,#fff)!important}.name-cell{font-weight:600;color:#1a252f}.phone-cell{font-family:Courier New,monospace;color:#495057}.status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;text-align:center;white-space:nowrap}.status-present{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:1px solid #c3e6cb}.status-absent{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:1px solid #f5c6cb}.status-not-marked{background:linear-gradient(135deg,#fff3cd,#ffeaa7);color:#856404;border:1px solid #ffeaa7}.action-buttons{display:flex;gap:10px;align-items:center}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:18px;cursor:pointer;transition:all .3s ease;text-decoration:none;box-shadow:0 2px 6px #0000001a}.icon-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #667eea4d}.empty-state{text-align:center;padding:60px 20px;color:#6c757d;font-size:16px}.empty-state p{margin:0}.table-container{background:#fff;border-radius:14px;padding:0;box-shadow:0 2px 12px #0000000f;overflow:hidden;margin-bottom:0}.table-container table{margin:0}.table-container thead{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.table-container th{padding:18px 16px;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:#495057;border-bottom:2px solid #dee2e6}.table-container td{padding:16px;border-bottom:1px solid #f0f2f5;vertical-align:middle}.table-container tr:last-child td{border-bottom:none}.table-container tr:hover{background:#667eea0a!important}.btn,.btn-primary{transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.btn:hover,.btn-primary:hover{box-shadow:0 6px 16px #00000026}.mobile-header{display:none;position:sticky;top:0;z-index:100;background:#fff;box-shadow:0 2px 12px #00000014}.mobile-header-content{display:flex;justify-content:space-between;align-items:center;padding:16px 20px}.mobile-logo{display:flex;align-items:center;gap:12px}.logo-icon{font-size:28px}.logo-text{font-size:18px;font-weight:700;color:#1a252f}.mobile-user-section{display:flex;align-items:center;gap:12px}.user-info-mobile{display:flex;align-items:center;gap:10px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;box-shadow:0 2px 8px #667eea4d}.user-details-mobile{display:flex;flex-direction:column;gap:2px}.user-name-mobile{font-size:14px;font-weight:700;color:#1a252f;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}.user-role-mobile{font-size:11px;color:#6c757d;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.mobile-menu-toggle{width:44px;height:44px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-dropdown{background:#fff;border-top:2px solid #f0f2f5;padding:20px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-user-card{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#667eea14,#764ba214);border-radius:14px;margin-bottom:16px}.user-avatar-large{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;box-shadow:0 4px 12px #667eea4d;flex-shrink:0}.user-info-card{flex:1}.user-info-card h3{font-size:18px;font-weight:700;color:#1a252f;margin:0 0 8px}.role-badge{display:inline-block;padding:6px 14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin:0}.mobile-logout-btn{width:100%;padding:16px;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 12px #e74c3c33}.mobile-logout-btn span{font-size:20px}.mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:99;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.mobile-header{display:block}.sidebar{display:none}.layout{flex-direction:column}.main-content{padding:20px 16px}.dashboard-header{padding:20px;margin-bottom:24px}.dashboard-header h1{font-size:26px;flex-direction:column;align-items:flex-start;gap:8px}.dashboard-header p{font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}.stat-card{padding:20px 16px}.stat-card .value{font-size:32px}.student-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.payment-options{grid-template-columns:1fr}.action-buttons-section{flex-direction:column}.action-btn{width:100%;justify-content:center}.section-header{flex-direction:column;gap:12px;align-items:stretch}.export-btn{width:100%;justify-content:center}.search-actions-wrapper{flex-direction:column}.search-box{min-width:100%}.sms-actions{flex-direction:column}.sms-btn{width:100%;justify-content:center}.attendance-legend{flex-direction:column;gap:12px}.table-container{overflow-x:auto;border-radius:12px}table{font-size:14px}th,td{padding:12px 8px}.modal{padding:24px 20px;max-width:95%}.login-card{padding:30px 24px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.user-details-mobile{display:none}}@media (max-width: 480px){.main-content{padding:16px 12px}.dashboard-header h1{font-size:22px}.stats-grid{grid-template-columns:1fr}.stat-card{padding:20px}.mobile-header-content{padding:12px 16px}.logo-text{font-size:16px}.user-avatar{width:36px;height:36px;font-size:16px}.mobile-menu-toggle{width:40px;height:40px;font-size:20px}.table-container{font-size:13px}th,td{padding:10px 6px}.status-badge{font-size:11px;padding:4px 10px}.icon-btn{width:32px;height:32px;font-size:16px}}
