@import "https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap";:root{color:#152825;font-synthesis:none;--ink:#102d2a;--green:#126455;--light-green:#21cdb0;--mint:#32d49d;--gold:#e9a92e;--paper:#fbfaf5;--line:#d8ddd5;--muted:#71807c;background:#f2f0e8;font-family:Noto Sans SC,system-ui,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at 15% 5%,#fffdf5 0,#0000 35%),#f2f0e8;min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.app-shell{min-height:100vh}.topbar{color:#fff;background:var(--ink);border-bottom:1px solid #31504b;align-items:center;gap:13px;height:78px;padding:0 clamp(20px,5vw,76px);display:flex}.brand-mark{width:42px;height:42px;color:var(--gold);background:#183a36;border:1px solid #53736d;border-radius:10px;place-items:center;font-size:22px;font-weight:800;display:grid}.brand-title{letter-spacing:.08em;font-weight:700}.brand-subtitle{color:#7fa29b;letter-spacing:.25em;margin-top:2px;font:600 9px/1 Space Grotesk}.brand-home{color:inherit;text-align:left;background:0 0;border:0;align-items:center;gap:13px;padding:0;display:flex}.brand-copy,.brand-title,.brand-subtitle{display:block}.brand-home:hover .brand-mark,.brand-home:focus-visible .brand-mark{border-color:var(--gold)}.brand-home:focus-visible{outline:2px solid var(--gold);outline-offset:5px;border-radius:9px}.privacy-note{color:#a9c0bb;margin-left:auto;font-size:12px}.privacy-note span{background:var(--mint);width:7px;height:7px;box-shadow:0 0 10px var(--mint);border-radius:50%;margin-right:6px;display:inline-block}.stepper{color:#78918c;background:#173633;justify-content:center;align-items:center;height:66px;padding:0 20px;display:flex}.step{color:inherit;white-space:nowrap;background:0 0;border:0;align-items:center;gap:8px;padding:5px;font-size:12px;display:flex}.step span{border:1px solid #46615c;border-radius:50%;place-items:center;width:25px;height:25px;font:700 11px Space Grotesk;display:grid}.step.active{color:#fff}.step.active span{color:#142c29;border-color:var(--gold);background:var(--gold)}.step.done{color:#8ed3bf}.step.done span{color:var(--mint);border-color:#3b8876}.step.done:hover,.step.active:hover{color:#fff}.step:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:7px}.step:disabled{cursor:default;opacity:.45}.step-line{background:#3d5753;width:clamp(24px,7vw,110px);height:1px;margin:0 13px}.step-line.done{background:#3b8876}main{padding:clamp(28px,5vw,70px) clamp(18px,5vw,72px) 80px}.hero-layout{grid-template-columns:minmax(0,1fr);align-items:center;width:100%;min-width:0;max-width:760px;min-height:580px;margin:0 auto;display:grid}.eyebrow,.section-kicker{color:#b77912;letter-spacing:.2em;text-transform:uppercase;font:700 11px/1.4 Space Grotesk,sans-serif}.hero-copy h1,.page-heading h1{color:var(--ink);letter-spacing:-.05em;margin:19px 0;font-size:clamp(38px,5vw,68px);line-height:1.12}.hero-copy h1 em{color:var(--green);font-style:normal;position:relative}.hero-copy h1 em:after{content:"";background:var(--gold);opacity:.75;height:5px;position:absolute;bottom:1px;left:0;right:0}.hero-copy>p{color:#60716d;max-width:540px;font-size:17px;line-height:1.9}.truth-card{border-left:3px solid var(--gold);background:#ebe7dc;flex-direction:column;gap:5px;margin-top:28px;padding:17px 20px;display:flex}.truth-card strong{font-size:14px}.truth-card span{color:var(--muted);font-size:12px}.upload-panel{text-align:center;background:#fbfaf5d9;border:1px solid #c9d1c8;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;width:100%;min-width:0;min-height:470px;padding:40px;transition:all .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 30px 70px #1b37321f}.upload-panel:before{content:"";pointer-events:none;border:1px dashed #bdc9c1;border-radius:17px;position:absolute;inset:13px}.upload-panel.dragging{border-color:var(--green);background:#f4fff9;transform:translateY(-3px)}.upload-panel input{display:none}.upload-icon{color:#fff;background:var(--green);border-radius:50%;place-items:center;width:78px;height:78px;margin-bottom:22px;display:grid;box-shadow:0 10px 24px #12645538}.upload-icon svg{width:40px;height:40px}.upload-panel h2{margin:0;font-size:22px}.upload-panel p{color:var(--muted);font-size:13px}.upload-panel small{color:#8a9693;margin-top:18px;font-size:11px}.primary-button,.secondary-button,.ghost-button{border:1px solid #0000;border-radius:9px;justify-content:center;align-items:center;min-height:46px;padding:0 23px;font-weight:700;text-decoration:none;display:inline-flex}.primary-button{color:#fff;background:var(--green);box-shadow:0 8px 18px #1264552e}.primary-button:hover{background:#0c5749}.secondary-button{color:var(--ink);background:#fff;border-color:#b9c5c0}.ghost-button{color:#586864;background:0 0;border-color:#0000}.upload-panel .primary-button{min-width:165px;margin-top:16px}.upload-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:16px;display:flex}.upload-panel .upload-actions .primary-button{min-width:165px;margin-top:0}.upload-actions .secondary-button{min-width:165px}.inline-error{color:#9a2632;background:#ffe9eb;border-radius:8px;margin-top:14px;padding:10px 13px;font-size:13px}.workspace-page{max-width:1180px;margin:0 auto}.workspace-page.wide{max-width:1500px}.page-heading{justify-content:space-between;align-items:end;gap:50px;margin-bottom:30px;display:flex}.page-heading h1{margin:8px 0 0;font-size:clamp(28px,3vw,42px)}.page-heading p{max-width:420px;color:var(--muted);margin:0;font-size:13px;line-height:1.7}.page-heading.compact{margin-bottom:24px}.crop-shell{background:#102522;border-radius:18px;place-items:center;min-height:450px;max-height:68vh;padding:17px;display:grid;overflow:hidden;box-shadow:0 25px 60px #132a262e}.crop-canvas{touch-action:none;cursor:move;max-width:100%;max-height:calc(68vh - 34px);display:block}.crop-canvas.drawing{cursor:crosshair}.secondary-button.active{color:#744d06;border-color:var(--gold);background:#fff5d8}.action-bar{justify-content:flex-end;align-items:center;gap:10px;margin-top:22px;display:flex}.action-bar.centered{justify-content:center}.panel{border:1px solid var(--line);background:#fbfaf5f5;border-radius:15px;box-shadow:0 9px 25px #2637330d}.hand-overview{margin-bottom:22px;padding:20px}.overview-total{color:#45625c;background:#e7eee9;border-radius:20px;padding:6px 10px;font-size:10px;font-weight:700}.region-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:11px;margin-top:17px;display:grid}.region-overview-card{background:#f6f5ef;border:1px solid #dde2dd;border-radius:10px;min-width:0;padding:12px}.region-overview-card>header{color:#40534f;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:11px;display:flex}.region-overview-card>header span{align-items:center;gap:7px;font-weight:700;display:flex}.region-overview-card>header i{border-radius:50%;width:8px;height:8px}.region-overview-card>header b{color:#84908d;font-size:9px}.visual-tile-rack{flex-wrap:wrap;align-items:flex-start;gap:6px;min-height:60px;display:flex}.visual-tile{width:46px;position:relative}.visual-tile-face{background:0 0;border:0;width:46px;padding:0;display:block}.visual-tile-face img{-webkit-user-select:none;user-select:none;width:46px;height:auto;display:block}.visual-tile-face:hover img{filter:drop-shadow(0 4px 3px #142d2824);transform:translateY(-2px)}.visual-tile-remove{z-index:1;color:#9d303b;opacity:0;background:#fff;border:1px solid #d8b8bb;border-radius:50%;place-items:center;width:17px;height:17px;padding:0;font-size:12px;line-height:1;transition:opacity .15s;display:grid;position:absolute;top:-5px;right:-5px}.visual-tile:hover .visual-tile-remove,.visual-tile:focus-within .visual-tile-remove{opacity:1}.visual-tile.winning{transform:translateY(-3px)}.visual-tile.winning .visual-tile-face img{filter:drop-shadow(0 0 3px var(--gold))}.visual-tile-win{color:#2c260d;background:var(--gold);border-radius:50%;place-items:center;width:18px;height:18px;font-size:9px;font-weight:800;display:grid;position:absolute;bottom:3px;right:-3px}.empty-region{color:#98a19f;align-self:center;font-size:10px}.region-tile-add{grid-template-columns:minmax(0,1fr) 68px;gap:5px;margin-top:9px;display:grid}.region-tile-add select{height:30px}.region-tile-add button,.add-meld-button{color:var(--green);background:#eef8f4;border:1px solid #c5d4ce;border-radius:6px;font-size:9px;font-weight:700}.meld-overview-card{grid-column:span 2}.meld-groups{gap:8px;display:grid}.meld-group{background:#fff;border:1px solid #d9dcd7;border-radius:8px;padding:9px}.meld-group.invalid{background:#fffaf1;border-color:#dc9e65}.meld-group-head{grid-template-columns:auto 75px 75px 1fr;align-items:center;gap:5px;margin-bottom:8px;display:grid}.meld-group-head strong{font-size:10px}.meld-group-head select{height:30px}.meld-delete{color:#9a3942;background:0 0;border:0;justify-self:end;font-size:9px}.meld-group small{color:#a06427;margin-top:7px;font-size:9px;display:block}.compact-add{max-width:245px}.add-meld-button{min-height:32px;margin-top:9px;padding:0 12px}.supported-note{color:#285b4f;background:#eaf7f2;border-color:#91c7b5}.correction-grid{grid-template-columns:minmax(0,1.1fr) minmax(470px,.9fr);align-items:start;gap:22px;display:grid}.visual-column,.form-column{flex-direction:column;gap:18px;min-width:0;display:flex}.editor-panel,.context-panel{padding:20px}.panel-title-row{justify-content:space-between;align-items:center;gap:15px;display:flex}.panel-title-row h2{margin:0;font-size:17px}.panel-title-row p{color:var(--muted);margin:4px 0 0;font-size:11px}.editor-actions{flex-wrap:wrap;justify-content:flex-end;gap:7px;display:flex}.draw-toggle{color:#61716d;background:#fff;border:1px solid #c9d3cf;border-radius:8px;padding:8px 13px;font-size:11px}.draw-toggle.active{color:#095345;background:#ddf7ee;border-color:#55b69c}.region-tools{flex-wrap:wrap;gap:7px;margin:17px 0 12px;display:flex}.region-tools button{color:#53645f;background:#fff;border:1px solid #d7ddd8;border-radius:7px;align-items:center;gap:6px;padding:7px 10px;font-size:11px;display:flex}.region-tools button i{background:var(--region-color);border-radius:50%;width:7px;height:7px}.region-tools button.selected{color:var(--ink);border-color:var(--region-color);box-shadow:inset 0 -2px 0 var(--region-color)}.image-stage-viewport{place-items:center;width:100%;min-height:0;display:grid}.image-stage{-webkit-user-select:none;user-select:none;background:#132724;border-radius:10px;flex:none;width:100%;position:relative;overflow:hidden}.image-stage img{object-fit:fill;width:100%;height:100%;position:absolute;inset:0}.image-stage svg{touch-action:none;width:100%;height:100%;position:absolute;inset:0}.image-stage svg.drawing{cursor:crosshair}body.region-editor-open{overflow:hidden}.editor-panel.fullscreen{z-index:900;background:var(--paper);border:0;border-radius:0;flex-direction:column;width:100vw;height:100dvh;padding:14px 18px;display:flex;position:fixed;inset:0}.editor-panel.fullscreen .panel-title-row,.editor-panel.fullscreen .region-tools,.editor-panel.fullscreen .region-list{flex:none}.editor-panel.fullscreen .image-stage-viewport{flex:1;overflow:hidden}.editor-panel.fullscreen .image-stage{width:auto;max-width:100%}.fullscreen-toggle.active{color:#31204e;background:#eee9ff;border-color:#8f7cff}.detection-box{fill:#0000;stroke-width:3px;vector-effect:non-scaling-stroke}.image-stage text{paint-order:stroke;stroke:#0b211e;stroke-width:4px;stroke-linejoin:round;font:700 15px sans-serif}.region-box{stroke-width:3px;stroke-dasharray:10 6;vector-effect:non-scaling-stroke}.region-box.draft{stroke-dasharray:5 4}.region-label{font-size:18px!important}.region-list{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.region-list span{background:#eef0eb;border-radius:20px;align-items:center;gap:6px;padding:5px 8px;font-size:10px;display:flex}.region-list i{border-radius:50%;width:7px;height:7px}.region-list button{color:#7b8885;background:0 0;border:0;padding:0}.text-button{color:var(--green);background:0 0;border:0;font-size:11px;font-weight:700}.tile-list{max-height:480px;margin-top:14px;padding-right:4px;overflow:auto}.tile-row{border-bottom:1px solid #e5e8e3;grid-template-columns:22px 25px minmax(130px,1fr) 105px 45px 75px;align-items:center;gap:6px;padding:7px 4px;display:grid}.tile-row.winning{background:#fff6db;border-radius:7px}.tile-index,.confidence{color:#85918e;text-align:center;font:600 10px Space Grotesk}.winner-radio input{display:none}.winner-radio span{border:2px solid #adb9b5;border-radius:50%;width:15px;height:15px;display:block}.winner-radio input:checked+span{border:4px solid var(--gold);background:var(--ink)}.winner-radio input:disabled+span{opacity:.3}select,input[type=number]{color:#293d39;background:#fff;border:1px solid #d3dad5;border-radius:7px;outline:none;width:100%;height:36px;padding:0 9px;font-size:11px}.tile-row select:focus,select:focus,input:focus{border-color:#4d9d89;box-shadow:0 0 0 3px #4d9d891f}.row-actions{gap:3px;display:flex}.row-actions button{color:#71807d;background:#fff;border:1px solid #d9dfda;border-radius:5px;width:22px;height:24px;padding:0}.development-note{color:#674a13;background:#fff5d9;border:1px solid #e3b75e;border-radius:10px;flex-direction:column;gap:4px;padding:14px 17px;display:flex}.development-note strong{font-size:13px}.development-note span{font-size:11px;line-height:1.5}.segmented{background:#e8ebe6;border-radius:9px;grid-template-columns:1fr 1fr;margin-top:15px;padding:3px;display:grid}.segmented button{color:#73817e;background:0 0;border:0;border-radius:7px;height:36px;font-size:11px}.segmented button.active{color:#fff;background:var(--green);box-shadow:0 3px 8px #1264552e}.game-mode-segmented{background:#e8e4f1;margin-top:14px}.game-mode-segmented button.active{background:#6552a6}.sanma-settings{background:#f5f1fd;border:1px solid #d4c8ed;border-radius:9px;justify-content:space-between;align-items:center;gap:16px;margin-top:14px;padding:12px 14px;display:flex}.sanma-settings>div{flex-direction:column;gap:3px;display:flex}.sanma-settings strong{font-size:11px}.sanma-settings span{color:#746b84;font-size:9px}.sanma-settings label{color:#655a78;align-items:center;gap:9px;font-size:10px;font-weight:700;display:flex}.nuki-stepper{text-align:center;grid-template-columns:30px 34px 30px;align-items:center;display:grid}.nuki-stepper button{color:#5c488d;background:#fff;border:1px solid #c8bce1;height:30px;padding:0}.nuki-stepper button:first-child{border-radius:7px 0 0 7px}.nuki-stepper button:last-child{border-radius:0 7px 7px 0}.nuki-stepper b{background:#fff;border-top:1px solid #c8bce1;border-bottom:1px solid #c8bce1;height:30px;padding-top:7px;font-size:11px}.form-grid{gap:10px;margin-top:14px;display:grid}.form-grid.two{grid-template-columns:1fr 1fr}.form-grid label{color:#61706d;flex-direction:column;gap:5px;font-size:10px;display:flex}.mini-segmented{background:#e8ebe6;border-radius:7px;grid-template-columns:1fr 1fr;height:36px;padding:2px;display:grid}.mini-segmented button{color:#71807d;background:0 0;border:0;border-radius:5px;font-size:10px}.mini-segmented button.active{color:#fff;background:var(--green)}.check-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:15px;display:grid}.check-grid label{background:#fff;border:1px solid #dde2dd;border-radius:7px;align-items:center;gap:6px;min-height:33px;padding:6px 8px;font-size:10px;transition:opacity .15s;display:flex}.check-grid label.disabled{opacity:.38;cursor:not-allowed}.check-grid input{accent-color:var(--green)}.indicator-line{grid-template-columns:95px 1fr;align-items:start;gap:10px;margin-top:14px;display:grid}.indicator-line>span{color:var(--muted);padding-top:5px;font-size:10px}.indicator-line>div{flex-wrap:wrap;gap:5px;display:flex}.indicator-line b{background:#fff6d7;border:1px solid #e0d09e;border-radius:6px;padding:5px 8px;font-size:10px}.indicator-line b button{background:0 0;border:0;margin-left:6px;padding:0}.indicator-line em{color:#9ba4a2;font-size:10px;font-style:normal}.add-indicator{grid-template-columns:1fr 110px;gap:7px;margin-top:12px;display:grid}.add-indicator button{color:var(--green);background:#eef8f4;border:1px solid #c5d4ce;border-radius:7px;font-size:10px;font-weight:700}.score-action{color:#fff;background:var(--ink);border-radius:12px;justify-content:space-between;align-items:center;gap:15px;padding:16px;display:flex}.score-action>div{flex-direction:column;gap:3px;display:flex}.score-action strong{font-size:12px}.score-action span{color:#9fb6b1;font-size:10px}.score-action .primary-button{background:var(--gold);color:#2c260d;box-shadow:none}.warning-strip{color:#725514;background:#fff6da;border:1px solid #e5c475;border-radius:9px;flex-direction:column;gap:4px;margin-bottom:15px;padding:11px 15px;font-size:11px;display:flex}.sticky-error{margin:0}.loading-card,.error-card{text-align:center;border:1px solid var(--line);background:var(--paper);border-radius:18px;flex-direction:column;justify-content:center;align-items:center;min-height:380px;display:flex}.loading-card h2{margin:20px 0 0}.loading-card p,.error-card p{color:var(--muted)}.loader{border:3px solid #d8e3df;border-top-color:var(--green);border-radius:50%;width:45px;height:45px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.result-page{max-width:1250px;margin:0 auto}.score-hero{border-bottom:1px solid #cad2cc;justify-content:space-between;align-items:end;padding:10px 5px 30px;display:flex}.score-hero h1{color:var(--ink);letter-spacing:-.07em;margin:8px 0 0;font-size:clamp(45px,7vw,82px)}.score-hero p{color:#596a66;margin:3px 0 0;font:600 20px Space Grotesk}.total-score{text-align:right}.total-score span{color:var(--muted);font-size:11px;display:block}.total-score strong{color:var(--green);letter-spacing:-.06em;font:700 clamp(50px,7vw,84px) Space Grotesk}.total-score em{color:#52635f;margin-left:6px;font-style:normal}.final-payment{text-align:right;min-width:280px}.final-payment>span{color:var(--muted);margin-bottom:8px;font-size:11px;display:block}.final-payment-line{justify-content:flex-end;align-items:baseline;gap:7px;display:flex}.final-payment-line+.final-payment-line{margin-top:4px}.final-payment-line small{color:#62736f;font-size:10px}.final-payment-line strong{color:var(--green);letter-spacing:-.05em;font:700 clamp(32px,4vw,54px) Space Grotesk}.final-payment-line em{color:#52635f;font-size:12px;font-style:normal}.result-grid{grid-template-columns:minmax(0,1fr) 320px;gap:20px;margin-top:22px;display:grid}.result-main,.result-side{flex-direction:column;gap:18px;display:flex}.result-section,.stat-panel,.payment-panel{padding:24px}.result-section h2{margin:21px 0 12px;font-size:14px}.summary-pills{flex-wrap:wrap;gap:6px;margin-top:13px;display:flex}.summary-pills span{color:#376059;background:#e4eee9;border-radius:20px;padding:5px 10px;font-size:10px;font-weight:600}.result-grid-single{grid-template-columns:minmax(0,1fr)}.result-actions{grid-template-columns:repeat(3,minmax(150px,180px));justify-content:end;gap:10px;margin-top:18px;display:grid}.result-actions button{width:100%}.result-capture-error{max-width:540px;margin-left:auto}.tile-rack{flex-wrap:wrap;gap:5px;display:flex}.tile-rack>span{background:linear-gradient(145deg,#fff,#eeece1);border:1px solid #d2d5cb;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;width:48px;height:65px;display:flex;box-shadow:0 3px #c5c3b8}.tile-rack b{font-size:13px}.tile-rack small{color:#8a9691;font:600 8px Space Grotesk}.tile-rack>span.win{outline:2px solid var(--gold);transform:translateY(-4px)}.compact-rack{justify-content:center;margin-top:25px}.indicator-summary{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:22px;display:grid}.indicator-summary>div{background:#eeefe9;border-radius:8px;padding:11px}.indicator-summary span{color:var(--muted);font-size:9px;display:block}.indicator-summary strong{margin-top:4px;font-size:11px;display:block}.result-melds{flex-wrap:wrap;gap:10px;display:flex}.result-melds>div{background:#f4f2e9;border:1px solid #dddcd3;border-radius:8px;padding:9px}.result-melds strong{color:#586864;margin-bottom:6px;font-size:9px;display:block}.result-melds img{vertical-align:bottom;width:38px}.yaku-list>div,.fu-list>div{border-bottom:1px solid #e3e6e1;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.yaku-list span,.fu-list span{flex-direction:column;display:flex}.yaku-list strong,.fu-list strong{font-size:13px}.yaku-list small,.fu-list small{color:var(--muted);margin-top:2px;font-size:9px}.yaku-list b,.fu-list b{color:var(--light-green);font:700 12px Space Grotesk}.result-total-line{color:#fff;background:var(--ink);border-radius:8px;justify-content:space-between;margin-top:15px;padding:13px;font-size:12px;display:flex}.empty-copy{color:var(--muted);font-size:12px}.stat-panel>div:not(.section-kicker){background:#eeefe9;border-radius:9px;justify-content:space-between;align-items:center;margin-top:14px;padding:12px 14px;font-size:11px;display:flex}.stat-panel strong{color:var(--green);font:700 22px Space Grotesk}.payment-panel{color:#fff;background:var(--ink);border-color:var(--ink)}.payment-panel .section-kicker{color:#eab854}.payment-panel>p{color:#9bb1ac;margin:20px 0 2px;font-size:10px}.payment-panel>strong{font:700 36px Space Grotesk}.payment-panel>strong small{font-size:12px}.payment-panel dl{margin:22px 0 0}.payment-panel dl div{border-top:1px solid #34504c;justify-content:space-between;padding:8px 0;font-size:10px;display:flex}.payment-panel dt{color:#92aaa4}.payment-panel dd{margin:0}.payment-panel dl .grand{padding-top:14px;font-size:14px;font-weight:700}.full{width:100%}.result-error{text-align:center;max-width:720px;margin:35px auto;padding:55px}.result-error-icon{color:#a5303d;background:#fee2e5;border-radius:50%;place-items:center;width:64px;height:64px;margin:0 auto 20px;font:700 30px Space Grotesk;display:grid}.result-error h1{margin:12px 0}.result-error>p{color:var(--muted)}.overview-add-bar{background:#eef0eb;border-radius:9px;flex-wrap:wrap;gap:7px;margin-top:16px;padding:10px;display:flex}.meld-create-form{background:#f7f3ff;border:1px solid #cfc4ee;border-radius:10px;margin-top:10px;padding:14px}.meld-create-form>div:first-child{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.meld-create-form label{color:#64736f;flex-direction:column;gap:5px;font-size:10px;display:flex}.meld-create-form label>select,.meld-create-form label>.tile-picker-trigger{width:100%;min-height:36px}.meld-inference-preview{flex-wrap:wrap;align-items:center;gap:5px;margin-top:12px;display:flex}.meld-inference-preview>span:first-child{color:#706685;margin-right:5px;font-size:10px;font-weight:700}.meld-inference-preview .mahjong-tile-image{width:38px}.meld-selection-hint{color:#7a718a;margin:12px 0 0;font-size:10px}.meld-create-actions{justify-content:flex-end;gap:7px;margin-top:12px;display:flex}.meld-create-actions .primary-button,.meld-create-actions .ghost-button{min-height:36px}.meld-single-selector{grid-template-columns:auto 125px 1fr;align-items:center;gap:8px;margin-bottom:9px;display:grid}.meld-single-selector>span{color:#64736f;font-size:9px;font-weight:700}.meld-single-selector .tile-picker-trigger{min-height:32px}.meld-single-selector small{color:#788682;margin:0}.tile-picker-trigger,.overview-add-bar .add-meld-button{min-height:34px;color:var(--green);background:#f7fcfa;border:1px solid #c5d4ce;border-radius:7px;justify-content:center;align-items:center;gap:7px;padding:5px 11px;font-size:10px;font-weight:700;display:inline-flex}.tile-picker-trigger img{width:32px;height:auto;display:block}.overview-add-bar .add-meld-button{margin:0}.meld-tile-picker{margin-top:9px}.text-button-picker{background:0 0;border:0;padding:4px 0}.tile-row{grid-template-columns:22px 25px minmax(100px,1fr) 105px 45px 75px}.tile-row-picker{color:#53645f;background:#fff;justify-content:flex-start;min-height:48px;padding:2px 8px}.tile-row-picker img{width:31px}.add-indicator-picker{margin-top:12px}.indicator-tile{width:38px;height:auto;display:block}.indicator-tile-wrap{position:relative}.indicator-tile-wrap>button{color:#9d303b;background:#fff;border:1px solid #d8b8bb;border-radius:50%;place-items:center;width:17px;height:17px;padding:0;display:grid;position:absolute;top:-5px;right:-5px}.tile-picker-backdrop{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#081916a6;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.tile-picker-dialog{background:var(--paper);border:1px solid #bdc9c1;border-radius:18px;width:min(720px,100%);max-height:min(760px,100vh - 40px);padding:22px;overflow-y:auto;box-shadow:0 30px 80px #04141159}.tile-picker-dialog>header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.tile-picker-dialog>header div{flex-direction:column;gap:3px;display:flex}.tile-picker-dialog>header strong{font-size:18px}.tile-picker-dialog>header span{color:var(--muted);font-size:10px}.tile-picker-dialog>header button{color:#5f706c;background:#e9ece7;border:0;border-radius:50%;width:34px;height:34px;padding:0;font-size:22px}.tile-picker-group+.tile-picker-group{margin-top:15px}.tile-picker-group h3{color:#667672;margin:0 0 8px;font-size:11px}.tile-picker-group>div{grid-template-columns:repeat(10,minmax(42px,1fr));gap:7px;display:grid}.tile-picker-group button{background:0 0;border:1px solid #0000;border-radius:7px;min-width:0;padding:3px}.tile-picker-group button:hover,.tile-picker-group button:focus-visible{background:#e8f4ef;border-color:#70aa9b;outline:none}.tile-picker-group button.selected{border-color:var(--gold);background:#fff3d0;box-shadow:0 0 0 2px #e9a92e2e}.tile-picker-group img{filter:drop-shadow(0 2px 2px #142d281f);width:100%;height:auto;display:block}.theme-toggle{color:#c7d8d4;background:#183a36;border:1px solid #46615c;border-radius:16px;min-width:72px;height:32px;padding:0 10px;font-size:10px}.theme-toggle:hover{color:#fff;border-color:#7da39b}.mahjong-tile-image{aspect-ratio:3/4;background:#fffdf4;border:1px solid #d5d2c5;border-radius:5px;width:46px;display:block;position:relative;overflow:hidden;box-shadow:0 3px #c5c1b2}.mahjong-tile-image img{object-fit:contain;-webkit-user-select:none;user-select:none;position:absolute;inset:0;width:100%!important;height:100%!important}.mahjong-tile-image .tile-art-black{display:none}.visual-tile-face>.mahjong-tile-image{width:46px}.visual-tile-face:hover .mahjong-tile-image{filter:drop-shadow(0 4px 3px #142d2824);transform:translateY(-2px)}.visual-tile-face:hover .mahjong-tile-image img{filter:none;transform:none}.visual-tile.winning .visual-tile-face .mahjong-tile-image{filter:drop-shadow(0 0 3px var(--gold))}.tile-picker-trigger>.mahjong-tile-image{width:32px}.tile-picker-group .mahjong-tile-image{width:100%}.tile-rack>span{width:48px;height:auto;box-shadow:none;background:0 0;border:0}.tile-rack .mahjong-tile-image{width:48px}.result-melds .mahjong-tile-image{vertical-align:bottom;width:38px;margin-right:3px;display:inline-block}.indicator-tile{width:38px}.summary-tile-images{flex-wrap:wrap;gap:4px;margin-top:7px;display:flex}.summary-tile-images .mahjong-tile-image{width:34px}.summary-tile-images em{color:var(--muted);font-size:10px;font-style:normal}html[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#e4ece9;background:#0e1513}html[data-theme=dark] body{color:#e4ece9;background:radial-gradient(circle at 15% 5%,#192522 0,#0000 35%),#0e1513}html[data-theme=dark] .topbar{background:#091c19;border-color:#263d38}html[data-theme=dark] .stepper{background:#102724}html[data-theme=dark] .theme-toggle{color:#152825;background:#efc76f;border-color:#d5ad59}html[data-theme=dark] .panel,html[data-theme=dark] .upload-panel,html[data-theme=dark] .loading-card,html[data-theme=dark] .error-card,html[data-theme=dark] .tile-picker-dialog{color:#e4ece9;background:#17211ef7;border-color:#34433f}html[data-theme=dark] .upload-panel:before{border-color:#50605b}html[data-theme=dark] .upload-panel.dragging{background:#18302a;border-color:#62d3b4}html[data-theme=dark] .hero-copy h1,html[data-theme=dark] .page-heading h1,html[data-theme=dark] .score-hero h1,html[data-theme=dark] .result-error h1{color:#f0f5f3}html[data-theme=dark] .upload-panel p,html[data-theme=dark] .upload-panel small,html[data-theme=dark] .page-heading p,html[data-theme=dark] .panel-title-row p,html[data-theme=dark] .empty-copy{color:#9caca7}html[data-theme=dark] .region-overview-card,html[data-theme=dark] .overview-add-bar,html[data-theme=dark] .meld-create-form,html[data-theme=dark] .region-list span,html[data-theme=dark] .indicator-summary>div,html[data-theme=dark] .stat-panel>div:not(.section-kicker){background:#202b28;border-color:#394742}html[data-theme=dark] .region-overview-card>header{color:#c0ceca}html[data-theme=dark] .overview-total,html[data-theme=dark] .summary-pills span{color:#a9d8cc;background:#243d37}html[data-theme=dark] .meld-group,html[data-theme=dark] .check-grid label{background:#151f1c;border-color:#3b4945}html[data-theme=dark] .meld-group.invalid{background:#32291e;border-color:#9d7042}html[data-theme=dark] .meld-create-form{background:#241f31;border-color:#564b74}html[data-theme=dark] select,html[data-theme=dark] input[type=number],html[data-theme=dark] .draw-toggle,html[data-theme=dark] .region-tools button,html[data-theme=dark] .row-actions button,html[data-theme=dark] .tile-row-picker,html[data-theme=dark] .secondary-button{color:#dce7e3;background:#111a18;border-color:#45534f}html[data-theme=dark] .tile-picker-trigger,html[data-theme=dark] .overview-add-bar .add-meld-button{color:#7bd6bd;background:#15241f;border-color:#405c54}html[data-theme=dark] .text-button-picker{background:0 0;border:0}html[data-theme=dark] .segmented,html[data-theme=dark] .mini-segmented{background:#101816}html[data-theme=dark] .game-mode-segmented{background:#211d2d}html[data-theme=dark] .sanma-settings{background:#241f31;border-color:#51466d}html[data-theme=dark] .sanma-settings span{color:#afa4c1}html[data-theme=dark] .nuki-stepper button,html[data-theme=dark] .nuki-stepper b{color:#d7c9f3;background:#17131f;border-color:#554873}html[data-theme=dark] .segmented button,html[data-theme=dark] .mini-segmented button{color:#99aaa5}html[data-theme=dark] .segmented button.active,html[data-theme=dark] .mini-segmented button.active{color:#fff;background:#18725f}html[data-theme=dark] .tile-row{border-color:#33413d}html[data-theme=dark] .tile-row.winning{background:#3a321c}html[data-theme=dark] .development-note.supported-note{color:#a8d9cc;background:#18322b;border-color:#3f7567}html[data-theme=dark] .warning-strip{color:#efd38f;background:#332b18;border-color:#755f2d}html[data-theme=dark] .inline-error{color:#ffb6bd;background:#3b1d22}html[data-theme=dark] .score-action,html[data-theme=dark] .payment-panel{background:#091512;border-color:#263a35}html[data-theme=dark] .score-hero{border-color:#394843}html[data-theme=dark] .score-hero p{color:#adbbb7}html[data-theme=dark] .final-payment>span{color:#c8d5d1}html[data-theme=dark] .final-payment-line small{color:#d5dfdc}html[data-theme=dark] .final-payment-line strong{color:#8ff0d2;text-shadow:0 0 18px #5ae0bc2e}html[data-theme=dark] .final-payment-line em{color:#e4ece9}html[data-theme=dark] .result-melds>div{background:#202a27;border-color:#3a4844}html[data-theme=dark] .yaku-list>div,html[data-theme=dark] .fu-list>div{border-color:#34423e}html[data-theme=dark] .ghost-button{color:#b2c0bc}html[data-theme=dark] .tile-picker-dialog>header button{color:#c4d0cc;background:#2a3733}html[data-theme=dark] .tile-picker-group h3{color:#aab9b5}html[data-theme=dark] .tile-picker-group button:hover,html[data-theme=dark] .tile-picker-group button:focus-visible{background:#1b342d;border-color:#4d8f7e}html[data-theme=dark] .tile-picker-group button.selected{border-color:var(--gold);background:#3a311c}html[data-theme=dark] .mahjong-tile-image{background:#111513;border-color:#3e4642;box-shadow:0 3px #050706}html[data-theme=dark] .mahjong-tile-image .tile-art-regular{display:none}html[data-theme=dark] .mahjong-tile-image .tile-art-black{display:block}@media (width<=900px){:-webkit-any(html:fullscreen .app-shell.stage-crop>.topbar,html:fullscreen .app-shell.stage-crop>.stepper,html:-webkit-full-screen .app-shell.stage-crop>.topbar,html:-webkit-full-screen .app-shell.stage-crop>.stepper){display:none}:is(html:fullscreen .app-shell.stage-crop>.topbar,html:fullscreen .app-shell.stage-crop>.stepper,html:fullscreen .app-shell.stage-crop>.topbar,html:fullscreen .app-shell.stage-crop>.stepper){display:none}:-webkit-any(html:fullscreen .app-shell.stage-crop>main,html:-webkit-full-screen .app-shell.stage-crop>main){height:100dvh;padding:0}:is(html:fullscreen .app-shell.stage-crop>main,html:fullscreen .app-shell.stage-crop>main){height:100dvh;padding:0}.crop-workspace.mobile-fullscreen{flex-direction:column;width:100%;max-width:none;height:100dvh;padding:10px;display:flex}.crop-workspace.mobile-fullscreen .page-heading{display:none}.crop-workspace.mobile-fullscreen .crop-shell{border-radius:0;flex:1;width:100%;min-height:0;max-height:none;padding:8px}.crop-workspace.mobile-fullscreen .crop-canvas{max-height:calc(100dvh - 82px)}.crop-workspace.mobile-fullscreen .action-bar{flex:none;margin-top:8px}}@media (width<=1050px){.correction-grid{grid-template-columns:1fr}.tile-list{max-height:600px}.hero-layout{gap:40px}.result-grid{grid-template-columns:1fr 280px}.region-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=760px){.topbar{padding:0 16px}.privacy-note{display:none}.theme-toggle{min-width:62px;margin-left:auto}.step{font-size:0}.step-line{margin:0 6px}.stepper{height:55px}main{padding:25px 12px 55px}.hero-layout{grid-template-columns:1fr;min-height:0}.hero-copy h1{font-size:42px}.upload-panel{min-height:420px;padding:34px 24px}.upload-actions{flex-direction:column;width:100%}.upload-actions .primary-button,.upload-actions .secondary-button{width:100%;min-height:50px}.page-heading{display:block}.page-heading p{margin-top:12px}.action-bar{flex-wrap:wrap}.action-bar .primary-button{width:100%}.correction-grid{display:block}.form-column{margin-top:16px}.tile-row{grid-template-columns:20px 22px minmax(105px,1fr) 90px}.tile-row .confidence{display:none}.row-actions{grid-column:3/-1;justify-content:end}.check-grid{grid-template-columns:1fr 1fr}.sanma-settings{flex-direction:column;align-items:flex-start}.sanma-settings label{justify-content:space-between;width:100%}.score-action{flex-direction:column;align-items:stretch}.region-overview-grid{grid-template-columns:1fr}.meld-overview-card{grid-column:auto}.meld-group-head{grid-template-columns:1fr 72px 72px}.meld-delete{grid-column:1/-1;justify-self:start}.visual-tile-remove{opacity:1}.tile-picker-dialog{padding:15px}.tile-picker-group>div{grid-template-columns:repeat(5,minmax(42px,1fr));gap:5px}.overview-add-bar{padding:8px}.overview-add-bar .tile-picker-trigger,.overview-add-bar .add-meld-button{flex:calc(50% - 4px)}.meld-create-form>div:first-child{grid-template-columns:1fr}.meld-single-selector{grid-template-columns:1fr 1fr}.meld-single-selector small{grid-column:1/-1}.score-hero{flex-direction:column;align-items:start}.total-score,.final-payment{text-align:left;width:100%;min-width:0;margin-top:20px}.final-payment-line{justify-content:flex-start}.result-grid,.indicator-summary,.result-actions{grid-template-columns:1fr}.result-error{padding:35px 18px}}
