@import"https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800&family=IBM+Plex+Sans+Arabic:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&family=Tajawal:wght@400;500;700;800;900&display=swap";:root{--primary: 220 65% 20%;--primary-light: 220 60% 30%;--accent: 43 85% 50%;--accent-light: 43 90% 62%;--success: 142 70% 42%;--warning: 38 92% 50%;--danger: 0 72% 51%;--bg-base: 220 65% 6%;--bg-surface: 220 60% 10%;--bg-elevated: 220 55% 14%;--bg-overlay: 220 50% 18%;--border: 220 40% 22%;--border-subtle: 220 40% 17%;--text-primary: 210 40% 95%;--text-secondary: 215 25% 68%;--text-muted: 215 20% 45%;--gradient-primary: linear-gradient(135deg, hsl(220, 65%, 22%) 0%, hsl(43, 85%, 45%) 100%);--gradient-gold: linear-gradient(135deg, hsl(43, 85%, 48%) 0%, hsl(43, 75%, 58%) 100%);--gradient-dark: linear-gradient(180deg, hsl(220, 65%, 8%) 0%, hsl(220, 65%, 4%) 100%);--gradient-card: linear-gradient(135deg, hsl(220, 60%, 12%) 0%, hsl(220, 55%, 9%) 100%);--shadow-sm: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4), 0 2px 6px rgba(0,0,0,.3);--shadow-lg: 0 10px 25px rgba(0,0,0,.5), 0 4px 10px rgba(0,0,0,.4);--shadow-glow: 0 0 24px rgba(212,175,55,.2);--shadow-gold: 0 0 20px rgba(212,175,55,.3), 0 2px 8px rgba(212,175,55,.15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in: cubic-bezier(.55, 0, 1, .45);--ease: cubic-bezier(.4, 0, .2, 1)}.portal-finance,.portal-admin,.portal-students,.portal-student,.portal-dashboard{--primary: 220 65% 20%;--primary-light: 220 60% 30%;--accent: 43 85% 50%;--accent-light: 43 90% 62%;--bg-base: 220 65% 5%;--bg-surface: 220 60% 9%;--bg-elevated: 220 55% 13%;--bg-overlay: 220 50% 17%;--border: 220 35% 20%;--border-subtle: 220 35% 15%;--gradient-primary: linear-gradient(135deg, hsl(220, 65%, 22%) 0%, hsl(43, 85%, 48%) 100%);--shadow-glow: 0 0 24px rgba(212, 175, 55, .2)}.theme-light{--bg-base: 0 0% 100%;--bg-surface: 220 20% 97%;--bg-elevated: 220 20% 93%;--bg-overlay: 220 20% 89%;--border: 220 25% 82%;--border-subtle: 220 25% 88%;--text-primary: 220 65% 12%;--text-secondary: 220 40% 30%;--text-muted: 220 30% 50%;--gradient-card: none;--shadow-sm: 0 1px 3px rgba(0,40,100,.08);--shadow-md: 0 4px 12px rgba(0,40,100,.1);--shadow-lg: 0 10px 25px rgba(0,40,100,.12)}.theme-light body{color:hsl(var(--text-primary))}.theme-light .sidebar{background:#0b1832;border-color:#ecae13;--text-primary: 210 40% 95%;--text-secondary: 215 25% 80%;--text-muted: 215 20% 60%}.theme-light .topbar{background:#fff!important;border-bottom:2px solid hsl(43,85%,50%)!important;--text-primary: 220 65% 12%;--text-secondary: 220 40% 30%;--text-muted: 220 30% 50%;color:hsl(var(--text-primary))}.theme-light .topbar-title{color:#d49d11!important}.theme-light .theme-toggle-btn{border-color:#d49d11;background:hsl(43,85%,45% / .08);color:#bd8c0f}.theme-light .theme-toggle-btn:hover{background:hsl(43,85%,45% / .15);border-color:#eeb72b}.theme-light .badge-gold{background:hsl(43,85%,45% / .12);color:#a57a0d}.theme-light .card,.theme-light .kpi-card{background:#fff!important;border:1px solid hsl(220,25%,82%)!important;--text-primary: 220 65% 12%;--text-secondary: 220 40% 30%;--text-muted: 220 30% 50%;--bg-elevated: 220 20% 97%;--bg-overlay: 220 20% 93%;--border: 220 25% 82%;--border-subtle: 220 25% 88%;color:hsl(var(--text-primary))!important;box-shadow:var(--shadow-sm)!important}.theme-light .card:hover,.theme-light .kpi-card:hover{border-color:#ecae13!important;box-shadow:0 6px 16px #00286414!important}.theme-light .modal{background:#fff!important;border:1px solid hsl(43,85%,50%)!important;--text-primary: 220 65% 12%;--text-secondary: 220 40% 30%;--text-muted: 220 30% 50%;--bg-elevated: 220 20% 97%;--bg-overlay: 220 20% 93%;--border: 220 25% 82%;--border-subtle: 220 25% 88%;color:hsl(var(--text-primary))!important;box-shadow:var(--shadow-lg)!important}.theme-light .input,.theme-light .select{background:#fff!important;border:1px solid hsl(220,25%,82%)!important;color:#0b1832!important}.theme-light .input::placeholder{color:#8592ad!important}.theme-light .input:focus,.theme-light .select:focus{border-color:#d49d11!important;box-shadow:0 0 0 3px hsl(43,85%,45% / .15)!important;background:#fff!important}.theme-light .table-container{background:#fff!important;border:1px solid hsl(220,25%,85%)!important}.theme-light table{background:#fff!important}.theme-light thead{background:#edeff3!important;border-bottom:2px solid hsl(220,25%,82%)!important}.theme-light th{color:#0d1e3f!important}.theme-light td{border-bottom:1px solid hsl(220,25%,90%)!important;color:#0b1832!important}.theme-light tbody tr:hover{background:#f3f4f7!important}.theme-light tbody tr:nth-child(2n){background:#fafbfc!important}.theme-light tbody tr:nth-child(2n):hover{background:#f3f4f7!important}.theme-light .divider,.theme-light .divider-v{background:#d2d8e4!important}.theme-light .search-bar{background:#f3f4f7!important;border:1px solid hsl(220,25%,82%)!important}.theme-light .search-bar input{color:#0b1832!important}.theme-light .search-bar input::placeholder{color:#7585a3!important}.theme-light .search-bar:focus-within{border-color:#d49d11!important;box-shadow:0 0 0 3px hsl(43,85%,45% / .15)!important}.theme-light .btn-secondary{background:#f3f4f7!important;border:1px solid hsl(220,25%,82%)!important;color:#0b1832!important}.theme-light .btn-secondary:hover{background:#e7e9ef!important;border-color:#a6b2c9!important}.theme-light .btn-ghost{color:#2e426b!important}.theme-light .btn-ghost:hover{background:#f0f1f5!important;color:#0b1832!important}.theme-light .badge-blue{background:#2a6df41a;color:#093eaa!important}.theme-light .badge-green{background:#22c35d1a;color:#136c34!important}.theme-light .badge-yellow{background:#f59f0a1a;color:#935f06!important}.theme-light .badge-red{background:#e633331a;color:#9f1414!important}.theme-light .badge-gray{background:#6270841a;color:#47566b!important}.theme-light .badge-purple{background:#8347eb1a;color:#5014b8!important}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Tajawal,Cairo,IBM Plex Sans Arabic,Inter,-apple-system,sans-serif;background:hsl(var(--bg-base));color:hsl(var(--text-primary));line-height:1.6;min-height:100vh;direction:rtl;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:hsl(var(--text-primary))}p{color:hsl(var(--text-secondary))}a{color:hsl(var(--primary));text-decoration:none;transition:opacity .15s}a:hover{opacity:.8}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:hsl(var(--bg-surface))}::-webkit-scrollbar-thumb{background:hsl(var(--border));border-radius:999px}::-webkit-scrollbar-thumb:hover{background:hsl(var(--text-muted))}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.flex-1{flex:1 1 0%}.flex-wrap{flex-wrap:wrap}.shrink-0{flex-shrink:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.min-h-screen{min-height:100vh}.h-screen{height:100vh}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.top-0{top:0}.inset-0{top:0;right:0;bottom:0;left:0}.z-10{z-index:10}.z-50{z-index:50}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-3{padding-right:.75rem;padding-left:.75rem}.px-4{padding-right:1rem;padding-left:1rem}.px-6{padding-right:1.5rem;padding-left:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-muted{color:hsl(var(--text-muted))}.text-secondary{color:hsl(var(--text-secondary))}.text-primary-color{color:hsl(var(--primary))}.text-success{color:hsl(var(--success))}.text-warning{color:hsl(var(--warning))}.text-danger{color:hsl(var(--danger))}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.bg-base{background:hsl(var(--bg-base))}.bg-surface{background:hsl(var(--bg-surface))}.bg-elevated{background:hsl(var(--bg-elevated))}.bg-primary{background:hsl(var(--primary))}.bg-success{background:hsl(var(--success))}.bg-danger{background:hsl(var(--danger))}.bg-warning{background:hsl(var(--warning))}.border{border:1px solid hsl(var(--border))}.border-t{border-top:1px solid hsl(var(--border))}.border-b{border-bottom:1px solid hsl(var(--border))}.border-subtle{border:1px solid hsl(var(--border-subtle))}.rounded{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-64{width:16rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.mx-auto{margin-right:auto;margin-left:auto}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.col-span-1{grid-column:span 1 / span 1}.col-span-2{grid-column:span 2 / span 2}.col-span-3{grid-column:span 3 / span 3}.col-span-4{grid-column:span 4 / span 4}.col-span-5{grid-column:span 5 / span 5}.col-span-6{grid-column:span 6 / span 6}.col-span-7{grid-column:span 7 / span 7}.col-span-8{grid-column:span 8 / span 8}.col-span-9{grid-column:span 9 / span 9}.col-span-10{grid-column:span 10 / span 10}.col-span-11{grid-column:span 11 / span 11}.col-span-12{grid-column:span 12 / span 12}.order-1{order:1}.order-2{order:2}.order-3{order:3}@media(min-width:768px){.md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.md\:col-span-1{grid-column:span 1 / span 1}.md\:col-span-2{grid-column:span 2 / span 2}.md\:col-span-3{grid-column:span 3 / span 3}.md\:col-span-4{grid-column:span 4 / span 4}.md\:col-span-5{grid-column:span 5 / span 5}.md\:col-span-6{grid-column:span 6 / span 6}.md\:col-span-12{grid-column:span 12 / span 12}.md\:flex{display:flex}.md\:inline-flex{display:inline-flex}.md\:block{display:block}.md\:hidden{display:none}.hidden.md\:block{display:block}.hidden.md\:flex{display:flex}.hidden.md\:inline-flex{display:inline-flex}}@media(min-width:1024px){.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:col-span-1{grid-column:span 1 / span 1}.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.lg\:col-span-4{grid-column:span 4 / span 4}.lg\:col-span-5{grid-column:span 5 / span 5}.lg\:col-span-6{grid-column:span 6 / span 6}.lg\:col-span-7{grid-column:span 7 / span 7}.lg\:col-span-8{grid-column:span 8 / span 8}.lg\:col-span-9{grid-column:span 9 / span 9}.lg\:col-span-10{grid-column:span 10 / span 10}.lg\:col-span-11{grid-column:span 11 / span 11}.lg\:col-span-12{grid-column:span 12 / span 12}.lg\:order-1{order:1}.lg\:order-2{order:2}.lg\:order-3{order:3}}.card{background:var(--gradient-card);border:1px solid hsl(var(--border));border-radius:var(--radius-lg);padding:1.5rem;transition:box-shadow .2s var(--ease),border-color .2s var(--ease)}.card:hover{box-shadow:var(--shadow-lg);border-color:hsl(var(--border-subtle))}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.kpi-card{background:var(--gradient-card);border:1px solid hsl(var(--border));border-radius:var(--radius-lg);padding:1.5rem;position:relative;overflow:hidden;transition:all .25s var(--ease-out);cursor:pointer}.kpi-card:before{content:"";position:absolute;top:0;right:0;width:100%;height:2px;background:var(--gradient-primary);opacity:0;transition:opacity .25s var(--ease-out)}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow);border-color:hsl(var(--primary) / .3)}.kpi-card:hover:before{opacity:1}.kpi-icon{width:2.5rem;height:2.5rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.kpi-value{font-size:1.875rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.kpi-label{font-size:.8125rem;color:hsl(var(--text-muted));margin-top:.25rem}.kpi-trend{font-size:.75rem;display:flex;align-items:center;gap:.25rem;margin-top:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .15s var(--ease);white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #d4af374d}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #d4af3766;transform:translateY(-1px)}.btn-secondary{background:hsl(var(--bg-elevated));color:hsl(var(--text-primary));border:1px solid hsl(var(--border))}.btn-secondary:hover:not(:disabled){background:hsl(var(--bg-overlay));border-color:hsl(var(--primary) / .4)}.btn-ghost{background:transparent;color:hsl(var(--text-secondary))}.btn-ghost:hover:not(:disabled){background:hsl(var(--bg-elevated));color:hsl(var(--text-primary))}.btn-danger{background:hsl(var(--danger));color:#fff}.btn-danger:hover:not(:disabled){background:#cc1919;transform:translateY(-1px)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem;border-radius:var(--radius-sm)}.btn-lg{padding:.875rem 2rem;font-size:1rem;border-radius:var(--radius-lg)}.btn-icon{width:2.25rem;height:2.25rem;padding:0;border-radius:var(--radius-md)}.input-group{display:flex;flex-direction:column;gap:.375rem}.input-label{font-size:.8125rem;font-weight:500;color:hsl(var(--text-secondary))}.input{width:100%;padding:.625rem .875rem;background:hsl(var(--bg-elevated));border:1px solid hsl(var(--border));border-radius:var(--radius-md);color:hsl(var(--text-primary));font-size:.9375rem;font-family:inherit;transition:all .15s var(--ease);outline:none;direction:rtl}.input::placeholder{color:hsl(var(--text-muted))}.input:focus{border-color:hsl(var(--primary) / .7);box-shadow:0 0 0 3px hsl(var(--primary) / .1);background:hsl(var(--bg-overlay))}.input-with-icon{position:relative}.input-with-icon .input{padding-right:2.75rem}.input-icon{position:absolute;right:.875rem;top:50%;transform:translateY(-50%);color:hsl(var(--text-muted));pointer-events:none}.input-error{border-color:hsl(var(--danger))}.input-error:focus{box-shadow:0 0 0 3px hsl(var(--danger) / .1)}.error-msg{font-size:.75rem;color:hsl(var(--danger));margin-top:.25rem}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;padding:.625rem 2.5rem .625rem .875rem;background:hsl(var(--bg-elevated)) 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%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat left .875rem center;border:1px solid hsl(var(--border));border-radius:var(--radius-md);color:hsl(var(--text-primary));font-size:.9375rem;font-family:inherit;transition:all .15s;cursor:pointer;outline:none;direction:rtl}.select:focus{border-color:hsl(var(--primary) / .7);box-shadow:0 0 0 3px hsl(var(--primary) / .1)}.table-container{width:100%;overflow-x:auto;border-radius:var(--radius-lg);border:1px solid hsl(var(--border))}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:hsl(var(--bg-elevated));border-bottom:1px solid hsl(var(--border))}th{padding:.875rem 1rem;text-align:right;font-weight:600;font-size:.8125rem;color:hsl(var(--text-secondary));white-space:nowrap}td{padding:.875rem 1rem;border-bottom:1px solid hsl(var(--border-subtle));color:hsl(var(--text-primary));vertical-align:middle}tbody tr{transition:background .1s}tbody tr:hover{background:hsl(var(--bg-elevated))}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500;white-space:nowrap}.badge-blue{background:#2a6df426;color:#6e9cf7}.badge-green{background:#22c35d26;color:#52e086}.badge-yellow{background:#f59f0a26;color:#f8bc54}.badge-red{background:#e6333326;color:#e77}.badge-gray{background:#62708433;color:#94a3b8}.badge-purple{background:#8347eb26;color:#b28cf2}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fadeIn .15s var(--ease-out)}.modal{background:hsl(var(--bg-surface));border:1px solid hsl(var(--border));border-radius:var(--radius-xl);width:100%;max-width:32rem;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s var(--ease-out)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid hsl(var(--border))}.modal-body{padding:1.5rem}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid hsl(var(--border))}.sidebar{width:16rem;background:hsl(var(--bg-surface));border-left:1px solid hsl(var(--border));display:flex;flex-direction:column;height:100vh;position:sticky;top:0;z-index:20}.sidebar-logo{height:4rem;display:flex;align-items:center;padding:0 1.25rem;border-bottom:1px solid hsl(var(--border));gap:.75rem}.logo-icon{width:2rem;height:2rem;background:var(--gradient-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;color:#fff;flex-shrink:0}.sidebar-nav{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.nav-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:hsl(var(--text-muted));padding:.75rem .75rem .375rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;border-radius:var(--radius-md);color:hsl(var(--text-secondary));font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s var(--ease);text-decoration:none;border:none;background:transparent;width:100%;text-align:right;font-family:inherit}.nav-item:hover{background:hsl(var(--bg-elevated));color:hsl(var(--text-primary))}.nav-item.active{background:hsl(var(--accent) / .12);color:hsl(var(--accent))}.sidebar .nav-item .nav-icon,.sidebar .nav-item svg{color:#edb21d!important;stroke:#edb21d!important;flex-shrink:0}.nav-item.active .nav-icon,.nav-item.active svg{color:#f5c447!important;stroke:#f5c447!important}.sidebar-collapsed{width:4rem!important}.sidebar-collapsed .sidebar-logo span,.sidebar-collapsed .nav-section-title,.sidebar-collapsed .nav-item span{opacity:0;width:0;overflow:hidden;white-space:nowrap;transition:all .25s var(--ease-out)}.sidebar-collapsed .sidebar-logo{justify-content:center;padding:0 .75rem}.sidebar-collapsed .sidebar-nav{padding:.5rem;align-items:center}.sidebar-collapsed .nav-item{justify-content:center;padding:.75rem;border-radius:var(--radius-md)}.sidebar-collapsed .nav-item .nav-icon,.sidebar-collapsed .nav-item svg{color:hsl(var(--accent))!important;stroke:hsl(var(--accent))!important;flex-shrink:0}.sidebar-collapsed .logo-icon{background:var(--gradient-gold)}.sidebar-collapsed .nav-item.active{background:hsl(var(--accent) / .15);border-color:hsl(var(--accent) / .4)}.sidebar{transition:width .28s var(--ease-out)}.btn-sidebar-control{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:var(--radius-sm);border:1px solid hsl(var(--border));background:hsl(var(--bg-elevated) / .4);color:hsl(var(--text-secondary));cursor:pointer;transition:all .2s var(--ease)}.btn-sidebar-control:hover{background:hsl(var(--accent) / .15);border-color:hsl(var(--accent) / .5);color:hsl(var(--accent))}.btn-sidebar-control.text-danger:hover{background:hsl(var(--danger) / .15);border-color:hsl(var(--danger) / .4);color:hsl(var(--danger))}.btn-sidebar-control-mini{display:inline-flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;border-radius:4px;border:1px solid hsl(var(--border));background:hsl(var(--bg-elevated) / .4);color:hsl(var(--text-secondary));cursor:pointer;transition:all .2s var(--ease)}.btn-sidebar-control-mini:hover{background:hsl(var(--accent) / .15);border-color:hsl(var(--accent) / .5);color:hsl(var(--accent))}.btn-sidebar-control-mini.text-danger:hover{background:hsl(var(--danger) / .15);border-color:hsl(var(--danger) / .4);color:hsl(var(--danger))}.btn-sidebar-reveal{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:50%;background:var(--gradient-gold);color:#09142a!important;border:2px solid hsl(220,65%,15%);cursor:pointer;box-shadow:var(--shadow-glow);transition:all .2s var(--ease);margin-left:.75rem}.btn-sidebar-reveal:hover{transform:scale(1.08);box-shadow:var(--shadow-gold)}.theme-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:var(--radius-md);border:1px solid hsl(var(--accent) / .4);background:hsl(var(--accent) / .1);color:hsl(var(--accent));cursor:pointer;font-size:.8rem;font-family:inherit;transition:all .15s}.theme-toggle-btn:hover{background:hsl(var(--accent) / .2);border-color:hsl(var(--accent) / .6);box-shadow:var(--shadow-gold)}.text-gold{color:#ecae13}.bg-gold{background:var(--gradient-gold)}.border-gold{border-color:#ecae13}.badge-gold{background:#ecae1326;color:#f5c447}.glow-gold{box-shadow:var(--shadow-gold)}@media print{.sidebar,.topbar,.btn,.btn-print-hide,.modal-overlay,nav,header{display:none!important}body,html{background:#fff!important;color:#0f172a!important;font-size:12px;direction:rtl;font-family:Cairo,IBM Plex Sans Arabic,sans-serif}*{background:transparent!important;color:#0f172a!important;box-shadow:none!important;border-color:#cbd5e1!important}.print-voucher{background:#fff!important;color:#0f172a!important;width:100%;max-width:800px;margin:0 auto;padding:24px;font-family:Cairo,IBM Plex Sans Arabic,sans-serif}.print-header{display:flex!important;flex-direction:column;align-items:center;border-bottom:3px solid #1e3a5f;padding-bottom:16px;margin-bottom:20px}.print-header h1{font-size:18px;font-weight:700;color:#1e3a5f!important;margin:4px 0}.print-header .print-school-name{font-size:22px;font-weight:800;color:#c9a227!important;letter-spacing:1px}.print-header .print-date{font-size:11px;color:#475569!important;margin-top:4px}.print-table{width:100%;border-collapse:collapse;margin-top:12px}.print-table th{background:#1e3a5f!important;color:#fff!important;padding:8px 12px;font-size:11px;font-weight:600;text-align:right}.print-table td{padding:7px 12px;border-bottom:1px solid #E2E8F0;font-size:11px}.print-table tr:nth-child(2n) td{background:#f8fafc!important}.print-total-row td{background:#eff6ff!important;color:#1e3a5f!important;font-weight:700;border-top:2px solid #1e3a5f}.print-footer{margin-top:24px;padding-top:12px;border-top:1px solid #CBD5E1;display:flex;justify-content:space-between;font-size:10px;color:#64748b!important}.print-signature-box{border:1px solid #CBD5E1;height:60px;width:180px;border-radius:6px;display:flex;align-items:flex-end;padding:6px;font-size:10px}.no-print{display:none!important}.print-only{display:block!important}}.print-only{display:none}.topbar{height:4rem;background:linear-gradient(90deg,#09142a,#0e1d39);border-bottom:1px solid hsl(43,85%,35% / .3);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;position:sticky;top:0;z-index:10}.topbar-title{color:#f6c955}.avatar{width:2rem;height:2rem;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.avatar-lg{width:3rem;height:3rem;font-size:1rem}.divider{height:1px;background:hsl(var(--border));width:100%}.divider-v{width:1px;background:hsl(var(--border));height:100%}.spinner{width:1.5rem;height:1.5rem;border:2px solid hsl(var(--border));border-top-color:hsl(var(--primary));border-radius:50%;animation:spin .6s linear infinite}.spinner-lg{width:3rem;height:3rem;border-width:3px}.glass{background:hsl(var(--bg-surface) / .7);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid hsl(var(--border))}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-title{font-size:1.5rem;font-weight:700}.page-subtitle{font-size:.875rem;color:hsl(var(--text-muted));margin-top:.25rem}.empty-state{text-align:center;padding:3rem 2rem;color:hsl(var(--text-muted))}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.toast-container{position:fixed;top:1rem;left:1rem;z-index:200;display:flex;flex-direction:column;gap:.5rem;max-width:22rem}.toast{padding:.875rem 1rem;border-radius:var(--radius-md);border:1px solid;font-size:.875rem;display:flex;align-items:center;gap:.75rem;animation:slideRight .3s var(--ease-out);box-shadow:var(--shadow-lg)}.toast-success{background:#082b15;border-color:hsl(var(--success) / .4);color:hsl(var(--success))}.toast-error{background:#2d0606;border-color:hsl(var(--danger) / .4);color:hsl(var(--danger))}.toast-info{background:#031230;border-color:hsl(var(--primary) / .4);color:hsl(var(--primary))}.search-bar{display:flex;align-items:center;gap:.5rem;background:hsl(var(--bg-elevated));border:1px solid hsl(var(--border));border-radius:var(--radius-md);padding:.5rem .875rem;transition:all .15s}.search-bar:focus-within{border-color:hsl(var(--primary) / .5);box-shadow:0 0 0 3px hsl(var(--primary) / .08)}.search-bar input{background:none;border:none;outline:none;color:hsl(var(--text-primary));font-family:inherit;font-size:.9rem;width:100%}.search-bar input::placeholder{color:hsl(var(--text-muted))}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.pointer-events-none{pointer-events:none}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.transition{transition:all .15s var(--ease)}.hidden{display:none}.block{display:block}.inline-flex{display:inline-flex}.space-y-2>*+*{margin-top:.5rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.col-span-full{grid-column:1 / -1}.login-page{min-height:100vh;background:var(--gradient-dark);display:flex;align-items:center;justify-content:center;padding:1rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-20%;right:-10%;width:50vw;height:50vw;background:radial-gradient(circle,hsl(220 90% 56% / .08) 0%,transparent 70%);pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-20%;left:-10%;width:40vw;height:40vw;background:radial-gradient(circle,hsl(262 80% 60% / .06) 0%,transparent 70%);pointer-events:none}.login-card{background:hsl(var(--bg-surface));border:1px solid hsl(var(--border));border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:24rem;box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:slideUp .4s var(--ease-out)}.gateway-container{display:grid;grid-template-columns:repeat(1,1fr);gap:1.25rem;width:100%;max-width:44rem;z-index:2;animation:slideUp .5s var(--ease-out)}@media(min-width:640px){.gateway-container{grid-template-columns:repeat(2,1fr)}}.gateway-card{background:linear-gradient(135deg,hsl(var(--bg-surface) / .8),hsl(var(--bg-elevated) / .6));border:1px solid hsl(var(--border));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--radius-lg);padding:1.75rem;display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .3s cubic-bezier(.25,.8,.25,1);cursor:pointer;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);color:inherit}.gateway-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,var(--portal-accent-color) 0%,transparent 60%);opacity:0;transition:opacity .3s ease;pointer-events:none}.gateway-card:hover{transform:translateY(-5px);border-color:var(--portal-border-hover);box-shadow:0 10px 30px #00000080,var(--portal-glow)}.gateway-card:hover:before{opacity:.15}.gateway-icon-container{width:3.5rem;height:3.5rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;background:var(--portal-bg-icon);color:var(--portal-accent-color);font-size:1.5rem;transition:transform .3s ease}.gateway-card:hover .gateway-icon-container{transform:scale(1.1) rotate(3deg)}.login-admin-theme{--portal-accent-color: #3b82f6;--portal-border-hover: rgba(59, 130, 246, .5);--portal-glow: 0 0 25px rgba(59, 130, 246, .25);--portal-bg-icon: rgba(59, 130, 246, .1);background:radial-gradient(circle at 10% 20%,#06090e,#081021 90%)}.admin-glass-card{background:#111827b3;border:1px solid rgba(59,130,246,.25);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 50px #0009,0 0 40px #3b82f61a}.admin-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f640}.admin-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 15px #2563eb4d}.admin-btn:hover{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 6px 20px #2563eb80}.login-finance-theme{--portal-accent-color: #c29b38;--portal-border-hover: rgba(194, 155, 56, .5);--portal-glow: 0 0 25px rgba(194, 155, 56, .25);--portal-bg-icon: rgba(194, 155, 56, .1);background:radial-gradient(circle at 50% 50%,#060f09,#050c19)}.finance-glass-card{background:#0f172abf;border:1px solid rgba(194,155,56,.3);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 50px #0009,0 0 40px #c29b381f}.finance-input:focus{border-color:#c29b38;box-shadow:0 0 0 3px #c29b3840}.finance-btn{background:linear-gradient(135deg,#c29b38,#9e7a28);box-shadow:0 4px 15px #c29b384d;color:#fff}.finance-btn:hover{background:linear-gradient(135deg,#d4af37,#c29b38);box-shadow:0 6px 20px #c29b3880}.login-teacher-theme{--portal-accent-color: #8b5cf6;--portal-border-hover: rgba(139, 92, 246, .5);--portal-glow: 0 0 25px rgba(139, 92, 246, .25);--portal-bg-icon: rgba(139, 92, 246, .1);background:radial-gradient(circle at 90% 80%,#0c0712,#070e1d)}.teacher-glass-card{background:#170f1ebf;border:1px solid rgba(139,92,246,.25);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 50px #0009,0 0 40px #8b5cf61a}.teacher-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf640}.teacher-btn{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 15px #7c3aed4d}.teacher-btn:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 6px 20px #7c3aed80}.login-student-theme{--portal-accent-color: #06b6d4;--portal-border-hover: rgba(6, 182, 212, .5);--portal-glow: 0 0 25px rgba(6, 182, 212, .25);--portal-bg-icon: rgba(6, 182, 212, .1);background:radial-gradient(circle at 80% 20%,#051214,#080e21)}.student-glass-card{background:#0f171eb3;border:1px solid rgba(6,182,212,.25);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:0 20px 50px #000000b3,0 0 40px #06b6d426}.student-input:focus{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d440}.student-btn{background:linear-gradient(135deg,#0891b2,#0369a1);box-shadow:0 4px 15px #06b6d44d}.student-btn:hover{background:linear-gradient(135deg,#06b6d4,#0891b2);box-shadow:0 6px 20px #06b6d480}.floating-shape{position:absolute;border-radius:50%;background:radial-gradient(circle,var(--color-glow) 0%,transparent 70%);filter:blur(40px);pointer-events:none;animation:float 20s infinite ease-in-out;z-index:0}.shape-1{width:300px;height:300px;top:-100px;left:-50px;--color-glow: rgba(6, 182, 212, .12);animation-duration:25s}.shape-2{width:400px;height:400px;bottom:-150px;right:-50px;--color-glow: rgba(139, 92, 246, .1);animation-duration:30s}.shape-3{width:250px;height:250px;top:50%;left:60%;--color-glow: rgba(194, 155, 56, .08);animation-duration:18s;animation-delay:-5s}@keyframes float{0%,to{transform:translateY(0) scale(1) rotate(0)}50%{transform:translateY(-40px) scale(1.15) rotate(180deg)}}.badge-portal-tag{font-size:.65rem;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;font-weight:700;padding:.15rem .5rem;background:var(--tag-bg);color:var(--tag-color);border:1px solid var(--tag-border)}.tag-admin{--tag-bg: rgba(59, 130, 246, .15);--tag-color: #60a5fa;--tag-border: rgba(59, 130, 246, .3)}.tag-finance{--tag-bg: rgba(194, 155, 56, .15);--tag-color: #f3c24b;--tag-border: rgba(194, 155, 56, .3)}.tag-teacher{--tag-bg: rgba(139, 92, 246, .15);--tag-color: #a78bfa;--tag-border: rgba(139, 92, 246, .3)}.tag-student{--tag-bg: rgba(6, 182, 212, .15);--tag-color: #22d3ee;--tag-border: rgba(6, 182, 212, .3)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid hsl(var(--border));background:hsl(var(--bg-surface));transition:border-color .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm);position:relative}.table-container::-webkit-scrollbar{height:8px;width:8px}.table-container::-webkit-scrollbar-track{background:hsl(var(--bg-elevated));border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.table-container::-webkit-scrollbar-thumb{background:#8b47eb80;border-radius:99px;border:2px solid hsl(var(--bg-elevated))}.table-container::-webkit-scrollbar-thumb:hover{background:#a875f0}.modal-overlay{background:#08050c99;backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);transition:all .3s ease}.modal-glass{background:#120c1cd9;border:1px solid rgba(139,92,246,.3);backdrop-filter:blur(25px) saturate(180%);-webkit-backdrop-filter:blur(25px) saturate(180%);border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000080,0 0 40px #8b5cf626;color:hsl(var(--text-primary));max-width:36rem;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:modalEnter .3s cubic-bezier(.16,1,.3,1)}@keyframes modalEnter{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-glass-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(139,92,246,.2);background:#8b5cf60d}.modal-glass-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-glass-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid rgba(139,92,246,.2);background:#8b5cf605}.theme-light .modal-glass{background:#ffffffd9;border:1px solid rgba(43,85,50,.25);box-shadow:0 25px 50px -12px #0028641f,0 0 30px #2b553214;color:hsl(var(--text-primary))}.theme-light .modal-glass-header{border-bottom:1px solid rgba(220,25,82,.1);background:#dc195208}.theme-light .modal-glass-footer{border-top:1px solid rgba(220,25,82,.1)}@media print{.no-print,header,aside,nav,button,.btn,.theme-toggle-btn,.tabs-nav-container,.sidebar,.topbar,.no-print-wrapper,.vision-simulator-section,.uploader-dropzone,.actions-cell,th.actions-column,td.actions-column{display:none!important}body,.app-container,.main-content,.dashboard-content,.tab-pane,.portal-dashboard{background:#fff!important;color:#000!important;width:100%!important;margin:0!important;padding:0!important;float:none!important;overflow:visible!important}body{font-size:11pt!important;line-height:1.4!important;direction:rtl!important}h1,h2,h3,h4,h5,h6{color:#000!important;page-break-after:avoid;margin-top:15pt!important;margin-bottom:8pt!important}.card,.kpi-card,.tab-content-card{border:1px solid #dddddd!important;background:transparent!important;box-shadow:none!important;padding:10pt!important;margin-bottom:15pt!important;page-break-inside:avoid;border-radius:0!important}.table-container{border:1px solid #000000!important;box-shadow:none!important;overflow:visible!important;background:transparent!important;border-radius:0!important;width:100%!important;margin-bottom:15pt!important}table{width:100%!important;table-layout:auto!important;border-collapse:collapse!important;page-break-inside:auto}tr{page-break-inside:avoid;page-break-after:auto}thead{display:table-header-group!important;background:#f5f5f5!important;border-bottom:2px solid #000000!important}th{color:#000!important;font-weight:700!important;border:1px solid #000000!important;padding:6pt 8pt!important;background:#e9e9e9!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}td{color:#000!important;border:1px solid #dddddd!important;padding:6pt 8pt!important;background:transparent!important}tbody tr:nth-child(2n){background:#f9f9f9!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}input,select,textarea{border:none!important;background:transparent!important;padding:0!important;color:#000!important;font-size:11pt!important;box-shadow:none!important;-moz-appearance:none!important;appearance:none!important;-webkit-appearance:none!important}@page{size:A4 portrait;margin:1.5cm}.page-break{page-break-before:always!important}}
