:root{--primary: #1B5E20;--primary-dark: #0D3B12;--primary-light: #2E7D32;--primary-hover: #256427;--accent-green: #4CAF50;--accent-yellow: #FFC107;--accent-red: #F44336;--accent-blue: #2196F3;--accent-orange: #FF9800;--accent-teal: #009688;--bg-main: #F5F6FA;--bg-card: #FFFFFF;--bg-sidebar: #1B5E20;--bg-header: #FFFFFF;--text-primary: #1A1A2E;--text-secondary: #6B7280;--text-muted: #9CA3AF;--text-white: #FFFFFF;--text-sidebar: rgba(255, 255, 255, .85);--text-sidebar-muted: rgba(255, 255, 255, .55);--border-color: #E5E7EB;--border-light: #F0F0F0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-card: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--sidebar-width: 260px;--sidebar-collapsed: 70px;--header-height: 64px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-main);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit;outline:none}ul,ol{list-style:none}.app-layout{display:flex;min-height:100vh}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.main-wrapper.sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.main-content{flex:1;padding:24px 28px;max-width:1400px;width:100%}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:var(--bg-sidebar);color:var(--text-white);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-normal);overflow-y:auto;overflow-x:hidden}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand{display:flex;align-items:center;gap:12px}.sidebar-logo{width:36px;height:36px;background:#ffffff26;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px}.sidebar-brand-text h3{font-size:16px;font-weight:700;letter-spacing:.3px}.sidebar-brand-text p{font-size:11px;color:var(--text-sidebar-muted);margin-top:1px}.sidebar-toggle{background:#ffffff1a;border:none;color:var(--text-white);width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast)}.sidebar-toggle:hover{background:#fff3}.sidebar-nav{flex:1;padding:12px 0}.nav-group{margin-bottom:4px}.nav-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-sidebar-muted);padding:12px 24px 6px}.nav-link{display:flex;align-items:center;gap:12px;padding:10px 24px;color:var(--text-sidebar);font-size:13.5px;font-weight:400;transition:all var(--transition-fast);cursor:pointer;border-left:3px solid transparent}.nav-link:hover{background:#ffffff14;color:var(--text-white)}.nav-link.active{background:#ffffff1f;color:var(--text-white);font-weight:500;border-left-color:var(--accent-green)}.nav-link .nav-icon{font-size:18px;flex-shrink:0;width:22px;display:flex;align-items:center;justify-content:center}.header{height:var(--header-height);background:var(--bg-header);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.header-search{position:relative;width:380px}.header-search input{width:100%;padding:9px 16px 9px 40px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:13.5px;color:var(--text-primary);background:var(--bg-main);transition:border-color var(--transition-fast)}.header-search input::placeholder{color:var(--text-muted)}.header-search input:focus{border-color:var(--primary)}.header-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:16px}.header-actions{display:flex;align-items:center;gap:16px}.header-notification{position:relative;background:none;border:none;color:var(--text-secondary);font-size:20px;padding:8px;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.header-notification:hover{color:var(--primary)}.notification-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--accent-red);border-radius:50%}.header-user{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px;border-radius:var(--radius-md);transition:background var(--transition-fast)}.header-user:hover{background:var(--bg-main)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:var(--text-white);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-info{display:flex;flex-direction:column}.user-name{font-size:13.5px;font-weight:600;color:var(--text-primary)}.user-role{font-size:11px;color:var(--text-secondary);text-transform:capitalize}.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-bottom:28px}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px 22px;box-shadow:var(--shadow-card);display:flex;align-items:flex-start;justify-content:space-between;border:1px solid var(--border-light);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.1}.stat-change{font-size:12px;margin-top:8px;display:flex;align-items:center;gap:4px}.stat-change.positive{color:var(--accent-green)}.stat-change.negative{color:var(--accent-red)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.stat-icon.green{background:#e8f5e9;color:#2e7d32}.stat-icon.yellow{background:#fff8e1;color:#f57f17}.stat-icon.red{background:#ffebee;color:#c62828}.stat-icon.blue{background:#e3f2fd;color:#1565c0}.stat-icon.teal{background:#e0f2f1;color:#00695c}.stat-icon.orange{background:#fff3e0;color:#e65100}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary)}.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.welcome-text{margin-bottom:28px}.welcome-text h1{font-size:26px;font-weight:700;color:var(--text-primary)}.welcome-text p{font-size:14px;color:var(--accent-green);margin-top:4px}.content-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-card);overflow:hidden}.content-card.allow-overflow{overflow:visible!important}.content-card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border-light)}.content-card-title{font-size:16px;font-weight:600;color:var(--text-primary)}.content-card-body{padding:22px}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:28px}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table thead th{text-align:left;padding:12px 16px;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-secondary);background:var(--bg-main);border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table tbody td{padding:13px 16px;font-size:13.5px;color:var(--text-primary);border-bottom:1px solid var(--border-light);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#fafbfc}.data-table tbody tr:last-child td{border-bottom:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 20px;font-size:13.5px;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--primary);color:var(--text-white)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-main);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-success{background:var(--accent-green);color:var(--text-white)}.btn-success:hover{background:#388e3c}.btn-danger{background:var(--accent-red);color:var(--text-white)}.btn-danger:hover{background:#d32f2f}.btn-warning{background:var(--accent-yellow);color:var(--text-primary)}.btn-sm{padding:6px 14px;font-size:12px}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:6px}.form-control{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);background:var(--bg-card);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1b5e201a}.form-control::placeholder{color:var(--text-muted)}.form-select{width:100%;padding:10px 36px 10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);background:var(--bg-card);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1b5e201a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border-light);margin-top:8px}.badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:11.5px;font-weight:600;border-radius:20px;text-transform:capitalize}.badge-green{background:#e8f5e9;color:#2e7d32}.badge-yellow{background:#fff8e1;color:#f57f17}.badge-red{background:#ffebee;color:#c62828}.badge-blue{background:#e3f2fd;color:#1565c0}.badge-gray{background:#f3f4f6;color:#6b7280}.badge-teal{background:#e0f2f1;color:#00695c}.tabs{display:flex;gap:2px;background:var(--bg-main);padding:4px;border-radius:var(--radius-md);margin-bottom:20px;width:fit-content}.tab{padding:8px 20px;font-size:13px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:transparent}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal{background:var(--bg-card);border-radius:var(--radius-lg);width:560px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border-light)}.modal-title{font-size:17px;font-weight:600}.modal-close{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:4px}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-light)}.filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filter-bar .form-select,.filter-bar .form-control{width:auto;min-width:160px;padding:8px 12px;font-size:13px}.report-document{display:none;background:#fff;color:#000;font-family:Times New Roman,Times,serif}.report-container{background:#fff;padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-light);max-width:210mm;margin:0 auto}.report-container .report-document{display:block}.report-header{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #000;padding-bottom:20px;margin-bottom:20px}.school-logo{width:80px;height:80px;display:flex;align-items:center;justify-content:center}.school-info{text-align:center;flex:1}.school-info h1{font-size:24px;font-weight:700;margin-bottom:4px;text-transform:uppercase;letter-spacing:1px}.school-info p{font-size:14px;margin-bottom:2px}.report-meta{width:100px;text-align:right}.meta-box{border:1px solid #000;padding:8px;text-align:center}.meta-box span{display:block;font-size:10px;text-transform:uppercase}.meta-box strong{display:block;font-size:14px}.student-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 40px;margin-bottom:30px;border:1px solid #ddd;padding:15px}.info-row{display:flex;border-bottom:1px dotted #ccc;padding-bottom:4px}.info-row .label{font-weight:700;width:120px;font-size:14px}.info-row .value{flex:1;font-size:14px}.results-section h3{background:#eee;padding:8px;text-align:center;text-transform:uppercase;font-size:14px;border:1px solid #000;margin-bottom:0}.report-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:20px}.report-table th,.report-table td{border:1px solid #000;padding:8px;text-align:center}.report-table th{background:#f9f9f9;font-weight:700}.summary-row{font-weight:700;background:#f9f9f9}.remarks-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.remark-box h4{font-size:13px;text-transform:uppercase;border-bottom:1px solid #000;margin-bottom:8px;padding-bottom:4px}.attendance-grid{font-size:13px}.conduct-text{font-size:13px;font-style:italic}.dots{letter-spacing:2px}.signatures-section{margin-top:30px;display:grid;gap:20px}.signature-box h4{font-size:13px;text-transform:uppercase;margin-bottom:8px}.remark-lines{font-size:13px;font-style:italic;margin-bottom:15px;min-height:40px}.sign-line{display:flex;justify-content:space-between;margin-top:20px;font-size:13px}.grading-key{margin-top:30px;border-top:1px solid #000;padding-top:10px}.grading-key h4{font-size:11px;margin-bottom:5px;text-transform:uppercase}.key-grid{display:flex;flex-wrap:wrap;gap:10px;font-size:10px}.report-footer{margin-top:30px;text-align:center;font-size:10px;color:#666;border-top:1px solid #ddd;padding-top:10px}@media print{@page{size:A4;margin:10mm}body{background:#fff;print-color-adjust:exact;-webkit-print-color-adjust:exact}.sidebar,.header,.no-print{display:none!important}.main-wrapper{margin:0!important;padding:0!important}.main-content{padding:0!important;max-width:none!important}.report-container{box-shadow:none;border:none;padding:0;margin:0;max-width:none}.report-document{display:block!important}}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:60px}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state h3{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.empty-state p{font-size:13px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f5e9,#f5f6fa,#e8f5e9)}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:48px 40px;width:420px;max-width:95vw;box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-logo-icon{width:48px;height:48px;background:var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-white);font-size:24px}.login-logo h2{font-size:22px;font-weight:700;color:var(--primary)}.login-logo p{font-size:12px;color:var(--text-secondary)}.login-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.login-subtitle{font-size:13.5px;color:var(--text-secondary);margin-bottom:28px}.login-form .form-group{margin-bottom:20px}.login-form .btn-primary{width:100%;padding:12px;font-size:15px;font-weight:600;margin-top:8px}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:28px}.quick-action{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:14px 16px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.quick-action:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.quick-action .qa-icon{font-size:16px;color:var(--primary)}.result-entry-grid{display:grid;grid-template-columns:2.5fr .8fr .8fr .6fr .5fr .8fr;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light)}.result-entry-grid.header{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding-bottom:12px;border-bottom:2px solid var(--border-color)}.result-entry-grid input{padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;width:100%;text-align:center}.result-entry-grid input:focus{border-color:var(--primary)}.grade-display{font-weight:700;text-align:center;font-size:15px}.remark-display{font-size:12px;text-align:center;color:var(--text-secondary)}.sms-preview{background:#f0fff0;border:1px solid #C8E6C9;border-radius:var(--radius-md);padding:16px;font-family:Courier New,monospace;font-size:13px;white-space:pre-line;line-height:1.6;margin-bottom:16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.stat-cards{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.main-wrapper{margin-left:0}.stat-cards,.form-row{grid-template-columns:1fr}.header-search{display:none}}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:20px;font-size:14px;color:var(--text-secondary)}
