@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap");:root{--bg:#f7f9ff;--ink:#0b1220;--muted:#526079;--brand:#1e3a8a;--brand-2:#0ea5e9;--accent:#22c55e;--card:#ffffff;--border:#dde5f3;--ok:#16a34a;--bad:#dc2626}*{box-sizing:border-box}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at 8% 8%,#dbeafe 0,transparent 42%),radial-gradient(circle at 92% 0,#dcfce7 0,transparent 38%),linear-gradient(180deg,#f8fbff 0,#eff5ff 100%),var(--bg)}a{color:inherit}.skip-link{position:absolute;left:12px;top:-40px;z-index:300;padding:8px 12px;border-radius:10px;background:#111827;color:#fff;text-decoration:none}.skip-link:focus-visible{top:12px}:where(button,[role=button],a,input,select,textarea,summary):focus-visible{outline:3px solid #60a5fa;outline-offset:2px}.app-shell{min-height:100vh}.app-header{position:-webkit-sticky;position:sticky;top:10px;z-index:120;padding:0 12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-header-inner{max-width:1240px;margin:0 auto;padding:12px 18px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;grid-gap:16px;gap:16px;border:1px solid #dfe7f6;border-radius:18px;background:rgba(255,255,255,.92);box-shadow:0 14px 28px rgba(30,58,138,.08)}.brand-block{display:grid;grid-gap:2px;gap:2px}.brand-block strong{font-family:Space Grotesk,Segoe UI,sans-serif;font-size:17px;letter-spacing:.01em}.brand-block span{color:var(--muted);font-size:12px}.app-nav{display:flex;align-items:center;gap:8px}.app-nav-link{display:inline-flex;align-items:center;justify-content:center;min-width:82px;padding:8px 12px;border-radius:10px;border:1px solid #dce6f7;text-decoration:none;color:#1e293b;font-weight:700;transition:background .2s ease,border-color .2s ease,color .2s ease}.app-nav-link:hover{background:#eaf2ff;border-color:#a9c7fb}.app-nav-link.active{background:#dbeafe;border-color:#60a5fa;color:#1e40af}.user-panel{display:flex;align-items:center;gap:10px}.user-meta{display:grid;text-align:right}.user-name{font-size:13px;font-weight:700}.user-role{font-size:11px;color:var(--muted);letter-spacing:.05em}.app-content{padding:28px 24px 26px}.app-content,.page{max-width:1240px;margin:0 auto}.login-wrap{min-height:calc(100vh - 48px);display:flex;align-items:center;justify-content:center}.login-card{width:min(460px,100%);background:#ffffff;border:1px solid var(--border);border-radius:20px;padding:24px;box-shadow:0 18px 40px rgba(15,23,42,.18)}.login-hint,.login-note{color:var(--muted);margin:6px 0 14px}.login-form{display:grid;grid-gap:12px;gap:12px}.login-form label{display:grid;grid-gap:6px;gap:6px;font-weight:600}.login-form input{border:1px solid var(--border);border-radius:10px;padding:10px 12px;font:inherit}.login-error{color:#b91c1c;font-weight:600;margin-top:10px}.hero{background:linear-gradient(120deg,rgba(255,255,255,.08),rgba(255,255,255,0) 35%),linear-gradient(130deg,#0f172a,#1e40af 64%,#2563eb);color:white;border-radius:26px;padding:30px;border:1px solid rgba(191,219,254,.35);box-shadow:0 24px 48px rgba(15,23,42,.24)}.eyebrow{text-transform:uppercase;letter-spacing:.09em;font-size:12px;opacity:.85}.hero h1{margin:8px 0;font-size:34px;font-family:Space Grotesk,Segoe UI,sans-serif}.hero p{opacity:.95;max-width:760px}.grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:16px;gap:16px}.folder-list,.grid{margin-top:20px;display:grid}.folder-list{grid-gap:14px;gap:14px}.folder{background:#ffffff;border:1px solid #d7e2f2;border-radius:18px;overflow:hidden;box-shadow:0 10px 22px rgba(30,58,138,.06)}.folder-head{list-style:none;cursor:pointer;padding:22px 20px;display:flex;align-items:center;justify-content:space-between;min-height:88px;background:#f8fbff;transition:background .2s ease}.folder-head::-webkit-details-marker{display:none}.folder:hover .folder-head{background:#eef5ff}.folder[open] .folder-head{border-bottom:1px solid var(--border)}.folder-left{gap:12px;font-size:20px}.folder-icon,.folder-left{display:inline-flex;align-items:center}.folder-icon{width:36px;height:36px;justify-content:center;border-radius:10px;background:linear-gradient(160deg,#dbeafe,#dcfce7);border:1px solid #c7ddfb;position:relative}.folder-icon:before{content:"";width:16px;height:11px;border:2px solid #1e3a8a;border-top:4px solid #1e3a8a;border-radius:3px}.folder-count{font-size:14px;color:var(--muted)}.folder-grid{margin-top:0;padding:14px}.card{background:var(--card);border:1px solid #d7e2f2;border-radius:16px;padding:18px;box-shadow:0 10px 22px rgba(30,58,138,.05)}.card-clickable{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.card-clickable:hover{transform:translateY(-4px);border-color:#93c5fd;box-shadow:0 16px 30px rgba(30,64,175,.14)}.card-clickable:focus-visible{outline:3px solid #5aa9ff;outline-offset:2px}.card-top{display:flex;justify-content:space-between;align-items:center}.pill{background:#eaf1ff;border:1px solid #bfd6ff;color:#1d4ed8}.pill,.status-pill{border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.status-pill{display:inline-flex;align-items:center;border:1px solid #cbd5e1;background:#f1f5f9;color:#334155}.status-pill.in_progress{background:#e0f2fe;border-color:#93c5fd;color:#1d4ed8}.status-pill.paused{background:#fff7ed;border-color:#fdba74;color:#c2410c}.btn{background:linear-gradient(135deg,#2563eb,#1e40af);color:white;border:1px solid #1e40af;border-radius:12px;padding:10px 14px;font-weight:600;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.btn:hover{transform:translateY(-1px);filter:brightness(1.03);box-shadow:0 10px 16px rgba(29,78,216,.28)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background:#334155;border-color:#334155}.btn-danger{background:var(--bad)}.btn.tiny{padding:7px 10px;font-size:12px}.actions-row{display:flex;gap:10px;flex-wrap:wrap}.exam-layout{display:grid;grid-template-columns:320px 1fr;grid-gap:16px;gap:16px;max-width:1400px;margin:0 auto}.exam-layout.paused{filter:blur(2px);opacity:.85;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.left-panel,.question-panel{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px}.left-panel{position:-webkit-sticky;position:sticky;top:98px;max-height:calc(100vh - 120px);overflow:auto}.timer{margin:10px 0;font-size:34px;font-weight:800;color:#1e3a8a;background:#eff6ff;border:1px solid #bfdbfe;border-radius:14px;text-align:center;padding:10px}.meta-row{display:flex;justify-content:space-between;color:var(--muted);font-size:14px}.palette{margin:14px 0;display:grid;grid-template-columns:repeat(5,1fr);grid-gap:8px;gap:8px}.palette-btn{position:relative;border:1px solid var(--border);background:#fff;border-radius:10px;padding:8px 0;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.palette-btn.active{outline:2px solid #5aa9ff}.palette-btn.answered,.palette-btn.correct{background:#def7ec;border-color:#98d8b9}.palette-btn.wrong{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.palette-btn.marked{border-color:#f59e0b}.q-flag{position:absolute;top:1px;right:5px;font-size:12px;line-height:1;color:#dc2626}.question-head{display:flex;justify-content:space-between;align-items:center}.question-box{background:#f8fbff;border:1px solid var(--border);border-radius:14px;padding:16px;line-height:1.6;overflow-wrap:anywhere;word-break:break-word}.answers{display:flex;flex-direction:column;gap:10px;margin-top:14px}.answer{display:grid;grid-template-columns:20px 28px 1fr;align-items:start;grid-column-gap:10px;column-gap:10px;border:1px solid var(--border);border-radius:14px;padding:12px;cursor:pointer;background:white}.answer.checked{border-color:#5aa9ff;background:#eff7ff}.answer input{margin:6px 0 0}.option-badge{min-width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-weight:800;background:#edf2f7}.answer>span:last-child>p:first-child{margin-top:0}.answer>span:last-child>p:last-child{margin-bottom:0}.question-actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}.history-table-wrap{margin-top:16px;background:white;border:1px solid var(--border);border-radius:14px;overflow:hidden}.history-table{width:100%;border-collapse:collapse}.history-table td,.history-table th{border-bottom:1px solid var(--border);padding:12px;text-align:left}.history-table th{background:#f4f8ff;color:#1e3a8a;font-weight:700}.review-list{display:grid;grid-gap:14px;gap:14px;margin-top:16px}.review-card{background:white;border:1px solid var(--border);border-left:6px solid #94a3b8;border-radius:14px;padding:16px}.review-card.correct{border-left-color:var(--ok)}.review-card.wrong{border-left-color:var(--bad)}.review-answers .answer.review{cursor:default;grid-template-columns:28px 1fr}.answer.review.is-correct{background:#def7ec;border-color:#98d8b9}.answer.review.is-selected{background:#fff4f2;border-color:#ffcabf}.answer.practice-correct{background:#def7ec;border-color:#98d8b9}.answer.practice-wrong{background:#fff4f2;border-color:#ffcabf}.explain-box,.review-html{overflow-wrap:anywhere;word-break:break-word}.explain-box img,.question-box img,.review-html img{max-width:100%;height:auto}.explain-box [class*=open-full-size-image--backdrop--],.explain-box [class*=open-full-size-image--button--],.explain-box button[class*=open-full-size-image--],.question-box [class*=open-full-size-image--backdrop--],.question-box [class*=open-full-size-image--button--],.question-box button[class*=open-full-size-image--],.review-html [class*=open-full-size-image--backdrop--],.review-html [class*=open-full-size-image--button--],.review-html button[class*=open-full-size-image--]{display:none!important}.explain-box [class*=open-full-size-image--wrapper--],.question-box [class*=open-full-size-image--wrapper--],.review-html [class*=open-full-size-image--wrapper--]{display:inline-block!important;width:auto!important;max-width:100%!important;height:auto!important;min-height:0!important;background:transparent!important;border:0!important;padding:0!important}.explain-box [class*=open-full-size-image--wrapper--]:not(:has(img)),.question-box [class*=open-full-size-image--wrapper--]:not(:has(img)),.review-html [class*=open-full-size-image--wrapper--]:not(:has(img)){display:none!important}.explain-box{margin-top:14px;background:#f9fafb;border:1px dashed #cfd8e3;border-radius:12px;padding:12px}.explain-box.practice-ok{background:#ecfdf5;border-color:#10b981}.explain-box.practice-bad{background:#fef2f2;border-color:#ef4444}.error,.notice{position:fixed;right:16px;z-index:100;border-radius:12px;padding:10px 12px;color:white;font-weight:600}.notice{top:16px;background:#2b6cb0}.error{top:64px;background:#c53030}.auth-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-weight:700}.top-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:rgba(37,99,235,.12);overflow:hidden}.top-progress span{display:block;width:35%;height:100%;background:linear-gradient(90deg,#2563eb,#0ea5e9);animation:top-progress-slide 1s ease-in-out infinite}@keyframes top-progress-slide{0%{transform:translateX(-100%)}to{transform:translateX(340%)}}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;z-index:300;padding:16px}.modal-card{width:min(480px,100%);background:#ffffff;border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 50px rgba(15,23,42,.25);padding:20px}.modal-card h3,.modal-card p{margin:0 0 8px}.modal-card p{color:var(--muted)}.modal-form{display:grid;grid-gap:8px;gap:8px}.modal-form label{display:grid;grid-gap:6px;gap:6px;font-weight:600}.modal-form input{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font:inherit;background:#fff}.admin-page{display:grid;grid-gap:16px;gap:16px}.admin-card{margin-top:0}.admin-form{display:grid;grid-gap:12px;gap:12px}.admin-form label{display:grid;grid-gap:6px;gap:6px;font-weight:600}.admin-form input,.admin-form select,.admin-form textarea{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font:inherit;background:#fff}.admin-form textarea{resize:vertical;min-height:80px}.admin-mode-btn{min-width:170px}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}@media (max-width:1024px){.exam-layout{grid-template-columns:1fr}.left-panel{position:static;height:auto}.hero h1{font-size:28px}}@media (max-width:768px){.app-header-inner{padding:8px 10px;grid-template-columns:auto 1fr auto;grid-template-areas:"brand nav user";align-items:center;gap:6px}.brand-block{grid-area:brand}.brand-block strong{font-size:14px}.brand-block span{display:none}.app-nav{grid-area:nav;width:100%;overflow-x:auto;padding-bottom:0;scrollbar-width:thin;justify-content:center;gap:6px;white-space:nowrap}.user-panel{grid-area:user;justify-content:flex-end;gap:0}.user-meta{display:none}.user-panel .btn{width:auto;padding:6px 9px;font-size:11px;border-radius:10px;min-height:30px}.app-nav-link{min-width:64px;padding:6px 8px;font-size:12px}.app-content{padding:12px}.page{max-width:100%}.hero{border-radius:16px;padding:18px}.hero h1{font-size:24px}.hero p{font-size:14px}.card{border-radius:14px;padding:14px}.actions-row{display:grid;grid-template-columns:1fr}.btn{width:100%;justify-content:center}.btn.tiny{width:auto}.left-panel,.question-panel{border-radius:14px;padding:14px}.timer{font-size:28px;padding:8px}.palette{grid-template-columns:repeat(6,1fr);gap:6px}.question-box{padding:12px}.answer{padding:10px;column-gap:8px}.question-actions{display:grid;grid-template-columns:1fr 1fr}.history-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.history-table{min-width:640px}.review-card{border-radius:12px;padding:12px}.explain-box{padding:10px}.error,.notice{right:12px;left:12px;width:auto;text-align:center}}@media (max-width:480px){.app-header{top:6px;padding:0 8px}.app-header-inner{padding:7px 8px;border-radius:14px;grid-template-columns:auto 1fr auto;grid-template-areas:"brand nav user";gap:6px}.user-panel{justify-content:flex-end}.app-nav-link{min-width:58px;padding:6px 7px;font-size:11px}.hero{border-radius:12px;padding:14px}.hero h1{font-size:21px}.eyebrow{font-size:11px}.login-card{border-radius:14px;padding:16px}.palette{grid-template-columns:repeat(5,1fr)}.option-badge{min-width:24px;height:24px;font-size:12px}.answer{grid-template-columns:18px 24px 1fr}.review-answers .answer.review{grid-template-columns:24px 1fr}.modal-card{border-radius:12px;padding:14px}.admin-form textarea{min-height:120px}}