*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(170deg,#1e2236,#141824 40%,#0e1220);background-attachment:fixed;color:#e0e0e0;min-height:100vh}.app{max-width:1100px;margin:0 auto;padding:20px}.header{text-align:center;margin-bottom:24px}.header h1{font-size:2rem;color:#e8c170;letter-spacing:1px}.subtitle{color:#888;font-size:.9rem;margin-top:4px}.hand-section{background:#1e2f4d;border-radius:12px;padding:20px;margin-bottom:20px}.hand-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.hand-header h2{font-size:1.2rem;color:#ccc}.shanten-badge{background:#2a2a4a;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:600;color:#aaa}.shanten-text{font-size:.85rem;display:inline;transform:none}.shanten-badge.tenpai{background:#2e6b2e;color:#90ee90}.turn-info{font-size:.8rem;color:#666}.new-hand-btn{margin-left:auto;padding:8px 16px;background:#e8c170;color:#1a1a2e;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.new-hand-btn:hover{background:#f0d090}.hand-tiles{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;align-items:flex-end}.tile{position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:60px;cursor:pointer;transition:transform .15s;-webkit-user-select:none;user-select:none;border-radius:5px;background:linear-gradient(135deg,#f8f6f0,#e8e4d8);box-shadow:1px 2px 3px #0006,inset 0 1px #fffc,inset -1px -1px #0000001a;border:1px solid #c8c4b8;overflow:hidden}.tile.discard-target:hover{transform:translateY(-6px);box-shadow:1px 4px 10px #0009,0 0 12px #648cc826,inset 0 1px #fffc,inset -1px -1px #0000001a}.tile.discard-target:hover .tile-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.tile.discard-target:active{transform:translateY(-2px);box-shadow:0 1px 2px #0006,inset 0 1px #fff9,inset -1px -1px #00000026}.tile-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);background:#0d0d1e;border:1px solid #333;border-radius:8px;padding:8px 10px;min-width:170px;max-width:220px;z-index:100;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s,transform .15s;pointer-events:none;box-shadow:0 4px 16px #00000080}.tile-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.tooltip-header{font-size:.7rem;color:#888;margin-bottom:4px}.tooltip-header strong{color:#ddd}.tooltip-changes{display:flex;flex-direction:column;gap:3px}.tooltip-change{font-size:.65rem;padding:2px 0}.tooltip-change.improve{color:#90ee90}.tooltip-change.worsen{color:#ee9090}.tooltip-empty{font-size:.65rem;color:#666;font-style:italic}.tile-gap{width:20px;flex-shrink:0}.tile.drawn{background:linear-gradient(135deg,#f8f6f0,#e8e4d8);box-shadow:0 0 0 2px #e8c17080,1px 2px 3px #0006,inset 0 1px #fffc,inset -1px -1px #0000001a}.tile.tsumo-win{box-shadow:0 0 0 2px #90ee9099,0 0 12px #90ee904d,1px 2px 3px #0006,inset 0 1px #fffc,inset -1px -1px #0000001a}.tile.insert-before:before{content:"▾";position:absolute;top:-16px;left:-2px;transform:translate(-50%);color:#90ee90;font-size:14px;line-height:1;z-index:10}.tile.insert-after:after{content:"▾";position:absolute;top:-16px;left:calc(100% + 2px);transform:translate(-50%);color:#90ee90;font-size:14px;line-height:1;z-index:10}.waiting-section{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#1a2e1a;border:1px solid #2e6b2e;border-radius:8px;margin-top:12px;flex-wrap:wrap}.waiting-label{font-size:.85rem;color:#90ee90;white-space:nowrap;font-weight:600}.waiting-tiles{display:flex;gap:6px;flex-wrap:wrap}.waiting-tile-item{display:flex;align-items:center;gap:6px;position:relative;padding:4px 8px;background:#90ee9014;border-radius:6px;cursor:default}.waiting-tile-unavailable{opacity:.4}.waiting-tile-detail{display:flex;flex-direction:column}.waiting-tile-name{font-size:.8rem;color:#ccc}.waiting-tile-count{font-size:.7rem;color:#888}.waiting-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);background:#0d0d1e;border:1px solid #333;border-radius:8px;padding:8px 10px;min-width:150px;z-index:100;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s,transform .15s;pointer-events:none;box-shadow:0 4px 16px #00000080;white-space:nowrap}.waiting-tile-item:hover .waiting-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.waiting-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.waiting-yaku-row{display:flex;justify-content:space-between;gap:12px;font-size:.7rem;color:#ccc;padding:2px 0}.waiting-yaku-han{color:#e8c170}.waiting-score-total{font-size:.75rem;color:#e8c170;font-weight:600;margin-top:4px;padding-top:4px;border-top:1px solid #333}.waiting-no-yaku{font-size:.7rem;color:#888;font-style:italic}.discard-hint{text-align:center;margin-top:10px;font-size:.8rem;color:#666}.section-label{font-size:1.1rem;color:#e0e0e0;margin-bottom:10px;font-weight:600}.opponent-discards-section{background:#16213e;border-radius:12px;padding:14px 20px;margin-bottom:20px}.player-discards{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}.discards-row{display:flex;flex-wrap:wrap;gap:4px;align-items:flex-end;min-height:44px}.discard-tile-styled{display:inline-flex;align-items:center;justify-content:center;width:32px;height:40px;border-radius:3px;background:linear-gradient(135deg,#f8f6f0,#e8e4d8);box-shadow:1px 1px 2px #0000004d,inset 0 1px #fff9,inset -1px -1px #00000014;border:1px solid #c8c4b8;overflow:hidden}.discard-tile-styled.call-candidate{transform:translate(4px,-4px);box-shadow:-4px 4px #64a0dc80,inset 0 1px #fff9;border-color:#c8c4b8}.discard-pile{margin-bottom:4px}.analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:768px){.analysis-grid{grid-template-columns:1fr}}.yaku-section,.discard-section{background:#16213e;border-radius:12px;padding:20px}.yaku-section h2,.discard-section h2{font-size:1.1rem;color:#ccc;margin-bottom:4px}.section-hint{font-size:.75rem;color:#666;margin-bottom:12px}.yaku-list{display:flex;flex-direction:column;gap:6px}.yaku-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#1a1a3e;border-radius:6px;border-left:3px solid #333}.yaku-item.close{border-left-color:#e8c170}.yaku-item.achieved{border-left-color:#90ee90;background:#1a2e1a}.yaku-name{display:flex;flex-direction:column}.yaku-name strong{font-size:.9rem;color:#ddd}.yaku-english{font-size:.7rem;color:#777}.yaku-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.yaku-han{font-size:.7rem;color:#888}.yaku-distance{font-size:.8rem;font-weight:600;padding:2px 8px;border-radius:10px;background:#2a2a4a}.dist-0{color:#90ee90;background:#1a3e1a}.dist-1{color:#b8e86e}.dist-2{color:#e8c170}.dist-3{color:#e89070}.dist-4{color:#e86060}.dist-5{color:#c44040}.dist-6{color:#888}.discard-list{display:flex;flex-direction:column;gap:6px}.discard-item{padding:8px 12px;background:#1a1a3e;border-radius:6px;border-left:3px solid #333}.discard-item.is-drawn{border-left-color:#e8c170;background:#1e1e40}.discard-tile{display:flex;align-items:center;gap:6px;font-weight:600;margin-bottom:4px}.tile-analysis{display:inline-flex;align-items:center;justify-content:center;width:26px;height:32px;border-radius:3px;background:linear-gradient(135deg,#f8f6f0,#e8e4d8);box-shadow:1px 1px 2px #0000004d,inset 0 1px #fff9,inset -1px -1px #00000014;border:1px solid #c8c4b8;overflow:hidden;flex-shrink:0}.analysis-tile-name{font-size:.85rem}.drawn-tag{font-size:.6rem;font-weight:400;background:#e8c17033;color:#e8c170;padding:1px 6px;border-radius:4px;margin-left:4px}.discard-stats{display:flex;gap:16px;font-size:.8rem;color:#aaa}.stat strong{color:#ddd}.yaku-changes{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.change{font-size:.7rem;padding:2px 6px;border-radius:4px}.change.improve{background:#1a3e1a;color:#90ee90}.change.worsen{background:#3e1a1a;color:#ee9090}.open-melds{display:flex;gap:16px;justify-content:center;margin-top:12px;margin-bottom:4px}.meld-group{display:flex;flex-direction:column;align-items:center;gap:4px}.meld-label{font-size:.65rem;color:#888;text-transform:uppercase;letter-spacing:1px}.meld-tiles{display:flex;gap:2px}.tile-small{display:flex;align-items:center;justify-content:center;width:36px;height:46px;border-radius:4px;background:linear-gradient(135deg,#f8f6f0,#e8e4d8);box-shadow:1px 1px 2px #0000004d,inset 0 1px #fff9;border:1px solid #c8c4b8;overflow:hidden}.tile-small.called-tile{transform:rotate(90deg);margin:0 6px;position:relative;z-index:1}.call-banner{background:#1e2a4e;border:2px solid #e8c170;border-radius:10px;padding:16px 20px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;animation:call-pulse 1.5s ease-in-out infinite alternate}@keyframes call-pulse{0%{border-color:#e8c170}to{border-color:#f0d090;box-shadow:0 0 12px #e8c1704d}}.call-banner-info{display:flex;align-items:center;gap:12px}.call-label{font-size:.9rem;color:#ccc}.call-label strong{color:#e8c170}.call-buttons{display:flex;gap:8px;flex-wrap:wrap}.call-btn{padding:8px 20px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .1s,background .2s}.call-btn:hover{transform:scale(1.05)}.call-btn:active{transform:scale(.98)}.call-pon-btn{background:#c44040;color:#fff}.call-pon-btn:hover{background:#d45050}.call-chi-btn{background:#2e6b2e;color:#fff}.call-chi-btn:hover{background:#3e8b3e}.call-btn-skip{background:#444;color:#ccc}.call-btn-skip:hover{background:#555}.self-kan-banner{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#1e2040;border:1px solid #6b4ec4;border-radius:8px;margin-bottom:12px}.kan-label{font-size:.85rem;color:#b0a0d0;white-space:nowrap}.kan-buttons{display:flex;gap:8px;flex-wrap:wrap}.kan-btn{padding:6px 16px;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .1s,background .2s}.kan-btn:hover{transform:scale(1.05)}.kan-btn:active{transform:scale(.98)}.ankan-btn{background:#6b4ec4;color:#fff}.ankan-btn:hover{background:#7b5ed4}.shouminkan-btn{background:#c46b4e;color:#fff}.shouminkan-btn:hover{background:#d47b5e}.call-daiminkan-btn{background:#6b4ec4;color:#fff}.call-daiminkan-btn:hover{background:#7b5ed4}.tile-small.face-down{background:linear-gradient(135deg,#2a3a5e,#1a2a4e);border-color:#3a4a6e}.score-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.score-section{background:#16213e;border:2px solid #90ee90;border-radius:12px;padding:24px;max-width:480px;width:90%;text-align:center}.score-section h2{color:#90ee90;font-size:1.4rem;margin-bottom:16px}.score-yaku-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;max-width:400px;margin-left:auto;margin-right:auto}.score-yaku-item{display:flex;justify-content:space-between;padding:6px 12px;background:#1a2e1a;border-radius:6px;font-size:.85rem;color:#ccc}.score-yaku-han{color:#e8c170;font-weight:600}.score-summary{margin-bottom:16px}.score-han-fu{font-size:1.1rem;color:#e8c170;margin-bottom:4px}.score-limit{font-size:1.6rem;font-weight:700;color:#ff6b6b;text-transform:uppercase;letter-spacing:2px;margin:8px 0}.score-points{font-size:1.3rem;color:#90ee90;font-weight:600}.score-payment-detail{font-size:.8rem;color:#888;font-weight:400}.wind-badge{display:inline-flex;align-items:center;gap:6px;background:#2a3a5e;padding:4px 12px;border-radius:20px;font-size:.8rem;color:#e8c170;border:1px solid #3a4a6e}.wind-icon{font-size:1.2rem;line-height:1;transform:translateY(-2px)}.wind-text{font-size:.8rem;font-weight:600}.opponent-discards-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.opponent-pile h3{font-size:.8rem;color:#888;margin-bottom:6px;font-weight:500}@media(max-width:600px){.opponent-discards-grid{grid-template-columns:1fr}}.riichi-badge{background:#c44040;padding:4px 12px;border-radius:20px;animation:riichi-pulse 1.5s ease-in-out infinite}.riichi-badge-text{font-size:.85rem;font-weight:700;color:#fff}@keyframes riichi-pulse{0%,to{box-shadow:0 0 4px #c4404066}50%{box-shadow:0 0 12px #c44040cc}}.furiten-badge{background:#8b6914;padding:4px 12px;border-radius:20px}.furiten-badge-text{font-size:.85rem;font-weight:600;color:gold}.riichi-banner{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#2a1520;border:1px solid #c44040;border-radius:8px;margin-bottom:12px}.riichi-banner-text{font-size:.85rem;color:#f0a0a0;flex:1}.riichi-btn{padding:8px 20px;border:none;border-radius:6px;font-size:.9rem;font-weight:700;cursor:pointer;background:#c44040;color:#fff;transition:transform .1s,background .2s}.riichi-btn:hover{background:#d45050;transform:scale(1.05)}.riichi-btn:active{transform:scale(.98)}.tile.riichi-invalid{opacity:.3;pointer-events:none}.call-ron-btn{background:#e03030;color:#fff;animation:ron-pulse 1s ease-in-out infinite}.call-ron-btn:hover{background:#f04040}@keyframes ron-pulse{0%,to{box-shadow:0 0 4px #e0303066}50%{box-shadow:0 0 16px #e03030cc}}.tile.ron-win{box-shadow:0 0 0 2px #e0303099,0 0 12px #e030304d,1px 2px 3px #0006,inset 0 1px #fffc,inset -1px -1px #0000001a}
