:root{--tile-w:50px;--tile-h:66px;--tile-sm-w:36px;--tile-sm-h:48px;--tile-symbol:1.4em;--tile-sm-symbol:1em;--gap-hand:2px;--gap-actions:12px;--btn-padding:10px 24px;--btn-primary-padding:14px 32px;--banner-font:2.5rem}.app{color:#e8e8e8;background:radial-gradient(at 20%,#1e5a3266 0%,#0000 60%),radial-gradient(at 80%,#1446284d 0%,#0000 60%),repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px),repeating-linear-gradient(90deg,#0000,#0000 2px,#00000005 2px 4px),linear-gradient(135deg,#1a5c2e 0%,#14472a 40%,#0f3a22 100%);flex-direction:column;max-width:800px;min-height:100dvh;margin:0 auto;padding:8px;font-family:"M PLUS Rounded 1c",Segoe UI,sans-serif;display:flex;overflow-x:hidden}.app__header{text-align:center;border-bottom:1px solid #2a6a3a;padding:8px 0}.app__header h1{color:#90ee90;margin:0;font-size:1.4rem}.logo{vertical-align:middle;align-items:center;gap:6px;display:inline-flex}.logo--large{gap:10px}.logo__icon{filter:drop-shadow(0 2px 4px #0000004d);flex-shrink:0}.logo__text{color:#e8dcc8;text-shadow:0 1px 2px #00000080,0 0 20px #4caf504d;letter-spacing:.08em;font-weight:700}.logo--large .logo__text{background:linear-gradient(#f5e6c8 0%,#d4a853 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 4px #00000080);-webkit-background-clip:text;background-clip:text}.header__content{justify-content:space-between;align-items:center;display:flex}.header__logo{text-decoration:none}.header__nav{align-items:center;gap:12px;font-size:.85rem;display:flex}.header__user{color:gold}.header__link{color:#90ee90;text-decoration:none}.header__link:hover{text-decoration:underline}.header__btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #555;border-radius:4px;padding:4px 10px;font-size:.85rem}.header__btn:hover{background:#333}.lobby{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;display:flex}.lobby__hero{margin-bottom:12px;animation:.6s ease-out fade-in}@keyframes fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.lobby p{color:#aaa;font-size:1.1rem}.lobby__spinner{border:3px solid #333;border-top-color:#90ee90;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-form{background:#0d2818;border-radius:12px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:320px;padding:20px;display:flex}.login-form h3{color:#90ee90;margin:0}.login-form__input{color:#e0e0e0;box-sizing:border-box;background:#1a472a;border:1px solid #333;border-radius:8px;width:100%;padding:10px 12px;font-size:1rem}.login-form__input:focus{border-color:#4caf50;outline:none}.login-form__error{color:#ff6b6b;margin:0;font-size:.9rem}.login-form__link{color:#90ee90;font-size:.9rem}.top-page__links{align-items:center;gap:16px;display:flex}.top-page__links a{color:#90ee90}.mypage-stats{background:#0d2818;border-radius:12px;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto;padding:20px;display:flex}.mypage-stats__item{justify-content:space-between;display:flex}.mypage-stats__label{color:#888}.mypage-stats__value{color:gold;font-weight:700}.mypage-stats__value--positive{color:#4caf50}.mypage-stats__value--negative{color:#f44336}.mypage-rating-history{background:#0d2818;border-radius:12px;flex-direction:column;gap:8px;width:100%;max-width:320px;padding:16px;display:flex}.mypage-rating-history--empty,.mypage-rating-history--error{text-align:center;color:#888;font-size:14px}.mypage-rating-history--error{color:#e57373}.mypage-rating-history__title{color:#888;margin:0;font-size:14px;font-weight:500}.rating-chart{flex-direction:column;gap:8px;display:flex}.rating-chart__svg{width:100%;height:auto;display:block}.rating-chart__line{fill:none;stroke:gold;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.rating-chart__area{fill:#ffd7001f;stroke:none}.rating-chart__dot{fill:gold;stroke:#0d2818;stroke-width:2px}.rating-chart__legend{justify-content:space-between;gap:8px;font-size:12px;display:flex}.rating-chart__legend-item{flex-direction:column;align-items:center;gap:2px;display:flex}.rating-chart__legend-label{color:#888}.rating-chart__legend-value{color:#e0e0e0;font-weight:600}.rating-chart__legend-item--diff.is-up .rating-chart__legend-value{color:#66bb6a}.rating-chart__legend-item--diff.is-down .rating-chart__legend-value{color:#e57373}.mypage-badges{background:#00000040;border:1px solid #ffd70026;border-radius:12px;width:100%;max-width:360px;margin:16px auto 0;padding:14px 12px}.legal-page>.mypage-stats,.legal-page>.mypage-badges,.legal-page>.mypage-rating-history,.legal-page>.mypage-match-history,.legal-page>.mypage__section{margin-top:20px;margin-bottom:8px}.legal-page>h1+.mypage-stats{margin-top:12px}.mypage-rating-history,.mypage-match-history,.mypage__section{box-sizing:border-box;background:#00000040;border:1px solid #ffd70026;border-radius:12px;width:100%;max-width:560px;margin:20px auto 8px;padding:14px 16px}.mypage-rating-history--empty,.mypage-match-history--empty{color:#ffffff8c;text-align:center;padding:12px;font-size:.85rem}.mypage-rating-history__title,.mypage-match-history__title,.mypage__section h3{color:gold;letter-spacing:.05em;text-align:center;margin:0 0 10px;font-size:.95rem;font-weight:600}.legal-page>.action-btn,.legal-page>.mypage-premium-badge{justify-content:center;width:100%;max-width:360px;margin:12px auto 0;display:flex}.mypage__section input[type=text],.mypage__section input[type=email]{flex:200px;min-width:160px}.mypage__section .action-btn{white-space:nowrap}.mypage-badges__title{color:gold;text-align:center;letter-spacing:.1em;margin:0 0 10px;font-size:14px;font-weight:600}.badge-list__summary{color:#ffffffb3;text-align:center;margin-bottom:8px;font-size:11px}.badge-list__grid{grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:8px;display:grid}.badge-list--empty{color:#fff9;text-align:center;padding:12px 0;font-size:13px}.badge{text-align:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;justify-content:flex-start;align-items:center;min-height:80px;padding:6px 4px;transition:transform .12s;display:flex}.badge.is-locked{opacity:.28;filter:grayscale(.7)}.badge.is-unlocked{background:#ffd7000d;border-color:#ffd70059}.badge.is-unlocked.badge--bronze{background:#cd7f3214;border-color:#cd7f328c}.badge.is-unlocked.badge--silver{background:#c0c0c014;border-color:#c0c0c08c}.badge.is-unlocked.badge--gold{background:#ffd7001f;border-color:#ffd700a6}.badge.is-unlocked.badge--platinum{background:linear-gradient(135deg,#ffffff1a,#c8c8ff1a);border-color:#e5e4e2b3;box-shadow:0 0 8px #ffffff26}.badge__icon{margin-bottom:4px;font-size:22px;line-height:1}.badge__label{color:#fff;font-size:11px;font-weight:600;line-height:1.2}.badge__desc{color:#ffffff8c;margin-top:2px;font-size:9px;line-height:1.2}.mypage-match-history{background:#00000040;border:1px solid #ffd70026;border-radius:12px;width:100%;max-width:360px;margin:16px auto 0;padding:14px 12px}.mypage-match-history__title{color:gold;text-align:center;letter-spacing:.1em;margin:0 0 10px;font-size:14px;font-weight:600}.mypage-match-history__error{color:#e57373;text-align:center;padding:8px;font-size:13px}.match-history--empty{color:#fff9;text-align:center;padding:12px 0;font-size:13px}.match-history__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.match-history__item{background:#ffffff08;border-left:3px solid #fff3;border-radius:8px;padding:8px 10px}.match-history__item.is-win{border-left-color:#66bb6a}.match-history__item.is-loss{border-left-color:#e57373}.match-history__row{color:#fff;align-items:center;gap:8px;font-size:13px;display:flex}.match-history__row--sub{color:#fff9;margin-top:2px;font-size:11px}.match-history__result{border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;display:inline-flex}.match-history__result.is-win{color:#000;background:#66bb6a}.match-history__result.is-loss{color:#000;background:#e57373}.match-history__vs{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.match-history__reason{color:#ffffffbf;font-size:12px}.match-history__scores{flex-shrink:0}.match-history__diff{text-align:right;flex:1}.match-history__diff.is-up{color:#66bb6a}.match-history__diff.is-down{color:#e57373}.match-history__date{color:#fff6;flex-shrink:0;font-size:10px}.match-history__yaku{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.match-history__han{color:gold;font-size:11px;font-weight:600}.match-history__yaku-tag{color:gold;background:#ffd7001f;border-radius:3px;padding:1px 6px;font-size:10px}.game-board{flex-direction:column;flex:1;justify-content:space-between;gap:8px;width:100%;padding:8px 4px;display:flex}.game-board__opponent{flex-direction:column;gap:4px;display:flex}.game-board__me{flex-direction:column;gap:4px;margin-top:auto;display:flex}.score-tag{background:linear-gradient(#0a1e14d9 0%,#05140cf2 100%);border:1px solid #ffd70033;border-radius:8px;align-items:center;gap:8px;padding:6px 14px;display:inline-flex;box-shadow:0 2px 8px #0000004d}.score-tag__label{color:#b0b8a0;text-shadow:0 1px 2px #00000080;font-size:.75rem}.score-tag__value{color:gold;text-shadow:0 0 8px #ffd7004d;font-size:1.1rem;font-weight:700}.score-tag__riichi-badge{color:#fff;background:#f44;border-radius:3px;margin-left:4px;padding:1px 5px;font-size:.7rem}.score-tag__rating{color:gold;font-variant-numeric:tabular-nums;background:#ffd7001a;border-radius:3px;margin-left:4px;padding:0 4px;font-size:.75rem;font-weight:700}.game-board__opponent .score-tag,.game-board__me .score-tag{align-self:flex-start}.score-display{background:#0d2818;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.score-display__opponent,.score-display__me{flex-direction:column;gap:2px;display:flex}.score-display__label{color:#888;font-size:.75rem}.score-display__value{color:gold;font-size:1.2rem;font-weight:700}.score-display__separator{background:#333;width:1px;height:30px}.score-display__riichi-badge{color:#fff;background:#f44;border-radius:4px;margin-left:4px;padding:2px 8px;font-size:.8rem;font-weight:700;animation:1.5s infinite riichi-pulse}@keyframes riichi-pulse{0%,to{opacity:1}50%{opacity:.6}}.tile{flex-direction:column;flex:0 1 var(--tile-w);min-width:0;max-width:var(--tile-w);height:var(--tile-h);touch-action:manipulation;cursor:pointer;background:linear-gradient(#fffef5 0%,#f0ead8 60%,#e0d8c0 100%);border-top:1px solid #b8a88a;border-bottom:3px solid #8a7a60;border-left:1px solid #b8a88a;border-right:2px solid #a09070;border-radius:5px;justify-content:center;align-items:center;padding:2px;font-family:inherit;transition:transform .15s,box-shadow .15s;display:inline-flex;position:relative;box-shadow:0 2px 4px #0000004d,inset 0 1px #ffffff1a,inset 0 -1px 2px #0000001a}.tile:hover:not(:disabled){transform:translateY(-8px);box-shadow:0 8px 16px #0006,inset 0 1px #ffffff1a}.tile--selected{border-color:#4caf50;transform:translateY(-10px);box-shadow:0 8px 20px #4caf5066,0 0 8px #4caf504d}.tile--drawn{margin-left:12px}.tile--disabled{cursor:default;opacity:.85}.tile--disabled:hover{transform:none;box-shadow:0 2px 4px #0000004d,inset 0 1px #ffffff1a}.tile--small{flex:0 1 var(--tile-sm-w);max-width:var(--tile-sm-w);height:var(--tile-sm-h);border-bottom-width:2px;border-right-width:1px;font-size:.8em;box-shadow:0 1px 3px #0000004d}.tile--facedown{cursor:default;background:linear-gradient(#e8d88c 0%,#d8c870 60%,#c4b060 100%);border-color:#b8a050 #b8a050 #a09040;box-shadow:0 2px 4px #0000004d,inset 0 1px #fff3}.tile__svg{margin:auto;display:block}.tile__img{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.tile__symbol{font-size:var(--tile-symbol);line-height:1}.tile--small .tile__symbol{font-size:var(--tile-sm-symbol)}.tile__number{color:#333;font-size:.7rem;font-weight:700}.hand{--hand-avail-w:calc(100vw - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px) - 40px);--hand-fit-tile-w:calc((var(--hand-avail-w) - 50px) / 14);--tile-w:clamp(20px, var(--hand-fit-tile-w), 50px);--tile-h:calc(var(--tile-w) * 1.35);--tile-symbol:calc(var(--tile-w) / 38 * 1em);--hand-gap:calc(var(--tile-w) / 2);gap:var(--hand-gap);box-sizing:border-box;flex-wrap:nowrap;justify-content:center;align-items:flex-end;max-width:100%;padding:8px 4px;display:flex;overflow:hidden}.hand__main{gap:var(--gap-hand);width:calc(13 * var(--tile-w) + 12 * var(--gap-hand));flex-wrap:nowrap;flex:none;justify-content:flex-end;display:flex}.hand__drawn-slot{width:var(--tile-w);height:var(--tile-h);flex:none;justify-content:center;align-items:center;display:flex}.hand__drawn-slot .tile--drawn{margin-left:0}@media (width<=600px){.hand{padding:6px 2px}}@media (width<=480px){.hand{padding:4px 2px}}@media (width<=380px){.hand{padding:3px 2px}}.hand--opponent{gap:var(--gap-hand)}.hand--riichi-locked{outline-offset:-2px;border-radius:8px;outline:2px solid #f44}.game-board__center{flex-direction:column;flex:1;justify-content:center;gap:4px;min-height:80px;padding:6px 8px;display:flex}.discards{padding:2px 0}.discards__tiles{width:calc(5 * var(--tile-sm-w) + 8px);box-sizing:border-box;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:2px;max-width:100%;min-height:28px;margin:0 auto;display:flex}.discards--reverse .discards__tiles{flex-direction:row-reverse}.ankans{gap:8px;padding:4px 8px;display:flex}.ankan-group{gap:1px;display:flex}.game-info{text-shadow:0 1px 2px #00000080;background:linear-gradient(#0a1e14b3 0%,#05140cd9 100%);border:1px solid #64a06426;border-radius:8px;justify-content:space-between;align-items:center;padding:6px 12px;font-size:.9rem;display:flex}.game-info__wall,.game-info__turn{color:#888}.game-info__turn--active{color:#90ee90;font-weight:700}.game-board__hand-area{position:relative}.game-board__hand-area .action-buttons{z-index:10;position:absolute;top:-4px;right:4px;transform:translateY(-100%)}.action-buttons{flex-direction:column;align-items:stretch;gap:6px;padding:4px;display:flex}.action-buttons__row{grid-template-columns:1fr 1fr;gap:6px;display:grid}.action-buttons .action-btn{width:100%;min-width:0;min-height:40px;padding:8px 10px;font-size:.9rem}.action-buttons .action-btn--draw,.action-buttons .action-btn--win,.action-buttons .action-btn--tsumo,.action-buttons .action-btn--ron,.action-buttons .action-btn--ankan,.action-buttons .action-btn--riichi{min-height:40px;padding:8px 10px;font-size:.9rem}.ron-banner{color:#ff80ab;background:#e91e6333;border:1px solid #e91e63;border-radius:6px;padding:4px 12px;font-size:.85rem;font-weight:700;animation:1.5s ease-in-out infinite pulse-glow}.action-btn{padding:var(--btn-padding);cursor:pointer;color:#fff;text-shadow:0 1px 2px #0000004d;background:linear-gradient(#555 0%,#3a3a3a 100%);border:none;border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;font-size:1rem;font-weight:700;text-decoration:none;transition:background .2s,transform .1s,box-shadow .2s;display:inline-flex;box-shadow:0 2px 4px #0000004d}a.action-btn,a.action-btn:hover,a.action-btn:visited,a.action-btn:focus{color:#fff;text-decoration:none}.action-btn:hover{filter:brightness(1.15);transform:translateY(-1px);box-shadow:0 4px 8px #0006}.action-btn--primary{background:linear-gradient(180deg, var(--btn-primary-bg-top) 0%, var(--btn-primary-bg-bottom) 100%);color:var(--btn-primary-fg,#fff);padding:var(--btn-primary-padding);font-size:1.2rem;box-shadow:0 3px 6px #0000004d}body,body.theme-green{--btn-primary-bg-top:#5cbf60;--btn-primary-bg-bottom:#43a047;--btn-primary-fg:#fff}body.theme-dark{--btn-primary-bg-top:#64b5f6;--btn-primary-bg-bottom:#1976d2;--btn-primary-fg:#fff}body.theme-light{--btn-primary-bg-top:#66bb6a;--btn-primary-bg-bottom:#2e7d32;--btn-primary-fg:#fff}.action-btn--share{background:#1da1f2}.action-btn--invite{border:1.5px solid var(--app-accent);color:var(--app-fg);text-shadow:none;box-shadow:none;background:0 0;font-weight:600}.action-btn--invite:hover:not(:disabled){background:color-mix(in srgb, var(--app-accent) 12%, transparent);filter:none;box-shadow:0 0 0 3px color-mix(in srgb, var(--app-accent) 18%, transparent);transform:none}.action-btn--secondary{background:linear-gradient(180deg, var(--btn-secondary-bg-top) 0%, var(--btn-secondary-bg-bottom) 100%)}body,body.theme-green{--btn-secondary-bg-top:#26a69a;--btn-secondary-bg-bottom:#00796b}body.theme-dark{--btn-secondary-bg-top:#9575cd;--btn-secondary-bg-bottom:#5e35b1}body.theme-light{--btn-secondary-bg-top:#26a69a;--btn-secondary-bg-bottom:#00695c}.lobby>.action-btn,.lobby>.invite-panel>.action-btn{width:240px;max-width:100%}.lobby>.action-btn--primary{padding:var(--btn-padding);font-size:1rem}.invite-code{text-align:center;margin:16px 0}.invite-code__label{color:#aaa;margin-bottom:4px;font-size:.9rem}.invite-code__value{letter-spacing:.3em;color:#90ee90;font-family:monospace;font-size:2.5rem;font-weight:700}.invite-panel{flex-direction:column;align-items:center;gap:6px;display:flex}.invite-panel__row{align-items:center;gap:6px;display:flex}.invite-panel__input{text-align:center;letter-spacing:.2em;color:#e0e0e0;text-transform:uppercase;background:#2a4a2a;border:2px solid #4caf50;border-radius:8px;width:5em;padding:6px 8px;font-family:monospace;font-size:1.1rem}.invite-panel__join{min-height:38px;padding:6px 16px!important;font-size:.9rem!important}.invite-panel__close{min-width:38px;min-height:38px;padding:6px 10px!important;font-size:1rem!important}.invite-panel__error{color:#ff6b6b;margin:0;font-size:.85rem}.action-btn--tsumo,.action-btn--ron,.action-btn--win{background:linear-gradient(#e91e63 0%,#c2185b 100%);min-height:36px;padding:6px 14px;font-size:.85rem}.action-btn--riichi{background:linear-gradient(#2196f3 0%,#1976d2 100%);min-height:36px;padding:6px 14px;font-size:.85rem}.action-btn--ankan{background:linear-gradient(#ff9800 0%,#f57c00 100%);min-height:36px;padding:6px 14px;font-size:.85rem}.action-btn--draw{background:linear-gradient(#2196f3,#1565c0);width:100%;min-height:36px;padding:6px 14px;font-size:.85rem}.action-btn:disabled,.action-btn[disabled]{pointer-events:none;opacity:.4!important;cursor:not-allowed!important;color:#888!important;box-shadow:none!important;text-shadow:none!important;background:linear-gradient(#444 0%,#333 100%)!important;border-color:#0000!important;transform:none!important}.action-btn:disabled:hover,.action-btn[disabled]:hover{filter:none;box-shadow:none;transform:none}.action-btn--ready{animation:1.5s ease-in-out infinite pulse-glow;box-shadow:0 0 12px #e91e6380}.round-result{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;padding:20px;display:flex}.round-result__banner{font-size:var(--banner-font);border-radius:12px;padding:12px 40px;font-weight:700}.round-result__banner--win{color:gold;background:#ffd7001a;border:2px solid gold}.round-result__banner--lose{color:#ff6b6b;background:#ff6b6b1a;border:2px solid #ff6b6b}.round-result__banner--draw{color:#aaa;background:#8080801a;border:2px solid #555}.round-result__yaku{text-align:center}.round-result__yaku h3{color:#ff80ab;margin:0 0 8px}.round-result__yaku ul{margin:0;padding:0;list-style:none}.round-result__yaku li{padding:4px 0}.round-result__score{margin-top:8px;font-size:1.3rem;font-weight:700}.round-result__score--win{color:gold}.round-result__score--lose{color:#ff6b6b}.round-result__scores{gap:24px;font-size:1.1rem;display:flex}.round-result__chombo{text-align:center}.round-result__chombo-label{color:#ff6b6b;margin-bottom:4px;font-size:1.1rem;font-weight:700}.round-result__board{background:#0a1e1499;border:1px solid #64a06433;border-radius:8px;flex-direction:column;gap:4px;width:100%;max-width:600px;padding:12px;display:flex}.round-result__hand-row{flex-direction:column;gap:2px;display:flex}.round-result__section-label{color:#888;font-size:.7rem}.round-result__hand{gap:calc(var(--tile-sm-w) / 2);flex-wrap:nowrap;justify-content:center;align-items:flex-end;width:100%;min-width:0;max-width:100%;display:flex}.round-result__hand-main{width:calc(13 * var(--tile-sm-w) + 12px);flex:0 auto;justify-content:flex-start;gap:1px;min-width:0;max-width:100%;display:flex}.round-result__hand-main .tile{min-width:0;max-width:var(--tile-sm-w);aspect-ratio:3/4;flex:1 1 0;height:auto}.round-result__hand-drawn{width:var(--tile-sm-w);aspect-ratio:3/4;flex:0 auto;justify-content:center;align-items:center;min-width:0;height:auto;display:flex}.round-result__hand-drawn .tile{max-width:var(--tile-sm-w);aspect-ratio:3/4;min-width:0;height:auto}.round-result__hand-drawn .tile--drawn{margin-left:0}.round-result__wall{color:#aaa;text-shadow:0 1px 2px #00000080;background:linear-gradient(#0a1e14b3 0%,#05140cd9 100%);border:1px solid #64a06426;border-radius:8px;justify-content:center;align-items:center;gap:6px;margin:6px 0;padding:4px 12px;font-size:.85rem;display:flex}.round-result__wall-label{color:#888}.round-result__wall-value{color:#fff;font-variant-numeric:tabular-nums;font-weight:700}.round-result__wall-unit{color:#888}.round-result__waiting{color:#aaa;padding:12px;font-style:italic}.game-result{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;padding:20px;display:flex}.game-result__banner{font-size:var(--banner-font);border-radius:12px;padding:12px 40px;font-weight:700}.game-result__practice-badge{color:#7fa98a;letter-spacing:.02em;background:#7fa98a1f;border:1px solid #7fa98a59;border-radius:999px;padding:4px 12px;font-size:.85rem;font-weight:600}.game-result__banner--win{color:gold;background:#ffd7001a;border:2px solid gold}.game-result__banner--lose{color:#888;background:#8080801a;border:2px solid #555}.game-result__reason{color:#aaa;font-style:italic}.game-result__yaku{text-align:center}.game-result__yaku h3{color:#ff80ab;margin:0 0 8px}.game-result__yaku ul{margin:0;padding:0;list-style:none}.game-result__yaku li{padding:4px 0}.game-result__score{color:gold;margin-top:8px;font-size:1.3rem;font-weight:700}.game-result__final-scores{gap:24px;font-size:1.1rem;display:flex}.game-result__rating{color:#e0e0e0;font-size:1rem}.game-result__rating--up{color:#4caf50;font-weight:700}.game-result__rating--down{color:#ff6b6b;font-weight:700}.game-result__actions{gap:12px;display:flex}.game-result__back{justify-content:center;width:100%;margin-top:16px;display:flex}.game-result__back .action-btn{min-width:220px}.connection-status{text-align:center;z-index:200;padding:8px;font-size:.85rem;font-weight:700;animation:.2s ease-out connection-status-slide-in;position:fixed;top:0;left:0;right:0}@keyframes connection-status-slide-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.ranking-table{border-collapse:collapse;width:100%;max-width:500px;font-size:.9rem}.ranking-table th,.ranking-table td{text-align:center;border-bottom:1px solid #333;padding:8px 12px}.ranking-table th{color:#90ee90;font-size:.8rem}.ranking-table td:first-child{color:gold;font-weight:700}.ranking-table td:nth-child(2){text-align:left}.ranking-pagination{align-items:center;gap:16px;margin-top:12px;display:flex}.connection-status--reconnecting{color:#000;background:#ff9800}.connection-status--disconnected{color:#fff;background:#f44336}@media (width<=480px){:root{--tile-w:32px;--tile-h:43px;--tile-sm-w:28px;--tile-sm-h:38px;--tile-symbol:1.2em;--tile-sm-symbol:.85em;--gap-hand:1px;--gap-actions:8px;--btn-padding:10px 16px;--btn-primary-padding:12px 24px;--banner-font:1.8rem}.game-board{gap:4px;padding:4px}.game-info{padding:4px 8px;font-size:.8rem}.discards__tiles{min-height:30px}.round-result__scores,.game-result__final-scores{flex-direction:column;gap:8px}.score-display{padding:4px 8px;font-size:.8rem}}@media (width<=480px) and (orientation:portrait){:root{--tile-w:26px;--tile-h:38px;--tile-sm-w:28px;--tile-sm-h:38px;--gap-hand:1px;--gap-actions:4px;--btn-padding:8px 14px;--btn-primary-padding:10px 18px;--banner-font:1.4rem}.app{min-height:100dvh;max-height:100dvh;padding:2px;overflow:hidden}.app__header{padding:1px 0}.app__header h1{font-size:.9rem}.game-board{gap:4px;padding:2px}.game-board__opponent{gap:2px}.game-board__center{min-height:140px;padding:8px 4px}.game-board__center-info{font-size:.7rem}.game-board__me{gap:4px;margin-top:0}.game-info{padding:4px 8px;font-size:.75rem}.hand{padding:4px 1px}.discards__tiles{gap:2px;min-height:36px;padding:4px 0}.action-buttons{gap:3px;margin-top:2px}.game-board .action-btn,.action-buttons .action-btn{padding:6px 10px;font-size:.75rem}.score-tag{padding:2px 6px;font-size:.65rem}.score-tag__value{font-size:.8rem}}@media (height<=500px) and (orientation:landscape){:root{--gap-hand:1px;--gap-actions:4px;--btn-padding:4px 10px;--btn-primary-padding:6px 16px;--banner-font:1.2rem}.app{padding:2px;padding-left:max(2px, env(safe-area-inset-left));padding-right:max(2px, env(safe-area-inset-right))}.app__header{padding:1px 0}.app__header h1{font-size:.9rem}.game-board{gap:1px;padding:1px 2px}.game-board__opponent,.game-board__me{gap:1px}.game-info{padding:1px 6px;font-size:.7rem}.hand{padding:2px 1px}.discards__tiles{gap:1px;min-height:20px}.action-buttons{gap:4px;margin-top:0}.tile__number{font-size:.6rem}.score-tag{padding:2px 8px;font-size:.7rem}.score-tag__value{font-size:.9rem}}@media (width>=481px) and (width<=768px){:root{--tile-w:38px;--tile-h:50px;--tile-sm-w:32px;--tile-sm-h:42px;--tile-symbol:1.3em;--tile-sm-symbol:.95em;--banner-font:2rem}}@keyframes tile-deal{0%{opacity:0;transform:translateY(20px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes tile-discard{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #ffd70033}50%{box-shadow:0 0 16px #ffd70080}}.legal-page{width:100%;max-width:720px;color:inherit;box-sizing:border-box;margin:0 auto;padding:16px 20px 40px;line-height:1.7}.legal-page h1{color:var(--app-accent);border-bottom:2px solid var(--app-panel-border);margin:16px 0 8px;padding-bottom:8px;font-size:1.6rem}.legal-page h2{color:var(--app-accent);opacity:.88;margin:24px 0 8px;font-size:1.1rem}.legal-page h3{color:var(--app-fg);opacity:.75;margin:16px 0 6px;font-size:1rem}.legal-page ol{margin:8px 0;padding-left:20px}.legal-page ol li{margin-bottom:4px}.legal-page__date{color:#aaa;margin-bottom:16px;font-size:.85rem}.legal-page section{margin-bottom:16px}.legal-page ul{margin:8px 0;padding-left:20px}.legal-page li{margin-bottom:4px}.legal-page a:not(.action-btn){color:var(--app-accent);text-decoration:underline}.legal-page__dl{grid-template-columns:max-content 1fr;gap:10px 20px;margin:12px 0;display:grid}.legal-page__dl dt{color:var(--app-accent);padding-top:2px;font-weight:700}.legal-page__dl dd{margin:0}.legal-page__footer{text-align:center;margin-top:32px}.app-footer{text-align:center;color:#888;border-top:1px solid #ffffff14;margin-top:auto;padding:12px;font-size:.75rem}.app-footer a{color:#81c784;margin:0 8px;text-decoration:none}.app-footer a:hover{text-decoration:underline}@media (width<=480px){.legal-page__dl{grid-template-columns:1fr;gap:4px}.legal-page__dl dt{margin-top:12px}}.column-list{flex-direction:column;gap:12px;margin-top:16px;display:flex}.column-card{color:inherit;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;padding:16px;text-decoration:none;transition:background .2s,border-color .2s;display:block}.column-card:hover{border-color:var(--app-accent);background:#ffffff1a}.column-card__date{color:#aaa;font-size:.8rem}.column-card__title{color:var(--app-accent);margin:4px 0 8px;font-size:1rem}.column-card__summary{color:#ccc;margin:0;font-size:.9rem;line-height:1.5}.efficiency-section{box-sizing:border-box;background:#00000040;border:1px solid #ffd70026;border-radius:12px;width:100%;max-width:720px;margin:20px auto 8px;padding:14px 16px}.efficiency-section__header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;display:flex}.efficiency-section__title{color:gold;letter-spacing:.03em;margin:0 0 10px;font-size:1rem;font-weight:600}.efficiency-section__hint{color:#999;font-size:.8rem}.efficiency-hand{background:#0003;border-radius:8px;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:4px;min-height:52px;padding:6px;display:flex}.efficiency-hand__empty{color:#888;margin:0;padding:8px 12px;font-size:.9rem}.efficiency-selector{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.efficiency-selector__slot{flex-direction:column;align-items:center;gap:2px;display:flex}.efficiency-selector__count{color:#999;font-size:.7rem;line-height:1}.efficiency-presets{flex-wrap:wrap;gap:8px;display:flex}.efficiency-presets__btn{flex:auto;min-width:140px;padding:8px 12px;font-size:.85rem}.efficiency-analysis{flex-direction:column;gap:10px;display:flex}.efficiency-analysis--empty{color:#aaa;text-align:center;padding:16px}.efficiency-analysis__row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:4px 0;display:flex}.efficiency-analysis__row--ukeire,.efficiency-analysis__row--candidates,.efficiency-analysis__row--yaku{flex-direction:column;align-items:stretch}.efficiency-analysis__label{color:#aaa;font-size:.85rem}.efficiency-analysis__value{color:#fff;font-weight:600}.efficiency-analysis__value--big{color:gold;font-size:1.1rem}.efficiency-analysis__hint{color:#888;margin:0;font-size:.75rem;line-height:1.4}.efficiency-ukeire-list{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.efficiency-ukeire-list__item{flex-direction:column;align-items:center;gap:2px;display:flex}.efficiency-ukeire-list__remain{color:gold;font-size:.7rem;font-weight:600}.efficiency-yaku-list{flex-direction:column;gap:4px;margin:6px 0 0;padding:0;list-style:none;display:flex}.efficiency-yaku-list__item{background:#ffd70014;border-radius:6px;justify-content:space-between;padding:4px 10px;font-size:.9rem;display:flex}.efficiency-candidates{border-collapse:collapse;width:100%;margin-top:6px;font-size:.85rem}.efficiency-candidates th,.efficiency-candidates td{text-align:left;vertical-align:middle;border-bottom:1px solid #ffffff14;padding:6px 4px}.efficiency-candidates th{color:#aaa;letter-spacing:.05em;font-size:.75rem;font-weight:500}.efficiency-candidates__row--best{background:#ffd70014}.efficiency-candidates__row--best td{color:gold}.efficiency-candidates__shanten{white-space:nowrap;font-size:.8rem}.efficiency-candidates__ukeire{color:#ccc;letter-spacing:.05em;font-size:.8rem}.efficiency-candidates__count{text-align:right;white-space:nowrap;font-weight:600}@media (width<=480px){.efficiency-selector{gap:3px}.efficiency-candidates{font-size:.75rem}.efficiency-candidates th{font-size:.7rem}}.contact-email{text-align:center;margin:16px 0}.contact-email a{color:var(--app-accent);font-size:1.2rem}.faq-list{flex-direction:column;gap:8px;margin:24px 0;display:flex}.faq-item{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;padding:12px 16px;transition:background .2s}.faq-item[open]{background:#ffffff14}.faq-item__question{cursor:pointer;color:var(--app-accent);-webkit-user-select:none;user-select:none;padding:4px 0;font-size:.95rem;font-weight:700}.faq-item__question:hover{color:var(--app-accent);filter:brightness(1.15)}.faq-item__answer{color:#ccc;margin:12px 0 4px;font-size:.9rem;line-height:1.7}.glossary{flex-direction:column;gap:12px;margin:16px 0;display:flex}.glossary__entry{border-left:3px solid var(--app-accent);background:#ffffff08;border-radius:4px;padding:12px 16px}.glossary__term{color:var(--app-accent);margin-bottom:4px;font-size:1rem;font-weight:700}.glossary__reading{color:#888;margin-left:4px;font-size:.85rem;font-weight:400}.glossary__description{color:#ccc;margin:4px 0 0;font-size:.9rem;line-height:1.6}.changelog{flex-direction:column;gap:24px;margin:24px 0;display:flex}.changelog__entry{border-left:3px solid #4caf50;padding-left:16px}.changelog__date{color:#a5d6a7;align-items:center;gap:12px;margin:0 0 8px;font-size:1.05rem;display:flex}.changelog__version{color:#888;background:#ffffff0d;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:400}.changelog__list{margin:0;padding:0;list-style:none}.changelog__item{flex-wrap:wrap;align-items:flex-start;gap:8px;padding:6px 0;display:flex}.changelog-tag{text-align:center;border-radius:10px;flex-shrink:0;min-width:60px;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-block}.changelog-tag--feat{color:#c8e6c9;background:#1b5e20}.changelog-tag--fix{color:#ffcdd2;background:#b71c1c}.changelog-tag--improve{color:#bbdefb;background:#0d47a1}.changelog-tag--content{color:#e1bee7;background:#4a148c}.changelog__description{color:#ccc;flex:1;min-width:200px;font-size:.9rem;line-height:1.6}.related-articles{border-top:1px solid #ffffff1a;margin-top:32px;padding-top:24px}.related-articles h2{margin-bottom:12px;font-size:1.1rem}.breadcrumbs{margin:0 0 16px;font-size:.85rem}.breadcrumbs__list{flex-wrap:wrap;gap:4px;margin:0;padding:0;list-style:none;display:flex}.breadcrumbs__item{align-items:center;display:inline-flex}.breadcrumbs__link{color:var(--app-accent);text-decoration:none}.breadcrumbs__link:hover{text-decoration:underline}.breadcrumbs__current{color:var(--app-muted)}.breadcrumbs__separator{color:var(--app-muted);opacity:.6;margin:0 4px}.legal-page__summary{color:#bbb;margin:-8px 0 24px;font-size:.95rem;font-style:italic;line-height:1.6}.wait-example{background:#81c78414;border-left:3px solid #81c784;border-radius:4px;margin:12px 0;padding:12px 16px;font-family:Menlo,Consolas,Courier New,monospace}.wait-example__name{color:#a5d6a7;margin-bottom:6px;font-family:system-ui,sans-serif;font-size:.9rem;font-weight:700}.wait-example__row{flex-wrap:wrap;gap:8px;margin:4px 0;font-size:.95rem;display:flex}.wait-example__label{color:#888;flex-shrink:0;min-width:48px}.wait-example__hand{color:#fff;letter-spacing:.5px}.wait-example__waits{color:#ffd54f;font-weight:700}.wait-example__note{color:#bbb;border-top:1px dashed #ffffff1a;margin-top:8px;padding-top:8px;font-family:system-ui,sans-serif;font-size:.85rem;line-height:1.5}.study-article__nav{border-top:1px solid #ffffff1a;flex-wrap:wrap;justify-content:space-between;gap:12px;margin:32px 0 16px;padding:16px 0;display:flex}.study-article__nav-link{color:#a5d6a7;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;flex:1;min-width:200px;padding:12px;font-size:.9rem;line-height:1.4;text-decoration:none;transition:background .2s,border-color .2s}.study-article__nav-link:hover{background:#ffffff14;border-color:#81c784}.study-article__nav-link--prev{text-align:left}.study-article__nav-link--next{text-align:right;margin-left:auto}@media (width<=600px){.study-article__nav{flex-direction:column}.study-article__nav-link--next{margin-left:0}}.hand--dealing .tile{animation:.3s ease-out backwards tile-deal}.hand--dealing .tile:first-child{animation-delay:0s}.hand--dealing .tile:nth-child(2){animation-delay:20ms}.hand--dealing .tile:nth-child(3){animation-delay:40ms}.hand--dealing .tile:nth-child(4){animation-delay:60ms}.hand--dealing .tile:nth-child(5){animation-delay:80ms}.hand--dealing .tile:nth-child(6){animation-delay:.1s}.hand--dealing .tile:nth-child(7){animation-delay:.12s}.hand--dealing .tile:nth-child(8){animation-delay:.14s}.hand--dealing .tile:nth-child(9){animation-delay:.16s}.hand--dealing .tile:nth-child(10){animation-delay:.18s}.hand--dealing .tile:nth-child(11){animation-delay:.2s}.hand--dealing .tile:nth-child(12){animation-delay:.22s}.hand--dealing .tile:nth-child(13){animation-delay:.24s}.hand--dealing .tile:nth-child(14){animation-delay:.26s}.hand--kan-mode{position:relative}.hand__kan-hint{text-align:center;color:gold;text-shadow:0 1px 2px #00000080;font-size:.8rem;animation:1.5s infinite pulse-glow;position:absolute;top:-28px;left:0;right:0}.discards__tiles .tile{animation:.2s ease-out tile-discard}.game-result,.round-result{animation:.4s ease-out slide-up}.tile:active:not(:disabled){transition:transform 50ms;transform:scale(.95)}.ad-banner{max-width:480px;min-height:50px;margin:8px auto}.ad-banner--placeholder{background:#ffffff0d;border:1px dashed #ffffff26;border-radius:6px;justify-content:center;align-items:center;min-height:60px;display:flex}.ad-banner__text{color:#ffffff40;letter-spacing:2px;font-size:.75rem}.mypage-emperor-badge{color:#1a1a2e;text-align:center;background:linear-gradient(135deg,gold 0%,#fa0 100%);border-radius:20px;margin-bottom:8px;padding:8px 16px;font-size:.9rem;font-weight:700}.mypage-checkout-msg{text-align:center;border-radius:8px;margin-bottom:12px;padding:8px 16px;font-size:.9rem}.mypage-checkout-msg--success{color:#81c784;background:#4caf5033;border:1px solid #4caf504d}.mypage-checkout-msg--cancel{color:#ffb74d;background:#ff980033;border:1px solid #ff98004d}.shanten-hint{-webkit-user-select:none;user-select:none;font-size:.85rem}.shanten-hint--toggle{color:#fff9;cursor:pointer;z-index:10;background:#ffffff14;border:1px solid #ffffff26;border-radius:12px;padding:4px 10px;transition:background .15s;position:absolute;top:8px;right:8px}.shanten-hint--toggle:hover{color:#ffffffe6;background:#ffffff26}.shanten-hint--panel{color:#e0e8f0;z-index:10;background:#1e283ce6;border:1px solid #6496ff4d;border-radius:8px;min-width:140px;padding:8px 28px 8px 12px;position:absolute;top:8px;right:8px;box-shadow:0 2px 8px #0000004d}.shanten-hint__row{justify-content:space-between;gap:8px;line-height:1.4;display:flex}.shanten-hint__label{color:#c8dcffb3;font-size:.8rem}.shanten-hint__value{color:#a0d0ff;font-weight:600}.shanten-hint__close{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:1rem;line-height:1;position:absolute;top:2px;right:4px}.shanten-hint__close:hover{color:#fff}.tenpai-fx{pointer-events:none;z-index:100;position:fixed;inset:0;overflow:hidden}.tenpai-fx__label{text-shadow:0 2px 8px #000c;letter-spacing:.1em;-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:4px;font-weight:900;display:flex;position:absolute;top:12%;left:50%;transform:translate(-50%)}.tenpai-fx__text{border-radius:8px;padding:4px 16px;font-size:clamp(1.5rem,6vw,3rem)}.tenpai-fx__count{color:#fff;background:#00000080;border-radius:12px;padding:2px 10px;font-size:.9rem}.tenpai-fx__text--chance{color:#fff;background:linear-gradient(135deg,#00bfff 0%,#0080ff 100%);animation:2s ease-in-out infinite tenpai-pulse-soft;box-shadow:0 0 16px #00bfff,0 0 32px #00bfff80}@keyframes tenpai-pulse-soft{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.tenpai-fx__text--super{color:#fff;background:linear-gradient(135deg,red 0%,#a00 100%);animation:1s ease-in-out infinite tenpai-pulse-strong;box-shadow:0 0 20px red,0 0 40px #f009}@keyframes tenpai-pulse-strong{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.tenpai-fx--super .tenpai-fx__vignette,.tenpai-fx--premium .tenpai-fx__vignette,.tenpai-fx--emperor .tenpai-fx__vignette{pointer-events:none;mix-blend-mode:screen;position:absolute;inset:0}.tenpai-fx--super .tenpai-fx__vignette{background:radial-gradient(#0000 55%,#ff000073 100%);animation:1.5s ease-in-out infinite tenpai-vignette-breath}@keyframes tenpai-vignette-breath{0%,to{opacity:.7}50%{opacity:1}}.tenpai-fx__text--premium{color:#1a1a00;background:linear-gradient(135deg,gold 0%,#fa0 50%,gold 100%) 0 0/200% 200%;animation:1.2s linear infinite tenpai-gold-shimmer,.15s linear infinite tenpai-shake-small;box-shadow:0 0 24px gold,0 0 48px #ffd700b3}@keyframes tenpai-gold-shimmer{0%{background-position:0%}to{background-position:200%}}@keyframes tenpai-shake-small{0%,to{transform:translate(-50%)translateY(0)}25%{transform:translate(calc(-50% - 2px))translateY(-1px)}75%{transform:translate(calc(2px - 50%))translateY(1px)}}.tenpai-fx--premium .tenpai-fx__vignette{background:radial-gradient(#0000 45%,#ffd7008c 100%);animation:.9s ease-in-out infinite tenpai-vignette-breath}.tenpai-fx__rays{pointer-events:none;animation:6s linear infinite tenpai-rays-spin;position:absolute;inset:0}.tenpai-fx__ray{transform-origin:50%;background:linear-gradient(#0000 0%,#ffd70066 30%,#0000 70%);width:3px;height:150vmax;margin-top:-75vmax;margin-left:-1.5px;position:absolute;top:50%;left:50%}@keyframes tenpai-rays-spin{to{transform:rotate(360deg)}}.tenpai-fx__text--emperor{color:#fff;background:linear-gradient(90deg,red,#ff8000,#ff0,#0f0,#0ff,#0080ff,#8000ff,#ff0080,red) 0 0/400% 100%;animation:1.5s linear infinite tenpai-rainbow-slide,80ms linear infinite tenpai-shake-hard;box-shadow:0 0 32px #fff,0 0 64px #fffc}@keyframes tenpai-rainbow-slide{0%{background-position:0%}to{background-position:400%}}@keyframes tenpai-shake-hard{0%,to{transform:translate(-50%)translateY(0)rotate(0)}20%{transform:translate(calc(-50% - 5px))translateY(-3px)rotate(-1deg)}40%{transform:translate(calc(4px - 50%))translateY(2px)rotate(1deg)}60%{transform:translate(calc(-50% - 3px))translateY(3px)rotate(-.5deg)}80%{transform:translate(calc(5px - 50%))translateY(-2px)rotate(.5deg)}}.tenpai-fx--emperor .tenpai-fx__vignette{background:radial-gradient(#0000 30%,#ffffff4d 80%,#0009 100%);animation:.5s ease-in-out infinite tenpai-vignette-breath}.tenpai-fx--emperor{animation:.12s linear infinite tenpai-screen-shake}@keyframes tenpai-screen-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px,2px)}50%{transform:translate(2px,-3px)}75%{transform:translate(-2px,-1px)}}.tenpai-fx__svg-defs{width:0;height:0;position:absolute}.game-board[data-tenpai-stage=chance] .hand .tile{animation:2s ease-in-out infinite tenpai-tile-pulse-blue;box-shadow:0 0 8px #00bfff,0 0 16px #00bfff80}@keyframes tenpai-tile-pulse-blue{0%,to{box-shadow:0 0 8px #00bfff,0 0 16px #00bfff66}50%{box-shadow:0 0 16px #00bfff,0 0 32px #00bfffb3}}.game-board[data-tenpai-stage=super] .hand .tile{animation:.6s ease-in-out infinite tenpai-tile-pulse-red;box-shadow:0 0 12px red,0 0 24px #f009}@keyframes tenpai-tile-pulse-red{0%,to{transform:translateY(0);box-shadow:0 0 12px red}50%{transform:translateY(-1px);box-shadow:0 0 28px red}}.game-board[data-tenpai-stage=premium] .hand .tile{animation:.12s linear infinite tenpai-tile-shake;box-shadow:0 0 16px gold,0 0 32px #ffd700cc}@keyframes tenpai-tile-shake{0%,to{transform:translate(0)}25%{transform:translate(-1px,1px)}75%{transform:translate(1px,-1px)}}.game-board[data-tenpai-stage=emperor] .hand .tile{filter:url(#liquify-distort);animation:2s linear infinite tenpai-tile-rainbow,.1s linear infinite tenpai-tile-shake-hard;box-shadow:0 0 20px #fff,0 0 40px #ff80ff}@keyframes tenpai-tile-rainbow{0%{filter:hue-rotate()url(#liquify-distort)}to{filter:hue-rotate(360deg)url(#liquify-distort)}}@keyframes tenpai-tile-shake-hard{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(-2px,2px)rotate(-1deg)}50%{transform:translate(1px,-2px)rotate(1deg)}75%{transform:translate(2px,1px)rotate(-.5deg)}}@media (prefers-reduced-motion:reduce){.tenpai-fx,.tenpai-fx *{animation:none!important}.game-board[data-tenpai-stage] .hand .tile{animation:none!important;transform:none!important}}.quiz-page .quiz-card{background:#fff;border:1px solid #e0d5b7;border-radius:12px;margin:16px 0;padding:16px;box-shadow:0 2px 6px #0000000d}.quiz-prompt{margin-bottom:16px}.quiz-prompt__header{color:#5a4a2c;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;display:flex}.quiz-prompt__size{background:#e0d5b7;border-radius:12px;padding:2px 10px;font-weight:600}.quiz-prompt__progress{font-variant-numeric:tabular-nums}.quiz-prompt__question{color:#3a2e1a;margin:8px 0;font-weight:600}.quiz-prompt__tiles{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.quiz-wait-input{grid-template-columns:repeat(9,1fr);gap:4px;margin:16px 0;display:grid}.quiz-wait-input__btn{cursor:pointer;background:#f8f4e8;border:2px solid #0000;border-radius:8px;padding:4px;transition:border-color .15s,background .15s}.quiz-wait-input__btn:hover:not(:disabled){background:#efe6cf}.quiz-wait-input__btn--selected{background:#d8e8c8;border-color:#4a7c2a}.quiz-wait-input__btn--disabled,.quiz-wait-input__btn:disabled{cursor:not-allowed;opacity:.6}.quiz-explanation{border:2px solid;border-radius:8px;margin-top:16px;padding:12px}.quiz-explanation--ok{background:#e6f5d8;border-color:#4a7c2a}.quiz-explanation--ng{background:#fce8e0;border-color:#b85a30}.quiz-explanation__title{margin:0 0 8px}.quiz-explanation--ok .quiz-explanation__title{color:#2c5e10}.quiz-explanation--ng .quiz-explanation__title{color:#8a3a10}.quiz-explanation__row{flex-wrap:wrap;align-items:center;gap:8px;margin:6px 0;display:flex}.quiz-explanation__label{color:#3a2e1a;min-width:100px;font-weight:600}.quiz-explanation__tiles{gap:4px;display:flex}.quiz-explanation__hint{color:#5a4a2c;margin-top:8px}.quiz-fallback-banner{color:#5a4a2c;background:#fff3d6;border:1px solid #d4b85a;border-radius:8px;margin:12px 0;padding:10px 12px}.quiz-fallback-banner__link{color:#b85a30;font:inherit;cursor:pointer;background:0 0;border:none;padding:0 4px;text-decoration:underline}.quiz-error{color:#8a3a10;background:#fce8e0;border-radius:6px;margin:8px 0;padding:8px 12px}.quiz-upsell-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.quiz-upsell-modal{background:#fff;border-radius:12px;width:100%;max-width:480px;padding:20px;box-shadow:0 10px 30px #0000004d}.quiz-upsell-modal__title{color:#3a2e1a;margin:0 0 12px}.quiz-upsell-modal__body{color:#3a2e1a;line-height:1.6}.quiz-upsell-modal__benefits{color:#3a2e1a;margin:12px 0;padding-left:20px}.quiz-upsell-modal__benefits li{margin:4px 0}.quiz-upsell-modal__actions{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}body,body.theme-green{--app-bg:#14472a;--app-fg:#e0e0e0;--app-panel:#ffffff0a;--app-panel-border:#ffffff1a;--app-accent:#81c784;--app-muted:#9aa59c;--app-nav-bg:#0a120ceb;--app-nav-border:#ffffff14;--app-nav-fg:#e0e0e0;--app-nav-active:#ffd54f}body.theme-dark{--app-bg:#0f1115;--app-fg:#e8e8ea;--app-panel:#ffffff09;--app-panel-border:#ffffff14;--app-accent:#90caf9;--app-muted:#8a8f95;--app-nav-bg:#16181cf0;--app-nav-border:#ffffff0f;--app-nav-fg:#e8e8ea;--app-nav-active:#ffd54f}body.theme-light{--app-bg:#f5f2e8;--app-fg:#2a2418;--app-panel:#ffffffd9;--app-panel-border:#00000014;--app-accent:#2e7d32;--app-muted:#666;--app-nav-bg:#fffcf4f2;--app-nav-border:#00000014;--app-nav-fg:#2a2418;--app-nav-active:#2e7d32}body.theme-dark{color:#e8e8ea;background:#0f1115}body.theme-light{color:#2a2418;background:#f5f2e8}body.theme-light .logo:not(.logo--large) .logo__text{color:#2a5c2a;text-shadow:none}.app-layout{flex-direction:column;min-height:100dvh;display:flex}body.theme-green .app-layout,body:not(.theme-dark):not(.theme-light) .app-layout{background:radial-gradient(at 20% 40%,#1e5a3259 0%,#0000 55%),linear-gradient(135deg,#1a5c2e 0%,#14472a 40%,#0f3a22 100%)}body.theme-dark .app-layout{color:#e8e8ea;background:radial-gradient(at 30% 10%,#788cb40f 0%,#0000 60%),linear-gradient(#15171c 0%,#0f1115 100%)}body.theme-light .app-layout{color:#2a2418;background:linear-gradient(#f5f2e8 0%,#ebe6d5 100%)}.app-layout__main{flex-direction:column;flex:1;min-height:0;padding-bottom:0;display:flex}.mobile-header{padding:max(8px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) 8px max(12px, env(safe-area-inset-left));background:var(--app-nav-bg);border-bottom:1px solid var(--app-nav-border);color:var(--app-nav-fg);z-index:50;-webkit-backdrop-filter:blur(6px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.mobile-header__menu{color:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:40px;min-height:40px;padding:8px;display:flex}.mobile-header__menu:hover,.mobile-header__menu:focus-visible{background:#ffffff0f}.mobile-header__logo{color:inherit;align-items:center;text-decoration:none;display:inline-flex}.mobile-header__spacer{min-width:40px}.bottom-tab-bar{background:var(--app-nav-bg);border-top:1px solid var(--app-nav-border);-webkit-backdrop-filter:blur(6px);z-index:40;padding-bottom:env(safe-area-inset-bottom,0);display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-tab-bar__item{color:var(--app-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:52px;padding:6px 4px 8px;font-size:11px;text-decoration:none;transition:color .12s;display:flex}.bottom-tab-bar__item.is-active{color:var(--app-nav-active)}.bottom-tab-bar__item:focus-visible{outline:2px solid var(--app-accent);outline-offset:-2px}.bottom-tab-bar__icon{justify-content:center;align-items:center;height:22px;display:inline-flex}.bottom-tab-bar__label{white-space:nowrap}@media (width<=1023px){.app-layout__main{padding-bottom:calc(52px + 16px + env(safe-area-inset-bottom,0))}.legal-page,.top-page{padding-bottom:calc(52px + 24px + env(safe-area-inset-bottom,0))}}@media (height<=500px) and (orientation:landscape){.bottom-tab-bar__item{gap:1px;min-height:32px;padding:2px 4px 3px;font-size:10px}.bottom-tab-bar__icon{height:16px}.bottom-tab-bar__icon svg{width:16px;height:16px}.app-layout__main{padding-bottom:calc(32px + env(safe-area-inset-bottom,0))}.mobile-header{padding:4px 12px}.mobile-header__logo{font-size:.95rem}}.side-drawer__backdrop{opacity:0;pointer-events:none;z-index:60;background:#00000080;transition:opacity .18s;position:fixed;inset:0}.side-drawer__backdrop.is-open{opacity:1;pointer-events:auto}.side-drawer{background:var(--app-nav-bg);border-right:1px solid var(--app-nav-border);width:280px;max-width:85vw;color:var(--app-nav-fg);z-index:70;flex-direction:column;gap:12px;padding:16px 0;transition:transform .22s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.side-drawer.is-open{transform:translate(0)}.side-drawer__user{border-bottom:1px solid var(--app-nav-border);align-items:center;gap:12px;padding:4px 16px 12px;display:flex}.side-drawer__user--guest .side-drawer__username{color:var(--app-muted)}.side-drawer__avatar{color:#fff;background:#8b6914;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;display:flex}.side-drawer__username{font-size:1rem;font-weight:600}.side-drawer__nav{flex-direction:column;display:flex}.side-drawer__link{color:var(--app-nav-fg);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;min-height:44px;padding:12px 16px;font-family:inherit;font-size:.95rem;text-decoration:none;display:flex}.side-drawer__link:hover,.side-drawer__link:focus-visible{background:#ffffff0f}.side-drawer__link--button{color:#e57373}.side-drawer__divider{border:none;border-top:1px solid var(--app-nav-border);margin:4px 0}.side-drawer__ping{color:var(--app-muted);justify-content:space-between;padding:10px 16px;font-size:.85rem;display:flex}.side-drawer__ping-label{font-weight:600}.top-nav-bar{z-index:50;background:var(--app-nav-bg);border-bottom:1px solid var(--app-nav-border);color:var(--app-nav-fg);-webkit-backdrop-filter:blur(6px);position:sticky;top:0}.top-nav-bar__inner{max-width:1200px;padding:max(10px, env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) 10px max(20px, env(safe-area-inset-left));align-items:center;gap:16px;margin:0 auto;display:flex}.top-nav-bar__menu{color:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:38px;min-height:38px;padding:8px;display:flex}.top-nav-bar__menu:hover,.top-nav-bar__menu:focus-visible{background:#ffffff0f}.top-nav-bar__logo{color:inherit;flex-shrink:0;align-items:center;text-decoration:none;display:inline-flex}.top-nav-bar__nav{flex:1;gap:8px;display:flex}.top-nav-bar__link{color:var(--app-nav-fg);border-radius:6px;padding:8px 14px;font-size:.95rem;font-weight:500;text-decoration:none;transition:background .12s,color .12s}.top-nav-bar__link:hover,.top-nav-bar__link:focus-visible{background:#ffffff0f}.top-nav-bar__link.is-active{color:var(--app-nav-active);background:#ffd54f14}.user-menu{position:relative}.user-menu__trigger{border:1px solid var(--app-nav-border);color:inherit;cursor:pointer;font:inherit;background:#ffffff0a;border-radius:20px;align-items:center;gap:8px;min-height:36px;padding:6px 12px;display:inline-flex}.user-menu__trigger:hover,.user-menu__trigger:focus-visible{background:#ffffff14}.user-menu__avatar{color:#fff;background:#8b6914;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:inline-flex}.user-menu__username{text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.9rem;font-weight:500;overflow:hidden}.user-menu__dropdown{background:var(--app-nav-bg);border:1px solid var(--app-nav-border);z-index:100;border-radius:8px;flex-direction:column;min-width:220px;padding:6px 0;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 8px 20px #00000059}.user-menu__item{color:var(--app-nav-fg);font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 14px;text-decoration:none;display:block}.user-menu__item:hover,.user-menu__item:focus-visible{background:#ffffff0f}.user-menu__divider{border:none;border-top:1px solid var(--app-nav-border);margin:4px 0}.user-menu__ping{color:var(--app-muted);justify-content:space-between;padding:8px 14px;font-size:.8rem;display:flex}.more-page{width:100%;max-width:720px;color:inherit;box-sizing:border-box;margin:0 auto;padding:16px 20px 40px}.more-page__title{color:var(--app-accent);margin:0 0 24px;font-size:1.5rem}.more-page__section{margin-bottom:24px}.more-page__section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--app-muted);margin:0 0 8px;padding:0 4px;font-size:.85rem;font-weight:600}.more-page__list{background:var(--app-panel);border:1px solid var(--app-panel-border);border-radius:10px;flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex;overflow:hidden}.more-page__item+.more-page__item{border-top:1px solid var(--app-panel-border)}.more-page__link{color:inherit;flex-direction:column;gap:2px;padding:14px 16px;text-decoration:none;transition:background .12s;display:flex}.more-page__link:hover,.more-page__link:focus-visible{background:#ffffff0d}body.theme-light .more-page__link:hover,body.theme-light .more-page__link:focus-visible{background:#0000000a}.more-page__link-label{font-size:1rem;font-weight:500}.more-page__link-desc{color:var(--app-muted);font-size:.8rem}.settings-page{width:100%;max-width:720px;color:inherit;box-sizing:border-box;margin:0 auto;padding:16px 20px 40px}.settings-page__title{color:var(--app-accent);margin:0 0 24px;font-size:1.5rem}.settings-page__section{background:var(--app-panel);border:1px solid var(--app-panel-border);border-radius:10px;margin-bottom:32px;padding:16px 20px}.settings-page__section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--app-muted);margin:0 0 12px;font-size:.85rem;font-weight:600}.settings-page__row{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.settings-page__row:last-child{margin-bottom:0}.settings-page__label{justify-content:space-between;font-size:.95rem;font-weight:500;display:flex}.settings-page__value{color:var(--app-muted);font-variant-numeric:tabular-nums}.settings-page__slider{width:100%;accent-color:var(--app-accent);min-height:32px}.settings-page__theme{flex-wrap:wrap;gap:8px;display:flex}.settings-page__theme-option{border:1px solid var(--app-panel-border);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:8px 14px;font-size:.95rem;display:inline-flex}.settings-page__theme-option.is-selected{border-color:var(--app-accent);background:#81c7841f}.settings-page__theme-option input{margin:0}.settings-page__note{color:var(--app-muted);margin:10px 0 0;font-size:.8rem}.top-page__rules-btn{top:calc(env(safe-area-inset-top,0px) + 10px);right:calc(env(safe-area-inset-right,0px) + 12px);z-index:10;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#00000059;border:1px solid #ffffff40;border-radius:18px;padding:6px 12px;font-size:.85rem;position:absolute}.top-page__rules-btn:hover,.top-page__rules-btn:focus-visible{background:#0000008c;outline:none}.rules-modal__backdrop{z-index:2000;background:#000000b3;justify-content:center;align-items:flex-start;padding:24px 16px;animation:.15s ease-out rules-modal-fade-in;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes rules-modal-fade-in{0%{opacity:0}to{opacity:1}}.rules-modal{background:var(--app-panel,#1f3a28);color:var(--app-fg,#f0f0f0);border:1px solid var(--app-panel-border,#ffd70033);box-sizing:border-box;border-radius:14px;width:100%;max-width:640px;margin:auto;padding:24px 20px;position:relative;box-shadow:0 8px 32px #00000080}.rules-modal__close{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;position:absolute;top:8px;right:10px}.rules-modal__close:hover,.rules-modal__close:focus-visible{background:#ffffff1a;outline:none}.rules-modal__title{color:#ffd54f;margin:0 30px 12px 0;font-size:1.3rem}.rules-modal__lead{margin:0 0 14px;font-size:.95rem;line-height:1.5}.rules-modal__section{margin:16px 0}.rules-modal__section h3{color:#81c784;letter-spacing:.02em;margin:0 0 6px;font-size:1rem}.rules-modal__section ul{margin:0;padding-left:20px;font-size:.9rem;line-height:1.6}.rules-modal__section li{margin:3px 0}.rules-modal__more{color:#c8e6c9;margin-top:16px;font-size:.85rem}.rules-modal__more a{color:#90caf9;text-decoration:underline}.rules-modal__ok-btn{width:100%;margin-top:18px}.top-page{flex-direction:column;flex:1;justify-content:center;align-items:stretch;gap:8px;width:100%;max-width:720px;min-height:0;margin:0 auto;padding:8px 16px;display:flex;overflow:hidden}.top-page .auth-panel{width:100%;max-width:480px;margin:0 auto}.auth-panel{background:var(--app-panel);border:1px solid var(--app-panel-border);border-radius:12px;flex-direction:column;gap:8px;width:100%;padding:14px 16px;display:flex}.auth-panel--loading{justify-content:center;align-items:center;min-height:160px}.auth-panel__title{text-align:center;color:var(--app-accent);margin:0 0 4px;font-size:1.2rem}.auth-panel__welcome,.auth-panel__rating{text-align:center;margin:0}.auth-panel__rating{color:var(--app-muted);font-size:.9rem}.auth-panel__error,.auth-panel__error-inline{color:#ff6b6b;text-align:center;margin:0;font-size:.85rem}.auth-panel__error-inline{text-align:left;margin-top:-6px}.auth-panel__input{border:1px solid var(--app-panel-border);width:100%;color:inherit;box-sizing:border-box;background:#00000026;border-radius:8px;padding:9px 12px;font-size:.95rem}body.theme-light .auth-panel__input{color:#2a2418;background:#fffc}.auth-panel__input::placeholder{color:var(--app-muted)}.auth-panel__input:focus{border-color:var(--app-accent);outline:none}.auth-panel__btn{width:100%;margin-top:4px}.auth-panel__links{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:8px;font-size:.9rem;display:flex}.auth-panel__links a{color:var(--app-accent);text-decoration:none}.auth-panel__links a:hover{text-decoration:underline}.auth-panel__text-btn{color:var(--app-muted);cursor:pointer;font-size:.9rem;font:inherit;background:0 0;border:none;padding:0}.auth-panel__text-btn:hover{color:var(--app-fg)}.game-page{flex-direction:column;flex:1;width:100%;max-width:720px;margin:0 auto;padding:16px 20px 40px;display:flex}.game-page--match{flex-direction:column;max-width:800px;min-height:100dvh;margin:0 auto;padding:4px;display:flex}body,body.theme-green{--match-bg:radial-gradient(ellipse at 20% 50%, #1e5a3266 0%, transparent 60%), radial-gradient(ellipse at 80% 50%, #1446284d 0%, transparent 60%), linear-gradient(135deg, #1a5c2e 0%, #14472a 40%, #0f3a22 100%)}body.theme-dark{--match-bg:radial-gradient(ellipse at 20% 40%, #5a64962e 0%, transparent 60%), radial-gradient(ellipse at 80% 60%, #3c466426 0%, transparent 60%), linear-gradient(135deg, #181a22 0%, #0f1115 45%, #14151a 100%)}body.theme-light{--match-bg:radial-gradient(ellipse at 20% 50%, #b4a07840 0%, transparent 60%), radial-gradient(ellipse at 80% 50%, #a08c642e 0%, transparent 60%), linear-gradient(135deg, #e8dfc8 0%, #d9cfb5 45%, #cfc3a1 100%)}.game-page--match{background:var(--match-bg)}.app-layout--bare{flex-direction:column;min-height:100dvh;display:flex}.game-page>.lobby{flex:1;justify-content:center;gap:16px}.logo{vertical-align:middle;align-items:center;display:inline-flex}.logo__img{object-fit:contain;filter:drop-shadow(0 1px 2px #00000059);display:block}.logo--large .logo__img{filter:drop-shadow(0 2px 6px #0006)}.app-layout__main .app{background:0 0;width:100%;max-width:none;min-height:auto;margin:0;padding:0}.app-layout__main .app__header{display:none}.app-layout__main .lobby{flex:none;justify-content:flex-start;gap:16px;padding:16px 0 32px}.app-layout__main .game-page>.lobby{flex:1;justify-content:center;gap:16px;padding:24px 0 48px}.app-layout__main .login-form{background:var(--app-panel);border:1px solid var(--app-panel-border)}.app-layout__main .login-form h3{color:var(--app-accent)}.app-layout__main .login-form__input{border-color:var(--app-panel-border);color:inherit;background:#00000026}.app-layout__main .login-form__input::placeholder{color:var(--app-muted)}.app-layout__main .login-form__input:focus{border-color:var(--app-accent)}.app-layout__main .login-form__link{color:var(--app-accent)}body.theme-light .app-layout__main .login-form__input{color:#2a2418;background:#fffc}@media (width>=1024px){.top-nav-bar__inner{padding:12px 32px}}html,body,#root,.app-layout,.app-layout--bare{height:100dvh;max-height:100dvh;overflow:hidden}.app-layout__main{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1 1 0;min-height:0;overflow-y:auto}.app-layout__main>.app{flex:none;height:auto;min-height:0;max-height:none;overflow:visible}.app-layout--bare .game-page--match{height:100dvh;min-height:100dvh;max-height:100dvh;overflow:hidden}.app-layout--bare .game-board{position:relative}.app-layout--bare .ankans{z-index:5;pointer-events:none;background:#00000073;border-radius:4px;gap:4px;padding:2px 4px;position:absolute}.app-layout--bare .game-board__me>.ankans{left:4px;bottom:calc(var(--tile-h,50px) + 16px)}.app-layout--bare .game-board__opponent>.ankans{left:4px;top:calc(var(--tile-h,50px) + 16px)}.app-layout--bare .ankans{flex-wrap:wrap;max-width:60%}.app-layout--bare .ankan-group{gap:1px}.app-layout--bare .round-result{box-sizing:border-box;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;width:100%;max-width:100%;height:100%;padding:4px 6px 4px calc(62% + 12px);display:flex;position:relative;overflow:hidden}.app-layout--bare .round-result__board{box-sizing:border-box;flex-direction:column;justify-content:space-between;gap:2px;width:62%;max-width:none;padding:4px 6px;display:flex;position:absolute;top:4px;bottom:4px;left:6px;overflow:hidden}.app-layout--bare .round-result__banner{border-width:1px;padding:6px 14px;font-size:1rem}.app-layout--bare .round-result__yaku{flex-direction:column;flex-shrink:1;align-items:center;gap:2px;min-height:0;display:flex;overflow:visible}.app-layout--bare .round-result__yaku h3{flex-shrink:0;margin-bottom:2px;font-size:.95rem}.app-layout--bare .round-result__yaku ul{overscroll-behavior:contain;background:#0006;border:1px solid #ffd70066;border-radius:6px;flex-direction:column;flex-shrink:1;gap:1px;min-width:140px;max-width:100%;min-height:0;max-height:90px;margin:2px 0 0;padding:4px 10px 4px 14px;list-style:none;display:flex;overflow-y:auto;box-shadow:0 1px 3px #0000004d}.app-layout--bare .round-result__yaku li{flex-shrink:0;padding:1px 0 1px 10px;font-size:.8rem;line-height:1.3;position:relative}.app-layout--bare .round-result__yaku li:before{content:"•";color:gold;font-weight:700;position:absolute;left:0}.app-layout--bare .round-result__yaku .round-result__score{flex-shrink:0;margin-top:4px}.app-layout--bare .round-result__score{margin-top:2px;font-size:1rem}.app-layout--bare .round-result__scores{gap:12px;font-size:.85rem}.app-layout--bare .round-result__chombo-label{font-size:.85rem}.app-layout--bare .round-result__board{--tile-sm-w:30px;--tile-sm-h:42px;padding:3px 4px}.app-layout--bare .round-result__hand-main{width:calc(13 * var(--tile-sm-w) + 12px);gap:1px}.app-layout--bare .round-result__hand{width:100%;min-width:0;max-width:100%}.round-result__ankans{flex-wrap:wrap;justify-content:center;gap:6px;padding:2px 0;display:flex}.round-result__ankans .ankan-group{background:#0000004d;border:1px solid #ffd70040;border-radius:4px;gap:1px;padding:2px;display:flex}.app-layout--bare .round-result__wall{margin:2px 0;padding:2px 8px;font-size:.75rem}.app-layout--bare .round-result__board .discards__tiles{min-height:46px;max-height:50px;padding-top:2px;padding-bottom:2px}.app-layout--bare .round-result .ad-banner{max-height:36px;padding:4px 8px;font-size:.75rem}.app-layout--bare .round-result .action-btn{padding:6px 18px;font-size:.85rem}.app-layout--bare .round-result__waiting{padding:4px;font-size:.85rem}.app-layout--bare .game-result{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:100%;height:100%;padding:6px 50% 6px 10px;display:flex;position:relative;overflow:hidden}.app-layout--bare .game-result>:not(.game-result__actions){flex-shrink:0;max-width:100%}.app-layout--bare .game-result__stats{overscroll-behavior:contain;max-height:100%;overflow-y:auto}.app-layout--bare .game-result__actions{flex-direction:column;gap:6px;min-width:140px;max-width:45%;display:flex;position:absolute;top:50%;left:75%;transform:translate(-50%,-50%)}.app-layout--bare .game-result__actions .action-btn{width:100%}.app-layout--bare .game-result__banner{padding:8px 24px;font-size:1.3rem}.app-layout--bare .game-result__yaku{flex-direction:column;flex-shrink:1;align-items:center;gap:2px;min-height:0;display:flex;overflow:visible}.app-layout--bare .game-result__yaku h3{flex-shrink:0;margin-bottom:2px;font-size:1rem}.app-layout--bare .game-result__yaku ul{overscroll-behavior:contain;background:#0006;border:1px solid #ffd70066;border-radius:6px;flex-direction:column;flex-shrink:1;gap:1px;min-width:160px;max-width:100%;min-height:0;max-height:100px;margin:2px 0 0;padding:4px 12px 4px 16px;list-style:none;display:flex;overflow-y:auto;box-shadow:0 1px 3px #0000004d}.app-layout--bare .game-result__yaku li{flex-shrink:0;padding:1px 0 1px 10px;font-size:.85rem;line-height:1.3;position:relative}.app-layout--bare .game-result__yaku li:before{content:"•";color:gold;font-weight:700;position:absolute;left:0}.app-layout--bare .game-result__yaku .game-result__score{flex-shrink:0;margin-top:4px}.app-layout--bare .game-result__score{margin-top:2px;font-size:1rem}.app-layout--bare .game-result__final-scores{gap:20px;font-size:.95rem}.app-layout--bare .game-result__rating{font-size:.9rem}.app-layout--bare .game-result .ad-banner{max-height:36px;padding:4px 8px;font-size:.75rem}.app-layout--bare .game-result .action-btn{padding:6px 18px;font-size:.85rem}.ranking-distribution{box-sizing:border-box;background:#00000040;border:1px solid #ffd7002e;border-radius:12px;max-width:600px;margin:16px auto 24px;padding:14px 16px}.ranking-distribution__title{color:gold;letter-spacing:.05em;margin:0 0 4px;font-size:.95rem;font-weight:600}.ranking-distribution__sub{color:#ffffff8c;margin:0 0 10px;font-size:.8rem}.ranking-distribution__chart-wrap{overscroll-behavior-x:contain;justify-content:center;display:flex;overflow-x:auto}.rating-dist{flex-direction:column;gap:6px;max-width:100%;display:flex}.rating-dist--empty{color:#ffffff8c;text-align:center;padding:20px}.rating-dist__tooltip{color:#ffffffd9;background:#0006;border:1px solid #ffd70033;border-radius:6px;flex-flow:wrap;align-items:center;gap:12px;min-height:32px;padding:6px 10px;font-size:.8rem;display:flex}.rating-dist__tooltip-range{color:gold;font-variant-numeric:tabular-nums;font-weight:600}.rating-dist__tooltip-percentile{color:#4caf50;font-weight:600}.game-result__stats{background:#0000004d;border:1px solid #ffd7004d;border-radius:8px;flex-direction:column;gap:6px;min-width:240px;padding:6px 10px;display:flex}.game-result__stats-common{border-bottom:1px dashed #ffd70033;flex-direction:column;gap:2px;padding-bottom:4px;display:flex}.game-result__stats-split{grid-template-columns:1fr 1fr;gap:8px;display:grid}.game-result__stats-col{background:#ffffff08;border:1px solid #ffffff1a;border-radius:4px;flex-direction:column;gap:1px;padding:4px 6px;display:flex}.game-result__stats-col-title{text-align:center;color:gold;letter-spacing:.05em;margin-bottom:2px;font-size:.8rem;font-weight:600}.game-result__stats-row{justify-content:space-between;gap:8px;font-size:.8rem;display:flex}.game-result__stats-row--score{border-bottom:1px solid #ffd70026;margin-bottom:2px;padding:2px 0 4px}.game-result__stats-row--score .game-result__stats-value{color:gold;font-size:1em}.game-result__stats-row--rating{border-top:1px solid #ffffff1a;margin-top:2px;padding-top:2px}.game-result__stats-row--rating .game-result__stats-value{font-size:.9em}.game-result__stats-label{color:#aaa}.game-result__stats-value{color:#fff;font-variant-numeric:tabular-nums;font-weight:600}.app-layout--bare .game-result__stats{gap:4px;min-width:220px;padding:4px 8px}.app-layout--bare .game-result__stats-common{padding-bottom:2px}.app-layout--bare .game-result__stats-split{gap:6px}.app-layout--bare .game-result__stats-col{padding:3px 5px}.app-layout--bare .game-result__stats-col-title{margin-bottom:1px;font-size:.75rem}.app-layout--bare .game-result__stats-row{font-size:.72rem;line-height:1.3}@media (orientation:portrait) and (width<=600px){.app-layout--bare{overflow:hidden}.app-layout--bare .game-page--match{transform-origin:0 0;touch-action:manipulation;width:100dvh;max-width:none;height:100vw;min-height:100vw;max-height:100vw;margin:0;position:absolute;top:0;left:0;transform:rotate(90deg)translateY(-100%)}.app-layout--bare .hand{--hand-avail-w:calc(100dvh - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px) - 16px)}.app-layout--bare .game-page--match--flipped{transform:rotate(-90deg)translate(-100%)}.app-layout--bare .game-page--match--portrait{width:100%;max-width:none;height:auto;min-height:100dvh;max-height:none;transform-origin:unset;position:relative;top:auto;left:auto;transform:none}.app-layout--bare .game-page--match--portrait .hand{--hand-avail-w:calc(100vw - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px) - 16px)}.flip-orientation-btn{top:calc(env(safe-area-inset-top,0px) + 6px);right:calc(env(safe-area-inset-right,0px) + 6px);z-index:1000;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:#0000008c;border:1px solid #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:18px;line-height:1;display:flex;position:fixed}.flip-orientation-btn:hover,.flip-orientation-btn:focus-visible{background:#000000bf;outline:none}}.flip-orientation-btn{display:none}@media (orientation:portrait) and (width<=600px){.flip-orientation-btn{display:flex}}@media (orientation:landscape){.game-page{gap:4px;padding:8px 16px}.game-page>.lobby{gap:10px}.game-page>.lobby .action-btn{padding:10px 20px}.auth-panel{gap:8px;padding:12px 20px}.auth-panel__title{margin-bottom:2px;font-size:1.1rem}.auth-panel__input{padding:8px 12px}.auth-panel__btn{padding:8px 16px}.top-page{gap:6px;padding:8px 20px 12px}}.top-page__hero{text-align:center;max-width:720px;margin:0 auto;padding:20px 16px 8px}.top-page__hero-title{color:inherit;margin:0 0 12px;font-size:clamp(1.3rem,4vw,2rem);font-weight:700;line-height:1.4}.top-page__hero-lead{opacity:.9;margin:0 0 16px;font-size:.95rem;line-height:1.75}.top-page__hero-cta{justify-content:center;display:flex}.top-page__hero-cta .action-btn{min-width:240px}.top-page__features,.top-page__start-nav{box-sizing:border-box;width:100%;max-width:720px;margin:0 auto;padding:12px 16px 0}.top-page__features-title,.top-page__start-nav-title{text-align:center;margin:0 0 10px;font-size:1.1rem;font-weight:700}.top-page__features-list,.top-page__start-nav-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin:0;padding:0;list-style:none;display:grid}.top-page__feature,.top-page__start-nav-list>li{text-align:left;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:10px 12px}.top-page__feature strong{margin-bottom:4px;font-size:.95rem;display:block}.top-page__feature span,.top-page__start-nav-list>li>span{opacity:.8;font-size:.82rem;line-height:1.55;display:block}.top-page__start-nav-list>li>a{color:inherit;margin-bottom:2px;font-weight:600;text-decoration:none;display:block}.top-page__start-nav-list>li>a:hover{text-decoration:underline}body.theme-light .top-page__feature,body.theme-light .top-page__start-nav-list>li{background:#0000000a;border-color:#00000014}.top-page--landing{justify-content:flex-start;min-height:auto;padding-top:12px;padding-bottom:24px;overflow:visible}.top-page__intro{box-sizing:border-box;flex-direction:column;gap:14px;width:100%;max-width:720px;margin:0 auto;padding:0 8px;display:flex}.top-page__login-panel{width:100%;max-width:480px;margin:0 auto}@media (width>=768px){.top-page--landing{max-width:960px}.top-page__intro{flex-direction:row;align-items:stretch;gap:24px;max-width:960px;padding:0 16px}.top-page__hero{text-align:left;flex:auto;max-width:none;margin:0;padding:12px 4px 4px}.top-page__hero-cta{justify-content:flex-start}.top-page__login-panel{flex:0 0 340px;width:340px;max-width:340px;margin:0}}.app-footer{text-align:center;opacity:.85;border-top:1px solid #80808040;flex:none;margin-top:48px;padding:24px 16px 32px;font-size:.85rem}.app-footer__nav{flex-wrap:wrap;justify-content:center;gap:6px 18px;margin-bottom:10px;display:flex}.app-footer__link{color:inherit;text-decoration:none}.app-footer__link:hover,.app-footer__link:focus-visible{text-decoration:underline}.app-footer__copyright{opacity:.75;font-size:.8rem;display:block}.lobby__guest-gate{box-sizing:border-box;background:#ffffff0a;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;align-items:stretch;gap:12px;width:100%;max-width:440px;margin:0 auto;padding:20px 16px;display:flex}.lobby__guest-gate-title{text-align:center;color:inherit;margin:0 0 4px;font-size:1.05rem;font-weight:700}.lobby__guest-gate-lead{opacity:.85;text-align:center;margin:0 0 4px;font-size:.9rem;line-height:1.6}.lobby__guest-gate-buttons{flex-direction:column;gap:8px;display:flex}.lobby__guest-gate-divider{background:#80808040;height:1px;margin:6px 0}.lobby__guest-gate-bot-note{opacity:.8;text-align:center;margin:0 0 4px;font-size:.85rem}body.theme-light .lobby__guest-gate{background:#00000008;border-color:#00000014}*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;-webkit-font-smoothing:antialiased;touch-action:manipulation;background:#111}
