@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Work+Sans:wght@400;500;600&display=swap";:root{color-scheme:light;font-family:Work Sans,sans-serif;--ink: #0f1b2d;--muted: #536075;--bg: #f2f6fb;--panel: #ffffff;--accent: #2f5faa;--accent-2: #8ad4e6;--sidebar: #182d5a;--shadow: 0 18px 40px rgba(15, 27, 45, .12);--radius: 18px}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,#f6d9b6,transparent 45%),radial-gradient(circle at 20% 20%,#cbe8e2,transparent 55%),var(--bg);color:var(--ink);min-height:100vh}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,#cfe2ff,transparent 45%),radial-gradient(circle at 15% 20%,#b9ecf5,transparent 55%),var(--bg);display:grid;place-items:center;z-index:10;padding:24px}.login-card{width:min(420px,92vw);background:var(--panel);border-radius:20px;padding:28px;box-shadow:var(--shadow);display:grid;gap:14px}.logo-frame{background:#fff;border-radius:14px;padding:10px 12px;display:inline-flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 8px 18px #0f1b2d2e}.login-logo{width:220px;display:block;margin:0 auto}.login-form{display:grid;gap:12px}.login-form label{display:grid;gap:6px;font-size:13px;color:var(--muted)}.login-form input{border:1px solid rgba(15,27,45,.15);border-radius:12px;padding:10px 12px;font-family:inherit}.login-error{margin:0;font-size:12px;color:#b52b2b}.login-divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#0f1b2d1f}.oauth{display:grid;grid-template-columns:1fr 1fr;gap:10px}.oauth-btn{border:1px solid rgba(15,27,45,.15);border-radius:12px;padding:10px 12px;background:#fff;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.oauth-icon{width:16px;height:16px;display:inline-block;border-radius:4px}.oauth-icon.google{background:conic-gradient(#4285f4,#4285f4 90deg,#34a853 90deg,#34a853 180deg,#fbbc05 180deg,#fbbc05 270deg,#ea4335 270deg,#ea4335 360deg)}.oauth-icon.microsoft{background:conic-gradient(#f25022,#f25022 90deg,#7fba00 90deg,#7fba00 180deg,#00a4ef 180deg,#00a4ef 270deg,#ffb900 270deg,#ffb900 360deg)}.sidebar{background:var(--sidebar);color:#f1f6f4;padding:32px 24px;display:flex;flex-direction:column;gap:32px}.brand{display:flex;flex-direction:column;align-items:center;gap:10px}.brand-logo{width:72px;height:auto;filter:drop-shadow(0 6px 16px rgba(15,27,45,.35))}.brand-sub{margin:0;font-size:12px;color:#f1f6f4b3}.sidebar-nav{display:flex;flex-direction:column;gap:12px}.nav-title{margin:0;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:#f1f6f480}.nav-pill{background:#ffffff0f;border:1px solid transparent;color:inherit;padding:10px 14px;border-radius:12px;text-align:left;cursor:pointer;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:10px}.nav-pill.active,.nav-pill:hover{background:#8ad4e638;border-color:#8ad4e6b3;color:#fff}.nav-icon svg{width:16px;height:16px;fill:currentColor}.profile-menu{position:relative}.profile-trigger{border:none;background:transparent;display:inline-flex;align-items:center;gap:10px;cursor:pointer;padding:0}.profile-badge{background:#2f5faa1f;color:var(--accent);border-radius:999px;padding:6px 10px;font-size:11px;font-weight:600}.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#1b2e5e);color:#fff;display:grid;place-items:center;font-weight:600}.menu-panel{position:absolute;right:0;top:52px;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:8px;min-width:180px;display:grid;gap:4px;z-index:5}.menu-panel button{border:none;background:transparent;text-align:left;padding:10px 12px;border-radius:10px;cursor:pointer;font-weight:500}.menu-panel button:hover{background:#0f1b2d0f}.menu-logout{color:#b52b2b}.sidebar-card{background:#ffffff14;border-radius:14px;padding:16px}.card-label{text-transform:uppercase;font-size:11px;letter-spacing:.12em;color:var(--muted);margin:0 0 8px}.sidebar-card .card-label{color:#f1f6f4b3}.card-value{font-size:20px;font-weight:700;margin:0 0 4px}.card-muted{margin:0;color:var(--muted);font-size:13px}.sidebar-card .card-muted{color:#f1f6f499}.main{padding:32px 40px 40px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.topbar h1{margin:0 0 6px;font-family:Space Grotesk,sans-serif}.topbar p{margin:0;color:var(--muted)}.profile{display:flex;align-items:center;gap:12px}.profile-name{margin:0;font-weight:600}.profile-role{margin:0;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:10px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}.hero-card{grid-column:1 / -1;display:grid;grid-template-columns:2fr 1fr;gap:20px;background:var(--panel);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.hero-card h2{margin:0 0 8px;font-family:Space Grotesk,sans-serif}.hero-metric{background:#fdf5e7;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:6px;justify-content:center}.student-select{border:1px solid rgba(15,27,45,.15);border-radius:10px;padding:6px 10px;font-family:inherit;background:#fff;color:var(--ink)}.hero-metric h3{margin:0;font-size:24px}.card{background:var(--panel);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.card h3{margin:0 0 8px;font-family:Space Grotesk,sans-serif}.primary{border:none;background:var(--accent);color:#fff;padding:10px 16px;border-radius:999px;font-weight:600;cursor:pointer;margin-top:10px}.ghost{border:1px solid rgba(15,27,45,.2);background:transparent;color:var(--ink);padding:8px 14px;border-radius:999px;cursor:pointer}.split{margin-top:20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.progress-panel{margin-top:20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}.route-card{display:grid;gap:12px}.route-roadmap{position:relative;display:grid;gap:18px;padding-left:28px}.route-roadmap:before{content:"";position:absolute;left:12px;top:6px;bottom:6px;width:2px;background:#2f5faa33}.route-step{display:grid;grid-template-columns:24px 1fr;gap:12px}.route-dot{width:12px;height:12px;border-radius:50%;background:#c3d4ea;margin-top:6px;justify-self:center}.route-step.current .route-dot{background:var(--accent);box-shadow:0 0 0 6px #2f5faa26}.route-content{background:#f5f7fb;border-radius:14px;padding:12px 14px;display:grid;gap:8px}.route-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.route-year{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.route-grade{font-weight:600;color:var(--ink)}.route-badge{background:#2f5faa26;color:var(--accent);padding:4px 8px;border-radius:999px;font-size:11px;font-weight:600}.route-status{font-weight:600;margin:0}.route-highlights{margin:0;padding-left:18px;color:var(--muted)}.route-comment{margin:0;color:var(--muted);font-size:13px}.placeholder-panel{margin-top:24px}.list{margin:0 0 12px;padding-left:18px;color:var(--muted)}.pill{background:#eef2f1;color:var(--ink);border-radius:999px;padding:8px 12px;display:inline-flex;margin:6px 6px 0 0;font-size:13px}.chart{width:100%;height:120px}.chart-wrap{height:220px}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{flex-direction:row;overflow-x:auto;gap:16px}.sidebar-card{display:none}.hero-card{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start;gap:12px}}
