@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1d4ed8;--primary-light:#3b82f6;--primary-dark:#1e40af;--accent:#f59e0b;--accent-light:#fbbf24;--success:#059669;--success-light:#10b981;--warning:#d97706;--danger:#dc2626;--info:#4f46e5;--purple:#7c3aed;--bg-base:#f0f4ff;--bg-surface:#fff;--bg-card:#fff;--bg-input:#f8faff;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--border:rgba(59,130,246,.15);--border-focus:rgba(59,130,246,.5);--glow-primary:rgba(59,130,246,.15);--glow-accent:rgba(245,158,11,.15);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-card:0 2px 16px rgba(59,130,246,.08),0 1px 4px rgba(0,0,0,.06);--shadow-glow:0 0 30px rgba(59,130,246,.1);--shadow-btn:0 4px 14px rgba(29,78,216,.3);--font-main:"Plus Jakarta Sans","Inter",system-ui,sans-serif;--transition:all 0.25s cubic-bezier(0.4,0,0.2,1)}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-main);background-color:var(--bg-base);color:var(--text-primary);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.page-wrapper{min-height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.page-wrapper:before{top:-10%;right:-15%;width:55%;height:55%;background:radial-gradient(ellipse,rgba(59,130,246,.12) 0,transparent 70%)}.page-wrapper:after,.page-wrapper:before{content:"";position:fixed;pointer-events:none;z-index:0}.page-wrapper:after{bottom:-15%;left:-10%;width:50%;height:50%;background:radial-gradient(ellipse,rgba(245,158,11,.1) 0,transparent 70%)}.container{width:100%;max-width:480px;margin:0 auto;padding:0 16px}.app-header,.container{position:relative;z-index:1}.app-header{padding:24px 16px 16px;text-align:center}.school-logo-wrap{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}.school-logo{width:56px;height:56px;object-fit:contain;border-radius:50%;border:2.5px solid rgba(29,78,216,.2);background:#fff;padding:4px;box-shadow:0 2px 12px rgba(29,78,216,.15)}.school-name-wrap{text-align:left}.school-label{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase}.school-name{font-size:15px;font-weight:800;color:var(--primary-dark);line-height:1.3}.header-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,rgba(29,78,216,.08),rgba(79,70,229,.08));border:1px solid rgba(29,78,216,.15);border-radius:20px;padding:6px 14px;margin-top:4px}.header-badge-text{font-size:12px;font-weight:600;color:var(--primary)}.card{background:var(--bg-card);border:1px solid rgba(59,130,246,.12);border-radius:var(--radius-xl);padding:24px 20px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-light),var(--primary),var(--info))}.login-heading{font-size:22px;font-weight:800;color:var(--text-primary);margin-bottom:4px;line-height:1.2}.login-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px;line-height:1.6}.form-group{margin-bottom:18px}.form-label{display:block;font-size:12px;font-weight:700;letter-spacing:.05em;color:var(--text-secondary);text-transform:uppercase;margin-bottom:8px}.form-input{width:100%;padding:14px 16px;background:var(--bg-input);border:1.5px solid #e2e8f0;border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-main);font-size:15px;font-weight:500;outline:none;transition:var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder{color:#94a3b8}.form-input:focus{border-color:var(--primary-light);background:#fff;box-shadow:0 0 0 3px var(--glow-primary)}input[type=date]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px 24px;border:none;border-radius:var(--radius-md);font-family:var(--font-main);font-size:15px;font-weight:700;cursor:pointer;transition:var(--transition);outline:none;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);color:#fff;box-shadow:var(--shadow-btn)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(29,78,216,.4)}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-btn)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-ghost{background:#fff;color:var(--text-secondary);border:1.5px solid #e2e8f0;width:auto;padding:10px 16px;font-size:13px;box-shadow:0 1px 4px rgba(0,0,0,.06)}.btn-ghost:hover{background:var(--bg-base);color:var(--primary);border-color:rgba(59,130,246,.3)}.error-msg{display:flex;align-items:center;gap:8px;padding:12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);color:#b91c1c;font-size:13px;font-weight:500;margin-bottom:16px;animation:shake .4s ease}@keyframes shake{0%,to{transform:translateX(0)}20%{transform:translateX(-4px)}60%{transform:translateX(4px)}}.result-header{text-align:center;margin-bottom:24px}.result-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary-dark));display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;margin:0 auto 14px;box-shadow:0 4px 20px rgba(29,78,216,.3);border:3px solid rgba(59,130,246,.2)}.result-name{font-size:20px;font-weight:800;color:var(--text-primary);margin-bottom:4px;line-height:1.3}.result-meta{font-size:12px;color:var(--text-muted)}.result-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,rgba(245,158,11,.12),rgba(251,191,36,.12));border:1px solid rgba(245,158,11,.3);color:#92400e;font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;margin-top:8px}.info-section{margin-bottom:20px}.info-section-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}.info-section-title:after{content:"";flex:1 1;height:1px;background:#e2e8f0}.info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid #f1f5f9;gap:12px}.info-row:last-child{border-bottom:none}.info-row-label{font-size:12px;color:var(--text-muted);font-weight:500;flex-shrink:0}.info-row-value{font-size:13px;color:var(--text-primary);font-weight:700;text-align:right;word-break:break-word}.scores-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;margin-bottom:16px}.score-card{background:var(--bg-input);border:1.5px solid #e2e8f0;border-radius:var(--radius-lg);padding:16px 14px;text-align:center;position:relative;overflow:hidden;transition:var(--transition)}.score-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:3px 3px 0 0}.score-card.math:before{background:linear-gradient(90deg,var(--primary-light),var(--info))}.score-card.bahasa:before{background:linear-gradient(90deg,var(--success-light),#34d399)}.score-card.math{border-color:rgba(59,130,246,.2)}.score-card.bahasa{border-color:rgba(16,185,129,.2)}.score-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;display:block}.score-value{font-size:34px;font-weight:800;line-height:1;margin-bottom:8px}.score-card.math .score-value{color:var(--primary)}.score-card.bahasa .score-value{color:var(--success)}.score-ket{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;display:inline-block}.ket-baik-istimewa{background:#f3e8ff;color:#6d28d9;border:1px solid #ddd6fe}.ket-baik{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.ket-memadai{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}.ket-kurang{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.score-total-card{background:linear-gradient(135deg,rgba(29,78,216,.06),rgba(99,102,241,.06));border:1.5px solid rgba(59,130,246,.2);border-radius:var(--radius-lg);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.score-total-label{font-size:13px;color:var(--text-secondary);font-weight:700}.score-total-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.score-total-value{font-size:30px;font-weight:800;color:var(--primary)}.app-footer{text-align:center;padding:20px 16px 36px;position:relative;z-index:1}.footer-card{background:#fff;border:1px solid rgba(59,130,246,.12);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:0 1px 6px rgba(0,0,0,.05);max-width:480px;margin:0 auto}.footer-school{font-size:13px;font-weight:700;color:var(--primary-dark);margin-bottom:2px}.footer-sub{font-size:11px;color:var(--text-muted);line-height:1.6;margin-bottom:10px}.footer-divider{height:1px;background:#f1f5f9;margin:10px 0}.footer-dev{font-size:11px;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:5px;flex-wrap:wrap}.footer-dev-name{font-size:12px;font-weight:700;color:var(--primary)}.spinner{width:18px;height:18px;border:2.5px solid hsla(0,0%,100%,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.fade-in{animation:fadeIn .4s ease both}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .35s cubic-bezier(.4,0,.2,1) both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hint-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;color:#1e40af;display:flex;gap:8px;align-items:flex-start;margin-top:16px}.divider{height:1px;background:#f1f5f9;margin:20px 0}@media (min-width:480px){.container{max-width:440px}.login-heading{font-size:26px}.score-value{font-size:38px}}@media (min-width:768px){.container{max-width:500px}}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/6fe53d21e6e7ebd8-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/8ebc6e9dde468c4a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/9e7b0a821b9dfcb4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/636a5ac981f94f8b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/6fe53d21e6e7ebd8-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/8ebc6e9dde468c4a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/9e7b0a821b9dfcb4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/636a5ac981f94f8b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/6fe53d21e6e7ebd8-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/8ebc6e9dde468c4a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/9e7b0a821b9dfcb4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/636a5ac981f94f8b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/6fe53d21e6e7ebd8-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/8ebc6e9dde468c4a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/9e7b0a821b9dfcb4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/636a5ac981f94f8b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/6fe53d21e6e7ebd8-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/8ebc6e9dde468c4a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/9e7b0a821b9dfcb4-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Plus_Jakarta_Sans_a11773;font-style:normal;font-weight:800;font-display:swap;src:url(/_next/static/media/636a5ac981f94f8b-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Plus_Jakarta_Sans_Fallback_a11773;src:local("Arial");ascent-override:98.88%;descent-override:21.15%;line-gap-override:0.00%;size-adjust:104.98%}.__className_a11773{font-family:__Plus_Jakarta_Sans_a11773,__Plus_Jakarta_Sans_Fallback_a11773;font-style:normal}.__variable_a11773{--font-main:"__Plus_Jakarta_Sans_a11773","__Plus_Jakarta_Sans_Fallback_a11773"}