.landing{min-height:100vh;background:#0b1220;color:#e2e8f0;font-family:var(--font, "DM Sans", system-ui, sans-serif)}.landing-nav{position:sticky;top:0;z-index:40;background:#0b1220e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgb(148 163 184 / 15%)}.landing-nav-inner{max-width:1200px;margin:0 auto;padding:.85rem 1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:.5rem;color:#f8fafc;font-weight:700;text-decoration:none}.landing-logo .brand-mark{width:2.25rem;height:2.25rem;border-radius:10px;background:linear-gradient(135deg,#14b8a6,#0d9488);display:grid;place-items:center;color:#fff;font-size:.85rem}.landing-nav-links{display:flex;gap:1.25rem;flex-wrap:wrap}.landing-nav-links a{color:#94a3b8;font-size:.9rem;text-decoration:none}.landing-nav-links a:hover{color:#5eead4}.landing-nav-cta{display:flex;gap:.5rem;align-items:center}.btn-ghost-light{padding:.45rem .85rem;border-radius:8px;color:#e2e8f0;text-decoration:none;font-size:.9rem}.btn-ghost-light:hover{background:#94a3b81f}.btn-primary-light{padding:.5rem 1rem;border-radius:8px;background:linear-gradient(135deg,#14b8a6,#0f766e);color:#fff;font-weight:600;font-size:.9rem;text-decoration:none}.btn-primary-light:hover{filter:brightness(1.06)}.landing-hero{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 4rem}.landing-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}@media(max-width:900px){.landing-hero-grid{grid-template-columns:1fr}}.landing-eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:#5eead4;margin:0 0 .75rem}.landing-hero h1{font-size:clamp(2rem,4.5vw,3.1rem);line-height:1.12;margin:0 0 1rem;color:#f8fafc}.landing-gradient-text{background:linear-gradient(90deg,#5eead4,#818cf8);-webkit-background-clip:text;background-clip:text;color:transparent}.landing-hero-text{font-size:1.05rem;color:#94a3b8;line-height:1.65;max-width:52ch;margin:0 0 1.5rem}.landing-hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.btn-primary{display:inline-block;padding:.65rem 1.35rem;border-radius:10px;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;font-weight:600;text-decoration:none;border:none;cursor:pointer;font-size:.95rem}.btn-primary:hover{filter:brightness(1.05)}.btn-outline{display:inline-block;padding:.65rem 1.35rem;border-radius:10px;border:1px solid rgb(148 163 184 / 35%);color:#e2e8f0;text-decoration:none;font-size:.95rem}.btn-outline:hover{border-color:#5eead4;color:#5eead4}.landing-bullets{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;font-size:.88rem;color:#64748b}.landing-bullets li:before{content:"✓ ";color:#2dd4bf}.landing-hero-visual{position:relative}.landing-hero-img{width:100%;height:auto;border-radius:20px;box-shadow:0 24px 80px #00000073;object-fit:cover}.landing-hero-card{position:absolute;bottom:-1rem;left:1rem;right:1rem;background:#0f172aeb;border:1px solid rgb(94 234 212 / 25%);border-radius:14px;padding:1rem 1.15rem;display:flex;flex-direction:column;gap:.25rem;font-size:.88rem;color:#94a3b8}.landing-hero-card strong{color:#f1f5f9}.landing-stats{background:linear-gradient(180deg,#0b1220,#111a2e);border-block:1px solid rgb(148 163 184 / 10%)}.landing-stats-inner{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}@media(max-width:768px){.landing-stats-inner{grid-template-columns:repeat(2,1fr)}}.landing-stat-num{display:block;font-size:1.75rem;font-weight:700;color:#5eead4}.landing-stat-label{font-size:.82rem;color:#64748b}.landing-section{max-width:1200px;margin:0 auto;padding:4rem 1.5rem}.landing-section.alt{background:#111a2e;max-width:none;padding-inline:1.5rem}.landing-section.alt h2,.landing-section.alt .landing-section-lede,.landing-section.alt .landing-features{max-width:1200px;margin-left:auto;margin-right:auto}.landing-section h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:0 0 .75rem;color:#f8fafc}.landing-section-lede{color:#94a3b8;max-width:62ch;line-height:1.6;margin:0 0 2rem}.landing-tabs{border:1px solid rgb(148 163 184 / 15%);border-radius:16px;overflow:hidden;background:#0f172a7f}.landing-tab-list{display:flex;flex-wrap:wrap;border-bottom:1px solid rgb(148 163 184 / 12%)}.landing-tab{flex:1;min-width:140px;padding:.85rem 1rem;background:transparent;border:none;color:#94a3b8;font-size:.88rem;cursor:pointer;font-family:inherit}.landing-tab.active{background:#14b8a61f;color:#5eead4;font-weight:600}.landing-tab-panel{padding:1.5rem;color:#cbd5e1;line-height:1.65}.landing-features{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.landing-feature-card{background:#0f172a99;border:1px solid rgb(148 163 184 / 12%);border-radius:14px;padding:1.25rem}.landing-feature-card h3{margin:0 0 .5rem;font-size:1rem;color:#e2e8f0}.landing-feature-card p{margin:0;font-size:.9rem;color:#64748b;line-height:1.5}.landing-split{max-width:1200px;margin:0 auto;padding:4rem 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}@media(max-width:900px){.landing-split{grid-template-columns:1fr}}.landing-split-img{width:100%;border-radius:18px;object-fit:cover}.landing-split-content h2{margin:0 0 1rem;font-size:1.75rem}.landing-checklist{margin:0;padding-left:1.1rem;color:#94a3b8;line-height:1.75;font-size:.95rem}.landing-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:768px){.landing-panels{grid-template-columns:1fr}}.landing-panel{padding:1.25rem;border-radius:14px;background:#0f172a8c;border:1px solid rgb(148 163 184 / 12%)}.landing-panel h3{margin:0 0 .35rem;font-size:1rem;color:#5eead4}.landing-panel p{margin:0;font-size:.88rem;color:#64748b;line-height:1.5}.landing-cta{background:linear-gradient(120deg,#0f766e,#3730a3);margin:2rem 0 0}.landing-cta-inner{max-width:720px;margin:0 auto;padding:3.5rem 1.5rem;text-align:center}.landing-cta-inner h2{margin:0 0 .75rem;font-size:clamp(1.5rem,3vw,2rem);color:#fff}.landing-cta-inner p{margin:0 0 1.5rem;color:#ffffffd9}.landing-cta-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:.75rem}.btn-outline-light{padding:.6rem 1.2rem;border-radius:10px;border:1px solid rgb(255 255 255 / 45%);color:#fff;text-decoration:none}.landing-footer{background:#070b14;padding:2.5rem 1.5rem 2rem;border-top:1px solid rgb(148 163 184 / 10%)}.landing-footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem}.landing-footer strong{color:#f8fafc}.landing-footer p{margin:.35rem 0 0;font-size:.85rem;color:#64748b}.landing-footer-links{display:flex;gap:1.25rem}.landing-footer-links a{color:#94a3b8;font-size:.9rem}.landing-footer-note{max-width:1200px;margin:2rem auto 0;font-size:.75rem;color:#475569;line-height:1.5}.auth-page{min-height:100vh;display:grid;place-items:center;padding:2rem 1rem;background:radial-gradient(ellipse 80% 60% at 50% -20%,rgb(20 184 166 / 18%),transparent),radial-gradient(ellipse 60% 40% at 100% 0%,rgb(99 102 241 / 12%),transparent),#0f172a}.auth-card{width:100%;max-width:420px;background:#1e293bd9;border:1px solid rgb(148 163 184 / 18%);border-radius:18px;padding:2rem;box-shadow:0 24px 64px #00000059}.auth-back{display:inline-block;margin-bottom:1rem;font-size:.88rem;color:#5eead4;text-decoration:none}.auth-back:hover{text-decoration:underline}.auth-card h1{margin:0 0 .5rem;font-size:1.65rem;color:#f8fafc}.auth-lede{margin:0 0 1.5rem;font-size:.9rem;color:#94a3b8;line-height:1.55}.auth-form{display:flex;flex-direction:column;gap:1.1rem}.auth-label{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;color:#cbd5e1;font-weight:500}.auth-input{padding:.65rem .85rem;border-radius:10px;border:1px solid rgb(148 163 184 / 25%);background:#0f172acc;color:#f1f5f9;font-size:1rem;font-family:inherit}.auth-input:focus{outline:none;border-color:#2dd4bf;box-shadow:0 0 0 3px #2dd4bf26}.auth-input.error{border-color:#f87171}.auth-field-error{font-size:.78rem;color:#fca5a5}.auth-banner.error{padding:.65rem .85rem;border-radius:10px;background:#7f1d1d59;border:1px solid rgb(248 113 113 / 35%);color:#fecaca;font-size:.88rem}.auth-submit{width:100%;margin-top:.25rem}.auth-hint{margin:1.5rem 0 0;font-size:.8rem;color:#64748b;line-height:1.5}.auth-loading{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#64748b}.auth-spinner{width:2.5rem;height:2.5rem;border:3px solid rgb(45 212 191 / 20%);border-top-color:#14b8a6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{color-scheme:light;--bg: #f4f6ffb8;--surface: #ffffff;--text: #0f172a;--muted: #64748b;--accent: #0d9488;--accent-dim: #ccfbf1;--border: #e2e8f0;--radius: 12px;--font: "DM Sans", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font);background:radial-gradient(1200px 600px at 10% -10%,#ccfbf1 0%,transparent 50%),radial-gradient(900px 500px at 100% 0%,#e0e7ff 0%,transparent 45%),var(--bg);color:var(--text);line-height:1.5}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:1.25rem 1rem;display:flex;flex-direction:column;gap:1.5rem;min-height:100vh}.brand{display:flex;align-items:center;gap:.75rem;padding:.25rem}.brand-mark{display:grid;place-items:center;width:2.5rem;height:2.5rem;border-radius:10px;background:linear-gradient(135deg,var(--accent),#0f766e);color:#fff;font-weight:700;font-size:.95rem}.brand-sub{font-size:.75rem;color:var(--muted)}.nav{display:flex;flex-direction:column;gap:.2rem}.nav-link{padding:.45rem .65rem;border-radius:8px;color:var(--text);font-size:.9rem;text-decoration:none}.nav-link:hover{background:var(--accent-dim);text-decoration:none}.nav-link.active{background:var(--accent-dim);color:#0f766e;font-weight:600}.main{padding:2rem clamp(1.25rem,4vw,3rem);max-width:1200px}.page-header h1{margin:0 0 .5rem;font-size:clamp(1.5rem,3vw,2rem)}.lede{color:var(--muted);max-width:62ch;margin:0}.eyebrow{text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;color:var(--muted);margin:0 0 .25rem}.page{display:flex;flex-direction:column;gap:1.5rem}.cards{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:0 1px 2px #0f172a0a}.card h2{margin:0 0 .5rem;font-size:1rem}.muted{color:var(--muted)}.small{font-size:.85rem}code{font-size:.85em;background:#f1f5f9;padding:.1em .35em;border-radius:4px}.pill{display:inline-block;padding:.15em .55em;border-radius:999px;font-size:.8rem;font-weight:600;text-transform:uppercase}.pill.ok{background:#d1fae5;color:#065f46}.pill.warn{background:#fef3c7;color:#92400e}.pill.bad{background:#fee2e2;color:#991b1b}.compact-list{margin:0;padding-left:1.1rem;color:var(--muted);font-size:.95rem}.compact-list li{margin-bottom:.35rem}.campus-picker{padding:0 .25rem .75rem;border-bottom:1px solid var(--border);margin-bottom:.5rem}.campus-picker label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.35rem}.campus-select{width:100%;padding:.45rem .5rem;border-radius:8px;border:1px solid var(--border);font-family:inherit;font-size:.85rem;background:var(--surface)}.role-pill{margin:.5rem 0 0;font-size:.78rem;color:var(--muted)}.sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border)}.user-line{margin:0;font-size:.88rem;font-weight:600}.user-email{margin:.15rem 0 .65rem;font-size:.75rem;color:var(--muted);word-break:break-all}.btn-ghost{width:100%;padding:.45rem;border-radius:8px;border:1px solid var(--border);background:transparent;font-family:inherit;font-size:.85rem;cursor:pointer;color:var(--text)}.btn-ghost:hover{background:var(--accent-dim)}@media(max-width:840px){.layout{grid-template-columns:1fr}.sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;border-right:none;border-bottom:1px solid var(--border);min-height:unset}.sidebar-footer{width:100%;margin-top:.5rem}.nav{flex-direction:row;flex-wrap:wrap;width:100%}}
