:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;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}}.container{max-width:720px;margin:0 auto;padding:24px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.card{border:1px solid #d9d9d9;border-radius:8px;padding:16px;margin-top:16px}form{display:grid;grid-template-columns:1fr 1fr auto;gap:8px}.app{min-height:100vh;background:#15171b;color:#e5e7eb;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.admin-theme{background:#12151f}.page{display:flex;justify-content:center;padding:40px 16px}.card{width:100%;max-width:420px;border:1px solid #4b5563;border-radius:12px;padding:20px;background:#1f2430}.card.wide{max-width:560px}.tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.tab{background:#2d3748;border:1px solid #4b5563;color:#e5e7eb;padding:8px 12px;border-radius:8px;text-transform:capitalize}.tab.active{border-color:#22c55e}.form{display:grid;gap:10px}input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #4b5563;background:#111827;color:#e5e7eb}button,.btn-link{display:inline-block;padding:10px 14px;border-radius:8px;border:1px solid #16a34a;background:#16a34a;color:#fff;cursor:pointer;text-decoration:none}button:disabled{opacity:.65}.helper{margin-top:12px;color:#cbd5e1}.link-button{border:none;background:transparent;padding:0;color:#93c5fd}.error{color:#f87171;margin-top:10px}.success{color:#4ade80;margin-top:10px}.admin-approvals{margin-top:16px;padding-top:12px;border-top:1px solid #374151}.approval-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.approval-item{display:flex;justify-content:space-between;align-items:center;gap:10px;border:1px solid #374151;border-radius:8px;padding:10px}.portal-layout{display:flex;min-height:100vh;background:#15171b}.portal-nav{width:250px;background:#1f2430;border-right:1px solid #374151;padding:20px;display:flex;flex-direction:column}.portal-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #374151}.portal-header h2{margin:0 0 8px;font-size:20px;color:#22c55e}.user-info{font-size:14px;color:#9ca3af;margin:0}.role-badge{display:inline-block;background:#16a34a;color:#fff;padding:2px 8px;border-radius:4px;font-size:12px;text-transform:uppercase;margin-left:4px}.nav-links{flex:1;display:flex;flex-direction:column;gap:4px}.nav-link{display:block;padding:12px 16px;color:#e5e7eb;text-decoration:none;border-radius:8px;transition:background .2s}.nav-link:hover{background:#2d3748}.nav-link.active{background:#16a34a;color:#fff}.logout-btn{margin-top:16px;width:100%;background:#dc2626;border-color:#dc2626}.logout-btn:hover{background:#b91c1c}.portal-content{flex:1;padding:32px;overflow-y:auto}.dashboard-page{max-width:1200px;margin:0 auto}.dashboard-page h1{margin:0 0 8px;color:#22c55e}.subtitle{color:#9ca3af;margin:0 0 24px}.admin-section{margin-top:32px;padding:24px;background:#1f2430;border-radius:12px;border:1px solid #374151}.quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:16px}.quick-link-card{padding:20px;background:#2d3748;border:1px solid #4b5563;border-radius:8px;text-decoration:none;color:#e5e7eb;transition:border-color .2s}.quick-link-card:hover{border-color:#22c55e}.quick-link-card h3{margin:0 0 8px;color:#22c55e}.quick-link-card p{margin:0;color:#9ca3af;font-size:14px}.academic-section{max-width:1200px;margin:0 auto}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}.section-header h2{margin:0;color:#22c55e}.section-info{color:#9ca3af;font-size:14px;margin:4px 0 0}.breadcrumb{margin-bottom:16px;color:#9ca3af;font-size:14px}.breadcrumb a{color:#93c5fd;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.success-msg{padding:12px 16px;background:#065f46;border:1px solid #10b981;border-radius:8px;color:#d1fae5;margin-bottom:16px}.error-msg{padding:12px 16px;background:#7f1d1d;border:1px solid #dc2626;border-radius:8px;color:#fecaca;margin-bottom:16px}.loading{text-align:center;padding:40px;color:#9ca3af}.empty-state{text-align:center;padding:40px;color:#9ca3af;font-style:italic}.form-card{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:24px;margin-bottom:24px}.form-card h3{margin:0 0 20px;color:#22c55e}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;color:#e5e7eb;font-size:14px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #4b5563;background:#111827;color:#e5e7eb;font-family:inherit}.form-group textarea{resize:vertical}.recurring-picker{background:#1f2430;border:1px solid #374151;border-radius:14px;padding:14px;margin-bottom:12px;box-shadow:0 10px 24px #0000004d}.recurring-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.recurring-title{font-size:14px;font-weight:600;color:#e5e7eb}.nav-btn{background:#111827;border:1px solid #374151;color:#9ca3af;width:30px;height:30px;border-radius:50%;cursor:default}.weekday-grid{display:grid;grid-template-columns:repeat(7,minmax(36px,1fr));gap:8px;margin-bottom:12px}.weekday-chip{border:1px solid #374151;border-radius:10px;background:#111827;color:#e5e7eb;padding:10px 0;text-align:center;cursor:pointer;font-weight:600;font-size:12px}.weekday-chip.selected{background:#22c55e;border-color:#22c55e;color:#0f172a}.weekday-summary{font-size:12px;color:#9ca3af;text-align:center}.schedule-input{margin-top:6px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;margin-top:20px}.btn-primary{padding:10px 20px;background:#16a34a;border:1px solid #16a34a;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500}.btn-primary:hover{background:#15803d}.btn-secondary{padding:10px 20px;background:transparent;border:1px solid #4b5563;border-radius:8px;color:#e5e7eb;cursor:pointer;font-size:14px}.btn-secondary:hover{background:#374151}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.course-card{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:20px;transition:border-color .2s}.course-card:hover{border-color:#4b5563}.course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.course-header h3{margin:0;color:#e5e7eb;font-size:18px}.course-code{background:#374151;color:#9ca3af;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap}.course-description{color:#9ca3af;font-size:14px;margin:0 0 16px;line-height:1.5}.course-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-link{padding:8px 12px;background:#2563eb;border:1px solid #2563eb;border-radius:6px;color:#fff;text-decoration:none;font-size:13px;cursor:pointer}.btn-link:hover{background:#1d4ed8}.btn-edit{padding:8px 12px;background:transparent;border:1px solid #4b5563;border-radius:6px;color:#e5e7eb;font-size:13px;cursor:pointer}.btn-edit:hover{background:#374151}.btn-delete{padding:8px 12px;background:transparent;border:1px solid #dc2626;border-radius:6px;color:#dc2626;font-size:13px;cursor:pointer}.btn-delete:hover{background:#7f1d1d;color:#fecaca}.sections-list{display:grid;gap:16px}.section-card{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:20px}.section-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:16px}.section-header-row h3{margin:0;color:#e5e7eb;font-size:18px}.tutor-badge,.section-badge{background:#374151;color:#e5e7eb;padding:6px 12px;border-radius:6px;font-size:13px;white-space:nowrap}.section-details{color:#9ca3af;font-size:14px;margin-bottom:16px}.section-details p{margin:6px 0}.section-actions{display:flex;gap:8px;flex-wrap:wrap}.enrollments-table{background:#1f2430;border:1px solid #374151;border-radius:12px;overflow:hidden}.enrollments-table table{width:100%;border-collapse:collapse}.enrollments-table th{background:#2d3748;color:#e5e7eb;padding:12px;text-align:left;font-weight:600;font-size:14px;border-bottom:1px solid #374151}.enrollments-table td{padding:12px;color:#9ca3af;font-size:14px;border-bottom:1px solid #374151}.enrollments-table tr:last-child td{border-bottom:none}.status-select{padding:6px 10px;border-radius:6px;border:1px solid #4b5563;background:#111827;color:#e5e7eb;font-size:13px}.status-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase}.status-active{background:#065f46;color:#d1fae5;border-color:#10b981}.status-dropped{background:#7f1d1d;color:#fecaca;border-color:#dc2626}.status-completed{background:#1e3a8a;color:#bfdbfe;border-color:#3b82f6}.btn-delete-small{padding:6px 12px;background:transparent;border:1px solid #dc2626;border-radius:6px;color:#dc2626;font-size:12px;cursor:pointer}.btn-delete-small:hover{background:#7f1d1d;color:#fecaca}.capacity-info{margin-top:16px;padding:12px;background:#2d3748;border-radius:8px;color:#e5e7eb;font-size:14px;text-align:center}.session-card{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:20px;margin-bottom:16px}.session-card.past{opacity:.7}.session-header-row h3{font-size:16px;margin:0 0 8px;color:#e5e7eb}.session-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase}.session-badge.upcoming{background:#065f46;color:#d1fae5}.session-badge.past{background:#374151;color:#9ca3af}.meeting-link-btn{padding:8px 16px;background:#2563eb;border:1px solid #2563eb;border-radius:6px;color:#fff;text-decoration:none;font-size:13px}.meeting-link-btn:hover{background:#1d4ed8}.session-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.attendance-marking,.attendance-view{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:24px}.attendance-table{overflow-x:auto}.attendance-table table{width:100%;border-collapse:collapse}.attendance-table th{background:#2d3748;color:#e5e7eb;padding:12px;text-align:left;font-weight:600;font-size:14px;border-bottom:1px solid #374151}.attendance-table td{padding:12px;color:#9ca3af;font-size:14px;border-bottom:1px solid #374151}.attendance-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase;margin-right:8px}.attendance-badge.status-present{background:#065f46;color:#d1fae5}.attendance-badge.status-absent{background:#7f1d1d;color:#fecaca}.attendance-badge.status-late{background:#92400e;color:#fde68a}.attendance-badge.status-excused{background:#1e3a8a;color:#bfdbfe}.marked-time{font-size:12px;color:#6b7280;font-style:italic}.attendance-buttons{display:flex;gap:6px;flex-wrap:wrap}.btn-attendance{padding:6px 12px;background:transparent;border:1px solid #4b5563;border-radius:6px;color:#e5e7eb;font-size:12px;cursor:pointer;transition:all .2s}.btn-attendance:hover{background:#374151}.btn-attendance.active{border-color:#22c55e;background:#065f46;color:#d1fae5}.btn-attendance:disabled{opacity:.5;cursor:not-allowed}.attendance-summary{margin-top:24px;padding:20px;background:#2d3748;border-radius:12px}.attendance-summary h3{margin:0 0 16px;color:#22c55e}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.summary-item{display:flex;flex-direction:column;padding:12px;background:#1f2430;border-radius:8px}.summary-label{font-size:13px;color:#9ca3af;margin-bottom:6px}.summary-value{font-size:24px;font-weight:600;color:#e5e7eb}.summary-value.present{color:#10b981}.summary-value.absent{color:#dc2626}.summary-value.late{color:#f59e0b}.summary-value.excused{color:#3b82f6}.attendance-status-card{text-align:center;padding:40px}.self-attendance-card{text-align:center;padding:40px;background:#2d3748;border-radius:12px;margin-top:24px}.attendance-marked-info{color:#10b981;font-weight:500;margin-bottom:16px}.section-info-note{color:#9ca3af;font-size:14px;margin-bottom:24px}.change-note{color:#6b7280;font-size:13px;margin-top:12px;font-style:italic}.attendance-buttons-group{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:24px}.btn-attendance-large{padding:12px 20px;background:transparent;border:2px solid #4b5563;border-radius:8px;color:#e5e7eb;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;min-width:120px}.btn-attendance-large:hover{background:#374151;border-color:#6b7280}.btn-attendance-large.active{border-color:#22c55e;background:#065f46;color:#d1fae5}.btn-attendance-large:disabled{opacity:.5;cursor:not-allowed}.attendance-badge-large{display:inline-block;padding:12px 24px;border-radius:8px;font-size:20px;font-weight:600;text-transform:uppercase}.meeting-link{margin-top:8px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:20px;text-align:center}.stat-value{font-size:36px;font-weight:700;color:#22c55e;margin-bottom:8px}.stat-label{font-size:14px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.dashboard-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.dashboard-link-card{padding:20px;background:#1f2430;border:1px solid #374151;border-radius:12px;text-decoration:none;color:#e5e7eb;transition:border-color .2s}.dashboard-link-card:hover{border-color:#22c55e}.dashboard-link-card h3{margin:0 0 8px;color:#22c55e}.dashboard-link-card p{margin:0;color:#9ca3af;font-size:14px}.enrollments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:32px}.enrollment-card{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:20px}.enrollment-card h4{margin:0 0 8px;color:#e5e7eb;font-size:18px}.enrollment-card .section-info{margin-bottom:12px}.enrollment-card .schedule{color:#9ca3af;font-size:13px;margin:8px 0}.enrollment-actions{margin-top:16px}.attendance-list-simple{display:grid;gap:12px}.attendance-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#1f2430;border:1px solid #374151;border-radius:8px}@media(max-width:768px){.portal-layout{flex-direction:column}.portal-nav{width:100%;border-right:none;border-bottom:1px solid #374151}.form-row,.courses-grid,.enrollments-grid{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr 1fr}}.notifications-panel{position:relative;display:inline-block}.notifications-badge{position:absolute;top:-8px;right:-8px;background:#ef4444;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.notifications-empty{padding:20px;text-align:center;color:#9ca3af;font-size:14px}.notifications-list{position:absolute;top:100%;right:0;background:#1f2430;border:1px solid #374151;border-radius:12px;width:400px;max-height:600px;overflow-y:auto;z-index:1000;box-shadow:0 10px 25px #00000080}.notification-item{padding:16px;border-bottom:1px solid #374151;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;transition:background .2s}.notification-item:hover{background:#2d3748}.notification-item.unread{background:#2d3748;border-left:3px solid #22c55e}.notification-content{flex:1;min-width:0}.notification-title{margin:0 0 6px;color:#e5e7eb;font-size:14px;font-weight:600}.notification-body{margin:0 0 8px;color:#9ca3af;font-size:13px;line-height:1.4;word-break:break-word}.notification-time{font-size:12px;color:#6b7280}.notification-actions{display:flex;gap:6px;flex-shrink:0}.btn-notification-action{padding:4px 8px;background:transparent;border:1px solid #4b5563;border-radius:4px;color:#9ca3af;cursor:pointer;font-size:12px;transition:all .2s}.btn-notification-action:hover{background:#374151;color:#e5e7eb}.notification-error{padding:12px;background:#7f1d1d;color:#fecaca;border-radius:8px;margin:8px;font-size:13px}.dashboard-header{margin-bottom:32px}.dashboard-header h2{margin:0 0 8px;color:#e5e7eb;font-size:28px}.dashboard-subtitle{color:#9ca3af;margin:0;font-size:14px}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:32px}.quick-link-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px;background:#1f2430;border:2px solid #374151;border-radius:12px;text-decoration:none;color:#e5e7eb;transition:all .3s ease}.quick-link-card:hover{border-color:#22c55e;background:#2d3748;transform:translateY(-2px)}.quick-link-icon{font-size:36px;margin-bottom:12px}.quick-link-card h3{margin:0 0 6px;color:#e5e7eb;font-size:16px;font-weight:600}.quick-link-card p{margin:0;color:#9ca3af;font-size:12px;line-height:1.3}.sections-grid-simple{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:16px}.section-card-compact{background:#1f2430;border:1px solid #374151;border-radius:12px;padding:16px}.section-card-compact h4{margin:0 0 8px;color:#e5e7eb;font-size:16px}.section-badge-inline{display:inline-block;background:#065f46;color:#d1fae5;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;margin-bottom:8px}.schedule-text,.enrollment-text{margin:6px 0;color:#9ca3af;font-size:13px}.section-actions-quick{display:flex;gap:8px;margin-top:12px}.btn-small{flex:1;padding:6px 12px;background:#2d3748;border:1px solid #4b5563;border-radius:6px;color:#e5e7eb;text-decoration:none;font-size:12px;text-align:center;cursor:pointer;transition:all .2s}.btn-small:hover{background:#374151;border-color:#22c55e}.enrollment-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.enrollment-header h4{margin:0;color:#e5e7eb;font-size:16px}.section-badge-minimal{background:#065f46;color:#d1fae5;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap}.enrollment-tutor{margin:8px 0;color:#9ca3af;font-size:13px}.enrollment-schedule{margin:8px 0;color:#6b7280;font-size:13px}.attendance-info{text-align:left;flex:1}.attendance-session{margin:4px 0 0;color:#6b7280;font-size:12px}
