:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#21313b;--muted:#65747c;--paper:#fffdf7;--surface:#fff;--mint:#8fe6c7;--mint-deep:#1f9b80;--coral:#ff8c73;--coral-deep:#d94f44;--yellow:#ffd86b;--yellow-deep:#a46b00;--teal:#60d8df;--teal-deep:#167c86;--rose:#ffb0c9;--blue:#8ac4ff;--violet:#b8a5ff;--gold:#ffd25a;--danger:#e94b5f;--success:#1c9b69;--line:#263844;--shadow:6px 6px 0 #263844;--small-shadow:3px 3px 0 #263844;background:var(--paper);color:var(--ink);font-family:Helvetica Neue,PingFang SC,Microsoft YaHei,system-ui,sans-serif}*{box-sizing:border-box}html{min-width:320px;min-height:100%}body{background:linear-gradient(#2638440a 1px, transparent 1px), linear-gradient(90deg, #2638440a 1px, transparent 1px), radial-gradient(circle at 10% 10%, #8fe6c72e, transparent 28%), radial-gradient(circle at 90% 0%, #ffd86b33, transparent 30%), var(--paper);background-size:18px 18px,18px 18px,auto,auto,auto;min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:inherit}h1,h2,h3,p{margin-top:0}.app-shell{flex-direction:column;min-height:100vh;display:flex}.topbar{z-index:20;border-bottom:3px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffdf7f0;grid-template-columns:minmax(180px,250px) 1fr auto;align-items:center;gap:14px;padding:14px clamp(14px,3vw,28px);display:grid;position:sticky;top:0}.brand,.nav-button,.text-button{color:var(--ink);background:0 0;border:0}.brand{text-align:left;align-items:center;gap:10px;font-size:18px;font-weight:900;display:inline-flex}.brand__mark{background:var(--yellow);border:3px solid var(--line);width:34px;height:34px;box-shadow:var(--small-shadow);place-items:center;display:grid}.topbar__nav,.topbar__user{align-items:center;gap:8px;display:flex}.topbar__nav{flex-wrap:wrap;justify-content:center}.topbar__user{justify-content:flex-end;min-width:160px}.topbar__loading{color:var(--muted);font-size:14px}.nav-button{border:2px solid #0000;align-items:center;gap:7px;min-height:38px;padding:8px 11px;font-size:14px;font-weight:800;display:inline-flex}.nav-button.is-active,.nav-button:hover{border-color:var(--line);box-shadow:2px 2px 0 var(--line);background:#fff}.text-button{text-underline-offset:4px;font-weight:800;text-decoration:underline}.app-main{flex:1;width:min(1240px,100% - 28px);margin:0 auto;padding:clamp(18px,3vw,34px) 0 48px}.footer{color:var(--muted);text-align:center;border-top:2px dashed #26384440;justify-content:center;align-items:center;gap:8px;padding:16px;font-size:14px;display:flex}.pixel-button{border:3px solid var(--line);min-width:98px;min-height:42px;color:var(--ink);background:var(--yellow);box-shadow:var(--small-shadow);justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-weight:900;transition:transform .12s,box-shadow .12s,filter .12s;display:inline-flex}.pixel-button:hover:not(:disabled){box-shadow:5px 5px 0 var(--line);transform:translate(-1px,-1px)}.pixel-button:active:not(:disabled){box-shadow:1px 1px 0 var(--line);transform:translate(2px,2px)}.pixel-button:disabled{filter:grayscale(.75);opacity:.58}.pixel-button--secondary{background:var(--mint)}.pixel-button--ghost{background:#fff}.pixel-button--danger{background:var(--coral)}.pixel-button__icon{place-items:center;display:inline-grid}.pixel-card{border:3px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;padding:clamp(16px,2.5vw,24px)}.pixel-card--mint{background:linear-gradient(135deg,#f5fff9 0%,#d7f9ec 100%)}.pixel-card--coral{background:linear-gradient(135deg,#fff7f1 0%,#ffd3c8 100%)}.pixel-card--yellow{background:linear-gradient(135deg,#fffbed 0%,#ffe69a 100%)}.pixel-card--teal{background:linear-gradient(135deg,#f0feff 0%,#c7f5f7 100%)}.pixel-card--ink{color:#fff;background:linear-gradient(135deg,#ffd86b1f,#60d8df1f),#263844}.title-badge{border:2px solid var(--line);width:fit-content;box-shadow:2px 2px 0 var(--line);background:#fff;align-items:center;gap:7px;padding:7px 10px;font-size:13px;font-weight:900;display:inline-flex}.hero-stage{grid-template-columns:minmax(0,1fr) minmax(300px,520px);align-items:center;gap:clamp(20px,4vw,42px);min-height:min(680px,100vh - 120px);padding-bottom:22px;display:grid}.hero-stage__copy h1{margin:14px 0;font-size:clamp(42px,7vw,84px);line-height:.96}.hero-stage__copy>p{max-width:640px;color:var(--muted);font-size:clamp(17px,2vw,22px);line-height:1.7}.hero-stage__actions{flex-wrap:wrap;gap:12px;margin-top:18px;display:flex}.hero-stage__visual{border:3px solid var(--line);box-shadow:var(--shadow);background:var(--mint);aspect-ratio:4/3;border-radius:8px;overflow:hidden}.hero-stage__visual img{object-fit:cover;width:100%;height:100%;display:block}.dialogue-box{border:3px solid var(--line);max-width:700px;box-shadow:var(--small-shadow);background:#fff;grid-template-columns:48px 1fr;gap:12px;padding:14px;display:grid}.dialogue-box__avatar{background:var(--coral);border:3px solid var(--line);place-items:center;width:44px;height:44px;display:grid}.dialogue-box strong{margin-bottom:4px;display:block}.dialogue-box p{margin:0;line-height:1.55}.dialogue-box__dialect{font-weight:800}.dialogue-box__mandarin{color:var(--muted);font-size:14px}.dashboard-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:10px 0 36px;display:grid}.stat-card{flex-direction:column;justify-content:space-between;gap:12px;min-height:190px;display:flex}.stat-card span,.page-hero>span,.teaching-block>span{color:var(--muted);font-size:13px;font-weight:900}.stat-card strong{font-size:clamp(24px,3vw,34px);line-height:1.1}.stat-card p,.rule-strip p{color:var(--muted);margin-bottom:0;line-height:1.6}.progress{width:100%}.progress__meta{color:var(--muted);justify-content:space-between;gap:12px;margin-bottom:6px;font-size:13px;font-weight:800;display:flex}.progress__track{border:2px solid var(--line);background:#fff;height:14px;overflow:hidden}.progress__track span{background:var(--mint-deep);min-width:0;height:100%;display:block}.progress__track--chapter span{background:var(--coral)}.progress__track--daily span{background:var(--yellow)}.section-heading{justify-content:space-between;align-items:end;gap:16px;margin:24px 0 16px;display:flex}.section-heading h2,.page-hero h1,.lesson-title h1{margin-bottom:8px}.section-heading p,.page-hero p{color:var(--muted);margin-bottom:0;line-height:1.7}.pixel-card--ink p{color:#eaf3f6}.pixel-card--ink .title-badge{color:var(--ink)}.chapter-map{gap:18px;display:grid}.map-node{border:3px solid var(--line);min-height:140px;box-shadow:var(--shadow);background:#fff;border-radius:8px;grid-template-columns:54px 70px minmax(0,1fr) auto;align-items:center;gap:16px;padding:18px;display:grid;position:relative}.map-node:before{content:"";background:var(--line);width:8px;height:20px;position:absolute;top:-20px;left:44px}.map-node:first-child:before{display:none}.map-node--mint{background:#e7fff4}.map-node--coral{background:#fff0e9}.map-node--yellow{background:#fff7ce}.map-node--teal{background:#e7fcff}.map-node--rose{background:#fff0f6}.map-node--blue{background:#eef7ff}.map-node--violet{background:#f4f0ff}.map-node--gold{background:#fff3bd}.map-node.is-locked{filter:saturate(.28)}.map-node__step{color:var(--muted);font-size:18px;font-weight:950}.map-node__icon{border:3px solid var(--line);width:66px;height:66px;box-shadow:var(--small-shadow);background:#fff;place-items:center;display:grid}.map-node__content p{color:var(--muted);margin-bottom:4px;font-size:13px;font-weight:900}.map-node__content h2{margin-bottom:6px;font-size:clamp(22px,3vw,30px)}.map-node__content>span{margin-bottom:12px;line-height:1.6;display:block}.map-node__actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.rule-strip{border:2px dashed var(--line);background:#ffffffb3;align-items:center;gap:10px;margin:24px 0 0;padding:14px;display:flex}.page-stack{gap:22px;display:grid}.page-hero{gap:10px;display:grid}.page-hero h1{font-size:clamp(34px,5vw,58px);line-height:1.05}.auth-page{place-items:center;min-height:calc(100vh - 210px);display:grid}.auth-card{width:min(520px,100%)}.auth-card h1{font-size:clamp(32px,5vw,50px)}.auth-card p{color:var(--muted);line-height:1.7}.auth-form{gap:14px;margin:20px 0;display:grid}.auth-form label,.search-box{gap:8px;font-weight:900;display:grid}.auth-form label span,.search-box{align-items:center;gap:8px;display:flex}.auth-form input,.search-box input{border:3px solid var(--line);background:#fff;border-radius:0;width:100%;min-height:46px;padding:10px 12px;box-shadow:3px 3px #26384433}.form-error{border:2px solid var(--danger);color:var(--danger);background:#fff2f4;padding:10px 12px;font-weight:800}.lesson-layout{grid-template-columns:290px minmax(0,1fr);align-items:start;gap:24px;display:grid}.lesson-rail{border:3px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:8px;gap:14px;padding:16px;display:grid;position:sticky;top:92px}.lesson-rail h2{margin-bottom:0;font-size:28px}.lesson-rail p{color:var(--muted);margin-bottom:0;line-height:1.6}.lesson-list{gap:8px;display:grid}.lesson-list__item{border:2px solid var(--line);text-align:left;background:#fff;grid-template-columns:30px 1fr;align-items:center;gap:8px;width:100%;min-height:44px;padding:8px;font-weight:850;display:grid}.lesson-list__item span{background:var(--yellow);border:2px solid var(--line);place-items:center;width:26px;height:26px;display:grid}.lesson-list__item.is-current{box-shadow:2px 2px 0 var(--line);background:#e7fff4}.lesson-list__item.is-done span{background:var(--mint)}.lesson-main,.teaching-blocks,.exercise-stack{gap:18px;display:grid}.lesson-title h1{font-size:clamp(34px,5vw,58px)}.teaching-block h2{font-size:clamp(22px,3vw,32px)}.teaching-block p{color:var(--muted);line-height:1.75}.mahjong-hand{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.mahjong-tile{border:3px solid var(--line);width:62px;height:86px;color:var(--ink);background:linear-gradient(145deg,#fffffff2 0%,#fffcecf0 56%,#e8f3ebf5 100%);border-radius:6px;flex-direction:column;justify-content:space-between;align-items:center;gap:1px;padding:7px 6px 5px;font-weight:950;transition:transform .12s,box-shadow .12s;display:flex;position:relative;overflow:hidden;box-shadow:3px 4px #26384447}.mahjong-tile:before{content:"";pointer-events:none;border:1px solid #26384440;border-radius:3px;position:absolute;inset:3px}.mahjong-tile:after{content:"";pointer-events:none;background:#ffffffb8;height:10px;position:absolute;inset:0 0 auto}.mahjong-tile:hover{transform:translateY(-2px)}.mahjong-tile.is-selected{outline:4px solid var(--yellow);transform:translateY(-4px)}.mahjong-tile.is-compact{width:50px;height:70px;padding:5px 4px 3px}.mahjong-tile__face{z-index:1;place-items:center;width:100%;min-height:58px;display:grid;position:relative}.mahjong-tile__suit{z-index:1;color:var(--muted);font-size:10px;line-height:1;position:relative;transform:scale(.9)}.tile-face-svg,.tile-face-img{width:50px;height:63px;display:block}.tile-face-img{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.tile-face-svg__border{fill:#ffffff7a;stroke:#26384438;stroke-width:1.2px}.tile-face-svg__wan-number{fill:#d8413b;font-size:13px;font-weight:900}.tile-face-svg__wan-main{fill:#263844;font-size:18px;font-weight:900}.tile-face-svg__wan-small{fill:#d8413b;font-size:9px;font-weight:900}.tile-face-svg__honor-main{font-size:27px;font-weight:950}.tile-face-svg--honor-red .tile-face-svg__honor-main{fill:#d8413b}.tile-face-svg--honor-green .tile-face-svg__honor-main{fill:#188a5d}.tile-face-svg--honor-wind .tile-face-svg__honor-main{fill:#4f5960}.mahjong-tile.is-compact .tile-face-svg,.mahjong-tile.is-compact .tile-face-img{width:40px;height:50px}.exercise{border:3px solid var(--line);box-shadow:var(--small-shadow);background:#fff;border-radius:8px;gap:14px;padding:18px;display:grid}.exercise.is-correct{background:#f0fff7}.exercise.is-wrong{background:#fff7f7}.exercise__header,.practice-meta{flex-wrap:wrap;justify-content:space-between;gap:10px;display:flex}.exercise__type,.exercise__difficulty,.practice-meta span{border:2px solid var(--line);background:var(--mint);padding:6px 8px;font-size:12px;font-weight:900}.exercise__difficulty{background:var(--yellow)}.exercise h3{margin-bottom:0;font-size:clamp(20px,3vw,28px);line-height:1.35}.exercise__options{gap:10px;display:grid}.exercise-option{border:3px solid var(--line);text-align:left;background:#fff;min-height:48px;padding:10px 12px;font-weight:850;box-shadow:2px 2px #26384438}.exercise-option.is-selected,.exercise-option:hover:not(:disabled){background:#fff2c5}.exercise__actions,.practice-actions{flex-wrap:wrap;gap:10px;display:flex}.exercise__hint{color:var(--muted);align-items:center;gap:8px;font-size:14px;display:flex}.feedback{border:2px solid var(--line);grid-template-columns:34px 1fr;gap:10px;padding:12px;display:grid}.feedback p{margin:4px 0 0;line-height:1.65}.feedback--right{background:#ddffe9}.feedback--wrong{background:#fff0f2}.feedback__icon{place-items:start center;display:grid}.drag-exercise{gap:14px;display:grid}.drag-exercise__instruction{color:var(--muted);margin:0;font-weight:800}.drag-exercise__bank{border:3px solid var(--line);background:#fffbed;flex-wrap:wrap;align-items:center;gap:8px;min-height:88px;padding:10px;display:flex}.drag-exercise__empty{color:var(--muted);font-weight:900}.drag-exercise__targets{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.drag-target{border:3px dashed var(--line);text-align:left;background:#fffefa;gap:6px;min-height:164px;padding:12px;transition:background .12s,box-shadow .12s,transform .12s;display:grid}.drag-target:hover,.drag-target.is-drag-over{box-shadow:inset 0 0 0 3px var(--mint);background:#e7fff4}.drag-target.is-drag-over{transform:translateY(-2px)}.drag-target span{color:var(--muted);line-height:1.45}.drag-target em{color:var(--teal-deep);align-self:end;font-style:normal;font-weight:900}.drag-target__tiles{background:#ffffffb3;border:2px solid #2638442e;flex-wrap:wrap;align-content:flex-start;gap:6px;min-height:72px;padding:8px;display:flex}.finish-card,.settlement-card,.mini-summary{justify-content:space-between;align-items:center;gap:16px;display:flex}.finish-card p,.settlement-card p,.mini-summary p{color:var(--muted);margin-bottom:0;line-height:1.6}.practice-page{max-width:880px;margin:0 auto}.modal-surface{z-index:40;background:#21313b42;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.result-card{width:min(520px,100%)}.result-card strong{margin-bottom:12px;font-size:38px;display:block}.achievement-grid,.glossary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.achievement{border:3px solid var(--line);min-height:130px;box-shadow:var(--small-shadow);opacity:.55;background:#fff;grid-template-columns:52px 1fr;gap:12px;padding:16px;display:grid}.achievement.is-unlocked{opacity:1;background:#fff7d1}.achievement__icon{border:3px solid var(--line);background:var(--yellow);place-items:center;width:48px;height:48px;display:grid}.achievement h3{margin-bottom:6px}.achievement p{color:var(--muted);margin-bottom:0;line-height:1.55}.glossary-card{align-content:start;gap:10px;display:grid}.glossary-card--wide{grid-column:1/-1}.glossary-card--wide .mahjong-hand{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.glossary-card--wide .mahjong-tile{flex:none}.glossary-card>span{color:var(--muted);font-size:12px;font-weight:900}.glossary-card h2{margin-bottom:0;font-size:30px}.glossary-card p{color:var(--muted);line-height:1.7}.glossary-card .dialogue-box{box-shadow:none;grid-template-columns:36px 1fr;margin-top:4px}.glossary-card .dialogue-box__avatar{width:34px;height:34px}.rule-config-card ul{margin:10px 0 0;padding-left:20px;line-height:1.8}.search-box{width:min(560px,100%)}@media (width<=980px){.topbar{grid-template-columns:1fr;position:static}.topbar__nav{flex-wrap:nowrap;justify-content:flex-start;padding-bottom:4px;overflow-x:auto}.topbar__user{justify-content:flex-start}.hero-stage,.lesson-layout{grid-template-columns:1fr}.hero-stage{min-height:auto}.hero-stage__visual{order:-1}.dashboard-grid,.achievement-grid,.glossary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.lesson-rail{position:static}}@media (width<=720px){.app-main{width:min(100% - 18px,1240px);padding-top:14px}.brand{font-size:16px}.nav-button span{display:none}.topbar__user .nav-button span{display:inline}.dashboard-grid,.achievement-grid,.glossary-grid,.drag-exercise__targets{grid-template-columns:1fr}.map-node{grid-template-columns:42px 54px minmax(0,1fr)}.map-node__actions{grid-column:1/-1;justify-content:flex-start}.map-node__icon{width:52px;height:52px}.section-heading,.finish-card,.settlement-card,.mini-summary{flex-direction:column;align-items:stretch}.mahjong-tile{width:54px;height:76px}.hero-stage__copy h1,.page-hero h1,.lesson-title h1{font-size:40px}}
