:root{--felt-0: #0e2a1d;--felt-1: #143a28;--felt-2: #1c4d35;--ink: #1a1714;--ivory: #f4ecd8;--paper: #f7f0df;--jade: #2f7d4f;--jade-deep: #1c5536;--vermilion: #b23a2e;--gold: #d8b25e;--gold-deep: #a87f33;--muted: #b9c7b6;--line: rgba(216, 178, 94, .28);--display: "Cormorant", Georgia, serif;--body: "Hanken Grotesk", system-ui, sans-serif;--han: "Noto Serif SC", serif;--radius: 16px;--shadow-soft: 0 10px 30px rgba(0, 0, 0, .35)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--body);color:var(--ivory);background:radial-gradient(140% 120% at 50% -10%,#1d4a33 0%,var(--felt-1) 42%,var(--felt-0) 100%);min-height:100%;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:.01em;margin:0}button{font-family:var(--body);cursor:pointer}a{color:var(--gold)}.app{position:relative;z-index:1;min-height:100%;display:flex;flex-direction:column}.masthead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding:26px clamp(20px,5vw,64px) 0}.brand{display:flex;align-items:center;gap:16px}.brand .seal{display:grid;place-items:center;width:54px;height:54px;border-radius:12px;background:linear-gradient(135deg,var(--vermilion),#8c2a20);box-shadow:var(--shadow-soft),inset 0 0 0 1px #ffffff2e;font-family:var(--han);font-weight:900;font-size:30px;color:var(--ivory)}.brand h1{font-size:clamp(30px,4vw,46px);line-height:.95}.brand .sub{font-family:var(--body);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-top:4px}.tabs{display:flex;gap:6px;padding:18px clamp(20px,5vw,64px) 0;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-top:14px}.tab{position:relative;background:transparent;border:none;color:var(--muted);padding:12px 18px 16px;border-radius:10px 10px 0 0;display:flex;flex-direction:column;gap:2px;align-items:flex-start;transition:color .15s ease,background .15s ease}.tab .han{font-family:var(--han);font-size:19px;font-weight:700;line-height:1}.tab .en{font-size:12.5px;letter-spacing:.04em}.tab:hover{color:var(--ivory);background:#ffffff0a}.tab.active{color:var(--ivory)}.tab.active:after{content:"";position:absolute;left:10px;right:10px;bottom:-1px;height:3px;border-radius:3px 3px 0 0;background:linear-gradient(90deg,var(--gold),var(--gold-deep))}.tab .badge{position:absolute;top:6px;right:8px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--felt-0);background:var(--gold);border-radius:999px;padding:1px 6px;font-weight:700}.modebar{display:flex;gap:8px;padding:18px clamp(20px,5vw,64px) 0}.modebar .seg{display:inline-flex;background:#00000040;border:1px solid var(--line);border-radius:999px;padding:4px}.modebar .seg button{border:none;background:transparent;color:var(--muted);font-weight:600;font-size:13px;letter-spacing:.02em;padding:8px 18px;border-radius:999px;transition:all .15s ease}.modebar .seg button.on{background:linear-gradient(180deg,var(--ivory),#e4d8ba);color:var(--ink);box-shadow:0 2px 8px #0000004d}.stage{flex:1;padding:26px clamp(20px,5vw,64px) 60px}.panel{background:linear-gradient(180deg,#ffffff0d,#0000001f);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.btn{border:1px solid var(--line);background:linear-gradient(180deg,#ffffff12,#0000001a);color:var(--ivory);border-radius:999px;padding:11px 22px;font-weight:600;font-size:14px;letter-spacing:.02em;transition:transform .12s ease,background .15s ease,border-color .15s ease}.btn:hover{transform:translateY(-1px);border-color:var(--gold)}.btn.primary{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:var(--ink);border-color:transparent}.btn:disabled{opacity:.45;cursor:default;transform:none}.coming-soon{display:grid;place-items:center;text-align:center;min-height:46vh;gap:14px}.coming-soon .big-han{font-family:var(--han);font-size:120px;color:#d8b25e2e;line-height:1}.coming-soon h2{font-size:34px}.coming-soon p{max-width:440px;color:var(--muted);line-height:1.6}@media (hover: none){.btn:hover{transform:none;border-color:var(--line)}}@media (max-width: 680px){.masthead{padding:max(14px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-left)) 0 max(12px,env(safe-area-inset-left))}.brand .seal{width:42px;height:42px;font-size:24px}.brand h1{font-size:30px}.brand .sub{font-size:10px;letter-spacing:.26em}.tabs{padding:12px 12px 0;gap:2px;margin-top:10px}.tab{padding:8px 12px 12px}.tab .han{font-size:16px}.tab .en{font-size:11px}.modebar{padding:12px 12px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}.modebar .seg{flex-wrap:nowrap}.modebar .seg button{padding:8px 13px;font-size:12.5px;white-space:nowrap}.stage{padding:16px 10px calc(40px + env(safe-area-inset-bottom))}}.tile{position:relative;display:inline-block;border-radius:12px;filter:drop-shadow(0 6px 8px rgba(20,30,22,.35)) drop-shadow(0 1px 0 rgba(255,255,255,.4));transition:transform .16s cubic-bezier(.2,.8,.2,1),filter .16s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.tile svg{display:block}.tile .tile-han{font-family:"Noto Serif SC",Cormorant,serif;font-weight:700;dominant-baseline:alphabetic}.tile .tile-sub{font-family:Hanken Grotesk,sans-serif;font-weight:600;letter-spacing:.04em}.tile.is-clickable{cursor:pointer}.tile.is-clickable:hover{transform:translateY(-8px);filter:drop-shadow(0 14px 16px rgba(20,30,22,.45)) drop-shadow(0 1px 0 rgba(255,255,255,.4))}.tile.is-clickable:focus-visible{outline:none;transform:translateY(-8px)}.tile.is-clickable:focus-visible:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:16px;border:2px solid var(--gold, #d8b25e)}.tile.is-selected{transform:translateY(-14px)}.tile.is-selected:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:15px;box-shadow:0 0 0 2px var(--gold, #d8b25e),0 0 18px 2px #d8b25e80}.tile.is-dimmed{filter:drop-shadow(0 4px 6px rgba(20,30,22,.3)) grayscale(.35) brightness(.82);opacity:.72}.tile.is-disabled{cursor:default;opacity:.55}.lead{font-size:17px;line-height:1.65;color:#ece4d0;max-width:60ch}.suit-stack{display:flex;flex-direction:column;gap:18px;margin:24px 0 8px}.suit-line{display:flex;flex-direction:column;gap:10px}.suit-head{display:flex;align-items:baseline;gap:12px}.suit-cn{font-family:var(--han);font-size:26px;font-weight:700;color:var(--gold)}.suit-en{font-family:var(--display);font-size:22px;color:var(--ivory)}.suit-note{font-size:13px;color:var(--muted)}.hint-bar{margin-top:18px;padding:12px 16px;border-radius:10px;background:#00000042;border:1px solid var(--line);font-size:15px;color:var(--ivory);min-height:20px}.honor-grid{display:flex;flex-wrap:wrap;gap:28px;margin:26px 0 8px}.meld-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:26px 0 8px}.meld-cn{position:absolute;top:10px;right:14px;font-family:var(--han);font-size:30px;color:#d8b25e66}.meld-card h4{font-family:var(--display);font-size:24px;margin:4px 0 0;color:var(--ivory)}.meld-card p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.5}.table-wrap{display:flex;flex-direction:column;gap:18px}.felt{position:relative;display:grid;grid-template-columns:minmax(120px,1fr) minmax(260px,2.2fr) minmax(120px,1fr);grid-template-rows:auto minmax(220px,1fr) auto;grid-template-areas:".    top   ." "left center right" ".    .     .";gap:10px;padding:26px;min-height:460px;border-radius:26px;background:radial-gradient(120% 120% at 50% 40%,#246b46,#1a4e34 55%,#123825);box-shadow:inset 0 0 0 2px #d8b25e66,inset 0 0 90px #00000080,var(--shadow-soft)}.felt:after{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:18px;border:1px solid rgba(216,178,94,.22);pointer-events:none}.seat-top{grid-area:top;justify-self:center;align-items:center}.seat-left{grid-area:left;justify-self:start;align-self:center}.seat-right{grid-area:right;justify-self:end;align-self:center}.seat{display:flex;flex-direction:column;gap:8px;z-index:2}.seat-left,.seat-right{flex-direction:column;align-items:center}.nameplate{display:inline-flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;border-radius:999px;background:#00000057;border:1px solid var(--line);position:relative}.nameplate.is-turn{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),0 0 16px #d8b25e66}.np-wind{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--vermilion),#8c2a20);font-family:var(--han);font-weight:700;font-size:16px;color:var(--ivory)}.nameplate.is-dealer .np-wind{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--ink)}.np-info{display:flex;flex-direction:column;line-height:1.1}.np-name{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:6px}.np-dealer{font-family:var(--han);font-size:11px;color:var(--ink);background:var(--gold);border-radius:4px;padding:0 4px}.np-score{font-size:11.5px;color:var(--gold);letter-spacing:.02em}.np-turn-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 1.3s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.opp-hand{display:flex;gap:2px}.opp-left,.opp-right{flex-direction:column}.tile-rot{transform:rotate(90deg)}.opp-left .tile-rot,.opp-right .tile-rot{margin:-10px 0}.seat-melds{display:flex;flex-wrap:wrap;gap:6px}.meld{display:flex;gap:1px;padding:3px;border-radius:7px;background:#0000002e}.meld-claimed{transform:translateY(-3px)}.flower-tag{filter:drop-shadow(0 3px 4px rgba(0,0,0,.3))}.center{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:1}.center-info{display:flex;gap:18px;align-items:baseline;padding:8px 18px;border-radius:999px;background:#0000004d;border:1px solid var(--line);font-size:13px}.ci-round{font-family:var(--display);font-size:18px;color:var(--ivory)}.ci-hand{color:var(--muted)}.ci-wall strong{color:var(--gold);font-size:16px}.pond{display:grid;grid-template-columns:repeat(auto-fit,42px);gap:4px;justify-content:center;max-width:460px;min-height:120px;padding:10px;border-radius:14px;background:#00000029}.pond-tile{filter:drop-shadow(0 3px 3px rgba(0,0,0,.35))}.pond-last{outline:2px solid var(--gold);outline-offset:1px;border-radius:7px}.you-area{display:flex;flex-direction:column;align-items:center;gap:12px}.you-melds{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.you-plate{align-self:center}.hand-rail{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;padding:14px 18px;border-radius:16px;background:linear-gradient(180deg,#00000038,#00000057);border:1px solid var(--line);min-height:110px;align-items:flex-end}.just-drawn{margin-left:16px}.tile-hint{transform:translateY(-8px)}.tile-hint:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:15px;box-shadow:0 0 0 2px var(--gold, #d8b25e),0 0 18px 4px #d8b25e80;animation:hintPulse 1.15s ease-in-out infinite;pointer-events:none}@keyframes hintPulse{0%,to{opacity:.4}50%{opacity:1}}.actions-bar{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;min-height:44px}.felt .opp-hand .tile,.felt .seat-melds .tile,.you-melds .tile,.pond-tile,.hand-rail .tile{width:auto!important;aspect-ratio:90 / 124}@media (max-width: 760px){.felt{grid-template-columns:1fr 1.6fr 1fr;padding:14px;min-height:380px}.hand-rail .tile{height:64px!important}}@media (max-width: 680px){.felt{grid-template-columns:minmax(50px,.8fr) minmax(150px,2.4fr) minmax(50px,.8fr);grid-template-rows:auto minmax(140px,1fr) auto;padding:10px;min-height:300px;gap:6px;border-radius:18px}.felt:after{top:8px;right:8px;bottom:8px;left:8px}.seat{gap:5px}.nameplate{padding:3px 8px 3px 3px;gap:7px}.np-wind{width:22px;height:22px;font-size:12px}.np-name{font-size:11px}.np-score{font-size:10px}.np-dealer{font-size:9px}.felt .opp-hand .tile{height:20px!important}.opp-top .opp-hand,.seat-top .opp-hand{flex-wrap:wrap;justify-content:center;max-width:220px}.opp-left .tile-rot,.opp-right .tile-rot{margin:-6px 0}.felt .seat-melds .tile{height:22px!important}.seat-melds{gap:4px}.center-info{gap:8px;padding:6px 10px;font-size:11px;flex-wrap:wrap;justify-content:center}.ci-round{font-size:14px}.ci-wall strong{font-size:13px}.pond{grid-template-columns:repeat(auto-fit,28px);min-height:70px;max-width:100%;padding:6px;gap:3px}.pond-tile{height:28px!important}.you-area{gap:8px}.you-melds .tile{height:32px!important}.hand-rail{padding:10px 6px;gap:3px;min-height:76px;border-radius:12px}.hand-rail .tile{height:50px!important}.just-drawn{margin-left:10px}}@media (max-width: 430px){.felt{grid-template-columns:minmax(40px,.7fr) minmax(120px,2.6fr) minmax(40px,.7fr);padding:8px}.felt .opp-hand .tile{height:17px!important}.opp-top .opp-hand,.seat-top .opp-hand{max-width:180px}.hand-rail .tile{height:44px!important}.pond{grid-template-columns:repeat(auto-fit,26px)}.pond-tile{height:26px!important}}@media (hover: none){.tile.is-clickable:hover{transform:none}}.card-lines-demo{display:flex;flex-direction:column;gap:10px;margin:24px 0 8px}.cld-line{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:12px;background:#00000038;border:1px solid var(--line)}.cld-desc{font-size:14.5px;color:var(--ivory)}.cld-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.charleston-demo{display:flex;flex-wrap:wrap;gap:14px;margin:24px 0 8px}.cd-step{display:flex;flex-direction:column;gap:6px;padding:16px 20px;border-radius:14px;background:#0000003d;border:1px solid var(--line);min-width:160px}.cd-num{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:var(--ink);font-weight:800}.cd-label{font-family:var(--display);font-size:20px;color:var(--ivory)}.cd-arrow{font-size:13px;color:var(--jade)}.joker-demo{display:flex;flex-wrap:wrap;gap:18px;margin:24px 0 8px}.jd-card{display:flex;flex-direction:column;gap:12px;align-items:center;padding:18px 20px;border-radius:14px}.jd-card span{font-size:13.5px}.jd-card.good{background:#2f7d4f33;border:1px solid var(--jade);color:#e7f3e8}.jd-card.bad{background:#b23a2e2e;border:1px solid rgba(178,58,46,.6);color:#f3e3e0}.pattern-list{list-style:none;margin:6px 0;padding:0;width:100%;display:flex;flex-direction:column;gap:4px;max-height:180px;overflow-y:auto}.am-play .charleston-hint,.am-play .discard-hint{font-size:12.5px;color:var(--muted);align-self:center}.btn.small{padding:5px 12px;font-size:12px}.rs-bonus{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);background:var(--gold);border-radius:999px;padding:3px 10px;font-weight:700}.am-result-line{font-size:14.5px;color:var(--ivory);font-style:italic;margin:0}.candidate-rail{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.cr-title{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}.cr-lines{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px}.cr-line{display:flex;flex-direction:column;gap:3px;padding:9px 12px;border-radius:10px;background:#0000003d;border:1px solid var(--line)}.cr-cat{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--jade)}.cr-desc{font-size:13px;color:var(--ivory);line-height:1.35}.cr-meta{font-size:12px;color:var(--gold);font-weight:600}.cr-joker{font-size:12.5px;color:#c9a8e0}.card-panel{padding:16px 18px}.card-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.card-panel-head h3{margin:0;font-family:var(--display);font-size:22px;color:var(--ivory)}.cp-year{font-size:12px;color:var(--muted)}.cp-edit-note{font-size:13.5px;color:#e2dac6;line-height:1.6}.cp-edit-note code{background:#00000059;padding:1px 5px;border-radius:5px;font-size:12px;color:var(--gold)}.cp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.cp-cat-name{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;border-bottom:1px solid var(--line);padding-bottom:4px}.cp-line{display:flex;flex-direction:column;gap:4px;padding:8px 10px;border-radius:9px;margin-bottom:5px;background:#0003}.cp-line.ready{background:#2f7d4f38;border:1px solid var(--jade)}.cp-desc{font-size:12.5px;color:var(--ivory);line-height:1.35}.cp-tags{display:flex;flex-wrap:wrap;gap:5px;align-items:center}.cp-pts{font-family:var(--display);font-size:16px;font-weight:700;color:var(--gold)}.cp-tag{font-size:10.5px;letter-spacing:.04em;padding:2px 7px;border-radius:999px;background:#ffffff14;color:var(--muted)}.cp-tag.c{background:#b23a2e4d;color:#f0d6d2}.cp-tag.nj{background:#7d4fa34d;color:#e2d2f0}.cp-tag.suit{background:#1f5f864d;color:#cfe6f3}.cp-tag.dist.ready,.cp-tag.dist{background:#d8b25e38;color:var(--gold)}.cp-tag.bad{background:#b23a2e66;color:#ffd9d3}.group-label{font-size:13.5px;color:var(--muted)}.win-shape{display:flex;flex-wrap:wrap;gap:16px;margin:26px 0 8px;align-items:flex-start}.win-group span{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}.yaku-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:24px 0 8px}.yaku-chip{padding:14px 16px;display:flex;flex-direction:column;gap:6px}.yaku-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.yaku-name{font-family:var(--display);font-size:19px;color:var(--ivory)}.yaku-han{font-size:12px;color:var(--gold);font-weight:700;white-space:nowrap}.yaku-chip p{margin:0;font-size:13px;color:var(--muted);line-height:1.5}.practice-hand{margin:24px 0 18px;padding:16px;border-radius:14px;background:#00000038;border:1px solid var(--line)}.candidate-tray{display:flex;gap:12px;flex-wrap:wrap;padding:4px 0}.verdict{margin-top:20px;padding:16px 18px;border-radius:12px;font-size:15.5px;line-height:1.55}.mini-yaku{margin:10px 0 0;padding-left:18px;font-size:13.5px;color:#e7f3e8}.mini-yaku em{color:var(--gold);font-style:normal;font-weight:700}.furiten-demo{display:flex;flex-wrap:wrap;gap:22px;margin:24px 0 8px}.furiten-demo>div{display:flex;flex-direction:column;gap:10px;padding:16px;border-radius:14px;background:#00000038;border:1px solid var(--line)}.fd-label{font-size:13px;letter-spacing:.04em;color:var(--gold);font-weight:600}.fd-label.fd-bad{color:#e08f84}.dora-demo{display:flex;flex-wrap:wrap;gap:28px;align-items:center;margin:24px 0 8px}.dora-pick{display:flex;flex-direction:column;gap:10px}.dora-arrow{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:14px;background:#d8b25e1a;border:1px solid rgba(216,178,94,.4)}.dora-arrow .arrow{font-size:30px;color:var(--gold)}.dora-out{display:flex;flex-direction:column;align-items:center;gap:6px}.dora-out span{font-size:12.5px;color:var(--ivory)}.dora-tray{display:flex;align-items:center;gap:10px}.dora-tiles{display:inline-flex;gap:3px;padding:4px 6px;background:#00000047;border:1px solid var(--line);border-radius:10px}.statusline{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ivory);min-height:22px;flex:1;justify-content:center;text-align:center}.btn.riichi-btn{border-color:var(--vermilion);color:#f3e3e0;background:#b23a2e2e}.result-card{width:min(460px,92vw);padding:30px 30px 26px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.result-score{display:flex;gap:12px;align-items:baseline;margin:4px 0;flex-wrap:wrap;justify-content:center}.rs-limit{font-family:var(--han);font-size:22px;color:var(--vermilion);font-weight:800}.rs-faan{font-family:var(--display);font-size:28px;color:var(--ivory)}.rs-fu{font-size:16px;color:var(--muted)}.pattern-list{list-style:none;margin:6px 0;padding:0;width:100%;display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto}.pattern-list li.dora-line{background:#d8b25e1f}.learn{display:grid;grid-template-columns:250px 1fr;gap:22px;align-items:start}.learn-rail{padding:18px 14px;position:sticky;top:18px}.rail-title{font-family:var(--display);font-size:22px;color:var(--ivory);padding:4px 10px 12px;border-bottom:1px solid var(--line);margin-bottom:8px}.learn-rail ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.learn-rail button{width:100%;display:flex;align-items:center;gap:12px;background:transparent;border:none;color:var(--muted);padding:11px 10px;border-radius:10px;text-align:left;transition:background .14s ease,color .14s ease}.learn-rail button:hover{background:#ffffff0d;color:var(--ivory)}.learn-rail .num{font-family:var(--han);font-weight:700;font-size:16px;width:26px;height:26px;display:grid;place-items:center;border-radius:7px;background:#00000047;color:var(--gold);flex:none}.learn-rail .txt{font-size:13.5px;font-weight:600;line-height:1.25}.learn-rail li.on button{background:linear-gradient(90deg,rgba(216,178,94,.16),transparent);color:var(--ivory)}.learn-rail li.on .num{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:var(--ink)}.learn-rail li.done .txt{color:var(--jade)}.learn-rail .check{margin-left:auto;color:var(--jade);font-weight:800}.learn-main{padding:0 0 24px;overflow:hidden}.learn-progress{height:4px;background:#0000004d}.learn-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-deep));transition:width .32s cubic-bezier(.2,.8,.2,1)}.learn-head{display:flex;align-items:center;gap:18px;padding:24px clamp(20px,3vw,36px) 8px}.learn-han{font-family:var(--han);font-size:56px;font-weight:900;color:#d8b25ee6;line-height:1;text-shadow:0 2px 0 rgba(0,0,0,.25)}.learn-kicker{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}.learn-head h2{font-size:clamp(26px,3.4vw,38px)}.learn-body{padding:10px clamp(20px,3vw,36px) 8px;min-height:320px}.lead{font-size:17px;line-height:1.65;color:#ece4d0;max-width:62ch}.lead strong{color:var(--ivory)}.aside{margin-top:22px;font-size:14.5px;color:var(--muted);line-height:1.6}.aside strong{color:var(--gold)}.strip{display:flex;flex-wrap:wrap;align-items:flex-end}.honor-grid{display:flex;flex-wrap:wrap;gap:28px;margin:22px 0 8px}.group{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:14px;background:#0003;border:1px solid var(--line)}.group--red{border-color:#b23a2e80}.group--gold{border-color:#d8b25e73}.group-label{font-size:13.5px;color:var(--muted);letter-spacing:.02em}.meld-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:24px 0 8px}.meld-card{position:relative;padding:20px 18px 18px;display:flex;flex-direction:column;gap:10px;align-items:flex-start}.meld-cn{position:absolute;top:10px;right:14px;font-family:var(--han);font-size:28px;color:#d8b25e66}.meld-card h4{font-family:var(--display);font-size:22px;margin:4px 0 0;color:var(--ivory)}.meld-card p{margin:0;font-size:13px;color:var(--muted);line-height:1.5}.win-shape{display:flex;flex-wrap:wrap;gap:16px;margin:24px 0 8px;align-items:flex-start}.win-group{display:flex;flex-direction:column;gap:8px;align-items:center;padding:14px 14px 10px;border-radius:14px;background:#00000038;border:1px solid var(--line)}.win-group span{font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}.band-list{display:flex;flex-direction:column;gap:6px;margin:22px 0 8px}.band{display:flex;align-items:center;gap:16px;width:100%;text-align:left;padding:10px 14px;border-radius:10px;background:#0000003d;border:1px solid var(--line);color:var(--muted);transition:background .14s ease,color .14s ease,border-color .14s ease}.band:hover{background:#ffffff0d;color:var(--ivory)}.band.on{background:linear-gradient(90deg,rgba(216,178,94,.14),transparent);border-color:#d8b25e80;color:var(--ivory)}.band-val{font-family:var(--display);font-size:22px;font-weight:700;color:var(--gold);width:44px;flex:none;text-align:right}.band-ex{font-size:13.5px;line-height:1.4}.practice-hand{margin:18px 0;padding:16px;border-radius:14px;background:#00000038;border:1px solid var(--line)}.candidate-tray{display:flex;gap:12px;flex-wrap:wrap;padding:14px 0 4px}.verdict{margin-top:16px;padding:14px 16px;border-radius:12px;font-size:14.5px;line-height:1.55}.verdict.good{background:#2f7d4f38;border:1px solid var(--jade);color:#e7f3e8}.verdict.bad{background:#b23a2e2e;border:1px solid rgba(178,58,46,.6);color:#f3e3e0}.pattern-list{list-style:none;margin:6px 0;padding:0;width:100%;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.pattern-list li{display:flex;justify-content:space-between;padding:6px 12px;border-radius:8px;background:#00000038;font-size:13.5px}.learn-nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px clamp(20px,3vw,36px) 0;margin-top:14px;border-top:1px solid var(--line)}.dots{display:flex;gap:8px}.dots i{width:8px;height:8px;border-radius:50%;background:#fff3;transition:background .16s ease,transform .16s ease}.dots i.on{background:var(--gold);transform:scale(1.3)}@media (max-width: 860px){.learn{grid-template-columns:1fr}.learn-rail{position:static}.learn-rail ol{flex-direction:row;overflow-x:auto}.learn-rail .txt{display:none}}.play{position:relative;display:flex;flex-direction:column;gap:16px}.play-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.topbar-controls{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.difficulty{display:flex;align-items:center;gap:10px}.casual-tag{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--felt-0);background:var(--gold);border-radius:999px;padding:2px 8px;font-weight:700}.min-tag{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-weight:700}.diff-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}.seg.small{display:inline-flex;background:#00000047;border:1px solid var(--line);border-radius:999px;padding:3px}.seg.small button{border:none;background:transparent;color:var(--muted);font-weight:600;font-size:12.5px;padding:6px 14px;border-radius:999px;transition:all .14s ease}.seg.small button.on{background:linear-gradient(180deg,var(--ivory),#e4d8ba);color:var(--ink)}.statusline{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ivory);min-height:22px;flex:1;justify-content:center}.spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(216,178,94,.3);border-top-color:var(--gold);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn.ghost{background:transparent;border-color:#ffffff2e;color:var(--muted)}.btn.hint-btn.on{background:linear-gradient(180deg,#d8b25e40,#d8b25e1a);border-color:var(--gold);color:var(--gold)}.guided-badge{font-family:var(--han);font-size:13px;letter-spacing:.04em;color:var(--felt-0);background:linear-gradient(180deg,var(--gold),var(--gold-deep));border-radius:999px;padding:6px 16px;font-weight:700}.coach{display:flex;align-items:center;gap:12px;padding:12px 18px;border-radius:14px;background:linear-gradient(90deg,#d8b25e29,#0000001f);border:1px solid var(--gold);box-shadow:0 4px 18px #00000040}.coach.win{border-color:var(--jade);background:linear-gradient(90deg,#2f7d4f47,#0000001f)}.coach-icon{flex:none;display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:#0000004d;font-family:var(--han);font-size:18px;font-weight:700;color:var(--gold)}.coach-text{font-size:15px;line-height:1.5;color:var(--ivory)}.btn .tile{vertical-align:middle;margin-left:4px}.win-btn{animation:glow 1.1s ease-in-out infinite alternate}@keyframes glow{0%{box-shadow:0 0 #d8b25e66}to{box-shadow:0 0 16px 3px #d8b25e99}}.result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#08140ebd;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.result-card{width:min(440px,92vw);padding:30px 30px 26px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.result-han{font-family:var(--han);font-size:64px;line-height:1;color:var(--gold);text-shadow:0 3px 0 rgba(0,0,0,.3)}.result-card h2{font-size:32px}.result-card>p{color:var(--muted);line-height:1.5;margin:0}.result-score{display:flex;gap:14px;align-items:baseline;margin:4px 0}.rs-faan{font-family:var(--display);font-size:30px;color:var(--ivory)}.rs-pts{font-size:18px;color:var(--gold)}.rs-how{font-size:12.5px;color:var(--muted);letter-spacing:.08em}.pattern-list{list-style:none;margin:6px 0;padding:0;width:100%;display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.pattern-list li{display:flex;justify-content:space-between;padding:7px 14px;border-radius:8px;background:#00000038;font-size:14px}.pattern-list .pf{color:var(--gold);font-weight:700}.payments{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;width:100%;margin:6px 0 4px}.pay{display:flex;flex-direction:column;gap:2px;padding:8px 4px;border-radius:8px;background:#0003;font-size:12.5px}.pay span:first-child{color:var(--muted)}.pay span:last-child{font-weight:800;font-size:16px}.pay.plus span:last-child{color:#76c98a}.pay.minus span:last-child{color:#e08f84}.btn.big{padding:13px 32px;font-size:15px;margin-top:6px}
