:root{--bg: #f1f5f9;--card: #ffffff;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--primary: #1d4ed8;--primary-dark: #1e3a8a;--primary-soft: #dbeafe;--green: #16a34a;--green-soft: #dcfce7;--red: #dc2626;--red-soft: #fee2e2;--radius: 14px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.45}#root{max-width:640px;margin:0 auto;min-height:100dvh}button{font:inherit;color:inherit;border:none;background:none;cursor:pointer}.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)}}.bottom-bar{position:sticky;bottom:0;display:flex;gap:12px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:linear-gradient(to top,var(--bg) 70%,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:52px;border-radius:var(--radius);font-size:17px;font-weight:600;transition:transform .05s ease,opacity .15s ease}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4}.btn.primary{background:var(--primary);color:#fff;box-shadow:0 4px 14px #1d4ed84d}.btn.finish{background:var(--green);color:#fff;box-shadow:0 4px 14px #16a34a4d}.btn.secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}.start-screen{text-align:center}.start-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px}.start-badge{font-size:56px;margin-bottom:8px}.start-screen h1{margin:0;font-size:30px;color:var(--primary-dark)}.subtitle{margin:6px 0 28px;color:var(--muted)}.home-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;max-width:360px;margin-bottom:12px}.home-stat{display:flex;flex-direction:column;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px 12px;text-align:left}.home-stat-value{font-size:22px;font-weight:800;line-height:1.1;color:var(--primary-dark);font-variant-numeric:tabular-nums}.home-stat-label{font-size:12px;color:var(--muted)}.history-link{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:360px;min-height:44px;margin-bottom:12px;padding:10px 14px;background:var(--primary-soft);color:var(--primary-dark);border:1px solid #bfdbfe;border-radius:12px;font-weight:700;text-align:left}.history-link:disabled{opacity:.45;cursor:default}.last-activity{margin:12px 0 0;color:var(--muted);font-size:13px}.start-info{list-style:none;margin:0;padding:0;width:100%;max-width:360px;text-align:left}.start-info li{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;font-weight:500}.info-icon{font-size:20px}.error-banner{margin-top:16px;padding:12px 16px;background:var(--red-soft);color:var(--red);border-radius:var(--radius);font-weight:500;max-width:360px}.mode-list{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px;margin-top:8px}.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;transition:border-color .15s ease,transform .05s ease}.mode-card:active{transform:scale(.99)}.mode-card:hover{border-color:var(--primary)}.mode-card:disabled{opacity:.55;cursor:default}.mode-card.review-mode{border-color:#bbf7d0;background:#f0fdf4}.mode-icon{font-size:28px;flex-shrink:0}.mode-text{display:flex;flex-direction:column;flex:1}.mode-title{font-size:17px;font-weight:700;color:var(--text)}.mode-desc{font-size:13px;color:var(--muted)}.mode-arrow{font-size:24px;color:var(--muted);flex-shrink:0}.overview-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:10px;padding:8px 12px;border:1px solid var(--border);border-radius:10px;background:var(--card);font-size:13px;font-weight:600;color:var(--text)}.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}.overview-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;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:#14532d}.overview-cell.incorrect{background:var(--red-soft);border-color:var(--red);color:#7f1d1d}.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: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}.feedback-banner.correct{background:var(--green-soft);color:#14532d}.feedback-banner.incorrect{background:var(--red-soft);color:#7f1d1d}.quiz-header{position:sticky;top:0;z-index:10;background:var(--bg);padding:calc(10px + env(safe-area-inset-top)) 16px 10px}.progress-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .25s ease}.quiz-meta{display:flex;align-items:center;gap:8px;margin-top:10px}.quiz-counter{font-weight:700;font-variant-numeric:tabular-nums}.category-chip,.points-chip{font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-chip{background:var(--primary-soft);color:var(--primary-dark)}.points-chip{background:var(--card);border:1px solid var(--border);color:var(--muted);margin-left:auto}.quiz-body{flex:1;padding:8px 16px 16px}.question-text{font-size:18px;font-weight:600;margin:8px 0 14px}.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:14px}.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:52px;transition:border-color .15s ease,background .15s ease}.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);border-radius:50%;background:#fff}.answer-mark.square{border-radius:6px}.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{text-align:center;color:#fff;padding:calc(32px + env(safe-area-inset-top)) 20px 24px;border-radius:0 0 24px 24px}.results-hero.passed{background:linear-gradient(160deg,#15803d,#16a34a)}.results-hero.failed{background:linear-gradient(160deg,#b91c1c,#dc2626)}.results-percent{font-size:56px;font-weight:800;line-height:1}.results-verdict{font-size:20px;font-weight:600;margin:8px 0 20px}.results-stats{display:flex;justify-content:center;gap:28px}.stat{display:flex;flex-direction:column}.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:20px 16px 8px}.results-body h2{font-size:18px;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:14px;margin-bottom:12px}.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:7px 10px;border-radius:8px;margin-bottom:4px;font-size:15px}.review-answers li.right{background:var(--green-soft);color:#14532d}.review-answers li.wrong{background:var(--red-soft);color:#7f1d1d}.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:10px;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}.review-rating-actions{display:flex;flex:2;gap:10px}.review-rating-actions .btn{min-width:0}.history-screen{background:var(--bg)}.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:var(--bg);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);font-size:32px;line-height:1;color:var(--primary-dark)}.history-header h1{margin:0;font-size:22px}.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:8px;margin-bottom:18px}.history-stat{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px}.history-stat-value{font-size:22px;font-weight:800;color:var(--primary-dark);font-variant-numeric:tabular-nums}.history-stat-label{font-size:12px;color:var(--muted)}.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}.empty-state{margin:0;padding:14px;background:var(--card);border:1px solid var(--border);border-radius:12px;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:12px;padding:12px}.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:800;color:var(--primary-dark)}.session-score{display:flex;flex-direction:column;align-items:flex-end;white-space:nowrap}.session-score strong{font-size:20px;color:var(--text);font-variant-numeric:tabular-nums}.session-score span{color:var(--muted);font-size:12px}.attempt-group h3{margin:14px 0 8px;color:var(--muted);font-size:13px;font-weight:800}.attempt-card{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--green);border-radius:12px;padding:12px;margin-bottom:8px}.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}
