@font-face{font-family:Cinzel;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/cinzel-latin-ext-700-normal-C24KFjuG.woff2) format("woff2"),url(/assets/cinzel-latin-ext-700-normal-CORa-yIv.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Cinzel;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/cinzel-latin-700-normal-Dkw14w9r.woff2) format("woff2"),url(/assets/cinzel-latin-700-normal-C-gK7hA8.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Cinzel;font-style:normal;font-display:swap;font-weight:900;src:url(/assets/cinzel-latin-ext-900-normal-CWXxiu5r.woff2) format("woff2"),url(/assets/cinzel-latin-ext-900-normal-BlZZvP7K.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Cinzel;font-style:normal;font-display:swap;font-weight:900;src:url(/assets/cinzel-latin-900-normal-BI3z7Tow.woff2) format("woff2"),url(/assets/cinzel-latin-900-normal-t_fSDEbn.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}*{margin:0;padding:0;box-sizing:border-box}:root{--parchment: #efe3c4;--parchment-dark: #e2d2a8;--ink: #3a2c1a;--brass: #b08d3f;--brass-bright: #e8c56a;--navy: rgba(32, 40, 68, .92);--navy-soft: rgba(40, 49, 80, .8);--gold-text: #ffe2a8}html,body,#root{width:100%;height:100%;overflow:hidden;font-family:"Noto Serif JP",Hiragino Mincho ProN,serif;background:#121b30}@supports (height: 100dvh){html,body,#root{height:100dvh}}.app{position:relative;width:100%;height:100%}.app canvas{display:block;touch-action:none}.hud{position:absolute;inset:0;pointer-events:none;-webkit-user-select:none;user-select:none}.hud button{pointer-events:auto;cursor:pointer;border:1px solid var(--brass);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:700;font-family:inherit;background:var(--navy-soft);color:var(--gold-text);transition:background .15s,transform .1s,box-shadow .15s}@media(hover:hover){.hud button:hover:not(:disabled){background:var(--navy);box-shadow:0 0 12px #e8c56a59;transform:translateY(-1px)}}.hud button:disabled{opacity:.4;cursor:default}.hud button.danger{border-color:#a33a30;color:#ff9d8a}.home{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:34px;background:radial-gradient(ellipse at center,#080a140d 40%,#080a1466);pointer-events:auto}.home-title{text-align:center;color:var(--gold-text);text-shadow:0 2px 24px rgba(232,197,106,.45),0 2px 6px rgba(0,0,0,.8)}.home-title-en{font-family:Cinzel,serif;font-weight:900;font-size:54px;letter-spacing:.22em}.home-title-en-sub{font-family:Cinzel,serif;font-weight:700;font-size:30px;letter-spacing:.6em;margin-top:4px;text-indent:.6em}.home-subtitle{margin-top:10px;font-size:13px;letter-spacing:.2em;color:#d8caa0}.home-panel{display:flex;flex-direction:column;gap:12px;width:340px;padding:26px 28px;background:var(--navy);border:1px solid var(--brass);border-radius:14px;box-shadow:0 0 0 4px #b08d3f26,0 18px 60px #0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.menu-btn{display:flex;flex-direction:column;gap:3px;padding:14px 18px!important;font-size:16px!important;text-align:left}.menu-btn .menu-note{font-size:11px;font-weight:500;color:#d3c69c}.menu-btn.small{padding:9px 14px!important;font-size:13px!important;text-align:center}.menu-btn.ghost{background:transparent;border-color:#b08d3f66;color:#d3c69c}.home-status{text-align:center;color:var(--gold-text);font-size:15px;padding:4px 0}.home-status.error{color:#ff9d8a}.home-hint{text-align:center;color:#d3c69c;font-size:12px;line-height:1.6}.room-code{text-align:center;font-family:Cinzel,serif;font-size:44px;font-weight:900;letter-spacing:.3em;color:var(--brass-bright);text-shadow:0 0 18px rgba(232,197,106,.5)}.code-input{pointer-events:auto;font-family:Cinzel,serif;font-size:28px;font-weight:700;letter-spacing:.3em;text-align:center;padding:10px;border-radius:8px;border:1px solid var(--brass);background:#080a1499;color:var(--gold-text);outline:none}.text-input{pointer-events:auto;font-family:inherit;font-size:15px;padding:10px 14px;border-radius:8px;border:1px solid var(--brass);background:#080a1499;color:var(--parchment);outline:none}.text-input.small{font-size:13px;padding:6px 10px;flex:1}.mini-btn{font-size:12px!important;padding:5px 10px!important}.mini-btn.wide{width:100%}.profile-card{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border:1px solid rgba(176,141,63,.5);border-radius:10px;background:#080a1473;margin-bottom:4px}.profile-row{display:flex;align-items:center;gap:8px}.profile-name{font-size:17px;font-weight:700;color:var(--gold-text);flex:1}.profile-rating{font-size:13px;color:var(--parchment)}.profile-rating strong{font-family:Cinzel,serif;font-size:17px;color:var(--brass-bright)}.profile-stats{font-size:12px;color:#d3c69c}.home-panel-footer{display:flex;justify-content:space-between;gap:8px;margin-top:4px}.ranking-list{overflow-y:auto;max-height:46vh;margin-bottom:10px;border:1px solid rgba(176,141,63,.4);border-radius:8px;background:#080a1480}.ranking-list table{width:100%;border-collapse:collapse;font-size:13px;color:var(--parchment)}.ranking-list th,.ranking-list td{padding:7px 12px;text-align:left;border-bottom:1px solid rgba(176,141,63,.18)}.ranking-list th{color:var(--gold-text);font-size:12px;position:sticky;top:0;background:#0e1222f2}.ranking-list tr:nth-child(1) td:first-child{color:#ffd34d;font-weight:700}.ranking-list tr:nth-child(2) td:first-child{color:#cfd8e3;font-weight:700}.ranking-list tr:nth-child(3) td:first-child{color:#d9904a;font-weight:700}.ranking-me{font-size:13px;color:var(--gold-text);margin-bottom:14px}.rated-badge{align-self:flex-start;font-size:11px;font-weight:700;color:#1a1408;background:linear-gradient(135deg,#e8c56a,#b08d3f);border-radius:999px;padding:3px 10px}.rating-delta{font-size:16px;font-weight:700;margin:-10px 0 18px}.rating-delta.up{color:#8fe39a}.rating-delta.down{color:#ff9d8a}.home-footer{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;align-items:center;gap:16px;font-size:11px;color:#d8caa0e6}.link-btn{background:none!important;border:none!important;padding:0!important;font-size:11px!important;color:#e8c56ad9!important;text-decoration:underline;cursor:pointer}.corner-menu-btn{position:absolute;top:max(14px,env(safe-area-inset-top));right:max(14px,env(safe-area-inset-right));font-size:20px!important;line-height:1;padding:6px 14px!important}.corner-menu-backdrop{position:absolute;inset:0;z-index:9}.corner-menu{position:absolute;top:calc(max(14px,env(safe-area-inset-top)) + 46px);right:max(14px,env(safe-area-inset-right));display:flex;flex-direction:column;min-width:210px;background:var(--navy);border:1px solid var(--brass);border-radius:12px;overflow:hidden;box-shadow:0 12px 40px #0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.corner-menu button{border:none!important;border-radius:0!important;background:transparent;text-align:left;padding:13px 18px!important;font-size:14px!important;border-bottom:1px solid rgba(176,141,63,.25)!important}.corner-menu button:last-child{border-bottom:none!important}.dialog.profile{min-width:min(340px,calc(100vw - 24px))}.dialog.profile .profile-card{text-align:left;margin-bottom:16px}.dialog.legal{max-width:640px;width:calc(100% - 80px);max-height:80vh;display:flex;flex-direction:column}.legal-text{flex:1;overflow-y:auto;text-align:left;white-space:pre-wrap;font-family:inherit;font-size:12px;line-height:1.8;color:var(--parchment);background:#080a1480;border:1px solid rgba(176,141,63,.4);border-radius:8px;padding:14px 16px;margin-bottom:16px;max-height:56vh}.title{position:absolute;top:14px;left:18px;font-size:17px;font-weight:700;color:var(--gold-text);text-shadow:0 2px 8px rgba(0,0,0,.6);letter-spacing:.18em}.turn-badge{position:absolute;top:14px;left:50%;transform:translate(-50%);display:flex;gap:10px;align-items:center;background:var(--navy);border:1px solid var(--brass);border-radius:999px;padding:8px 20px;font-size:15px;font-weight:700;color:#efe3c4;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.turn-badge .sente{color:#9fdcff}.turn-badge .gote{color:#ff9d8a}.check-label{color:#ff4438;animation:pulse .8s infinite}@keyframes pulse{50%{opacity:.35}}.clock-panel{position:absolute;top:60px;left:14px;display:flex;flex-direction:column;gap:8px}.clock{display:flex;justify-content:space-between;gap:14px;width:168px;padding:8px 14px;background:var(--navy-soft);border:1px solid rgba(176,141,63,.4);border-radius:10px;color:#d8caa0;font-size:14px}.clock.active{border-color:var(--brass-bright);color:var(--gold-text);box-shadow:0 0 14px #e8c56a4d}.clock-time{font-family:Cinzel,serif;font-weight:700}.kifu-panel{position:absolute;top:60px;right:14px;width:196px;max-height:calc(100% - 150px);display:flex;flex-direction:column;background:var(--navy);border:1px solid var(--brass);border-radius:12px;padding:12px;color:var(--parchment);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto}.kifu-toggle{display:none}.kifu-title{font-size:13px;font-weight:700;margin-bottom:6px;color:var(--gold-text);letter-spacing:.2em}.kifu-list{flex:1;overflow-y:auto;list-style:none;font-size:13px;line-height:1.7;min-height:60px;max-height:38vh}.kifu-list li{white-space:nowrap}.kifu-empty{opacity:.5}.kifu-buttons{display:flex;gap:8px;margin-top:10px}.kifu-buttons button{flex:1;padding:8px 4px}.toggles{position:absolute;bottom:16px;left:16px;display:flex;gap:8px}.toggles button.on{background:#b08d3f8c;color:#fff3d6}.home-btn{position:absolute;top:56px;left:18px}.home-btn-confirm{position:absolute;top:56px;left:18px;display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--navy);border:1px solid var(--brass);border-radius:10px;color:var(--parchment);font-size:13px;pointer-events:auto}.clock-panel+.home-btn,.home-btn{top:auto;bottom:64px}.stamp-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:6px}.stamp-bar button{font-size:12px;padding:7px 10px}.stamp-bubbles{position:absolute;top:110px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:6px;align-items:center}.stamp-bubble{padding:8px 16px;border-radius:999px;font-size:14px;font-weight:700;animation:bubble 4s forwards;border:1px solid var(--brass);background:var(--navy)}.stamp-bubble.mine{color:#9fdcff}.stamp-bubble.theirs{color:#ffd98a}@keyframes bubble{0%{opacity:0;transform:translateY(8px)}8%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.disconnect-banner{position:absolute;top:64px;left:50%;transform:translate(-50%);padding:10px 22px;background:#78241ee0;border:1px solid #ff6a5f;border-radius:10px;color:#ffe2dd;font-size:14px;font-weight:700}.overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#06081073;pointer-events:auto}.dialog{background:var(--navy);border:1px solid var(--brass);border-radius:16px;padding:28px 36px;color:var(--parchment);text-align:center;box-shadow:0 0 0 4px #b08d3f26,0 12px 48px #0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dialog-title{font-size:18px;font-weight:700;margin-bottom:18px}.dialog-buttons{display:flex;gap:10px;justify-content:center}.dialog button{padding:10px 22px;font-size:14px}.dialog button.primary{background:#b08d3fb3;color:#fff3d6}.dialog button.ghost{background:transparent;border-color:#b08d3f66;color:#d3c69c}.result-sub{font-size:14px;opacity:.7;margin-bottom:6px}.result-main{font-size:30px;font-weight:800;margin-bottom:22px}.result-main.sente{color:#9fdcff}.result-main.gote{color:#ff9d8a}.hand-count{background:var(--navy);border:1px solid var(--brass);color:var(--gold-text);font-size:13px;font-weight:700;padding:2px 7px;border-radius:999px;white-space:nowrap}@media(max-width:700px){.home{gap:20px;padding:16px}.home-title-en{font-size:34px;letter-spacing:.16em}.home-title-ja{font-size:19px;letter-spacing:.4em}.home-subtitle{font-size:11px}.home-panel{width:min(340px,100%);padding:18px 16px;max-height:min(64vh,64dvh);overflow-y:auto}.room-code{font-size:34px}.text-input{font-size:16px}.code-input{font-size:24px}.home-footer{flex-wrap:wrap;gap:4px 12px;padding:0 12px;font-size:10px;bottom:max(8px,env(safe-area-inset-bottom))}.dialog{padding:20px 18px;max-width:calc(100vw - 24px)}.dialog.legal{width:calc(100% - 24px);max-height:86vh}.dialog-buttons{flex-wrap:wrap}.ranking-list th,.ranking-list td{padding:6px 8px}.title{display:none}.turn-badge{top:max(10px,env(safe-area-inset-top));width:max-content;max-width:calc(100vw - 16px);padding:6px 14px;font-size:12px;white-space:nowrap}.clock-panel{top:calc(max(10px,env(safe-area-inset-top)) + 44px);left:max(8px,env(safe-area-inset-left));gap:6px}.clock{width:138px;padding:5px 10px;gap:8px;font-size:12px}.rated-badge{font-size:10px}.kifu-toggle{display:block;position:absolute;top:calc(max(10px,env(safe-area-inset-top)) + 44px);right:max(8px,env(safe-area-inset-right))}.kifu-toggle.on{background:#b08d3f8c;color:#fff3d6}.kifu-panel{display:none}.kifu-panel.open{display:flex;top:calc(max(10px,env(safe-area-inset-top)) + 88px);right:max(8px,env(safe-area-inset-right));width:min(58vw,200px);max-height:46vh}.kifu-list{max-height:28vh;font-size:12px}.stamp-bar{left:0;right:0;transform:none;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:4px 10px;bottom:calc(max(10px,env(safe-area-inset-bottom)) + 44px);scrollbar-width:none}.stamp-bar::-webkit-scrollbar{display:none}.stamp-bar button{white-space:nowrap;flex-shrink:0}.toggles{left:max(8px,env(safe-area-inset-left));bottom:max(10px,env(safe-area-inset-bottom));gap:6px}.toggles button{font-size:11px;padding:7px 9px}.clock-panel+.home-btn,.home-btn{top:auto;left:auto;right:max(8px,env(safe-area-inset-right));bottom:max(10px,env(safe-area-inset-bottom))}.home-btn-confirm{top:auto;bottom:calc(max(10px,env(safe-area-inset-bottom)) + 44px);left:50%;transform:translate(-50%);width:max-content;max-width:calc(100vw - 16px);flex-wrap:wrap;justify-content:center}.stamp-bubbles{top:calc(max(10px,env(safe-area-inset-top)) + 44px);width:max-content;max-width:70vw}.stamp-bubble{font-size:12px;padding:6px 12px}.disconnect-banner{top:calc(max(10px,env(safe-area-inset-top)) + 44px);width:calc(100vw - 24px);font-size:12px;text-align:center;padding:8px 12px}}@media(pointer:coarse){.hud button{min-height:38px}.link-btn{min-height:0!important}}
