:root{font-family:Manrope,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#0f172a;background:radial-gradient(circle at top left,rgba(14,165,233,.18),transparent 30%),radial-gradient(circle at right 15%,rgba(244,114,182,.16),transparent 22%),linear-gradient(135deg,#f8fafc,#d9e8ff 48%,#edf6ff)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}.page{min-height:100vh;padding:24px}.auth-layout{width:min(1180px,100%);margin:0 auto;min-height:calc(100vh - 48px);display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}.auth-showcase,.auth-card,.dashboard-shell{border-radius:28px;background:#ffffffe0;border:1px solid rgba(148,163,184,.25);box-shadow:0 24px 80px #0f172a1f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.auth-showcase{padding:38px;min-height:620px;display:flex;flex-direction:column;justify-content:center;background:radial-gradient(circle at top right,rgba(14,165,233,.18),transparent 32%),linear-gradient(155deg,#0f172af0,#0f766edb);color:#f8fafc}.auth-card{width:min(100%,460px);padding:32px;justify-self:end}.brand-block{margin-bottom:24px}.eyebrow{margin:0 0 8px;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#0369a1}.auth-showcase .eyebrow,.dashboard-hero .eyebrow,.topbar .eyebrow{color:#38bdf8}.brand-block h1{margin:0;font-size:2rem;line-height:1.1}.description{margin:12px 0 0;color:#475569}.auth-showcase h1{margin:0;font-size:clamp(2.6rem,4vw,4.2rem);line-height:1}.auth-showcase .description{color:#e2e8f0d6;max-width:600px;font-size:1.05rem}.role-showcase-grid{margin-top:32px;display:grid;gap:14px}.role-card{border:1px solid rgba(148,163,184,.24);border-radius:20px;padding:18px 20px;background:#ffffff14;color:#e2e8f0;text-align:left;display:grid;gap:6px;transition:transform .2s ease,border-color .2s ease,background .2s ease}.role-card.active{border-color:#7dd3fccc;background:#ffffff29}.role-card-label{font-size:1.05rem;font-weight:800}.role-card-tagline{color:#e2e8f0d1;line-height:1.45}.switcher{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.switch-button,.submit-button{border:none;border-radius:14px;cursor:pointer;transition:transform .2s ease,opacity .2s ease,background .2s ease}.switch-button{padding:12px 16px;background:#e2e8f0;color:#0f172a;font-weight:600}.switch-button.active{background:#0f172a;color:#fff}.auth-form{display:grid;gap:12px}.auth-form label{font-size:.95rem;font-weight:600}.auth-form input{padding:14px 16px;border:1px solid #cbd5e1;border-radius:14px;background:#fff}.auth-form input:focus{outline:2px solid #38bdf8;border-color:transparent}.selected-role{margin-top:8px;padding:14px 16px;border-radius:16px;background:#eff6ff;display:flex;justify-content:space-between;align-items:center;color:#0f172a}.selected-role span{color:#475569}.submit-button{margin-top:8px;padding:14px 16px;background:linear-gradient(135deg,#0284c7,#0f172a);color:#fff;font-weight:700}.submit-button:disabled{opacity:.7;cursor:not-allowed}.switch-button:hover,.submit-button:hover,.role-card:hover,.ghost-button:hover{transform:translateY(-1px)}.feedback{margin:16px 0 0;padding:12px 14px;border-radius:14px;font-weight:600}.feedback.success{background:#dcfce7;color:#166534}.feedback.error{background:#fee2e2;color:#991b1b}.dashboard-shell{width:min(1220px,100%);margin:0 auto;padding:22px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;padding:18px 20px;border-radius:22px;background:#0f172aed;color:#f8fafc}.ghost-button{border:1px solid rgba(148,163,184,.3);border-radius:14px;background:transparent;color:#f8fafc;padding:12px 16px;cursor:pointer}.dashboard-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;padding:28px;border-radius:28px;color:#f8fafc;margin-bottom:22px}.student-hero{background:linear-gradient(135deg,#0f172a,#0f766e)}.teacher-hero{background:linear-gradient(135deg,#1e1b4b,#2563eb)}.admin-hero{background:linear-gradient(135deg,#3f1d24,#b45309)}.dashboard-hero .description{color:#f1f5f9db;max-width:720px}.dashboard-hero h1{margin:0;font-size:clamp(2.1rem,4vw,3.4rem)}.hero-chip{min-width:220px;padding:18px;border-radius:20px;background:#ffffff24;display:grid;gap:8px}.hero-chip span{font-size:.86rem;text-transform:uppercase;letter-spacing:.08em;color:#e2e8f0d6}.hero-chip strong{font-size:1rem;line-height:1.4}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}.metric-card{padding:20px;border-radius:22px;border:1px solid rgba(148,163,184,.22);background:#ffffffe6;box-shadow:0 10px 30px #0f172a0f}.metric-card p,.metric-card span{margin:0;color:#64748b}.metric-card h3{margin:10px 0 6px;font-size:1.8rem}.metric-success{background:linear-gradient(180deg,#f0fdf4,#dcfce7)}.metric-info{background:linear-gradient(180deg,#eff6ff,#dbeafe)}.metric-warm{background:linear-gradient(180deg,#fff7ed,#ffedd5)}.dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.dashboard-section{padding:22px;border-radius:24px;background:#ffffffeb;border:1px solid rgba(148,163,184,.22);box-shadow:0 10px 30px #0f172a0f}.spotlight-section{background:linear-gradient(180deg,#fffffff5,#eff6fff5)}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px}.section-header h2{margin:4px 0 0;font-size:1.35rem}.section-kicker{margin:0;color:#0284c7;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800}.course-list,.marks-table,.timeline-list,.bullet-stack,.stats-stack,.info-stack{display:grid;gap:14px}.course-row,.marks-row,.timeline-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid rgba(226,232,240,.9)}.course-row:last-child,.marks-row:last-child,.timeline-row:last-child{border-bottom:none;padding-bottom:0}.course-row strong,.marks-row strong,.timeline-row strong,.stats-stack strong,.info-stack strong{display:block}.course-row span,.marks-row span,.timeline-row span,.stats-stack span,.info-stack span,.course-meta span{color:#64748b}.course-meta{text-align:right}.timeline-badge{min-width:72px;padding:8px 10px;border-radius:999px;background:#e2e8f0;color:#0f172a;font-weight:700;text-align:center}.compact .timeline-badge{min-width:94px}.info-stack>div,.stats-stack>div{padding:14px 0;border-bottom:1px solid rgba(226,232,240,.9)}.info-stack>div:last-child,.stats-stack>div:last-child{border-bottom:none;padding-bottom:0}.bullet-item{display:flex;gap:12px;align-items:flex-start}.bullet-item p{margin:0;line-height:1.55}.bullet-dot{width:10px;height:10px;margin-top:7px;border-radius:999px;background:#0284c7;flex-shrink:0}.insight-copy{margin:0;line-height:1.75;color:#334155}@media(max-width:1080px){.auth-layout{grid-template-columns:1fr}.auth-card{width:100%;justify-self:stretch}.metrics-grid,.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-hero{flex-direction:column}}@media(max-width:720px){.page{padding:16px}.auth-showcase,.auth-card,.dashboard-shell{padding:22px}.metrics-grid,.dashboard-grid,.switcher{grid-template-columns:1fr}.topbar,.course-row,.marks-row,.timeline-row{flex-direction:column;align-items:flex-start}.course-meta{text-align:left}}@media(max-width:480px){.brand-block h1,.dashboard-hero h1{font-size:1.9rem}}
