.auth-wrapper{min-height:100vh;background-color:#f97316;display:flex;align-items:stretch}.auth-left{flex:1;background-color:#f97316;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 40px;position:relative;overflow:hidden;min-height:100vh}.auth-left:before{content:"";position:absolute;top:-80px;left:-80px;width:240px;height:240px;background:#ffffff14;border-radius:50%}.auth-left:after{content:"";position:absolute;bottom:-60px;right:-60px;width:200px;height:200px;background:#ffffff0f;border-radius:50%}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:40px;z-index:1}.auth-brand .brand-name{font-size:32px;font-weight:800;color:#fff;letter-spacing:-.5px;font-family:Poppins,sans-serif}.auth-brand .brand-icon{font-size:36px}.auth-tagline{text-align:center;color:#fff;z-index:1;max-width:380px}.auth-tagline h2{font-size:28px;font-weight:700;line-height:1.3;margin-bottom:16px;font-family:Poppins,sans-serif}.auth-tagline p{font-size:16px;opacity:.9;line-height:1.7;margin-bottom:32px}.auth-illustration{width:100%;max-width:360px;margin-top:32px;z-index:1}.auth-illustration img{width:100%;height:auto;filter:drop-shadow(0 10px 30px rgba(0,0,0,.2))}.auth-illustration-placeholder{width:320px;height:280px;background:#ffffff26;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px dashed rgba(255,255,255,.3)}.auth-illustration-placeholder .material-icons{font-size:80px;color:#ffffffb3}.auth-illustration-placeholder p{color:#ffffffb3;font-size:14px;text-align:center}.auth-right{width:480px;min-width:420px;background-color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;position:relative;box-shadow:-10px 0 40px #0000001a}.auth-right-inner{width:100%;max-width:380px}.auth-form-header{margin-bottom:32px}.auth-form-header h1{font-size:26px;font-weight:700;color:#2d3748;margin-bottom:8px;font-family:Poppins,sans-serif}.auth-form-header p{font-size:14px;color:#718096;line-height:1.6}.login-toggle{display:flex;background-color:#f7fafc;border-radius:10px;padding:4px;margin-bottom:28px;border:1px solid #e2e8f0}.login-toggle-btn{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:8px;font-size:13px;font-weight:500;color:#718096;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.login-toggle-btn.active{background-color:#f97316;color:#fff;box-shadow:0 2px 8px #0de1e866}.login-toggle-btn .material-icons{font-size:18px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:8px;letter-spacing:.3px}.input-wrapper{position:relative}.input-wrapper .form-control{padding:13px 16px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#2d3748;transition:all .2s ease;background-color:#fafafa;width:100%}.input-wrapper .form-control:focus{border-color:#f97316;box-shadow:0 0 0 3px #0de1e826;background-color:#fff;outline:none}.input-wrapper .form-control.has-icon{padding-right:48px}.input-wrapper .input-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#a0aec0;cursor:pointer;font-size:20px;transition:color .2s;-webkit-user-select:none;user-select:none}.input-wrapper .input-icon:hover{color:#f97316}.input-wrapper .input-icon-left{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#a0aec0;font-size:20px}.input-wrapper .form-control.has-left-icon{padding-left:44px}.password-hint{font-size:11px;color:#a0aec0;margin-top:6px;line-height:1.5}.forgot-password-link{font-size:13px;color:#f97316;font-weight:600;text-decoration:none;float:right;margin-bottom:24px;transition:color .2s}.forgot-password-link:hover{color:#ea6c0a;text-decoration:underline}.btn-auth-submit{width:100%;padding:14px;background-color:#f97316;border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;margin-top:8px;font-family:Poppins,sans-serif}.btn-auth-submit:hover{background-color:#ea6c0a;transform:translateY(-2px);box-shadow:0 6px 20px #0de1e873}.btn-auth-submit:active{transform:translateY(0)}.btn-auth-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:#718096;font-size:14px;font-weight:500;cursor:pointer;padding:0;margin-bottom:32px;transition:color .2s;text-decoration:none}.btn-back:hover{color:#f97316}.btn-back .material-icons{font-size:20px}.otp-container{display:flex;gap:16px;justify-content:center;margin:32px 0}.otp-input{width:68px;height:68px;border:2px solid #e2e8f0;border-radius:12px;text-align:center;font-size:24px;font-weight:700;color:#2d3748;background-color:#fafafa;transition:all .2s ease;outline:none}.otp-input:focus{border-color:#f97316;box-shadow:0 0 0 3px #0de1e833;background-color:#fff}.otp-input.filled{border-color:#f97316;background-color:#0de1e814}.otp-footer{text-align:center;margin-bottom:28px}.otp-resend{font-size:14px;color:#718096}.otp-resend a{color:#f97316;font-weight:600;cursor:pointer;text-decoration:none}.otp-resend a:hover{text-decoration:underline}.otp-timer{font-size:13px;color:#e53e3e;font-weight:600;margin-top:8px}.auth-footer{text-align:center;font-size:11px;color:#a0aec0;margin-top:auto;padding-top:32px;font-weight:500;letter-spacing:.3px}.auth-icon-box{width:80px;height:80px;background-color:#0de1e81a;border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 28px}.auth-icon-box .material-icons{font-size:40px;color:#f97316}.alert-error{background-color:#fff5f5;border:1px solid #fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.alert-success{background-color:#f0fff4;border:1px solid #9ae6b4;color:#276749;padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:20px;display:flex;align-items:center;gap:8px}@media (max-width: 900px){.auth-left{display:none}.auth-right{width:100%;min-width:unset;padding:40px 28px;box-shadow:none}}@media (max-width: 480px){.auth-right{padding:28px 20px}.auth-right-inner{max-width:100%}.otp-input{width:54px;height:54px;font-size:20px}}.app-layout{display:flex;min-height:100vh;background-color:#f8fafc}.sidebar{width:260px;min-width:260px;background:#0f172a;box-shadow:2px 0 12px #0003;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:1000;transition:all .3s ease;overflow-y:auto;overflow-x:hidden}.sidebar.collapsed{width:72px;min-width:72px}.sidebar-brand{padding:18px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.08);min-height:68px}.sidebar-brand .brand-logo{width:38px;height:38px;min-width:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;box-shadow:0 2px 6px #00000040}.sidebar-brand .brand-logo-img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;border-radius:10px;background:#fff}.sidebar-brand .brand-logo-initials{color:#fff;font-size:14px;font-weight:800;font-family:Poppins,sans-serif;letter-spacing:.5px;line-height:1;-webkit-user-select:none;user-select:none}.sidebar-brand .brand-text{overflow:hidden;min-width:0;flex:1;transition:opacity .3s ease,width .3s ease}.sidebar-brand .brand-name{font-size:14px;font-weight:800;color:#fff;font-family:Poppins,sans-serif;line-height:1.2;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-brand .brand-tagline{font-size:10px;color:#89a;font-weight:500;white-space:nowrap}.sidebar.collapsed .brand-text{opacity:0;width:0;flex:0}.sidebar-toggle{position:absolute;top:20px;right:-16px;width:32px;height:32px;background:#0de1e8;border:3px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;z-index:10;transition:all .2s;box-shadow:0 2px 8px #00000026}.sidebar-toggle:hover{background:#0eb5da;transform:scale(1.1)}.sidebar-toggle .material-icons{font-size:16px}.sidebar-nav{flex:1;padding:20px 12px;display:flex;flex-direction:column;gap:4px}.nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#a0aec0;padding:12px 12px 8px;overflow:hidden;white-space:nowrap}.sidebar.collapsed .nav-section-label{opacity:0}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;cursor:pointer;transition:all .2s ease;color:#89b;font-size:14px;font-weight:500;white-space:nowrap;text-decoration:none;position:relative}.nav-item:hover{background-color:#0de1e826;color:#0de1e8}.nav-item.active{background-color:#0de1e833;color:#0de1e8;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;background-color:#0de1e8;border-radius:0 3px 3px 0}.nav-item .material-icons{font-size:20px;flex-shrink:0;transition:color .2s}.nav-item .nav-label{transition:all .3s ease;overflow:hidden}.sidebar.collapsed .nav-item .nav-label{opacity:0;width:0}.nav-item .nav-badge{margin-left:auto;background-color:#0de1e8;color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;min-width:20px;text-align:center}.sidebar.collapsed .nav-badge{display:none}.sidebar.collapsed .nav-item:hover:after{content:attr(data-tooltip);position:absolute;left:72px;background:#2d3748;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:999;pointer-events:none}.nav-item.nav-logout{color:#ff6b6b;margin-top:auto}.nav-item.nav-logout:hover{background-color:#e53e3e26;color:#f44}.sidebar-bottom{padding:16px 12px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background .2s}.sidebar-user:hover{background-color:#ffffff0d}.sidebar-user .user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0de1e8,#0eb5da);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0}.sidebar-user .user-info{overflow:hidden;transition:all .3s ease}.sidebar-user .user-name{font-size:13px;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-role{font-size:11px;color:#89b;font-weight:500}.nav-section-label{color:#567!important}.sidebar.collapsed .sidebar-user .user-info{opacity:0;width:0}.main-content{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}.main-content.sidebar-collapsed{margin-left:72px}.top-navbar{background:#fff;padding:0 28px;height:72px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 4px #0000000f;position:sticky;top:0;z-index:100;border-bottom:1px solid #f0f4f8}.navbar-left{display:flex;align-items:center;gap:16px}.navbar-left h2{font-size:20px;font-weight:700;color:#2d3748}.navbar-breadcrumb{font-size:13px;color:#a0aec0}.navbar-right{display:flex;align-items:center;gap:16px}.navbar-icon-btn{width:40px;height:40px;border:none;background:#f7fafc;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#718096;position:relative}.navbar-icon-btn:hover{background:#0de1e81a;color:#0de1e8}.navbar-icon-btn .notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:#e53e3e;border-radius:50%;border:2px solid #fff}.navbar-user{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px;border-radius:10px;transition:background .2s}.navbar-user:hover{background-color:#f8fafc}.navbar-user .user-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#0de1e8,#0eb5da);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:700}.navbar-user .user-name{font-size:14px;font-weight:600;color:#2d3748}.navbar-user .user-role{font-size:11px;color:#a0aec0}.page-content{padding:28px;flex:1}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:999}@media (max-width: 1024px){.sidebar{transform:translate(-100%);z-index:1001}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay.visible{display:block}.main-content,.main-content.sidebar-collapsed{margin-left:0}}@media (max-width: 768px){.page-content{padding:16px}.top-navbar{padding:0 16px}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.stats-grid{grid-template-columns:1fr}}.charts-section{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:28px}@media (max-width: 1024px){.charts-section{grid-template-columns:1fr}}.chart-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f4f8}.chart-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.chart-card-title{font-size:16px;font-weight:700;color:#2d3748}.chart-card-subtitle{font-size:12px;color:#a0aec0;margin-top:2px}.chart-card-actions{display:flex;gap:8px}.chart-period-btn{padding:4px 12px;border:1px solid #e2e8f0;border-radius:6px;background:transparent;font-size:12px;font-weight:500;color:#718096;cursor:pointer;transition:all .2s}.chart-period-btn.active{background:#e06a0a;border-color:#0de1e8;color:#fff}.tables-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}@media (max-width: 1024px){.tables-section{grid-template-columns:1fr}}.data-table-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f4f8}.data-table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.data-table-title{font-size:16px;font-weight:700;color:#2d3748}.btn-view-all{font-size:13px;color:#0de1e8;font-weight:600;background:none;border:none;cursor:pointer;padding:0;text-decoration:none;transition:color .2s}.btn-view-all:hover{color:#0eb5da;text-decoration:underline}.data-table{width:100%;border-collapse:collapse}.data-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#a0aec0;padding:10px 12px;text-align:left;border-bottom:1px solid #f0f4f8;background:#fafafa}.data-table td{padding:12px;font-size:13px;color:#4a5568;border-bottom:1px solid #f7fafc;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background-color:#fafafa}.student-cell{display:flex;align-items:center;gap:10px}.student-avatar-sm{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0de1e8,#0eb5da);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.student-name{font-weight:600;color:#2d3748;font-size:13px}.student-class{font-size:11px;color:#a0aec0;margin-top:1px}.status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.status-paid{background:#f0fff4;color:#276749}.status-pending{background:#fffaf0;color:#c05621}.status-overdue{background:#fff5f5;color:#c53030}.status-present{background:#f0fff4;color:#276749}.status-absent{background:#fff5f5;color:#c53030}.status-late{background:#fffaf0;color:#c05621}.action-btns{display:flex;gap:8px;align-items:center}.action-btn{width:30px;height:30px;border:none;border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.action-btn .material-icons{font-size:16px}.action-btn-edit{background:#0de1e81a;color:#0de1e8}.action-btn-edit:hover{background:#0de1e833}.action-btn-delete{background:#e53e3e1a;color:#e53e3e}.action-btn-delete:hover{background:#e53e3e33}.action-btn-view{background:#3182ce1a;color:#3182ce}.action-btn-view:hover{background:#3182ce33}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-container{background:#fff;border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{padding:24px 24px 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:18px;font-weight:700;color:#2d3748}.modal-close{width:36px;height:36px;border:none;background:#f7fafc;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#718096;transition:all .2s}.modal-close:hover{background:#fed7d7;color:#e53e3e}.modal-body{padding:0 24px 24px}.modal-footer{padding:16px 24px 24px;display:flex;gap:12px;justify-content:flex-end;border-top:1px solid #f0f4f8}.search-filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.search-input-wrapper{flex:1;min-width:200px;position:relative}.search-input-wrapper .material-icons{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#a0aec0;font-size:20px}.search-input{width:100%;padding:10px 12px 10px 40px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#2d3748;background:#fafafa;outline:none;transition:all .2s}.search-input:focus{border-color:#0de1e8;box-shadow:0 0 0 3px #0de1e826;background:#fff}.filter-select{padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#4a5568;background:#fafafa;outline:none;cursor:pointer;transition:all .2s;min-width:140px}.filter-select:focus{border-color:#0de1e8}.btn-add{display:flex;align-items:center;gap:6px;padding:10px 18px;background:#0de1e8;border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add:hover{background:#0eb5da;transform:translateY(-1px);box-shadow:0 4px 12px #0de1e866}.btn-add .material-icons{font-size:18px}.progress-bar-custom{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#0de1e8,#0eb5da);border-radius:3px;transition:width .5s ease}.grade-circle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.grade-a{background:#f0fff4;color:#276749}.grade-b{background:#ebf8ff;color:#2b6cb0}.grade-c{background:#fffaf0;color:#c05621}.grade-d{background:#fff5f5;color:#c53030}.schedule-card{background:#fff;border-radius:14px;padding:20px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f4f8;margin-bottom:20px}.schedule-item{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid #f7fafc}.schedule-item:last-child{border-bottom:none}.schedule-time{min-width:80px;font-size:12px;font-weight:600;color:#a0aec0;text-align:right}.schedule-connector{display:flex;flex-direction:column;align-items:center;gap:4px}.schedule-dot{width:10px;height:10px;border-radius:50%;background:#0de1e8;flex-shrink:0}.schedule-line{width:2px;height:24px;background:#e2e8f0}.schedule-info{flex:1}.schedule-subject{font-size:14px;font-weight:600;color:#2d3748}.schedule-class{font-size:12px;color:#a0aec0;margin-top:2px}.fee-summary{background:linear-gradient(135deg,#0de1e8,#0eb5da);border-radius:14px;padding:24px;color:#fff;margin-bottom:20px}.fee-summary h3{font-size:14px;font-weight:600;opacity:.85;margin-bottom:8px}.fee-summary .amount{font-size:32px;font-weight:800;font-family:Poppins,sans-serif}.fee-summary .due-date{font-size:12px;opacity:.75;margin-top:8px}.message-item{display:flex;align-items:flex-start;gap:12px;padding:16px 0;border-bottom:1px solid #f7fafc;cursor:pointer;transition:background .2s}.message-item:last-child{border-bottom:none}.message-item:hover{background:#fafafa}.message-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#0de1e8,#0eb5da);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:700;flex-shrink:0}.message-content{flex:1;min-width:0}.message-sender{font-size:14px;font-weight:600;color:#2d3748;margin-bottom:2px}.message-preview{font-size:12px;color:#a0aec0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-time{font-size:11px;color:#a0aec0;flex-shrink:0}.message-unread .message-sender{color:#0de1e8}.message-unread-dot{width:8px;height:8px;background:#0de1e8;border-radius:50%;margin-top:6px;flex-shrink:0}.child-info-card{background:linear-gradient(135deg,#0de1e8,#0eb5da);border-radius:16px;padding:28px;color:#fff;display:flex;align-items:center;gap:20px;margin-bottom:24px;position:relative;overflow:hidden}.child-info-card:before{content:"";position:absolute;top:-30px;right:-30px;width:150px;height:150px;background:#ffffff1a;border-radius:50%}.child-photo{width:80px;height:80px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;flex-shrink:0;border:3px solid rgba(255,255,255,.4)}.child-details h2{font-size:22px;font-weight:700;margin-bottom:4px;font-family:Poppins,sans-serif}.child-details .child-class{font-size:14px;opacity:.85;margin-bottom:8px}.child-details .child-tags{display:flex;gap:8px;flex-wrap:wrap}.child-tag{background:#fff3;padding:3px 12px;border-radius:20px;font-size:12px;font-weight:500}.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 0 0;border-top:1px solid #f0f4f8;margin-top:8px}.pagination-info{font-size:13px;color:#a0aec0}.pagination-controls{display:flex;gap:6px;align-items:center}.page-btn{width:32px;height:32px;border:1.5px solid #e2e8f0;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:#4a5568;cursor:pointer;transition:all .2s}.page-btn:hover{border-color:#0de1e8;color:#0de1e8}.page-btn.active{background:#0de1e8;border-color:#0de1e8;color:#fff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.empty-state{text-align:center;padding:48px 24px}.empty-state .material-icons{font-size:56px;color:#e2e8f0;margin-bottom:16px}.empty-state h3{font-size:18px;font-weight:600;color:#a0aec0;margin-bottom:8px}.empty-state p{font-size:14px;color:#cbd5e0}.exam-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.exam-page-title{font-size:22px;font-weight:700;color:#1a202c;margin:0;display:flex;align-items:center;gap:10px}.exam-page-title .material-icons{font-size:26px;color:#0de1e8}.exam-page-subtitle{font-size:13px;color:#718096;margin:2px 0 0}.exam-tabs{display:flex;gap:4px;background:#f0f4f8;border-radius:12px;padding:4px;margin-bottom:24px;overflow-x:auto}.exam-tab{flex:1;min-width:130px;padding:10px 18px;border:none;background:transparent;border-radius:9px;font-size:13px;font-weight:600;color:#718096;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s;white-space:nowrap}.exam-tab.active{background:#fff;color:#0de1e8;box-shadow:0 2px 8px #00000014}.exam-tab .material-icons{font-size:16px}.exam-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.exam-stat-card{background:#fff;border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:14px;box-shadow:0 1px 6px #0000000f;border:1px solid #f0f4f8}.exam-stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exam-stat-icon .material-icons{font-size:22px}.exam-stat-value{font-size:24px;font-weight:800;color:#1a202c;line-height:1}.exam-stat-label{font-size:11px;color:#718096;margin-top:3px;font-weight:500}.exam-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.exam-search-box{flex:1;min-width:200px;position:relative}.exam-search-box .material-icons{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:#a0aec0;pointer-events:none}.exam-search-box input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid #e2e8f0;border-radius:9px;font-size:13px;color:#2d3748;background:#fff;outline:none;transition:border .2s;box-sizing:border-box}.exam-search-box input:focus{border-color:#0de1e8}.exam-filter-select{padding:9px 14px;border:1.5px solid #e2e8f0;border-radius:9px;font-size:13px;color:#2d3748;background:#fff;outline:none;cursor:pointer;min-width:130px}.exam-filter-select:focus{border-color:#0de1e8}.btn-exam-primary{padding:9px 18px;background:#0de1e8;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .2s;white-space:nowrap}.btn-exam-primary:hover{background:#0eb5da}.btn-exam-secondary{padding:9px 18px;background:#f0f4f8;color:#4a5568;border:none;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .2s;white-space:nowrap}.btn-exam-secondary:hover{background:#e2e8f0}.exam-table-card{background:#fff;border-radius:14px;box-shadow:0 1px 6px #0000000f;border:1px solid #f0f4f8;overflow:hidden}.exam-table-wrap{overflow-x:auto}.exam-table{width:100%;border-collapse:collapse;font-size:13px}.exam-table thead th{background:#f8fafc;padding:12px 16px;text-align:left;font-weight:700;color:#4a5568;font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap}.exam-table tbody td{padding:12px 16px;border-bottom:1px solid #f7fafc;color:#2d3748;vertical-align:middle}.exam-table tbody tr:last-child td{border-bottom:none}.exam-table tbody tr:hover{background:#f8fafc}.exam-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.exam-badge-green{background:#f0fff4;color:#0de1e8}.exam-badge-blue{background:#ebf8ff;color:#2b6cb0}.exam-badge-orange{background:#fffaf0;color:#c05621}.exam-badge-red{background:#fff5f5;color:#c53030}.exam-badge-purple{background:#faf5ff;color:#553c9a}.exam-badge-gray{background:#f7fafc;color:#4a5568}.exam-action-btn{width:32px;height:32px;border:none;border-radius:8px;background:#f0f4f8;color:#4a5568;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;margin-right:4px}.exam-action-btn:hover{background:#e2e8f0}.exam-action-btn.danger:hover{background:#fff5f5;color:#c53030}.exam-action-btn.success:hover,.exam-action-btn.primary:hover{background:#f0fff4;color:#0de1e8}.exam-action-btn .material-icons{font-size:16px}.exam-empty{text-align:center;padding:60px 20px;color:#a0aec0}.exam-empty .material-icons{font-size:52px;display:block;margin-bottom:12px;color:#e2e8f0}.exam-empty p{margin:0;font-size:14px}.exam-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.exam-modal{background:#fff;border-radius:16px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003;animation:examModalIn .2s ease}@keyframes examModalIn{0%{opacity:0;transform:scale(.96) translateY(-12px)}to{opacity:1;transform:scale(1) translateY(0)}}.exam-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f0f4f8}.exam-modal-header h2{font-size:18px;font-weight:700;color:#1a202c;margin:0;display:flex;align-items:center;gap:8px}.exam-modal-header h2 .material-icons{font-size:20px;color:#0de1e8}.exam-modal-close{width:32px;height:32px;border:none;background:#f0f4f8;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#718096;transition:all .2s}.exam-modal-close:hover{background:#e2e8f0;color:#2d3748}.exam-modal-body{padding:20px 24px}.exam-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #f0f4f8}.exam-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.exam-form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.exam-form-grid.full{grid-template-columns:1fr}@media (max-width: 540px){.exam-form-grid,.exam-form-grid.cols-3{grid-template-columns:1fr}}.exam-form-group{display:flex;flex-direction:column;gap:5px}.exam-form-group.span-2{grid-column:span 2}.exam-form-group label{font-size:12px;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.4px}.exam-form-group input,.exam-form-group select,.exam-form-group textarea{padding:9px 12px;border:1.5px solid #e2e8f0;border-radius:9px;font-size:13px;color:#2d3748;background:#fff;outline:none;transition:border .2s;font-family:inherit}.exam-form-group textarea{resize:vertical;min-height:80px}.exam-form-group input:focus,.exam-form-group select:focus,.exam-form-group textarea:focus{border-color:#0de1e8}.exam-form-error{font-size:11px;color:#e53e3e;margin-top:2px}.hall-ticket-preview{border:2px solid #1a202c;border-radius:12px;overflow:hidden;font-family:Arial,sans-serif;max-width:600px;margin:0 auto}.ht-header{background:linear-gradient(135deg,#1a3c5e,#2d6a4f);color:#fff;padding:18px 24px;display:flex;align-items:center;gap:16px}.ht-school-logo{width:56px;height:56px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.ht-school-name{font-size:18px;font-weight:800;letter-spacing:.5px}.ht-exam-title{font-size:12px;opacity:.85;margin-top:2px;text-transform:uppercase;letter-spacing:1px}.ht-body{padding:20px 24px}.ht-info-row{display:grid;grid-template-columns:1fr auto;gap:16px;margin-bottom:16px;align-items:start}.ht-student-photo{width:80px;height:90px;border:2px solid #e2e8f0;border-radius:8px;object-fit:cover;background:#f0f4f8;display:flex;align-items:center;justify-content:center;font-size:32px;color:#a0aec0;flex-shrink:0}.ht-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ht-field label{font-size:10px;text-transform:uppercase;color:#718096;font-weight:700;letter-spacing:.5px;display:block;margin-bottom:2px}.ht-field span{font-size:13px;font-weight:600;color:#1a202c}.ht-ticket-number{font-size:11px;text-align:right;color:#718096;margin-bottom:12px}.ht-schedule-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:12px}.ht-schedule-table th{background:#f8fafc;border:1px solid #e2e8f0;padding:8px 10px;text-align:left;font-weight:700;color:#4a5568;font-size:10px;text-transform:uppercase}.ht-schedule-table td{border:1px solid #e2e8f0;padding:8px 10px;color:#2d3748}.ht-footer{background:#f8fafc;padding:14px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:flex-end}.ht-instructions{font-size:11px;color:#718096;flex:1}.ht-instructions strong{display:block;margin-bottom:4px;color:#4a5568}.ht-sign{text-align:center;font-size:10px;color:#718096}.ht-sign-line{width:100px;border-top:1px solid #4a5568;margin:0 auto 4px}.cert-preview{border:3px solid #c8a951;border-radius:12px;overflow:hidden;font-family:Georgia,serif;max-width:620px;margin:0 auto;position:relative}.cert-preview:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:1px solid #c8a951;border-radius:8px;pointer-events:none}.cert-header{background:linear-gradient(135deg,#1a3c5e,#1a5e3c);color:#fff;padding:24px;text-align:center}.cert-logo{font-size:36px;margin-bottom:8px}.cert-school-name{font-size:20px;font-weight:800;letter-spacing:2px;text-transform:uppercase}.cert-school-sub{font-size:11px;opacity:.8;margin-top:2px;letter-spacing:1px}.cert-type-banner{background:#c8a951;color:#1a202c;text-align:center;padding:8px;font-size:14px;font-weight:800;letter-spacing:3px;text-transform:uppercase}.cert-body{padding:28px 32px;background:#fffdf5}.cert-id-line{text-align:right;font-size:11px;color:#718096;margin-bottom:16px;font-family:Arial,sans-serif}.cert-date-line{text-align:right;font-size:12px;color:#4a5568;margin-bottom:20px;font-family:Arial,sans-serif}.cert-to-whom{font-size:13px;color:#4a5568;margin-bottom:6px;font-family:Arial,sans-serif}.cert-student-name{font-size:22px;font-weight:800;color:#1a202c;border-bottom:2px solid #c8a951;display:inline-block;padding-bottom:2px;margin-bottom:12px}.cert-content{font-size:14px;color:#2d3748;line-height:1.8}.cert-content strong{color:#1a202c}.cert-footer{padding:20px 32px;display:flex;justify-content:space-between;align-items:flex-end;background:#fffdf5;border-top:1px solid #e2e8f0}.cert-sign-block{text-align:center}.cert-sign-line{width:120px;border-top:1px solid #4a5568;margin:0 auto 6px}.cert-sign-label{font-size:11px;color:#718096;font-family:Arial,sans-serif}.cert-seal{width:64px;height:64px;border:2px dashed #c8a951;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:#c8a951;text-align:center;font-weight:700;letter-spacing:1px}.cert-verified-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f0fff4;border:1px solid #c6f6d5;border-radius:9px;font-size:13px;color:#0de1e8;font-weight:600;margin-bottom:16px}@media (max-width: 640px){.exam-page-header{flex-direction:column;align-items:flex-start}.exam-stats-row{grid-template-columns:1fr 1fr}.ht-info-row,.ht-fields{grid-template-columns:1fr}.cert-footer{flex-direction:column;gap:16px;align-items:center}}body.printing-hall-ticket *{visibility:hidden}body.printing-hall-ticket #hall-ticket-print-root,body.printing-hall-ticket #hall-ticket-print-root *{visibility:visible}body.printing-hall-ticket #hall-ticket-print-root{position:fixed;top:0;right:0;bottom:0;left:0;margin:0;padding:16px;z-index:99999;background:#fff;overflow:auto}@media print{@page{size:A4 portrait;margin:10mm 12mm}body>*{display:none!important}#hall-ticket-print-root{display:block!important;visibility:visible!important;position:static!important;width:100%!important;max-width:none!important;border:none!important;box-shadow:none!important;margin:0!important;padding:0!important;page-break-inside:avoid;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}#hall-ticket-print-root *{display:revert!important;visibility:visible!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}}@media print{.exam-modal-overlay{position:static!important;background:none!important;padding:0!important;display:block!important}.exam-modal{max-height:none!important;box-shadow:none!important;width:100%!important;max-width:none!important}.exam-modal-header,.exam-modal-footer,.exam-toolbar,.exam-tabs,.exam-page-header,.exam-stats-row,.exam-table-card,.exam-action-btn,nav,aside,header{display:none!important}}:root{--primary: #F97316;--primary-green: #F97316;--primary-green-dark: #EA6C0A;--primary-green-light: #EBF5FF;--sidebar-bg: #1e2a3a;--secondary-color: #2c3e50;--text-primary: #2d3748;--text-secondary: #718096;--text-muted: #a0aec0;--border-color: #e2e8f0;--bg-light: #f7fafc;--bg-white: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .12);--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 20px;--transition: all .3s ease;--font-primary: "Poppins", "Inter", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);color:var(--text-primary);background-color:var(--bg-light);line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}.text-primary-green{color:var(--primary-green)!important}.bg-primary-green{background-color:var(--primary-green)!important}.btn-primary-green{background-color:var(--primary-green);border-color:var(--primary-green);color:#fff;font-weight:600;padding:12px 24px;border-radius:var(--border-radius-sm);transition:var(--transition);font-size:15px}.btn-primary-green:hover,.btn-primary-green:focus{background-color:var(--primary-green-dark);border-color:var(--primary-green-dark);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #1a56db66}.btn-outline-green{background-color:transparent;border:2px solid var(--primary-green);color:var(--primary-green);font-weight:600;padding:10px 24px;border-radius:var(--border-radius-sm);transition:var(--transition)}.btn-outline-green:hover{background-color:var(--primary-green);color:#fff}.card-shadow{box-shadow:var(--shadow-md);border:none;border-radius:var(--border-radius)}.card-hover{transition:var(--transition)}.card-hover:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.stat-card{background:var(--bg-white);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:var(--transition);position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.stat-card .stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-card .stat-label{font-size:13px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-card .stat-change{font-size:12px;font-weight:600;margin-top:8px}.stat-card .stat-change.positive{color:#28a745}.stat-card .stat-change.negative{color:#dc3545}.table-container{background:var(--bg-white);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.table-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:20px}.custom-table{width:100%;border-collapse:collapse}.custom-table th{background-color:var(--bg-light);color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;border-bottom:1px solid var(--border-color)}.custom-table td{padding:14px 16px;border-bottom:1px solid var(--border-color);font-size:14px;color:var(--text-primary)}.custom-table tr:last-child td{border-bottom:none}.custom-table tr:hover td{background-color:var(--bg-light)}.badge-success{background-color:#d4edda;color:#155724;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-warning{background-color:#fff3cd;color:#856404;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-danger{background-color:#f8d7da;color:#721c24;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-info{background-color:#d1ecf1;color:#0c5460;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.form-input{border:1.5px solid var(--border-color);border-radius:var(--border-radius-sm);padding:12px 16px;font-size:14px;transition:var(--transition);width:100%;color:var(--text-primary)}.form-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #1a56db26}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background-color:var(--primary-green);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px}.avatar-sm{width:32px;height:32px;font-size:13px}.avatar-lg{width:64px;height:64px;font-size:24px}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{width:40px;height:40px;border:3px solid var(--primary-green-light);border-top-color:var(--primary-green);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-header{margin-bottom:28px}.page-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.page-header p{font-size:14px;color:var(--text-secondary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-light)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 768px){.stat-card .stat-value{font-size:22px}.page-header h1{font-size:20px}}.print-only{display:none}@media print{.no-print{display:none!important}.print-only{display:block!important}.sidebar,.top-navbar,.sidebar-overlay{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}body{background:#fff!important}.card,.data-table-card{box-shadow:none!important;border:1px solid #dee2e6!important}@page{margin:1cm}}
