.dashboard-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem;margin-bottom:1.5rem}.col-span-12{grid-column:span 12}.col-span-8{grid-column:span 8}.col-span-6{grid-column:span 6}.col-span-4{grid-column:span 4}.col-span-3{grid-column:span 3}@media(max-width:1200px){.dashboard-grid{gap:1.25rem}.col-span-8,.col-span-6,.col-span-4,.col-span-3{grid-column:span 6}}@media(max-width:768px){.dashboard-grid{display:flex;flex-direction:column}.col-span-8,.col-span-6,.col-span-4,.col-span-3,.col-span-12{grid-column:span 12;width:100%}}.widget-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;height:100%}.widget-card.no-padding{padding:0;overflow:hidden}.widget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.widget-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.widget-subtitle{font-size:.75rem;color:var(--text-muted)}.dashboard-hero{position:relative;padding:2.25rem 2rem;border-radius:var(--radius-xl);overflow:hidden;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:flex-end;background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-xs)}.dashboard-hero-bg{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(37,99,235,.04) 0%,rgba(124,58,237,.03) 50%,transparent 100%);z-index:0}.dashboard-hero-content{position:relative;z-index:1}.hero-title{font-size:2rem;font-weight:800;margin-bottom:.35rem;color:var(--text-primary);letter-spacing:-.02em}.hero-subtitle{font-size:1rem;color:var(--text-muted)}.hero-stats{position:relative;z-index:1;display:flex;gap:1rem}.hero-stat{background:var(--bg-tertiary);padding:.85rem 1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:.2rem}.hero-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.hero-stat-value{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-bottom:2rem}.kpi-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;position:relative;overflow:hidden;transition:all .2s ease;box-shadow:var(--shadow-xs)}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-glow{display:none}.kpi-content{position:relative;z-index:1}.kpi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.kpi-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff}.kpi-trend{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:var(--radius-full)}.kpi-trend.positive{background:var(--success-50);color:var(--success-600)}.kpi-trend.negative{background:var(--danger-50);color:var(--danger-600)}.kpi-value-container{display:flex;flex-direction:column}.kpi-value{font-family:Inter,sans-serif;font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1.1;letter-spacing:-.02em}.kpi-label{font-size:.825rem;color:var(--text-muted);font-weight:500;margin-top:.25rem}.ai-insights{background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;position:relative;overflow:hidden}.ai-sparkle{position:absolute;top:1.5rem;right:1.5rem;color:var(--accent-500);animation:pulse-glow 2s infinite alternate}@keyframes pulse-glow{0%{transform:scale(1);opacity:.6}to{transform:scale(1.1);opacity:1}}.ai-title{font-size:1rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;color:var(--primary-700)}.ai-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.85rem}.ai-card{background:var(--bg-secondary);border:1px solid var(--primary-100);border-radius:var(--radius-md);padding:1rem;display:flex;align-items:flex-start;gap:.75rem;transition:all .2s ease}.ai-card:hover{box-shadow:var(--shadow-sm)}.ai-card-icon{padding:.4rem;border-radius:var(--radius-sm);flex-shrink:0}.ai-card-text{font-size:.825rem;color:var(--text-secondary);line-height:1.4}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.85rem}.action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.65rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem 1rem;cursor:pointer;transition:all .2s ease;text-align:center}.action-card:hover{background:var(--primary-50);border-color:var(--primary-200);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.action-icon-wrapper{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;background:var(--bg-tertiary);color:var(--text-secondary);transition:all .2s ease}.action-card:hover .action-icon-wrapper{background:var(--primary-500);color:#fff}.action-label{font-size:.78rem;font-weight:500;color:var(--text-secondary)}.dashboard-grid-2{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2rem}@media(max-width:1024px){.dashboard-grid-2{grid-template-columns:1fr}}.timeline{display:flex;flex-direction:column;gap:1rem}.timeline-item{display:flex;gap:1rem;position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:11px;top:24px;bottom:-1rem;width:2px;background:var(--border-color)}.timeline-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;z-index:1;flex-shrink:0;box-shadow:0 0 0 4px var(--bg-card)}.timeline-content{flex:1;padding-bottom:.5rem}.timeline-title{font-size:.875rem;font-weight:500;color:var(--text-primary)}.timeline-time{font-size:.75rem;color:var(--text-muted);margin-top:.2rem}.premium-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px dashed var(--border-color)}.premium-empty-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.4}.premium-empty-title{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.premium-empty-text{font-size:.85rem;color:var(--text-muted);max-width:300px;margin-bottom:1.5rem}.ht-config-panel{display:flex;flex-direction:column;gap:1.25rem}.ht-config-card{padding:1.5rem}.ht-config-card .card-header{margin-bottom:1rem}.ht-student-list{margin-top:1.25rem;display:flex;flex-direction:column;gap:.4rem;max-height:320px;overflow-y:auto;padding:.25rem}.ht-student-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.ht-student-item:hover{border-color:var(--primary-400);background:var(--primary-50)}.ht-student-item.selected{border-color:var(--primary-500);background:var(--primary-50);box-shadow:0 0 0 2px #2563eb26}.ht-student-item-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-500);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0;overflow:hidden}.ht-student-item-avatar img{width:100%;height:100%;object-fit:cover}.ht-student-item-info{flex:1;min-width:0}.ht-student-item-name{font-size:.92rem;font-weight:600;color:var(--text-primary)}.ht-student-item-meta{font-size:.78rem;color:var(--text-muted);margin-top:.1rem}.ht-student-item-check{width:28px;height:28px;border-radius:50%;background:var(--primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.ht-subjects-editor{display:flex;flex-direction:column;gap:.5rem}.ht-subject-row{display:flex;align-items:center;gap:.75rem}.ht-subject-num{width:28px;height:28px;border-radius:50%;background:var(--primary-50);color:var(--primary-600);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.ht-subject-row .form-input{flex:1}.ht-date-input{max-width:200px!important;flex:0 0 200px!important}.ht-remove-btn{color:var(--danger-400)!important;font-size:1rem!important;padding:.3rem .5rem!important}.ht-remove-btn:hover{background:var(--danger-50)!important}.ht-generate-row{display:flex;justify-content:center;margin-top:.5rem;padding-top:.75rem}.ht-page{font-family:Inter,sans-serif;color:#0f172a;background:#fff;width:297mm;min-height:210mm;margin:0 auto;padding:10mm;display:flex;justify-content:center;align-items:center}.ht-border{border:3px solid #002b5e;border-radius:12px;padding:6mm 10mm;width:100%;max-width:280mm;background:#fff;position:relative}.ht-border:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border:1px solid #002b5e;border-radius:9px;pointer-events:none}.ht-header-wrapper{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}.ht-logo-col{display:flex;align-items:center;gap:15px;width:28%}.ht-logo{width:90px;height:90px;object-fit:contain}.ht-school-text{display:flex;flex-direction:column}.ht-school-name-main{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:800;color:#002b5e;line-height:1.1;letter-spacing:.5px}.ht-school-name-sub{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:600;color:#002b5e}.ht-tagline{font-size:.75rem;color:#002b5e;margin-top:4px;font-weight:500;letter-spacing:.5px}.ht-title-col{text-align:center;flex:1}.ht-exam-title{font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:900;color:#002b5e;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.ht-pill-container{display:flex;align-items:center;justify-content:center;gap:15px}.ht-line{height:2px;width:50px;background:#002b5e;position:relative}.ht-line:after{content:"";position:absolute;width:6px;height:6px;background:#002b5e;border-radius:50%;top:-2px}.ht-line:first-child:after{right:-3px}.ht-line:last-child:after{left:-3px}.ht-pill{background:#002b5e;color:#fff;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700;padding:4px 20px;border-radius:20px;letter-spacing:2px}.ht-photo-col{width:28%;display:flex;justify-content:flex-end}.ht-photo-box{width:100px;height:125px;border:2px solid #002b5e;border-radius:4px;background:#f8fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}.ht-photo-box img{width:100%;height:100%;object-fit:cover}.ht-table{width:100%;border-collapse:collapse;border:2px solid #002b5e;border-radius:6px;overflow:hidden;margin-bottom:15px}.ht-table th,.ht-table td{border:1px solid #002b5e;padding:8px 12px}.ht-table th{background:#002b5e!important;color:#fff!important;font-weight:600;font-size:.85rem;text-align:center;text-transform:uppercase}.ht-table td{font-weight:700;font-size:.9rem;color:#1e293b;text-align:center}.ht-student-table th{font-size:.8rem}.ht-student-table td{font-size:1rem;padding:10px 12px}.ht-subject-table th{font-size:.8rem}.ht-subject-table td{font-size:.85rem}.ht-subject-table td:nth-child(2){text-align:left}.ht-footer-box{border:2px solid #002b5e;border-radius:6px;padding:12px 20px;margin-top:10px}.ht-footer-flex{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:20px}.ht-timings{flex:1}.ht-timing-title{font-weight:800;color:#002b5e;font-size:.9rem;margin-bottom:8px;display:flex;align-items:center;gap:8px}.ht-timing-row{display:flex;font-size:.85rem;font-weight:700;color:#1e293b;margin-bottom:4px}.ht-timing-label{width:120px}.ht-timing-colon{margin:0 10px}.ht-sig-col{text-align:center;width:200px}.ht-sig-cursive{font-family:Caveat,cursive;font-size:2rem;color:#334155;height:40px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:5px}.ht-sig-cursive.principal{color:#16a34a;font-size:2.2rem;font-family:Great Vibes,cursive}.ht-sig-line{border-top:2px solid #002b5e;padding-top:6px;font-weight:700;color:#002b5e;font-size:.8rem;letter-spacing:.5px}.ht-seal-col{text-align:center;width:150px;display:flex;justify-content:center}.ht-seal-circle{width:90px;height:90px;border-radius:50%;border:2px dashed #002b5e;display:flex;align-items:center;justify-content:center;position:relative}.ht-seal-inner{width:76px;height:76px;border-radius:50%;border:1px solid #002b5e;display:flex;align-items:center;justify-content:center;font-size:.5rem;color:#002b5e;text-align:center;font-weight:700;text-transform:uppercase}.ht-footer-bottom{display:flex;align-items:center;border-top:1px solid rgba(0,43,94,.2);padding-top:12px;font-size:.85rem;font-weight:600;color:#002b5e}.ht-issue-date{display:flex;align-items:center;gap:8px}.ht-divider-vert{height:15px;width:1px;background:#002b5e;margin:0 20px}.ht-address{display:flex;align-items:center;gap:8px}.teachers-page{background:var(--bg-page);min-height:100vh;padding:2rem 2.5rem;font-family:Inter,Segoe UI,sans-serif;color:var(--text-primary)}.teachers-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted);margin-bottom:2rem}.teachers-breadcrumb a{color:var(--text-muted);text-decoration:none;transition:color .2s ease}.teachers-breadcrumb a:hover{color:var(--text-primary)}.teachers-breadcrumb .breadcrumb-separator{color:var(--border-color-input);font-size:.75rem}.teachers-breadcrumb .breadcrumb-active{color:var(--text-primary);font-weight:600}.teachers-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.teachers-search-wrapper{position:relative;width:240px}.teachers-search-wrapper input{width:100%;padding:.6rem 1rem .6rem 2.4rem;border:1px solid var(--border-color-input);border-radius:var(--radius-md);background:var(--bg-secondary);font-size:.85rem;color:var(--text-primary);outline:none;transition:all .2s ease}.teachers-search-wrapper input::placeholder{color:var(--text-placeholder)}.teachers-search-wrapper input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #2563eb1a}.teachers-search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1rem;pointer-events:none}.teachers-top-right{display:flex;align-items:center;gap:1rem}.teachers-notification-btn{width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all .2s ease}.teachers-notification-btn:hover{border-color:var(--primary-300);color:var(--primary-500)}.teachers-user-avatar{width:38px;height:38px;border-radius:var(--radius-md);background:var(--primary-500);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem;letter-spacing:.02em}.teachers-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.teachers-header-info h1{font-size:1.75rem;font-weight:800;color:var(--text-primary);margin:0 0 .35rem;letter-spacing:-.02em;line-height:1.2}.teachers-header-info p{font-size:.9rem;color:var(--text-muted);margin:0;font-weight:400}.teachers-add-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.4rem;background:var(--primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.teachers-add-btn:hover{background:var(--primary-600);box-shadow:var(--shadow-sm)}.teachers-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.teacher-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border-color);transition:all .2s ease;position:relative;overflow:hidden;box-shadow:var(--shadow-xs)}.teacher-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-500);opacity:0;transition:opacity .2s ease}.teacher-card:hover{border-color:var(--primary-200);box-shadow:var(--shadow-md);transform:translateY(-2px)}.teacher-card:hover:before{opacity:1}.teacher-card-top{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.teacher-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;letter-spacing:.02em;flex-shrink:0}.teacher-avatar.avatar-navy{background:var(--primary-50);color:var(--primary-700)}.teacher-avatar.avatar-gold{background:var(--warning-50);color:var(--warning-600)}.teacher-avatar.avatar-teal{background:#ecfdf5;color:#047857}.teacher-avatar.avatar-rose{background:#fef2f2;color:#b91c1c}.teacher-avatar.avatar-purple{background:#f5f3ff;color:#6d28d9}.teacher-avatar.avatar-orange{background:#fff7ed;color:#c2410c}.teacher-card-name-area{flex:1;min-width:0}.teacher-card-name{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .15rem;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-card-subject{font-size:.825rem;color:var(--text-muted);margin:0;font-weight:400}.teacher-card-rating{display:flex;align-items:center;gap:.3rem;color:var(--warning-500);font-weight:700;font-size:.9rem;flex-shrink:0}.teacher-card-rating svg{width:16px;height:16px;fill:var(--warning-500)}.teacher-card-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.teacher-stat{display:flex;flex-direction:column;gap:.2rem}.teacher-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.teacher-stat-value{font-size:.95rem;font-weight:700;color:var(--text-primary)}.teachers-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:2px dashed var(--border-color);text-align:center}.teachers-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;color:var(--text-muted)}.teachers-empty h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.teachers-empty p{font-size:.875rem;color:var(--text-muted);max-width:320px;margin:0 0 1.5rem;line-height:1.5}.teachers-loading{display:flex;align-items:center;justify-content:center;min-height:40vh}.teachers-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--primary-500);border-radius:50%;animation:teachers-spin .8s linear infinite}@keyframes teachers-spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.teachers-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.teachers-page{padding:1.25rem 1rem}.teachers-grid{grid-template-columns:1fr}.teachers-header{flex-direction:column;gap:1rem}.teachers-top-bar{flex-direction:column;gap:1rem;align-items:stretch}.teachers-search-wrapper{width:100%}.teachers-header-info h1{font-size:1.5rem}}@media(max-width:480px){.teacher-card{padding:1.25rem}.teacher-card-stats{grid-template-columns:1fr 1fr;gap:.75rem}}:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #2563eb;--primary-600: #1d4ed8;--primary-700: #1e40af;--primary-800: #1e3a8a;--primary-900: #172554;--accent-400: #a78bfa;--accent-500: #7c3aed;--accent-600: #6d28d9;--success-50: #f0fdf4;--success-100: #dcfce7;--success-400: #4ade80;--success-500: #22c55e;--success-600: #16a34a;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-400: #fbbf24;--warning-500: #f59e0b;--warning-600: #d97706;--danger-50: #fef2f2;--danger-100: #fee2e2;--danger-400: #f87171;--danger-500: #ef4444;--danger-600: #dc2626;--info-50: #ecfeff;--info-100: #cffafe;--info-400: #22d3ee;--info-500: #06b6d4;--info-600: #0891b2;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--bg-glass: #ffffff;--bg-input: #ffffff;--bg-page: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-placeholder: #94a3b8;--text-inverse: #ffffff;--border-color: #e2e8f0;--border-color-input: #cbd5e1;--border-color-focus: #2563eb;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--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-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--sidebar-width: 264px;--sidebar-collapsed: 72px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-full: 9999px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Inter,sans-serif;font-weight:700;line-height:1.3;letter-spacing:-.01em;color:var(--text-primary)}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:inherit;font-size:.925rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);background:var(--bg-page)}.main-content.sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.page-content{padding:1.75rem 2rem;padding-top:calc(var(--header-height) + 1.75rem);max-width:1400px;margin:0 auto}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{padding:1.25rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid var(--border-color);min-height:var(--header-height)}.sidebar-logo{width:38px;height:38px;border-radius:var(--radius-md);background:var(--primary-500);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;font-weight:800;flex-shrink:0}.sidebar-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden}.sidebar-subtitle{font-size:.68rem;color:var(--primary-500);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.sidebar-nav{flex:1;padding:.75rem;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-section-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:1rem .75rem .4rem;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-fast);white-space:nowrap;position:relative}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--primary-50);color:var(--primary-600);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:55%;background:var(--primary-500);border-radius:var(--radius-full)}.nav-item-icon{font-size:1.2rem;flex-shrink:0;display:flex;align-items:center}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border-color)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:.5rem;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.header{position:fixed;top:0;right:0;left:var(--sidebar-width);height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:90;transition:left var(--transition-base)}.header.sidebar-collapsed{left:var(--sidebar-collapsed)}.header-left{display:flex;align-items:center;gap:1rem}.page-title{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:1rem}.header-user{display:flex;align-items:center;gap:.75rem;padding:.35rem .75rem .35rem .35rem;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-color);transition:all var(--transition-fast)}.header-user:hover{border-color:var(--primary-200)}.header-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-500);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700}.header-user-info{display:flex;flex-direction:column}.header-user-name{font-size:.825rem;font-weight:600;color:var(--text-primary)}.header-user-role{font-size:.68rem;color:var(--text-muted);text-transform:capitalize}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.card:hover{box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.card-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;transition:all var(--transition-base);position:relative;overflow:hidden;box-shadow:var(--shadow-xs)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stat-card.primary:before{background:var(--primary-500)}.stat-card.success:before{background:var(--success-500)}.stat-card.warning:before{background:var(--warning-500)}.stat-card.danger:before{background:var(--danger-500)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-icon.primary{background:var(--primary-50);color:var(--primary-500)}.stat-icon.success{background:var(--success-50);color:var(--success-600)}.stat-icon.warning{background:var(--warning-50);color:var(--warning-600)}.stat-icon.danger{background:var(--danger-50);color:var(--danger-600)}.stat-icon.info{background:var(--info-50);color:var(--info-600)}.stat-info{flex:1}.stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500;margin-bottom:.25rem}.stat-value{font-family:Inter,sans-serif;font-size:1.6rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-change{font-size:.75rem;margin-top:.35rem;font-weight:500}.stat-change.positive{color:var(--success-600)}.stat-change.negative{color:var(--danger-600)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;transition:all var(--transition-fast);border:none;cursor:pointer;white-space:nowrap}.btn-primary{background:var(--primary-500);color:#fff}.btn-primary:hover{background:var(--primary-600);box-shadow:var(--shadow-sm)}.btn-success{background:var(--success-500);color:#fff}.btn-success:hover{background:var(--success-600);box-shadow:var(--shadow-sm)}.btn-danger{background:var(--danger-500);color:#fff}.btn-danger:hover{background:var(--danger-600);box-shadow:var(--shadow-sm)}.btn-warning{background:var(--warning-500);color:#fff}.btn-warning:hover{background:var(--warning-600)}.btn-accent{background:var(--accent-500);color:#fff}.btn-accent:hover{background:var(--accent-600);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-color-input)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:.375rem .85rem;font-size:.8rem}.btn-lg{padding:.8rem 1.75rem;font-size:.95rem}.btn-icon{padding:.5rem;width:36px;height:36px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.825rem;font-weight:500;color:var(--text-secondary);margin-bottom:.4rem}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;background:var(--bg-input);border:1px solid var(--border-color-input);border-radius:var(--radius-md);color:var(--text-primary);font-size:.925rem;transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #2563eb1a}.form-input::placeholder{color:var(--text-placeholder)}.form-select{-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 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.form-error{font-size:.8rem;color:var(--danger-500);margin-top:.25rem}.form-help{font-size:.78rem;color:var(--text-muted);margin-top:.25rem}.table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.table-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:1rem}.table-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.table-actions{display:flex;align-items:center;gap:.75rem}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}thead{background:var(--bg-tertiary)}th{padding:.75rem 1.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border-color)}td{padding:.75rem 1.25rem;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--bg-tertiary)}tbody tr:last-child td{border-bottom:none}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-tertiary)}.data-table th{padding:.75rem 1.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border-color)}.data-table td{padding:.75rem 1.25rem;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.data-table tbody tr:hover{background:var(--bg-tertiary)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .65rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:capitalize}.badge-success{background:var(--success-50);color:var(--success-600)}.badge-warning{background:var(--warning-50);color:var(--warning-600)}.badge-danger{background:var(--danger-50);color:var(--danger-600)}.badge-info{background:var(--info-50);color:var(--info-600)}.badge-primary{background:var(--primary-50);color:var(--primary-600)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.search-bar{position:relative;flex:1;min-width:200px}.search-bar input{width:100%;padding:.575rem .9rem .575rem 2.5rem;background:var(--bg-input);border:1px solid var(--border-color-input);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;outline:none;transition:all var(--transition-fast)}.search-bar input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #2563eb1a}.search-bar input::placeholder{color:var(--text-placeholder)}.search-bar-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1rem;pointer-events:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fadeIn .2s ease}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem;z-index:201;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);font-size:1.25rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:0}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding-top:1.25rem;margin-top:1.25rem;border-top:1px solid var(--border-color)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#e8ecf4,#f8fafc);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(37,99,235,.06) 0%,transparent 70%);top:-200px;right:-200px;pointer-events:none}.login-page:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(124,58,237,.04) 0%,transparent 70%);bottom:-200px;left:-100px;pointer-events:none}.login-card{width:420px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-logo{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--primary-500);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;margin:0 auto 1.5rem}.login-title{text-align:center;font-size:1.4rem;margin-bottom:.35rem;color:var(--text-primary)}.login-subtitle{text-align:center;font-size:.875rem;color:var(--text-muted);margin-bottom:2rem}.login-form .btn{width:100%;margin-top:.5rem}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}.empty-state-title{font-size:1.05rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.empty-state-text{font-size:.875rem;max-width:320px;margin:0 auto 1.5rem}.spinner-container{display:flex;align-items:center;justify-content:center;padding:3rem}.spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.page-header-info h1{font-size:1.5rem;margin-bottom:.2rem;color:var(--text-primary)}.page-header-info p{font-size:.875rem;color:var(--text-muted)}.page-header-actions{display:flex;gap:.75rem}.filter-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-bar .form-select{width:auto;min-width:160px}.fee-head-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.fee-head-row .form-input{flex:1}.fee-head-row .btn-icon{flex-shrink:0}.fee-total{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--primary-50);border-radius:var(--radius-md);margin-top:1rem;border:1px solid var(--primary-100)}.fee-total-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.fee-total-value{font-family:Inter,sans-serif;font-size:1.2rem;font-weight:700;color:var(--primary-600)}.promotion-student-list{display:flex;flex-direction:column;gap:.5rem;max-height:400px;overflow-y:auto;padding:.5rem}.promotion-student-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.promotion-student-item.has-pending{border-color:var(--warning-500);background:var(--warning-50)}.promotion-student-item:hover{border-color:var(--primary-400)}.receipt-container{background:#fff;color:#1a1a1a;padding:2rem;border-radius:var(--radius-lg);max-width:700px;margin:0 auto}.receipt-header{display:flex;align-items:center;gap:1rem;border-bottom:2px solid #1a1a1a;padding-bottom:1rem;margin-bottom:1.5rem}.receipt-school-name{font-size:1.5rem;font-weight:800;color:#1a1a1a}.receipt-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px dashed #ccc}.receipt-total{display:flex;justify-content:space-between;padding:.75rem 0;font-weight:700;font-size:1.1rem;border-top:2px solid #1a1a1a;margin-top:.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn var(--transition-base)}.animate-slide-up{animation:slideUp var(--transition-base)}@media(max-width:1024px){.form-row{grid-template-columns:1fr}.form-row-3{grid-template-columns:1fr 1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%);z-index:200}.sidebar.mobile-open{transform:translate(0)}.main-content{margin-left:0!important}.header{left:0!important}.page-content{padding:1rem;padding-top:calc(var(--header-height) + 1rem)}.stat-grid{grid-template-columns:1fr}.page-header,.table-header{flex-direction:column;align-items:flex-start}.form-row-3{grid-template-columns:1fr}.search-bar{width:100%}.login-card{width:100%;margin:1rem;padding:1.5rem}}.logout-btn{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius-md);color:var(--danger-500);font-size:.875rem;font-weight:500;background:transparent;width:100%;transition:all var(--transition-fast)}.logout-btn:hover{background:var(--danger-50)}.checkbox-wrapper{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-wrapper input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-500);cursor:pointer}.toast-custom{background:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important}.btn-google{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.85rem;background:#fff;color:#3c4043;font-size:.95rem;font-weight:500;border:1px solid #dadce0;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:1.5rem}.btn-google:hover{background:#f8f9fa;box-shadow:var(--shadow-sm)}.btn-google:disabled{opacity:.7;cursor:not-allowed}.login-divider{display:flex;align-items:center;text-align:center;margin-bottom:1.5rem}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.login-divider span{padding:0 1rem;color:var(--text-muted);font-size:.85rem}.print-section-footer{display:flex;justify-content:center;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn-print{display:inline-flex;align-items:center;gap:.6rem;padding:.7rem 1.5rem;background:var(--text-secondary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-print:hover{background:var(--text-primary);box-shadow:var(--shadow-sm)}.btn-print:active{transform:translateY(0)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.blog-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column;box-shadow:var(--shadow-xs)}.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.blog-card-cover{width:100%;height:180px;overflow:hidden;position:relative}.blog-card-cover img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.blog-card:hover .blog-card-cover img{transform:scale(1.05)}.blog-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}.blog-card-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;line-height:1.3}.blog-card-excerpt{font-size:.85rem;color:var(--text-muted);line-height:1.6;margin-bottom:1rem;flex:1}.blog-card-meta{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.blog-meta-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-muted)}.blog-card-actions{display:flex;gap:.35rem;border-top:1px solid var(--border-color);padding-top:.75rem;margin-top:auto}.blog-view-content{max-height:500px;overflow-y:auto}.admission-form-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2rem;max-width:900px;box-shadow:var(--shadow-sm)}.admission-form{max-width:800px;margin:0 auto}.form-header{display:flex;align-items:center;gap:1rem;border-bottom:2px solid var(--border-color);padding-bottom:1rem;margin-bottom:1.5rem}.school-name-print{font-size:1.3rem;font-weight:800;color:var(--text-primary)}.form-title-print{text-align:center;font-size:1rem;font-weight:700;margin:1.25rem 0;text-transform:uppercase;letter-spacing:.06em;padding:.5rem;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius-md);color:var(--primary-600)}.photo-box-print{width:100px;height:120px;border:2px solid var(--border-color);border-radius:var(--radius-md);float:right;margin-left:1rem;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-muted);overflow:hidden;background:var(--bg-tertiary)}.info-grid-print{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.info-item-print{display:flex;padding:.35rem 0;border-bottom:1px dotted var(--border-color)}.info-label-print{font-weight:600;min-width:140px;font-size:.8rem;color:var(--text-muted)}.info-value-print{font-size:.875rem;color:var(--text-primary);font-weight:500}.section-title-print{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--primary-600);border-bottom:2px solid var(--primary-500);padding-bottom:.25rem;margin:1.5rem 0 .75rem}.fee-table-print{width:100%;border-collapse:collapse;margin:.75rem 0}.fee-table-print th{background:var(--primary-50);padding:.5rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;text-align:left;border:1px solid var(--border-color);color:var(--text-muted)}.fee-table-print td{padding:.5rem .75rem;font-size:.85rem;border:1px solid var(--border-color);color:var(--text-secondary)}.declaration-print{margin-top:2rem;padding:.75rem;border:1px solid var(--warning-100);border-radius:var(--radius-md);font-size:.8rem;color:var(--text-muted);line-height:1.6;background:var(--warning-50)}.footer-signatures{margin-top:3rem;display:flex;justify-content:space-between;font-size:.85rem}.signature-line-print{border-top:1px solid var(--text-muted);padding-top:.5rem;min-width:180px;text-align:center;color:var(--text-muted);font-size:.8rem}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:.35rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:140px;z-index:50;display:none;overflow:hidden}.dropdown:hover .dropdown-menu,.dropdown:focus-within .dropdown-menu{display:block}.dropdown-menu button{display:block;width:100%;padding:.6rem 1rem;text-align:left;font-size:.85rem;color:var(--text-secondary);background:transparent;transition:all var(--transition-fast)}.dropdown-menu button:hover{background:var(--bg-tertiary);color:var(--text-primary)}@media print{.sidebar,.header,.print-section-footer,.btn-print,.page-header-actions,.filter-bar,.search-bar,.modal-overlay,.no-print{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}body{background:#fff!important;color:#1a1a1a!important}.card{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:none!important}.print-only-header{display:block!important}.print-area{margin:0;padding:0;width:100%}.data-table th{background-color:#f1f5f9;color:#0f172a;-webkit-print-color-adjust:exact;print-color-adjust:exact}.data-table td{color:#000}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#e8ecf4,#f8fafc);position:relative;overflow:hidden;padding:2rem}.auth-page-admin{background:linear-gradient(135deg,#fffbeb,#fef3c7,#f8fafc)}.auth-bg-effects{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.auth-bg-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.auth-bg-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(37,99,235,.08),transparent 70%);top:-150px;right:-100px;animation:auth-float-1 20s ease-in-out infinite}.auth-bg-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(124,58,237,.06),transparent 70%);bottom:-100px;left:-100px;animation:auth-float-2 25s ease-in-out infinite}.auth-bg-orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(37,99,235,.04),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:auth-float-3 18s ease-in-out infinite}.auth-bg-orb-admin.auth-bg-orb-1{background:radial-gradient(circle,rgba(245,158,11,.08),transparent 70%)}.auth-bg-orb-admin.auth-bg-orb-2{background:radial-gradient(circle,rgba(239,68,68,.05),transparent 70%)}.auth-bg-orb-admin.auth-bg-orb-3{background:radial-gradient(circle,rgba(251,191,36,.04),transparent 70%)}@keyframes auth-float-1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-30px,20px) scale(1.05)}66%{transform:translate(20px,-15px) scale(.95)}}@keyframes auth-float-2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(25px,-20px) scale(1.08)}66%{transform:translate(-15px,25px) scale(.92)}}@keyframes auth-float-3{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.15)}}.auth-card{width:100%;max-width:440px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg);position:relative;z-index:1}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--primary-500);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;position:relative;overflow:hidden}.auth-logo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.15));pointer-events:none}.auth-logo-icon{font-size:1.75rem;position:relative;z-index:1;color:#fff}.auth-logo-admin,.auth-logo-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.auth-logo-shield{font-size:1.75rem;color:#fff;position:relative;z-index:1}.auth-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin-bottom:.4rem;letter-spacing:-.02em}.auth-subtitle{font-size:.875rem;color:var(--text-muted);line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.auth-field{display:flex;flex-direction:column;gap:.45rem}.auth-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:.35rem;letter-spacing:.02em;text-transform:uppercase}.auth-label-icon{font-size:.9rem;color:var(--text-muted)}.auth-input{width:100%;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border-color-input);border-radius:var(--radius-md);color:var(--text-primary);font-size:.925rem;font-family:inherit;transition:all .2s ease;outline:none}.auth-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #2563eb1a}.auth-input::placeholder{color:var(--text-placeholder)}.auth-input-group{position:relative}.auth-input-group .auth-input{padding-right:3rem}.auth-toggle-password{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color .2s ease}.auth-toggle-password:hover{color:var(--text-primary)}.auth-actions-row{display:flex;justify-content:flex-end;margin-top:-.5rem}.auth-link{font-size:.85rem;color:var(--primary-500);text-decoration:none;font-weight:500;transition:color .2s ease;display:inline-flex;align-items:center;gap:.25rem}.auth-link:hover{color:var(--primary-600)}.auth-link-subtle{color:var(--text-muted);font-size:.8rem}.auth-link-subtle:hover{color:var(--text-secondary)}.auth-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.5rem;border-radius:var(--radius-md);font-size:.925rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all .25s ease;text-decoration:none;width:100%;margin-top:.5rem}.auth-btn-primary{background:var(--primary-500);color:#fff}.auth-btn-primary:hover:not(:disabled){background:var(--primary-600);box-shadow:var(--shadow-sm)}.auth-btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-btn-admin{background:#d97706;color:#fff}.auth-btn-admin:hover:not(:disabled){background:#b45309;box-shadow:var(--shadow-sm)}.auth-btn-admin:disabled{opacity:.6;cursor:not-allowed}.auth-btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.auth-btn-outline:hover{background:var(--bg-tertiary);border-color:var(--border-color-input);color:var(--text-primary)}.auth-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:auth-spin .6s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-footer{margin-top:2rem;text-align:center;padding-top:1.25rem;border-top:1px solid var(--border-color)}.password-strength{display:flex;align-items:center;gap:.75rem;margin-top:.35rem}.password-strength-bar{flex:1;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.password-strength-fill{height:100%;border-radius:2px;transition:width .3s ease,background .3s ease}.password-strength-label{font-size:.7rem;font-weight:600;white-space:nowrap;letter-spacing:.02em}.auth-field-error{font-size:.78rem;color:var(--danger-500);margin-top:.15rem;font-weight:500}.auth-success{text-align:center;padding:1rem 0}.auth-success-icon{color:var(--success-500);margin-bottom:1.5rem;animation:auth-check-pop .5s ease-out}@keyframes auth-check-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@media(max-width:480px){.auth-page{padding:1rem}.auth-card{padding:1.75rem;border-radius:var(--radius-lg)}.auth-title{font-size:1.35rem}.auth-logo{width:56px;height:56px}.auth-logo-icon,.auth-logo-shield{font-size:1.5rem}}.filter-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center}.filter-modal-container{width:95vw;max-width:1200px;height:90vh;max-height:800px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl)}.filter-modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:flex-start}.header-title{display:flex;gap:1rem;align-items:flex-start}.header-title .icon-blue{color:var(--primary-500);background:var(--primary-50);padding:.5rem;border-radius:var(--radius-md);width:42px;height:42px}.header-title h2{font-size:1.15rem;color:var(--text-primary);margin-bottom:.25rem}.header-title p{font-size:.85rem;color:var(--text-muted)}.filter-modal-body{display:flex;flex:1;overflow:hidden}.filter-sidebar{width:250px;border-right:1px solid var(--border-color);background:var(--bg-tertiary);padding:1.5rem 1rem;overflow-y:auto}.filter-sidebar .sidebar-title{font-size:.7rem;font-weight:700;color:var(--text-muted);letter-spacing:.05em;margin-bottom:1rem;padding-left:.5rem}.report-list{list-style:none}.report-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;margin-bottom:.2rem;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.report-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.report-item.active{background:var(--primary-50);color:var(--primary-600);font-weight:600}.filter-content{flex:1;padding:1.5rem 2rem;overflow-y:auto;background:var(--bg-secondary)}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-title{font-size:.8rem;font-weight:700;color:var(--text-primary);letter-spacing:.04em;text-transform:uppercase}.filter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem}.date-inputs{display:flex;align-items:center;gap:.5rem}.date-separator{color:var(--text-muted)}.columns-section{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.columns-section .section-title{margin-bottom:1rem}.columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem;cursor:pointer}.custom-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--border-color-input);border-radius:4px;background:var(--bg-input);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.custom-checkbox:checked{background:var(--primary-500);border-color:var(--primary-500)}.custom-checkbox:checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.sort-group-section{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1rem}.filter-modal-footer{padding:1.25rem 2rem;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-tertiary)}.footer-right{display:flex;gap:1rem}@keyframes slideUpFade{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-skeleton{0%,to{opacity:1}50%{opacity:.5}}.animate-slide-up{animation:slideUpFade .4s ease-out forwards}.skeleton{background:var(--border-color);border-radius:var(--radius-sm);animation:pulse-skeleton 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-text{height:1rem;width:100%;margin-bottom:.5rem}.skeleton-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-xs)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;background:var(--bg-card);border:1px dashed var(--border-color-input);border-radius:var(--radius-xl)}.empty-state-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:1.25rem}.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state-description{font-size:.925rem;color:var(--text-muted);max-width:320px;margin-bottom:1.5rem;line-height:1.5}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px);border-color:var(--border-color-input)}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.stat-card-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.stat-card-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.stat-card-icon.blue{background:var(--primary-50);color:var(--primary-600)}.stat-card-icon.green{background:var(--success-50);color:var(--success-600)}.stat-card-icon.amber{background:var(--warning-50);color:var(--warning-600)}.stat-card-icon.red{background:var(--danger-50);color:var(--danger-600)}.stat-card-icon.purple{background:#f3e8ff;color:var(--accent-600)}.stat-card-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.5rem}.stat-card-trend{display:inline-flex;align-items:center;gap:.25rem;font-size:.85rem;font-weight:500}.stat-card-trend.positive{color:var(--success-600)}.stat-card-trend.negative{color:var(--danger-600)}.stat-card-trend.neutral{color:var(--text-muted)}.badge{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-success{background:var(--success-50);color:var(--success-600);border:1px solid var(--success-100)}.badge-warning{background:var(--warning-50);color:var(--warning-600);border:1px solid var(--warning-100)}.badge-danger{background:var(--danger-50);color:var(--danger-600);border:1px solid var(--danger-100)}.badge-info{background:var(--info-50);color:var(--info-600);border:1px solid var(--info-100)}.badge-primary{background:var(--primary-50);color:var(--primary-600);border:1px solid var(--primary-100)}.badge-neutral{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}
