:root{--bg: #f4f5fb;--bg-soft: #eceefa;--card: #ffffff;--card-raised: #ffffff;--text: #101426;--muted: #666e85;--border: #e4e6f0;--border-strong: #d4d8e8;--primary: #4f46e5;--primary-strong: #4338ca;--primary-dark: #312e81;--primary-soft: #e4e2fd;--primary-soft-border: #c9c6fa;--green: #059669;--green-soft: #d8f3e7;--green-text: #065f46;--red: #e11d48;--red-soft: #fde5ea;--red-text: #9f1239;--hero-pass: linear-gradient(150deg, #047857, #10b981);--hero-fail: linear-gradient(150deg, #be123c, #f43f5e);--primary-grad: linear-gradient(135deg, #6366f1, #4f46e5);--radius: 16px;--radius-sm: 12px;--shadow-sm: 0 1px 2px rgb(16 20 38 / 4%), 0 2px 8px rgb(16 20 38 / 4%);--shadow-md: 0 2px 4px rgb(16 20 38 / 5%), 0 10px 24px rgb(16 20 38 / 7%);--shadow-primary: 0 8px 20px rgb(79 70 229 / 28%);--shadow-green: 0 8px 20px rgb(5 150 105 / 28%);--ring: 0 0 0 3px rgb(99 102 241 / 35%);color-scheme:light}@media(prefers-color-scheme:dark){:root{--bg: #0d1020;--bg-soft: #12152a;--card: #181c33;--card-raised: #1e2340;--text: #eef0fa;--muted: #99a0bd;--border: #272c4a;--border-strong: #353b61;--primary: #818cf8;--primary-strong: #6d77f2;--primary-dark: #c7cbfd;--primary-soft: #272a55;--primary-soft-border: #3d4180;--green: #34d399;--green-soft: #11342c;--green-text: #86efc5;--red: #fb7185;--red-soft: #3c1b27;--red-text: #fda4b4;--hero-pass: linear-gradient(150deg, #065f46, #059669);--hero-fail: linear-gradient(150deg, #9f1239, #e11d48);--primary-grad: linear-gradient(135deg, #6366f1, #4f46e5);--shadow-sm: 0 1px 2px rgb(0 0 0 / 25%);--shadow-md: 0 2px 4px rgb(0 0 0 / 25%), 0 10px 24px rgb(0 0 0 / 35%);--shadow-primary: 0 8px 20px rgb(0 0 0 / 35%);--shadow-green: 0 8px 20px rgb(0 0 0 / 35%);--ring: 0 0 0 3px rgb(129 140 248 / 45%);color-scheme:dark}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background:radial-gradient(900px 480px at 85% -10%,rgb(99 102 241 / 9%),transparent 60%),radial-gradient(700px 420px at -10% 0%,rgb(16 185 129 / 6%),transparent 55%),var(--bg);background-attachment:fixed}#root{max-width:640px;margin:0 auto;min-height:100dvh}button{font:inherit;color:inherit;border:none;background:none;cursor:pointer}button:focus-visible{outline:none;box-shadow:var(--ring)}.screen{display:flex;flex-direction:column;min-height:100dvh}.center{justify-content:center;align-items:center}.spinner{width:44px;height:44px;border:4px solid var(--primary-soft);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.bottom-bar{position:sticky;bottom:0;display:flex;gap:12px;padding:14px 16px calc(14px + env(safe-area-inset-bottom));background:linear-gradient(to top,var(--bg) 60%,transparent)}.bottom-bar.split .btn.secondary{flex:1}.bottom-bar.split .btn.primary,.bottom-bar.split .btn.finish{flex:2}.btn{flex:1;min-height:54px;border-radius:var(--radius);font-size:17px;font-weight:600;letter-spacing:-.01em;transition:transform .1s ease,opacity .15s ease,box-shadow .2s ease,filter .15s ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4}.btn.primary{background:var(--primary-grad);color:#fff;box-shadow:var(--shadow-primary)}.btn.primary:hover:not(:disabled){filter:brightness(1.07)}.btn.finish{background:var(--hero-pass);color:#fff;box-shadow:var(--shadow-green)}.btn.secondary{background:var(--card);color:var(--text);border:1px solid var(--border-strong);box-shadow:var(--shadow-sm)}.btn.secondary:hover:not(:disabled){border-color:var(--primary-soft-border)}.start-screen{text-align:center}.start-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:32px 24px;animation:rise .35s ease both}.start-badge{width:88px;height:88px;display:flex;align-items:center;justify-content:center;font-size:44px;margin-bottom:16px;background:var(--primary-grad);border-radius:28px;box-shadow:var(--shadow-primary)}.start-screen h1{margin:0;font-size:32px;font-weight:800;letter-spacing:-.03em;background:linear-gradient(120deg,var(--primary-strong),var(--primary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.subtitle{margin:6px 0 28px;color:var(--muted);font-size:15px}.home-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:100%;max-width:380px;margin-bottom:14px}.home-stat{display:flex;flex-direction:column;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;text-align:left;box-shadow:var(--shadow-sm)}.home-stat-value{font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1.1;color:var(--text);font-variant-numeric:tabular-nums}.home-stat-label{font-size:12px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.history-link{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:380px;min-height:48px;margin-bottom:22px;padding:12px 16px;background:var(--primary-soft);color:var(--primary-dark);border:1px solid var(--primary-soft-border);border-radius:var(--radius-sm);font-weight:700;text-align:left;transition:filter .15s ease,transform .1s ease}.history-link:hover:not(:disabled){filter:brightness(1.03)}.history-link:active:not(:disabled){transform:scale(.99)}.history-link:disabled{opacity:.45;cursor:default}.last-activity{margin:16px 0 0;color:var(--muted);font-size:13px}.error-banner{margin-top:16px;padding:12px 16px;background:var(--red-soft);color:var(--red-text);border:1px solid var(--red);border-radius:var(--radius);font-weight:500;max-width:380px}.mode-list{display:flex;flex-direction:column;gap:12px;width:100%;max-width:380px}.mode-card{display:flex;align-items:center;gap:14px;text-align:left;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);transition:border-color .15s ease,transform .1s ease,box-shadow .2s ease}.mode-card:active{transform:scale(.985)}.mode-card:hover{border-color:var(--primary-soft-border);box-shadow:var(--shadow-md)}.mode-card:disabled{opacity:.55;cursor:default}.mode-card.review-mode{border-color:var(--green);background:linear-gradient(135deg,var(--green-soft),var(--card) 70%)}.mode-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;background:var(--bg-soft);border-radius:14px}.review-mode .mode-icon{background:var(--green-soft);color:var(--green);font-weight:700}.mode-text{display:flex;flex-direction:column;flex:1}.mode-title{font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.mode-desc{font-size:13px;color:var(--muted)}.mode-arrow{font-size:24px;color:var(--muted);flex-shrink:0;transition:transform .15s ease,color .15s ease}.mode-card:hover .mode-arrow,.history-link:hover:not(:disabled) .mode-arrow{transform:translate(3px);color:var(--primary)}.overview-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:10px;padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);font-size:13px;font-weight:600;color:var(--text);box-shadow:var(--shadow-sm)}.overview-score{color:var(--muted);font-variant-numeric:tabular-nums}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:6px;margin-top:10px;max-height:180px;overflow-y:auto;padding:2px;animation:rise .2s ease both}.overview-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:10px;background:var(--card);font-size:14px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.overview-cell.correct{background:var(--green-soft);border-color:var(--green);color:var(--green-text)}.overview-cell.incorrect{background:var(--red-soft);border-color:var(--red);color:var(--red-text)}.overview-cell.current{outline:2px solid var(--primary);outline-offset:1px}.answer.right{border-color:var(--green);background:var(--green-soft)}.answer.wrong{border-color:var(--red);background:var(--red-soft)}.answer.right .answer-mark{border-color:var(--green);background:var(--green);box-shadow:inset 0 0 0 3px var(--green-soft)}.answer.wrong .answer-mark{border-color:var(--red);background:var(--red);box-shadow:inset 0 0 0 3px var(--red-soft)}.answer:disabled{cursor:default}.answer-status{flex-shrink:0;font-weight:800;font-size:18px}.answer.right .answer-status{color:var(--green)}.answer.wrong .answer-status{color:var(--red)}.feedback-banner{margin-top:16px;padding:14px 16px;border-radius:var(--radius);font-weight:700;font-size:17px;text-align:center;animation:rise .25s ease both}.feedback-banner.correct{background:var(--green-soft);color:var(--green-text);border:1px solid var(--green)}.feedback-banner.incorrect{background:var(--red-soft);color:var(--red-text);border:1px solid var(--red)}.quiz-header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 75%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:calc(10px + env(safe-area-inset-top)) 16px 10px;border-bottom:1px solid var(--border)}.progress-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-grad);border-radius:3px;transition:width .3s ease}.quiz-meta{display:flex;align-items:center;gap:8px;margin-top:10px}.quiz-counter{font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.category-chip,.points-chip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-chip{background:var(--primary-soft);color:var(--primary-dark);border:1px solid var(--primary-soft-border)}.points-chip{background:var(--card);border:1px solid var(--border);color:var(--muted);margin-left:auto}.quiz-body{flex:1;padding:14px 16px 16px}.question-text{font-size:19px;font-weight:600;letter-spacing:-.015em;line-height:1.4;margin:8px 0 16px}.question-image{display:block;width:100%;max-height:280px;object-fit:contain;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;box-shadow:var(--shadow-sm)}.question-image.small{max-height:200px}.multi-hint{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--primary)}.answers{display:flex;flex-direction:column;gap:10px}.answer{display:flex;align-items:flex-start;gap:12px;text-align:left;background:var(--card);border:2px solid var(--border);border-radius:var(--radius);padding:14px;min-height:54px;box-shadow:var(--shadow-sm);transition:border-color .15s ease,background .15s ease,transform .1s ease}.answer:not(:disabled):active{transform:scale(.99)}.answer:not(:disabled):hover{border-color:var(--primary-soft-border)}.answer.selected{border-color:var(--primary);background:var(--primary-soft)}.answer-mark{flex-shrink:0;width:22px;height:22px;margin-top:1px;border:2px solid var(--border-strong);border-radius:50%;background:var(--card);transition:border-color .15s ease,background .15s ease}.answer-mark.square{border-radius:7px}.answer.selected .answer-mark{border-color:var(--primary);background:var(--primary);box-shadow:inset 0 0 0 3px var(--primary-soft)}.answer-text{flex:1}.results-hero{position:relative;overflow:hidden;text-align:center;color:#fff;padding:calc(36px + env(safe-area-inset-top)) 20px 28px;border-radius:0 0 28px 28px}.results-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(420px 220px at 85% -20%,rgb(255 255 255 / 18%),transparent 65%),radial-gradient(360px 200px at 10% 110%,rgb(255 255 255 / 10%),transparent 60%);pointer-events:none}.results-hero>*{position:relative}.results-hero.passed{background:var(--hero-pass)}.results-hero.failed{background:var(--hero-fail)}.results-percent{font-size:60px;font-weight:800;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}.results-verdict{font-size:20px;font-weight:600;margin:10px 0 22px}.results-stats{display:flex;justify-content:center;gap:10px}.stat{display:flex;flex-direction:column;min-width:84px;padding:10px 14px;background:#ffffff24;border:1px solid rgb(255 255 255 / 22%);border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stat-value{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums}.stat-label{font-size:12px;opacity:.85}.results-body{flex:1;padding:24px 16px 8px}.results-body h2{font-size:18px;letter-spacing:-.01em;margin:0 0 12px}.review-card{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.review-card.incorrect{border-left-color:var(--red)}.review-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.review-number{font-weight:700;color:var(--muted)}.review-points{font-size:13px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums}.review-question{margin:0 0 10px;font-weight:600}.review-answers{list-style:none;margin:0;padding:0}.review-answers li{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:10px;margin-bottom:4px;font-size:15px}.review-answers li.right{background:var(--green-soft);color:var(--green-text)}.review-answers li.wrong{background:var(--red-soft);color:var(--red-text)}.review-mark{flex-shrink:0;width:18px;font-weight:700}.your-pick{margin-left:auto;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;opacity:.7;white-space:nowrap;padding-left:8px}.explanation{margin-top:12px;border-top:1px solid var(--border);padding-top:10px}.explanation summary{font-weight:600;font-size:14px;color:var(--primary);cursor:pointer}.explanation-body{margin-top:8px;font-size:14px;color:var(--muted);overflow-wrap:break-word}.explanation-body img{max-width:100%;height:auto;border-radius:var(--radius-sm)}.review-rating-actions{display:flex;flex:2;gap:10px}.review-rating-actions .btn{min-width:0}.history-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;background:color-mix(in srgb,var(--bg) 75%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.icon-back{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-sm);font-size:28px;line-height:1;padding-bottom:3px;color:var(--primary)}.history-header h1{margin:0;font-size:22px;letter-spacing:-.02em}.history-header p{margin:2px 0 0;color:var(--muted);font-size:13px}.history-body{flex:1;padding:16px 16px 8px}.history-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:20px}.history-stat{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;box-shadow:var(--shadow-sm)}.history-stat-value{font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--text);font-variant-numeric:tabular-nums}.history-stat-label{font-size:12px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.history-section{margin-bottom:20px}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.section-head h2{margin:0;font-size:18px;letter-spacing:-.01em}.empty-state{margin:0;padding:16px;background:var(--card);border:1px dashed var(--border-strong);border-radius:var(--radius-sm);color:var(--muted)}.session-list{display:flex;flex-direction:column;gap:8px}.session-card{display:flex;justify-content:space-between;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;box-shadow:var(--shadow-sm)}.session-card time,.attempt-topline time{display:block;color:var(--muted);font-size:12px}.session-mode{display:inline-block;margin-bottom:3px;font-size:13px;font-weight:700;color:var(--primary)}.session-score{display:flex;flex-direction:column;align-items:flex-end;white-space:nowrap}.session-score strong{font-size:20px;letter-spacing:-.01em;color:var(--text);font-variant-numeric:tabular-nums}.session-score span{color:var(--muted);font-size:12px}.share-btn{margin-left:auto;padding:5px 12px;font:inherit;font-size:13px;font-weight:600;color:var(--primary);background:var(--card);border:1px solid var(--primary);border-radius:999px;cursor:pointer;white-space:nowrap}.sort-chips{display:flex;gap:6px;margin-bottom:10px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.sort-chips::-webkit-scrollbar{display:none}.sort-chip{flex-shrink:0;padding:6px 12px;font:inherit;font-size:13px;font-weight:600;color:var(--muted);background:var(--card);border:1px solid var(--border);border-radius:999px;cursor:pointer}.sort-chip.active{color:var(--primary);border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,var(--card))}.question-stat-list{display:flex;flex-direction:column;gap:8px}.question-stat-card{display:block;width:100%;font:inherit;color:inherit;text-align:left;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;box-shadow:var(--shadow-sm);cursor:pointer}.question-stat-card:hover,button.attempt-card:hover{border-color:var(--primary)}.question-stat-card p{margin:0 0 8px;font-weight:600}.question-stat-meta{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:12px}.question-stat-meta>span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.question-stat-counts{display:flex;gap:10px;white-space:nowrap;font-weight:700;font-variant-numeric:tabular-nums}.count-correct{color:var(--green)}.count-wrong{color:var(--red)}.count-accuracy{color:var(--text)}.attempt-group h3{margin:14px 0 8px;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.attempt-card{display:block;width:100%;font:inherit;color:inherit;text-align:left;background:var(--card);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow-sm);cursor:pointer}.attempt-card.incorrect{border-left-color:var(--red)}.attempt-topline,.attempt-meta{display:flex;justify-content:space-between;gap:12px}.attempt-card p{margin:6px 0 8px;font-weight:600}.attempt-meta{color:var(--muted);font-size:12px}.attempt-meta span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
