/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-outline-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.w-full{width:100%}.shrink-0{flex-shrink:0}.cursor-pointer{cursor:pointer}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-full{border-radius:3.40282e38px}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-input{border-color:var(--input)}.border-primary{border-color:var(--primary)}.bg-background{background-color:var(--background)}.bg-destructive{background-color:var(--destructive)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.fill-current{fill:currentColor}.whitespace-nowrap{white-space:nowrap}.text-current{color:currentColor}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary-foreground{color:var(--secondary-foreground)}.underline-offset-4{text-underline-offset:4px}.ring-offset-background{--tw-ring-offset-color:var(--background)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.placeholder\:text-muted-foreground::-moz-placeholder{color:var(--muted-foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media (hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive)90%,transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary)90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--secondary)80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--ring)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:var(--background)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}:root{color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(64.6% .222 41.116);--chart-2:oklch(60% .118 184.704);--chart-3:oklch(39.8% .07 227.392);--chart-4:oklch(82.8% .189 84.429);--chart-5:oklch(76.9% .188 70.08);--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0);background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(48.8% .243 264.376);--chart-2:oklch(69.6% .17 162.48);--chart-3:oklch(76.9% .188 70.08);--chart-4:oklch(62.7% .265 303.9);--chart-5:oklch(64.5% .246 16.439);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}@layer base{*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring)50%,transparent)}}body{background-color:var(--background);color:var(--foreground)}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100vh;overflow:hidden}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.loading-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #a5b4fc;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner p{color:#fff;font-size:16px;font-weight:500}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:4px;font-size:14px;text-align:center}.dashboard-layout{display:flex;height:100vh;width:100vw;background:#f8fafc}.dashboard-sidebar{width:280px;background:#1f2937;display:flex;flex-direction:column;box-shadow:4px 0 10px #0000001a}.sidebar-header{padding:24px 20px;border-bottom:1px solid #374151}.sidebar-logo{display:flex;align-items:center;gap:12px;margin-bottom:8px}.logo-circle{width:40px;height:40px;background:#3b82f6;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.logo-icon{width:20px;height:20px;stroke-width:2;stroke:currentColor;fill:none}.sidebar-title h2{color:#f9fafb;font-size:18px;font-weight:600;margin:0}.sidebar-nav{flex:1;padding:20px 0}.sidebar-footer{padding:20px 0;border-top:1px solid #374151}.nav-item{display:flex;align-items:center;padding:12px 20px;color:#d1d5db;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;margin:0 12px;border-radius:8px}.nav-item:hover{background:#374151;color:#f9fafb}.nav-item.active{background:#3b82f6;color:#fff}.nav-item.logout-item:hover{background:#dc2626;color:#fff}.nav-icon{margin-right:12px;width:20px;height:20px}.nav-icon .icon{width:16px;height:16px;stroke-width:2;stroke:currentColor;fill:none}.icon{width:24px;height:24px;stroke-width:2;stroke:currentColor;fill:none}.dashboard-main{flex:1;display:flex;flex-direction:column;background:#f8fafc;overflow:hidden}.dashboard-header{background:#fff;padding:20px 32px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;min-height:80px}.university-info{display:flex;align-items:center;gap:16px}.header-logo{width:48px;height:48px;border-radius:8px}.university-details{display:flex;flex-direction:column}.university-name{font-size:18px;font-weight:700;color:#111827;line-height:1.2}.university-tagline{font-size:13px;color:#6b7280;font-weight:500}.student-info{display:flex;align-items:center;gap:24px}.student-details{display:flex;flex-direction:column;gap:4px}.detail-row{display:flex;align-items:center;gap:8px}.student-label{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.05em;min-width:80px}.student-value{font-size:14px;color:#111827;font-weight:600}.user-avatar{display:flex;align-items:center;gap:12px}.avatar-circle{width:48px;height:48px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.user-info{display:flex;flex-direction:column}.user-name{font-size:14px;font-weight:600;color:#111827;line-height:1.2}.user-role{font-size:12px;color:#6b7280;font-weight:500}.dashboard-content{flex:1;padding:32px;overflow-y:auto;background:#f8fafc}.content-header{margin-bottom:32px}.content-title{font-size:28px;font-weight:700;color:#111827;margin:0 0 8px}.content-subtitle{font-size:16px;color:#6b7280;font-weight:500;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-header{display:flex;align-items:center;gap:16px;margin-bottom:12px}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-icon.attendance{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.grades{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.stat-icon.credits{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-icon.fees{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon .icon{width:20px;height:20px;stroke-width:2;stroke:currentColor;fill:none}.stat-info{flex:1}.stat-title{font-size:14px;font-weight:600;color:#6b7280;margin:0 0 4px;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:24px;font-weight:700;color:#111827;margin:0}.stat-description{font-size:14px;color:#6b7280;margin:0;font-weight:500}.quick-actions,.info-sections,.academic-sections{margin-bottom:32px}.section-title{font-size:20px;font-weight:700;color:#111827;margin:0 0 20px}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.action-card,.info-card,.academic-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb;transition:all .2s ease;cursor:pointer}.action-card:hover,.info-card:hover,.academic-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.action-icon{width:48px;height:48px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:16px}.action-icon .icon{width:20px;height:20px;stroke-width:2;stroke:currentColor;fill:none}.action-card:nth-child(1) .action-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.action-card:nth-child(2) .action-icon{background:linear-gradient(135deg,#10b981,#059669)}.action-card:nth-child(3) .action-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.action-card:nth-child(4) .action-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.action-card h3,.info-card h3,.academic-card h3{font-size:16px;font-weight:600;color:#111827;margin:0 0 8px}.action-card p,.info-card p{font-size:14px;color:#6b7280;margin:0;line-height:1.5}.course-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.course-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.course-code{font-size:12px;font-weight:600;color:#3b82f6;background:#eff6ff;padding:4px 8px;border-radius:6px}.course-name{font-size:14px;font-weight:500;color:#111827;flex:1;margin:0 12px}.course-credits{font-size:12px;font-weight:500;color:#6b7280}.grade-summary{display:flex;flex-direction:column;gap:12px;margin-top:16px}.grade-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.semester{font-size:14px;font-weight:500;color:#111827}.gpa{font-size:14px;font-weight:600;color:#059669}.results-sections{margin-bottom:32px}.results-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.result-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.result-item:hover{background:#f1f5f9;border-color:#cbd5e1}.result-info{display:flex;flex-direction:column;gap:4px}.result-semester{font-size:16px;font-weight:600;color:#111827}.result-status{font-size:12px;font-weight:500;color:#059669;background:#dcfce7;padding:2px 8px;border-radius:4px;width:-moz-fit-content;width:fit-content}.result-actions{display:flex;gap:8px}.view-result-btn{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.view-result-btn:hover{background:#2563eb;transform:translateY(-1px)}.pdf-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000}.pdf-viewer{width:100vw;height:100vh;background:#fff;overflow:hidden;display:flex;flex-direction:column}.pdf-header{background:#f8fafc;padding:16px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.pdf-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.close-pdf-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.close-pdf-btn:hover{background:#f3f4f6;color:#374151}.pdf-content{flex:1;background:#fff;height:calc(100vh - 60px)}.pdf-content iframe{background:#fff;width:100%;height:100%}.fees-sections{margin-bottom:32px}.fees-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.fee-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.fee-item:hover{background:#f1f5f9;border-color:#cbd5e1}.fee-info{display:flex;flex-direction:column;gap:4px}.fee-semester{font-size:16px;font-weight:600;color:#111827}.fee-amount{font-size:14px;font-weight:500;color:#6b7280}.fee-status{padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.fee-status.paid{background:#dcfce7;color:#059669;border:1px solid #bbf7d0}.no-results-container{display:flex;justify-content:center;align-items:center;min-height:400px}.no-results-card{background:#fff;border-radius:12px;padding:48px 32px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb;text-align:center;max-width:400px;width:100%}.no-results-icon{width:64px;height:64px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#9ca3af}.no-results-icon .icon{width:28px;height:28px;stroke-width:1.5}.no-results-card h3{font-size:20px;font-weight:600;color:#111827;margin:0 0 12px}.no-results-card p{font-size:14px;color:#6b7280;line-height:1.6;margin:0}.student-details-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d;border:1px solid #e5e7eb}.student-details-card h3{font-size:18px;font-weight:600;color:#111827;margin:0 0 20px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.detail-label{font-size:14px;font-weight:600;color:#374151;text-transform:capitalize}.detail-value{font-size:14px;font-weight:500;color:#111827;text-align:right}.calendar-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.calendar-info{display:flex;flex-direction:column;gap:4px}.calendar-year{font-size:14px;font-weight:600;color:#111827}.institute-name{font-size:12px;color:#6b7280}.holiday-stats{display:flex;gap:16px;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e5e7eb;min-width:80px}.stat-label{font-size:10px;color:#6b7280;font-weight:500;text-align:center;line-height:1.2}.stat-count{font-size:16px;font-weight:700;color:#111827;margin-top:2px}.calendar-chart{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;margin-bottom:16px}.chart-header,.chart-row{display:grid;grid-template-columns:40px 60px repeat(31,24px);border-bottom:1px solid #e5e7eb}.chart-row:last-child{border-bottom:none}.chart-cell{padding:6px 4px;text-align:center;font-size:11px;border-right:1px solid #f3f4f6;display:flex;align-items:center;justify-content:center;min-height:32px}.chart-cell:last-child{border-right:none}.chart-cell.header{background:#f8fafc;font-weight:600;color:#374151;font-size:10px}.chart-cell.day-header{font-size:9px}.chart-cell.month-cell{font-weight:600;color:#111827;background:#f8fafc}.chart-cell.day-cell{background:#fff}.chart-cell.day-cell.weekend{background:#10b981}.chart-cell.day-cell.invalid{background:#f3f4f6}.calendar-legend{display:flex;gap:16px;align-items:center;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.legend-color{width:16px;height:16px;border-radius:2px;border:1px solid #e5e7eb}.legend-color.weekend{background:#10b981}.legend-color.holiday{background:#f59e0b}.legend-color.event{background:#3b82f6}.dashboard{height:100vh;width:100vw;background:linear-gradient(135deg,#e5e7eb,#d1d5db);display:flex;flex-direction:column;overflow:hidden}.dashboard-header{background:#fff;padding:24px 32px;box-shadow:0 2px 4px #0000001a;text-align:center}.dashboard-header h1{color:#374151;font-size:24px;font-weight:600;margin-bottom:8px}.dashboard-header p{color:#6b7280;font-size:16px}.dashboard-card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a}.dashboard-card h3{color:#374151;font-size:18px;font-weight:600;margin-bottom:16px}.dashboard-card p{color:#6b7280;font-size:14px;margin-bottom:8px}.dashboard-button{margin-right:12px;margin-bottom:8px}.login-container{height:100vh;width:100vw;background:linear-gradient(135deg,#e5e7eb,#d1d5db);display:flex;align-items:center;justify-content:center;overflow:hidden;position:fixed;top:0;left:0}.login-card{width:100%;max-width:400px;margin-bottom:26px;background:#fff;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:40px 32px;display:flex;flex-direction:column;align-items:center;border-top:4px solid #a5b4fc}.footer{width:100vw;background:#22292f;color:#f3f4f6;font-size:14px;display:flex;justify-content:space-between;align-items:center;padding:12px 40px 10px;position:fixed;left:0;bottom:0;z-index:10}.footer a{color:#a5b4fc;text-decoration:underline}.header-section{display:flex;align-items:center;gap:12px;margin-bottom:24px}.arrow-icon{color:#f59e0b}.login-title{color:#374151;font-size:24px;font-weight:600;text-align:center}.university-logo{margin-bottom:24px}.university-logo img{width:80px;height:80px;-o-object-fit:contain;object-fit:contain}.user-type-section{margin-bottom:24px}.user-type-indicator{display:flex;align-items:center;gap:8px}.purple-circle{width:12px;height:12px;background:#8b5cf6;border-radius:50%}.user-type-indicator span{color:#6b7280;font-size:14px;font-weight:500}.form-section{width:100%;display:flex;flex-direction:column;gap:16px}.form-input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.form-input:focus{outline:none;border-color:#a5b4fc;box-shadow:0 0 0 3px #a5b4fc1a}.form-input::-moz-placeholder{color:#9ca3af}.form-input::placeholder{color:#9ca3af}.checkbox-section{display:flex;align-items:center;gap:8px;margin:8px 0}.checkbox-label{color:#374151;font-size:14px;cursor:pointer}.portal-checkbox{width:16px;height:16px;accent-color:#a5b4fc;cursor:pointer}.links-section{display:flex;justify-content:space-between;margin:8px 0}.forgot-link,.signup-link{color:#a5b4fc;text-decoration:none;font-size:14px;cursor:pointer}.forgot-link:hover,.signup-link:hover{text-decoration:underline}.login-button{width:100%;padding:12px 24px;background:#a5b4fc;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:16px}.login-button:hover{background:#8b5cf6}.login-button:focus{outline:none;box-shadow:0 0 0 3px #a5b4fc4d}.login-button:disabled{background:#9ca3af;cursor:not-allowed}
