@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@400;500;600;700&display=swap";:root{--bg: #0b1220;--panel: #0f1629;--card: #121c33;--card-strong: #0d1628;--border: rgba(255, 255, 255, .08);--muted: #8ea0bf;--text: #e6edf5;--text-strong: #f8fbff;--accent: #3dd6a5;--accent-2: #f3b432;--danger: #ff6b6b;--radius-lg: 18px;--radius-md: 12px;--radius-sm: 10px;--shadow-1: 0 15px 60px rgba(0, 0, 0, .35);--shadow-2: 0 10px 40px rgba(0, 0, 0, .28);--shadow-soft: 0 12px 30px rgba(61, 214, 165, .12);--focus-ring: 0 0 0 4px rgba(61, 214, 165, .32);--focus-outline: 2px solid #d2ffe9}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Manrope,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at 20% 20%,rgba(61,214,165,.08),transparent 30%),radial-gradient(circle at 80% 0%,rgba(243,180,50,.08),transparent 25%),linear-gradient(140deg,#0b1324,#0a1020 45%,#09101f 80%,#0b1324);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5{font-family:Space Grotesk,Manrope,system-ui,sans-serif;margin:0;letter-spacing:-.01em}p{margin:0;color:var(--muted)}input,select,textarea,button{font:inherit;color:inherit}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:#0b1220b8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--text-strong)}.top-actions{display:flex;align-items:center;gap:12px}.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#ffffff0a;border:1px solid var(--border);color:var(--text)}.pill[data-tone=accent]{background:#3dd6a51f;border-color:#3dd6a559;color:#b8ffe6}.nav{display:inline-flex;gap:8px;padding:6px;border-radius:12px;background:#ffffff0a;border:1px solid var(--border)}.nav a{padding:10px 14px;border-radius:10px;color:var(--muted);transition:all .2s ease}.nav a.active{background:linear-gradient(120deg,#3dd6a529,#f3b4321f);color:var(--text-strong);border:1px solid rgba(61,214,165,.35)}.page{max-width:1260px;margin:0 auto;padding:24px 18px 56px}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.grid.three{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-2)}.card-strong{background:var(--card-strong);border-color:#ffffff14}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.card-header.centered{justify-content:center;text-align:center}.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:10px;background:#ffffff0d;border:1px solid var(--border);color:var(--text);font-weight:600;font-size:12px;letter-spacing:.01em}.badge[data-tone=accent]{background:#3dd6a529;border-color:#3dd6a566;color:#c9ffe9}.badge[data-tone=warn]{background:#f3b43224;border-color:#f3b43266;color:#ffecc5}.badge[data-tone=danger]{background:#ff6b6b29;border-color:#ff6b6b73;color:#ffd0d0}@keyframes panelIntro{0%{opacity:0;transform:translate(42px) scale(1.12)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes badgePop{0%{opacity:0;transform:scale(1.18) translateY(10px)}50%{opacity:1;transform:scale(1.02) translateY(0)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes textLift{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes cardRise{0%{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.btn{border:none;border-radius:12px;padding:10px 14px;background:#ffffff0f;color:var(--text);cursor:pointer;transition:all .2s ease;border:1px solid var(--border);display:inline-flex;align-items:center;gap:10px;font-weight:600}.btn:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn.icon{width:40px;height:40px;padding:0;border-radius:12px;justify-content:center}.btn.icon svg{width:18px;height:18px}.btn.icon:hover:not(:disabled){background:#ffffff14;border-color:#3dd6a559}.btn.icon.plain{background:transparent;border-color:var(--border)}.btn.icon.plain:hover:not(:disabled){background:#ffffff14;border-color:#ffffff24}.btn.primary{background:linear-gradient(120deg,#3dd6a5,#2ac493);color:#0a0f1c;border-color:#3dd6a533;box-shadow:var(--shadow-soft)}.btn.primary:hover:not(:disabled){background:linear-gradient(120deg,#4de4b3,#3dd6a5);transform:translateY(-1px);box-shadow:0 4px 12px #3dd6a54d}.btn.soft{background:#3dd6a51f;border-color:#3dd6a559;color:#b3ffe2}.btn.soft:hover:not(:disabled){background:#3dd6a533}.btn.ghost{background:transparent}.btn.ghost:hover:not(:disabled){background:#ffffff0f}.btn.danger{background:#ff6b6b24;border-color:#ff6b6b59;color:#ffb2b2}.btn.danger:hover:not(:disabled){background:#ff6b6b40}.btn:disabled{opacity:.55;cursor:not-allowed}.input-group{display:flex;flex-direction:column;gap:6px}.input-group.center{align-items:center}.input-group.center .input{text-align:center}.input,.select,.textarea{width:100%;border-radius:12px;border:1px solid var(--border);background:#ffffff08;color:var(--text);padding:12px;outline:none;transition:border-color .2s ease,background .2s ease}.input:focus,.select:focus,.textarea:focus{border-color:#3dd6a573;background:#ffffff0d}.input:focus-visible,.select:focus-visible,.textarea:focus-visible{outline:var(--focus-outline);outline-offset:3px;box-shadow:var(--focus-ring);border-color:#3dd6a5;background:#3dd6a514}.btn:focus-visible,button:focus-visible,a:focus-visible,.pill:focus-visible{outline:var(--focus-outline);outline-offset:3px;box-shadow:var(--focus-ring)}.input.error{border-color:var(--danger);background:#ff6b6b14}.label{font-weight:600;color:var(--text-strong)}.helper{color:var(--muted);font-size:13px}.table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:12px;overflow:hidden}.table thead{background:#ffffff0a}.table th,.table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}.table tbody tr:hover{background:#ffffff08}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.stat{padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#ffffff08}.stat h4{margin:0 0 4px;font-size:14px;color:var(--muted)}.stat .value{font-size:20px;font-weight:700}.empty{border:1px dashed var(--border);padding:16px;border-radius:12px;text-align:center;color:var(--muted)}.modal-backdrop{position:fixed;inset:0;background:#080b12d9;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:16px;overflow:hidden;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-card{width:min(560px,100%);max-height:calc(100vh - 32px);max-height:calc(100dvh - 32px);background:#0f1629;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-1);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease-out}.modal-header{flex-shrink:0;padding:18px 18px 0}.modal-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 18px;overscroll-behavior:contain}.modal-footer{flex-shrink:0;padding:0 18px 18px}body.modal-open,html.modal-open{overflow:hidden}@media(max-width:640px){.modal-backdrop{padding:8px}.modal-card{max-height:calc(100vh - 16px);max-height:calc(100dvh - 16px);border-radius:12px}.modal-header,.modal-content,.modal-footer{padding-left:14px;padding-right:14px}}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;background:#ffffff0d;border:1px solid var(--border);border-radius:12px;color:var(--text)}.chip.active{background:#3dd6a524;border-color:#3dd6a573}.pill-switch{display:inline-flex;background:#ffffff0a;border:1px solid var(--border);border-radius:12px;padding:4px;gap:4px}.pill-switch button{background:transparent;border:none;color:var(--muted);padding:8px 12px;border-radius:10px;cursor:pointer}.pill-switch button.active{background:#3dd6a529;color:var(--text)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#0f182c;border-radius:14px;border:1px solid var(--border);box-shadow:var(--shadow-1);min-width:240px;padding:8px;z-index:15;animation:dropdownSlide .15s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu button,.dropdown-menu a{width:100%;background:transparent;border:none;text-align:left;padding:10px 12px;border-radius:10px;color:var(--text);cursor:pointer}.dropdown-menu button:focus-visible,.dropdown-menu a:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.dropdown-menu button:hover,.dropdown-menu a:hover{background:#ffffff0d}.tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:10px;background:#ffffff0f;color:var(--text);border:1px solid var(--border);font-weight:600}.tag[data-tone=success]{background:#3dd6a524;color:#c9ffe9;border-color:#3dd6a559}.tag[data-tone=warn]{background:#f3b43224;color:#ffe7b8;border-color:#f3b43259}.tag[data-tone=muted]{color:var(--muted)}.list{display:flex;flex-direction:column;gap:8px}.list-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;background:#ffffff0a;border:1px solid var(--border)}.danger-text{color:#ffb2b2}.success-text{color:#b6ffd9}.hero{padding:18px;border-radius:18px;border:1px solid rgba(61,214,165,.25);background:linear-gradient(120deg,#3dd6a529,#f3b4321f);box-shadow:var(--shadow-soft)}.skeleton{background:linear-gradient(90deg,#ffffff0a,#ffffff14,#ffffff0a);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{pointer-events:none}.fade-in{animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.topbar{padding:14px 16px}.main-content{padding:20px 16px 48px}.grid.two,.grid.three{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){:root{--radius-lg: 14px;--radius-md: 10px}body{font-size:15px}h1{font-size:1.6rem}h2{font-size:1.35rem}h3{font-size:1.15rem}.topbar{padding:12px 14px;gap:8px}.brand{gap:8px;font-size:14px}.brand-mark{width:34px;height:34px;border-radius:10px}.top-actions{gap:8px}.pill{padding:6px 10px;font-size:13px}.main-content{padding:16px 12px 40px}.grid{gap:12px}.grid.two,.grid.three{grid-template-columns:1fr}.card{padding:14px 16px;border-radius:var(--radius-md)}.card-header{flex-wrap:wrap;gap:8px}.hero{padding:14px;border-radius:14px}.stat-grid{grid-template-columns:1fr;gap:10px}.stat{padding:12px 14px}.table{font-size:13px}.table th,.table td{padding:10px 8px}.table th:nth-child(4),.table td:nth-child(4){display:none}.toolbar{gap:8px}.pill-switch{flex-wrap:wrap;width:100%}.pill-switch button{flex:1;min-width:0;padding:8px 10px;font-size:13px;text-align:center}.btn{padding:10px 14px;font-size:14px}.btn.icon{padding:8px}.input,.select,textarea{padding:10px 12px;font-size:15px}.list-row{padding:10px;flex-wrap:wrap}.dropdown-menu{min-width:200px;right:-10px}}@media(max-width:380px){.topbar{padding:10px 12px}.brand-mark{width:30px;height:30px}.main-content{padding:12px 10px 36px}.card{padding:12px}.pill-switch button{padding:6px 8px;font-size:12px}}@media(pointer:coarse){.btn,.pill-switch button,.chip,.list-row{min-height:44px}.btn.icon{min-width:44px;min-height:44px}}@media(max-height:500px)and (orientation:landscape){.modal-card{max-height:calc(100vh - 20px)}.modal-content{max-height:50vh}}@supports (padding: env(safe-area-inset-bottom)){.main-content{padding-bottom:calc(40px + env(safe-area-inset-bottom))}.modal-backdrop{padding-bottom:env(safe-area-inset-bottom)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.timeline-canvas{display:flex;flex-direction:column;gap:20px;padding:12px 0}.grade-band{position:relative;padding:16px;border-radius:14px;background:#ffffff05;border:1px solid var(--border);border-left:4px solid rgba(61,214,165,.3);transition:all .2s ease}.grade-band:hover{background:#ffffff08}.grade-band.current{border-left-color:var(--accent);background:#3dd6a50a}.grade-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.grade-title{display:flex;align-items:center;gap:10px}.grade-name{font-weight:700;font-size:16px;color:var(--text-strong)}.semesters-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.semester-section{min-width:180px;flex:1;padding:12px;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);transition:all .2s ease}.semester-section:hover{background:#ffffff0d}.semester-section.current{border-color:#3dd6a566;background:#3dd6a50f}.semester-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.semester-name{font-weight:600;font-size:14px;color:var(--text)}.current-indicator{padding:2px 8px;border-radius:10px;background:var(--accent);color:#0a0f1c;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.assessments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:8px}.assessment-node{width:48px;height:48px;border-radius:12px;border:2px solid transparent;background:#ffffff0f;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.assessment-node:hover{transform:scale(1.08);box-shadow:0 4px 16px #0000004d}.assessment-node .subject-initial{font-weight:700;font-size:14px;line-height:1}.assessment-node .assessment-type{font-size:9px;font-weight:600;opacity:.7;margin-top:2px}.assessment-node.status-submitted{background:#3dd6a533;border-color:#3dd6a580;color:#b8ffe6}.assessment-node.status-submitted:hover{background:#3dd6a54d}.assessment-node.status-in_progress{background:#f3b43233;border-color:#f3b43280;color:#ffe7b8}.assessment-node.status-in_progress:hover{background:#f3b4324d}.assessment-node.status-not_started{background:#ffffff0a;border-color:#ffffff1a;color:var(--muted)}.assessment-node.status-not_started:hover{background:#ffffff14;border-color:#fff3}.no-assessments{padding:16px;text-align:center;border-radius:8px;background:#ffffff05;border:1px dashed rgba(255,255,255,.08)}.timeline-legend{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:12px 16px;border-radius:10px;background:#ffffff05;border:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:12px;height:12px;border-radius:4px}.legend-dot.status-submitted{background:#3dd6a580;border:2px solid rgba(61,214,165,.8)}.legend-dot.status-in_progress{background:#f3b43280;border:2px solid rgba(243,180,50,.8)}.legend-dot.status-not_started{background:#ffffff1a;border:2px solid rgba(255,255,255,.2)}@media(max-width:768px){.grade-band{padding:12px}.semesters-row{flex-direction:column}.semester-section{min-width:unset}.assessments-grid{grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:6px}.assessment-node{width:44px;height:44px}.assessment-node .subject-initial{font-size:12px}.assessment-node .assessment-type{font-size:8px}.timeline-legend{justify-content:center}}@media(max-width:480px){.grade-header{flex-direction:column;align-items:flex-start;gap:8px}.assessments-grid{grid-template-columns:repeat(5,1fr)}}
