:root{--bg:#f5f7fb;--surface:#fff;--surface-soft:#eef5f1;--text:#1f2933;--muted:#657282;--line:#d8e0ea;--green:#2f6f5e;--green-soft:#e4f2eb;--blue:#2367a2;--blue-soft:#e5f0fb;--orange:#b66b1f;--orange-soft:#fff0da;--red:#bf3f32;--red-soft:#fde8e5;--shadow:0 18px 45px #26374d21;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html{min-height:100%}body{background:linear-gradient(90deg, #2367a20f 1px, transparent 1px), linear-gradient(#2f6f5e0f 1px, transparent 1px), var(--bg);background-size:42px 42px;min-height:100%;margin:0}button,select{font:inherit}button{cursor:pointer}button:disabled,select:disabled{cursor:not-allowed;opacity:.58}#app{min-height:100vh}.app-page{width:min(1180px,100% - 32px);min-height:100vh;margin:0 auto;padding:28px 0 48px}.home-page{flex-direction:column;justify-content:center;gap:24px;display:flex}.home-grid{grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);align-items:stretch;gap:24px;display:grid}.home-copy,.map-asset,.setup-board,.quiz-board,.summary-board,.match-board{box-shadow:var(--shadow);background:#ffffffeb;border:1px solid #d8e0eadb;border-radius:8px}.home-copy{flex-direction:column;justify-content:center;padding:44px;display:flex}.eyebrow{color:var(--green);margin:0 0 10px;font-size:14px;font-weight:800}h1,h2,h3,p{margin:0}h1{letter-spacing:0;max-width:800px;font-size:42px;line-height:1.12}h2{letter-spacing:0;font-size:24px;line-height:1.35}h3{letter-spacing:0;font-size:17px;line-height:1.4}.home-stats{flex-wrap:wrap;gap:10px;margin-top:30px;display:flex}.ai-feature-row{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.home-stats span,.ai-feature-row span,.question-meta span,.score-strip span,.card-stat{background:var(--surface-soft);min-height:32px;color:var(--muted);border-radius:8px;align-items:center;padding:6px 10px;font-size:14px;font-weight:700;display:inline-flex}.ai-feature-row span{color:var(--blue);background:#edf7ff}.map-asset{background:#dbece5;justify-content:center;align-items:center;min-height:315px;display:flex;overflow:hidden}.map-asset img{object-fit:cover;width:100%;height:100%;min-height:315px;display:block}.game-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.game-card,.select-card,.answer-option,.link-card,.analysis-card,.review-item{border:1px solid var(--line);background:var(--surface);border-radius:8px}.game-card{text-align:left;flex-direction:column;align-items:flex-start;gap:12px;min-height:190px;padding:22px;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex}.game-card:hover,.select-card:hover,.answer-option:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 14px 30px #26374d1c}.game-card strong{font-size:28px;line-height:1.15}.game-card small,.select-card small{color:var(--muted);line-height:1.45}.card-action{margin-top:auto;font-weight:800}.tone-green{--tone:var(--green);--tone-soft:var(--green-soft)}.tone-blue{--tone:var(--blue);--tone-soft:var(--blue-soft)}.tone-orange{--tone:var(--orange);--tone-soft:var(--orange-soft)}.game-card.tone-green,.game-card.tone-blue,.game-card.tone-orange{border-top:5px solid var(--tone)}.game-card.tone-green .card-stat,.game-card.tone-blue .card-stat,.game-card.tone-orange .card-stat{background:var(--tone-soft);color:var(--tone)}.play-page{flex-direction:column;gap:18px;display:flex}.topbar{grid-template-columns:150px minmax(0,1fr) 150px;align-items:center;gap:14px;padding:18px 0 8px;display:grid}.topbar h1{text-align:center;max-width:none;font-size:30px}.topbar .eyebrow{text-align:center}.setup-board,.quiz-board,.summary-board,.match-board{padding:28px}.setup-board{gap:26px;display:grid}.setup-section{gap:14px;display:grid}.segmented-grid,.mode-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.mode-grid{grid-template-columns:repeat(2,minmax(0,260px))}.select-card{text-align:left;align-content:center;gap:8px;min-height:116px;padding:18px;transition:transform .2s,border-color .2s,background .2s;display:grid}.select-card.compact{min-height:92px}.select-card.active{border-color:var(--green);background:var(--green-soft)}.ai-note{background:linear-gradient(135deg,#e4f2ebf2,#e5f0fbd1);border:1px solid #b8d2c7;border-radius:8px;gap:6px;padding:14px 16px;display:grid}.ai-note strong{color:var(--green)}.ai-note span{color:var(--muted);font-size:14px;font-weight:700;line-height:1.6}.pill-row,.action-row,.score-strip,.question-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pill-button,.primary-button,.ghost-button,.icon-button{border:1px solid var(--line);background:var(--surface);min-height:42px;color:var(--text);border-radius:8px;font-weight:800}.pill-button{min-width:92px;padding:0 16px}.pill-button.active{color:var(--tone);border-color:var(--tone);background:var(--tone-soft)}.primary-button,.ghost-button{padding:0 18px}.primary-button{border-color:var(--green);background:var(--green);color:#fff}.primary-button.wide{width:min(360px,100%);min-height:50px}.ghost-button{background:#ffffffc7}.icon-button{width:42px;padding:0;font-size:24px;line-height:1}.quiz-board,.match-board{gap:18px;display:grid}.score-strip{justify-content:space-between}.progress-track{background:#e8edf3;border-radius:8px;height:10px;overflow:hidden}.progress-track div{border-radius:inherit;background:linear-gradient(90deg, var(--green), var(--blue), var(--orange));height:100%;transition:width .25s}.question-panel{border:1px solid var(--line);background:#fbfcfe;border-radius:8px;gap:18px;padding:22px;display:grid}.option-list,.truefalse-grid{gap:12px;display:grid}.truefalse-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.answer-option{text-align:left;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:12px;min-height:70px;padding:16px;transition:transform .2s,border-color .2s,background .2s;display:grid}.answer-option span{background:var(--blue-soft);width:42px;height:42px;color:var(--blue);border-radius:8px;place-items:center;font-weight:900;display:grid}.answer-option strong{line-height:1.45}.answer-option.selected{border-color:var(--blue);background:var(--blue-soft)}.answer-option.correct{border-color:var(--green);background:var(--green-soft)}.answer-option.correct span{background:var(--green);color:#fff}.answer-option.wrong{border-color:var(--red);background:var(--red-soft)}.answer-option.wrong span{background:var(--red);color:#fff}.answer-option.muted{opacity:.64}.feedback-panel{border:1px dashed var(--line);min-height:118px;color:var(--muted);background:#ffffffc7;border-radius:8px;padding:18px}.feedback-panel.visible{background:#fbfcfe;border-style:solid}.feedback-panel p{line-height:1.7}.result-line{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;font-size:18px;display:flex}.result-line span{font-weight:900}.result-line.is-right{color:var(--green)}.result-line.is-wrong{color:var(--red)}.ai-line{color:var(--blue);margin-top:10px;font-weight:700}.ai-explain-card,.diagnosis-card{background:linear-gradient(135deg,#fbfcfe,#eef7f2);border:1px solid #c7d8e7;border-radius:8px;gap:14px;padding:16px;display:grid}.diagnosis-card{text-align:left;width:min(860px,100%)}.diagnosis-card.compact{width:100%}.diagnosis-card.compact p{color:var(--muted);font-weight:700;line-height:1.65}.ai-card-head{gap:6px;display:grid}.ai-card-head span{background:var(--blue-soft);width:fit-content;min-height:28px;color:var(--blue);border-radius:8px;align-items:center;padding:4px 9px;font-size:13px;font-weight:900;display:inline-flex}.ai-card-head strong{color:var(--text);line-height:1.5}.ai-explain-grid,.diagnosis-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.diagnosis-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.ai-explain-grid section,.diagnosis-grid article{background:#ffffffc7;border:1px solid #d8e0eacc;border-radius:8px;align-content:start;gap:8px;min-height:118px;padding:14px;display:grid}.ai-explain-grid.mini{grid-template-columns:repeat(3,minmax(0,1fr))}.ai-explain-grid h3,.diagnosis-grid h3{color:var(--green);font-size:15px}.ai-explain-grid p,.diagnosis-grid p{color:var(--muted);font-size:14px;line-height:1.65}.action-row{justify-content:space-between}.action-row.center{justify-content:center}.summary-board{text-align:center;justify-items:center;gap:22px;display:grid}.summary-board h1{color:var(--green);font-size:56px}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;width:min(680px,100%);display:grid}.summary-grid div{border:1px solid var(--line);background:#fbfcfe;border-radius:8px;place-items:center;gap:6px;min-height:116px;padding:18px;display:grid}.summary-grid strong{color:var(--blue);font-size:34px}.summary-grid span{color:var(--muted);font-weight:700}.match-heading{color:var(--muted);padding:8px 10px;font-size:14px;font-weight:900}.connection-help{color:var(--muted);flex-wrap:wrap;justify-content:space-between;gap:10px;font-size:14px;font-weight:800;display:flex}.active-match-panel{background:linear-gradient(135deg,#fbfcfef5,#eef7f2eb);border:1px solid #c7d8e7;border-radius:8px;grid-template-columns:minmax(0,1.15fr) minmax(280px,.95fr) auto;align-items:stretch;gap:14px;padding:14px;display:grid}.active-match-copy,.active-match-status>div{align-content:start;gap:6px;display:grid}.active-match-copy span,.active-match-status span{color:var(--blue);font-size:13px;font-weight:900}.active-match-copy strong{line-height:1.55}.active-match-status{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.active-match-status>div{background:#ffffffc2;border:1px solid #d8e0ead9;border-radius:8px;min-height:86px;padding:10px 12px}.active-match-status strong{color:var(--muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}.active-match-actions{align-content:center;gap:8px;display:grid}.mini-button{border:1px solid var(--line);background:var(--surface);min-height:34px;color:var(--blue);border-radius:8px;padding:0 11px;font-size:13px;font-weight:900}.match-connect{grid-template-columns:1.1fr 1fr 1fr;align-items:start;gap:22px;display:grid;position:relative}.match-lines{z-index:0;pointer-events:none;position:absolute;inset:0;overflow:visible}.match-lines path{fill:none;stroke:var(--blue);stroke-width:4px;stroke-linecap:round;stroke-dasharray:9 8;opacity:.72;filter:drop-shadow(0 3px 5px #2367a229)}.match-lines path.correct{stroke:var(--green);stroke-dasharray:none}.match-lines path.wrong{stroke:var(--red);stroke-dasharray:none}.match-column{z-index:1;gap:12px;display:grid;position:relative}.link-card{text-align:left;grid-template-rows:auto minmax(0,1fr) auto;gap:8px;width:100%;height:124px;padding:15px;line-height:1.45;transition:transform .2s,border-color .2s,background .2s,box-shadow .2s;display:grid;overflow:hidden}.link-card:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 14px 30px #26374d1c}.link-card strong{-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:15px;line-height:1.42;display:-webkit-box;overflow:hidden}.link-card small{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:800;overflow:hidden}.link-card.phenomenon{border-left:5px solid var(--green);height:118px}.link-card.phenomenon strong{-webkit-line-clamp:2}.link-card.option{height:126px}.link-card.active{border-color:var(--blue);background:var(--blue-soft);box-shadow:0 0 0 3px #2367a21f}.link-card.linked{background:#f2f7fc;border-color:#9ab8d4}.link-card.correct{border-color:var(--green);background:var(--green-soft)}.link-card.wrong{border-color:var(--red);background:var(--red-soft)}.link-index{background:var(--green-soft);width:38px;height:30px;color:var(--green);border-radius:8px;place-items:center;font-weight:900;display:inline-grid}.analysis-list{gap:12px;display:grid}.analysis-card{gap:8px;padding:16px;line-height:1.55;display:grid}.analysis-card span{color:var(--blue);font-weight:900}.drawer-shell{z-index:40;background:#1f29335c;justify-content:flex-end;display:flex;position:fixed;inset:0}.review-drawer{background:var(--surface);width:min(520px,100%);height:100%;padding:22px;overflow:auto;box-shadow:-18px 0 45px #1f29332e}.drawer-head{z-index:1;background:var(--surface);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding-bottom:14px;display:flex;position:sticky;top:0}.empty-state{min-height:180px;color:var(--muted);align-content:center;place-items:center;gap:8px;display:grid}.empty-state strong{color:var(--text);font-size:22px}.review-item{grid-template-columns:42px minmax(0,1fr);gap:12px;margin-top:14px;padding:16px;display:grid}.review-index{background:var(--orange-soft);width:42px;height:42px;color:var(--orange);border-radius:8px;place-items:center;font-weight:900;display:grid}.review-copy{gap:8px;line-height:1.55;display:grid}.review-copy p{color:var(--muted)}.review-explanation{border-left:4px solid var(--blue);background:#f7f9fc;border-radius:6px;padding:10px 12px;color:var(--text)!important}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=900px){.home-grid,.game-grid,.segmented-grid,.mode-grid,.summary-grid,.ai-explain-grid,.ai-explain-grid.mini,.diagnosis-grid,.active-match-panel{grid-template-columns:1fr}.active-match-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.home-copy{padding:30px}h1{font-size:34px}.topbar{grid-template-columns:1fr}.topbar h1,.topbar .eyebrow{text-align:left}}@media (width<=760px){.app-page{width:min(100% - 20px,1180px);padding-top:12px}.home-copy,.setup-board,.quiz-board,.summary-board,.match-board{padding:18px}h1{font-size:28px}h2{font-size:20px}.truefalse-grid,.match-connect{grid-template-columns:1fr}.match-lines,.match-heading{display:none}.answer-option{grid-template-columns:36px minmax(0,1fr)}.answer-option span{width:36px;height:36px}}
