:root{--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--color-bg:#f7fafc;--color-surface:#fff;--color-surface-strong:#eef6ff;--color-text:#172033;--color-muted:#5f6b7a;--color-border:#d8e1ea;--color-safe:#15803d;--color-safe-bg:#dcfce7;--color-warning:#b45309;--color-warning-bg:#fef3c7;--color-danger:#b91c1c;--color-danger-bg:#fee2e2;--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-teal:#0f766e;--shadow-soft:0 18px 50px #0f172a1f;--app-max-width:480px;--font-base:system-ui, -apple-system, "Hiragino Sans", "Yu Gothic UI", sans-serif;--font-mono:ui-monospace, "SF Mono", Consolas, "Noto Sans Mono CJK JP", monospace}html,body{overscroll-behavior:contain;min-height:100%;font-family:var(--font-base);color:var(--color-text);background:radial-gradient(circle at 0 0,#2563eb1f,#0000 32rem),linear-gradient(#f8fbff 0%,#edf5f2 100%);margin:0;overflow-x:hidden}*{box-sizing:border-box}button,input,select,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}#root{width:100%;min-height:100dvh}.app-root{width:min(100%, var(--app-max-width));max-width:var(--app-max-width);background:var(--color-bg);min-height:100dvh;margin:0 auto;position:relative;overflow-x:hidden;box-shadow:0 0 0 1px #0f172a0f}.sticky-header{z-index:10;min-height:calc(64px + var(--safe-top));padding:calc(8px + var(--safe-top)) 12px 8px;border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff0;grid-template-columns:56px minmax(0,1fr) 160px;align-items:center;gap:6px;display:grid;position:sticky;top:0}.header-actions{justify-content:flex-end;gap:5px;display:flex}.icon-button{border:1px solid var(--color-border);min-width:48px;min-height:48px;color:var(--color-text);background:var(--color-surface);border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.icon-button--text{font-size:13px;font-weight:800}.icon-button:disabled{opacity:.35}.progress{min-width:0}.progress__track{background:#d9e4ee;border-radius:999px;height:10px;overflow:hidden}.progress__fill{border-radius:inherit;background:linear-gradient(90deg, var(--color-teal), var(--color-primary));height:100%}.progress__label{color:var(--color-muted);text-align:center;margin-top:4px;font-size:12px;line-height:1.2;display:block}.app-main{min-height:calc(100dvh - 152px);padding:18px 14px 116px}.sticky-footer{right:max(0px, calc((100vw - var(--app-max-width)) / 2));bottom:0;left:max(0px, calc((100vw - var(--app-max-width)) / 2));z-index:10;max-width:var(--app-max-width);padding:12px 14px calc(16px + var(--safe-bottom));border-top:1px solid var(--color-border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;grid-template-columns:auto minmax(0,1fr);gap:10px;margin:0 auto;display:grid;position:fixed}.sticky-footer .action-button--full:first-child{grid-column:1/-1}.action-button{color:#fff;background:var(--color-primary);border:1px solid #0000;border-radius:8px;min-height:52px;padding:0 18px;font-weight:700;line-height:1.2}.action-button--full{width:100%}.action-button--primary:hover{background:var(--color-primary-dark)}.action-button--secondary{color:var(--color-text);border-color:var(--color-border);background:var(--color-surface)}.action-button--ghost{color:var(--color-muted);background:0 0;border-color:#0000}.action-button--danger{background:var(--color-danger)}.action-button:disabled,.choice-button:disabled{cursor:not-allowed;opacity:.56}.home-screen,.stage-map,.final-result,.main-card{flex-direction:column;gap:16px;display:flex}.home-screen h1,.stage-map h1,.main-card h1,.final-result h1{color:var(--color-text);letter-spacing:0;margin:0;font-size:clamp(28px,9vw,42px);line-height:1.04}.main-card h1{font-size:clamp(26px,8vw,36px)}.eyebrow{color:var(--color-teal);letter-spacing:0;text-transform:uppercase;margin:0;font-size:13px;font-weight:800}.hero-copy,.card-body,.main-card p,.home-screen p{overflow-wrap:anywhere;color:var(--color-muted);margin:0;font-size:16px;line-height:1.7}.hero-copy{color:var(--color-text);font-size:20px;font-weight:800}.promise-box,.checkpoint-box,.complete-banner,.answer-panel,.git-panel,.ending-summary,.mistake-top{border:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-soft);border-radius:8px;padding:14px}.promise-box strong,.checkpoint-box strong,.complete-banner strong,.answer-panel strong{margin-bottom:4px;display:block}.home-actions,.result-actions{gap:10px;display:grid}.main-card{border:1px solid var(--color-border);background:var(--color-surface);border-radius:8px;min-height:54dvh;padding:22px 18px}.main-card--checkpoint{background:linear-gradient(#fff,#effdf5);border-color:#15803d59}.main-card--feedback_wrong{background:linear-gradient(#fff,#fff1f2);border-color:#b91c1c59}.card-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.card-list li{background:var(--color-surface-strong);border-radius:8px;padding:12px}.note{border-left:4px solid var(--color-warning);background:var(--color-warning-bg);border-radius:8px;padding:12px}.git-panel{background:#f8fafc;gap:12px;display:grid}.git-panel__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}code,pre{font-family:var(--font-mono)}code{overflow-wrap:anywhere}.diff-block{gap:8px;display:grid}.diff-block pre{white-space:pre-wrap;overflow-wrap:anywhere;color:#dbeafe;background:#102033;border-radius:8px;max-width:100%;margin:0;padding:12px;overflow-x:hidden}.file-list{gap:8px;display:grid}.file-row{border:1px solid var(--color-border);background:#fff;border-left-width:5px;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:10px;display:grid}.file-row div{min-width:0}.file-row code,.file-row span{display:block}.file-row span{color:var(--color-muted);margin-top:3px;font-size:13px}.file-row--safe{border-left-color:var(--color-safe)}.file-row--warning{border-left-color:var(--color-warning)}.file-row--danger{border-left-color:var(--color-danger)}.quiz-prompt{color:var(--color-text);background:#eef6ff;border-radius:8px;padding:14px;font-weight:800}.choice-list,.order-list,.stage-list,.checklist,.match-grid{gap:10px;display:grid}.choice-button,.stage-button,.checklist-item,.order-chip,.match-button,.settings-list button{overflow-wrap:anywhere;border:1px solid var(--color-border);width:100%;min-height:56px;color:var(--color-text);text-align:left;background:var(--color-surface);border-radius:8px;padding:13px 14px}.swipe-card{border:1px solid var(--color-border);text-align:center;touch-action:pan-y;background:linear-gradient(90deg,#fff7ed,#eff6ff);border-radius:8px;place-items:center;gap:12px;min-height:168px;padding:16px;display:grid}.swipe-card strong{font-size:20px;line-height:1.4}.swipe-card span{color:var(--color-muted);font-size:13px;font-weight:800}.swipe-card--ok{border-color:var(--color-safe);background:var(--color-safe-bg)}.swipe-card--ng{border-color:var(--color-danger);background:var(--color-danger-bg)}.swipe-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.match-grid section{gap:8px;display:grid}.match-grid h2{margin:0;font-size:16px}.match-button{gap:4px;display:grid}.match-button span{color:var(--color-muted);font-size:13px}.match-button--selected{border-color:var(--color-primary);background:#eff6ff}.match-button--paired{border-color:var(--color-safe);background:var(--color-safe-bg)}.case-situation{border:1px solid var(--color-border);background:#f8fafc;border-radius:8px;gap:6px;padding:14px;display:grid}.copy-checklist-button{border:1px solid var(--color-border);min-height:52px;color:var(--color-primary);background:var(--color-surface);border-radius:8px;font-weight:800}.choice-button{gap:4px;display:grid}.choice-button small{color:var(--color-muted)}.choice-button--selected{border-color:var(--color-primary);background:#eff6ff}.choice-button--correct{border-color:var(--color-safe);background:var(--color-safe-bg)}.choice-button--wrong{border-color:var(--color-danger);background:var(--color-danger-bg)}.answer-panel--correct{background:var(--color-safe-bg);border-color:#15803d4d}.answer-panel--wrong{background:var(--color-danger-bg);border-color:#b91c1c4d}.order-area{gap:14px;display:grid}.order-area h2,.mistake-top h2,.ending-summary h2{letter-spacing:0;margin:0 0 8px;font-size:17px}.order-chip{align-items:center;gap:10px;display:flex}.order-chip span,.checklist-item span,.stage-number{color:#fff;background:var(--color-primary);border-radius:999px;flex:none;justify-content:center;align-items:center;width:32px;height:32px;font-weight:800;display:inline-flex}.empty-state{border:1px dashed var(--color-border);text-align:center;border-radius:8px;padding:14px}.stage-button{grid-template-columns:40px minmax(0,1fr);align-items:start;gap:12px;display:grid}.stage-button strong,.stage-button small,.stage-button em{display:block}.stage-button small{color:var(--color-muted);margin-top:4px;line-height:1.45}.stage-button em{color:var(--color-teal);margin-top:6px;font-size:12px;font-style:normal;font-weight:800}.stage-button--current{border-color:var(--color-primary);background:#eff6ff}.checklist-item{grid-template-columns:36px minmax(0,1fr);align-items:center;gap:10px;display:grid}.checklist-item--checked{border-color:var(--color-safe);background:var(--color-safe-bg)}.complete-banner{color:#14532d;background:var(--color-safe-bg)}.feedback-mark{color:#fff;background:var(--color-primary);border-radius:999px;justify-content:center;align-items:center;width:56px;height:56px;font-weight:900;display:inline-flex}.score-ring{background:#fff;border:12px solid #bfdbfe;border-radius:999px;justify-content:center;align-items:baseline;width:152px;height:152px;margin:0 auto;display:flex}.score-ring strong{color:var(--color-primary);margin-top:42px;font-size:48px}.score-ring span{color:var(--color-muted)}.result-message{background:var(--color-safe-bg);border-radius:8px;padding:12px}.result-message--warning{background:var(--color-warning-bg)}.result-message--danger{background:var(--color-danger-bg)}.mistake-top ol,.ending-summary ol{gap:8px;margin:0;padding-left:22px;display:grid}.mistake-top li,.ending-summary li{color:var(--color-text)}.mistake-top li span,.ending-summary li span{color:var(--color-muted);margin-left:8px;font-size:13px}.toast{right:16px;bottom:calc(92px + var(--safe-bottom));z-index:30;color:#fff;text-align:center;background:#111827;border-radius:8px;max-width:448px;margin:0 auto;padding:12px 14px;position:fixed;left:16px}.dialog-backdrop,.sheet-backdrop{z-index:40;background:#0f172a6b;place-items:end center;padding:16px;display:grid;position:fixed;inset:0}.confirm-dialog,.bottom-sheet{background:var(--color-surface);width:min(100%,448px);box-shadow:var(--shadow-soft);border-radius:8px;padding:18px}.confirm-dialog h2,.sheet-header h2{margin:0;font-size:20px}.confirm-dialog p{color:var(--color-muted);line-height:1.7}.dialog-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;display:grid}.bottom-sheet{max-height:78dvh;overflow-y:auto}.sheet-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.sheet-list,.settings-list{gap:10px;display:grid}.sheet-list div,.settings-list p{background:#f8fafc;border-radius:8px;gap:4px;padding:12px;display:grid}.sheet-list span,.settings-list p{color:var(--color-muted)}.settings-list button{justify-content:space-between;display:flex}.git-badge,.commit-dot,.branch-line{display:inline-flex}.commit-dot{background:var(--color-border);border-radius:999px;width:12px;height:12px}.commit-dot--active{background:var(--color-safe)}.branch-line{align-items:center;gap:8px}.branch-line span{background:var(--color-primary);width:28px;height:2px}@media (width<=380px){.sticky-header{grid-template-columns:46px minmax(0,1fr) 146px;padding-left:8px;padding-right:8px}.icon-button{min-width:44px;min-height:46px}.main-card{padding:18px 14px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important}}
