@import"https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;500;700;900&display=swap";:root{--felt: #111111;--felt-dark: #080808;--felt-light: #1c1c1c;--card-bg: #faf8f3;--card-red: #c0392b;--card-black: #1a1a2e;--card-border: #e0d8c8;--gold: #c9a84c;--gold-light: #e8c96a;--text-light: #f0ead6;--text-dim: #8fad96;--shadow: rgba(0,0,0,.45);--radius: 10px;--card-w: 72px;--card-h: 105px;--card-sm-w: 50px;--card-sm-h: 72px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans,sans-serif;background:var(--felt-dark);color:var(--text-light);min-height:100vh;overflow-x:hidden}#app{min-height:100vh;display:flex;flex-direction:column}.conn-dot{position:fixed;top:10px;right:14px;font-size:11px;z-index:100;opacity:.7}.conn-dot.online{color:#7fff7f}.conn-dot.offline{color:#ff9f7f}.rejoin-btn{position:fixed;top:10px;right:90px;background:none;border:none;font-size:14px;cursor:pointer;opacity:.6;z-index:100;padding:0;line-height:1}.rejoin-btn:hover{opacity:1}.notifications{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;pointer-events:none}.notification{background:#222;color:var(--text-light);padding:8px 18px;border-radius:20px;font-size:13px;border:1px solid #444;box-shadow:0 4px 16px var(--shadow)}.notification.error{background:#5c1a1a;border-color:#a03030}.notification.success{background:#1a4a2e;border-color:#2a7a4e}.notification.warn{background:#4a3a1a;border-color:#8a6a2a}.notif-enter-active,.notif-leave-active{transition:all .3s}.notif-enter-from,.notif-leave-to{opacity:0;transform:translateY(-12px)}.card{width:var(--card-w);height:var(--card-h);border-radius:var(--radius);border:1.5px solid var(--card-border);box-shadow:0 3px 10px var(--shadow);position:relative;flex-shrink:0;-webkit-user-select:none;user-select:none;transition:transform .15s,box-shadow .15s}.card.card-sm{width:var(--card-sm-w);height:var(--card-sm-h)}.card.clickable{cursor:pointer}.card.clickable:hover{transform:translateY(-6px);box-shadow:0 8px 20px var(--shadow)}.card.selected{transform:translateY(-12px);box-shadow:0 10px 24px var(--shadow),0 0 0 2px var(--gold)}.card.faded{filter:grayscale(1) brightness(.55)}.card-face{background:var(--card-bg);display:flex;align-items:center;justify-content:center;flex-direction:column}.card-face.red .rank,.card-face.red .suit,.card-face.red .center-suit{color:var(--card-red)}.card-face.black .rank,.card-face.black .suit,.card-face.black .center-suit{color:var(--card-black)}.corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1.1}.corner.top-left{top:5px;left:6px}.corner.bottom-right{bottom:5px;right:6px;transform:rotate(180deg)}.rank{font-family:Noto Sans,sans-serif;font-size:13px;font-weight:800}.suit{font-size:11px}.card-sm .rank{font-size:10px}.card-sm .suit{font-size:8px}.center-suit{font-size:26px}.card-sm .center-suit{font-size:18px}.card-back{background:var(--card-black);background-image:repeating-linear-gradient(45deg,rgba(201,168,76,.12) 0,rgba(201,168,76,.12) 1px,transparent 0,transparent 50%);background-size:8px 8px;display:flex;align-items:center;justify-content:center}.back-pattern{color:var(--gold);font-size:22px;opacity:.6}.card-sm .back-pattern{font-size:15px}.empty-slot-inner{color:#888;font-size:22px}.stack-ghost{z-index:0}.lobby{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse at center,var(--felt) 0%,var(--felt-dark) 100%)}.lobby-card{background:#00000080;border:1px solid rgba(201,168,76,.3);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0009}.game-title{font-family:Noto Sans,sans-serif;font-size:48px;font-weight:900;color:var(--gold);text-align:center;letter-spacing:2px;text-shadow:0 2px 10px rgba(201,168,76,.4)}.subtitle{text-align:center;color:var(--text-dim);font-size:13px;margin-bottom:28px;margin-top:4px}.tabs{display:flex;border-bottom:1px solid #333;margin-bottom:24px}.tab{flex:1;background:none;border:none;color:var(--text-dim);padding:10px;cursor:pointer;font-family:Noto Sans,sans-serif;font-size:13px;transition:color .2s}.tab.active{color:var(--gold);border-bottom:2px solid var(--gold)}.form{display:flex;flex-direction:column;gap:10px}.form label{font-size:12px;color:var(--text-dim)}.hint{color:#666}.form input{background:#ffffff12;border:1px solid #444;border-radius:8px;padding:10px 12px;color:var(--text-light);font-family:Noto Sans,sans-serif;font-size:14px;outline:none;transition:border-color .2s}.form input:focus{border-color:var(--gold)}.code-input{text-transform:uppercase;letter-spacing:4px;font-size:20px;text-align:center}.number-row{display:flex;align-items:center;gap:16px}.number-row button{background:#ffffff1a;border:1px solid #555;border-radius:6px;color:var(--text-light);width:32px;height:32px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}.number-row span{font-size:20px;font-family:Noto Sans,sans-serif;color:var(--gold);min-width:24px;text-align:center}.btn-primary{background:linear-gradient(135deg,var(--gold),#a0782e);border:none;border-radius:8px;color:#1a1a1a;font-family:Noto Sans,sans-serif;font-size:14px;font-weight:700;padding:12px;cursor:pointer;margin-top:8px;transition:opacity .2s,transform .1s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.error-msg{color:#ff7f7f;font-size:12px;text-align:center;margin-top:6px}.shed-link{text-align:center;margin-top:16px;font-size:12px;color:var(--text-dim)}.shed-link a{color:var(--gold);text-decoration:none}.shed-link a:hover{text-decoration:underline}.waiting-room{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,var(--felt) 0%,var(--felt-dark) 100%)}.waiting-card{background:#00000080;border:1px solid rgba(201,168,76,.3);border-radius:16px;padding:40px;text-align:center;max-width:360px;width:100%}.room-code{font-family:Noto Sans,sans-serif;color:var(--gold);font-size:36px;letter-spacing:6px;display:block;margin:8px 0}.waiting-sub{color:var(--text-dim);font-size:12px;margin-bottom:12px}.room-code-box{display:flex;flex-direction:column;align-items:center;gap:4px;background:#c9a84c14;border:1.5px solid rgba(201,168,76,.4);border-radius:12px;padding:16px 24px;margin-bottom:24px;cursor:pointer;transition:background .2s,border-color .2s}.room-code-box:hover{background:#c9a84c26;border-color:#c9a84cb3}.copy-hint{font-size:11px;color:var(--text-dim);letter-spacing:1px}.players-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.player-row{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#ffffff0d;border-radius:8px}.player-row.me{border:1px solid rgba(201,168,76,.4)}.player-row.empty{opacity:.4}.player-dot{color:var(--gold)}.player-dot.muted{color:#555}.waiting-note{color:var(--text-dim);font-size:12px}.swap-phase{flex:1;display:flex;flex-direction:column;align-items:center;padding:24px 16px;background:radial-gradient(ellipse at center,var(--felt) 0%,var(--felt-dark) 100%);gap:20px}.swap-header{text-align:center;max-width:500px}.swap-header h2{font-family:Noto Sans,sans-serif;color:var(--gold);font-size:28px}.swap-header p{color:var(--text-dim);font-size:12px;margin:8px 0}.ready-status{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:8px}.ready-dot{font-size:12px;padding:4px 10px;border-radius:12px;background:#ffffff12;color:var(--text-dim);transition:all .3s}.ready-dot.ready{background:#2a7a4e66;color:#7fff7f}.swap-table{display:flex;flex-direction:column;gap:16px;width:100%;max-width:600px}.card-row-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.card-row{display:flex;gap:10px;flex-wrap:wrap}.game-board{flex:1;display:grid;grid-template-rows:auto auto auto auto auto 1fr;background:radial-gradient(ellipse at center,var(--felt) 30%,var(--felt-dark) 100%);padding:12px;gap:12px;min-height:100vh}.opponents-ring{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.opponent{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px 12px;min-width:120px;transition:border-color .3s}.opponent.active-player{border-color:var(--gold);box-shadow:0 0 12px #c9a84c4d}.opponent.lost{opacity:.5}.opp-name{font-size:12px;color:var(--gold);margin-bottom:6px}.opp-cards{display:flex;flex-direction:column;gap:4px}.opp-section{display:flex;gap:3px;flex-wrap:wrap}.opp-hand-section{min-height:var(--card-sm-h);align-items:flex-end}.opp-fan{display:flex;align-items:flex-end}.opp-fan>.card~.card{margin-left:-28px}.opp-no-hand{width:var(--card-sm-w);height:var(--card-sm-h);border:2px dashed rgba(255,255,255,.12);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff3;font-size:9px;text-align:center}.opp-card-stack{position:relative;width:var(--card-sm-w);height:calc(var(--card-sm-h) + 8px);flex-shrink:0}.table-centre{display:flex;gap:24px;justify-content:center;align-items:flex-end;padding:16px;background:#0003;border-radius:16px;border:1px solid rgba(255,255,255,.05)}.pile-area{display:flex;flex-direction:column;align-items:center;gap:6px}.pile-label{font-size:11px;color:var(--text-dim);text-align:center}.pile-stack{position:relative;width:var(--card-w);height:var(--card-h)}.pile-stack--discard{height:calc(var(--card-h) + 14px)}.pile-stack>.card{position:absolute;top:0;left:0}.discard-fan{position:absolute;top:0;left:0;width:var(--card-w);height:var(--card-h);display:flex;align-items:flex-start;justify-content:center;overflow:visible}.discard-fan>.card~.card{margin-left:-55px}.empty-pile{width:var(--card-w);height:var(--card-h);border:2px dashed rgba(255,255,255,.15);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff3;font-size:12px}.pile-layer{position:absolute;width:var(--card-w);height:var(--card-h);border-radius:var(--radius);border:1.5px solid var(--card-border);background:var(--card-black);background-image:repeating-linear-gradient(45deg,rgba(201,168,76,.12) 0,rgba(201,168,76,.12) 1px,transparent 0,transparent 50%);background-size:8px 8px}.pile-layer-1{transform:translate(3px,-4px) rotate(2deg)}.pile-layer-2{transform:translate(-2px,-7px) rotate(-1.5deg)}.top-value{font-size:11px;color:var(--gold);text-align:center}.low-badge{display:block;color:#fa4;font-size:11px}.burnt .burnt-count{font-size:22px}.turn-banner{text-align:center;font-size:13px;color:var(--text-dim);padding:8px;border-radius:8px;background:#0003}.turn-banner.my-turn{color:#fff;font-size:16px;font-weight:700;background:#c9a84c38;border:2px solid var(--gold);text-shadow:0 0 12px rgba(201,168,76,.8);animation:pulse 1.4s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #c9a84c80}50%{box-shadow:0 0 18px 6px #c9a84c59}}.my-table-cards{display:flex;gap:24px;justify-content:center}.table-section{display:flex;flex-direction:column;align-items:center;gap:6px}.section-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.section-cards{display:flex;gap:6px}.table-card-stack{position:relative;width:var(--card-w);height:calc(var(--card-h) + 12px);flex-shrink:0}.stack-bottom{position:absolute;bottom:0;left:0}.stack-top{position:absolute;top:0;left:0;z-index:1}.my-hand{display:flex;flex-direction:column;align-items:center;gap:10px}.hand-label{font-size:12px;color:var(--text-dim);display:flex;gap:12px;align-items:center}.selected-hint{color:var(--gold)}.hand-cards{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.action-buttons{display:flex;gap:10px}.hand-cards{position:relative}.discard-top-enter-active{animation:card-land .35s ease-out}@keyframes card-land{0%{opacity:0;transform:rotate(-4deg)}to{opacity:1;transform:none}}.btn-play{background:linear-gradient(135deg,#2a7a4e,#1a5c2e);border:1px solid #3a9a6e;border-radius:8px;color:#fff;font-family:Noto Sans,sans-serif;font-size:13px;padding:10px 20px;cursor:pointer;transition:opacity .2s}.btn-play:disabled{opacity:.35;cursor:not-allowed}.btn-play:not(:disabled):hover{opacity:.85}.btn-pickup{background:#b43c3c4d;border:1px solid rgba(180,60,60,.5);border-radius:8px;color:#faa;font-family:Noto Sans,sans-serif;font-size:13px;padding:10px 20px;cursor:pointer;transition:opacity .2s}.btn-pickup:disabled{opacity:.25;cursor:not-allowed}.btn-pickup:not(:disabled):hover{opacity:.8}.game-log{background:#0000004d;border-radius:8px;padding:10px 14px;display:flex;flex-direction:column;gap:3px;overflow:hidden;align-self:end}.log-entry{font-size:11px;color:var(--text-dim)}.log-entry:first-child{color:var(--text-light);font-size:14px;font-weight:600}.end-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000008c;z-index:500}.end-card{background:#0009;border:1px solid rgba(201,168,76,.3);border-radius:16px;padding:48px 40px;text-align:center;max-width:400px;width:100%;position:relative}.end-close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--text-dim);font-size:22px;cursor:pointer;line-height:1;padding:0}.end-close:hover{color:var(--text-light)}.end-emoji{font-size:64px;margin-bottom:16px}.winner-title{font-family:Noto Sans,sans-serif;color:var(--gold);font-size:32px}.loser-title{font-family:Noto Sans,sans-serif;color:#c0392b;font-size:32px}.loser-note{color:var(--text-dim);font-size:13px;margin:8px 0 20px}.final-standings{display:flex;flex-direction:column;gap:8px;margin:20px 0}.standing{padding:8px 16px;border-radius:8px;font-size:13px}.standing.survived{background:#2a7a4e33;color:#7fff7f}.standing.lost{background:#b43c3c33;color:#ff9f9f}@media (max-width: 500px){:root{--card-w: 58px;--card-h: 84px;--card-sm-w: 40px;--card-sm-h: 58px}.rank{font-size:11px}.center-suit{font-size:20px}.game-title{font-size:36px}.discard-fan>.card~.card{margin-left:-44px}.opp-fan>.card~.card{margin-left:-22px}.table-centre{gap:16px;padding:10px 12px}.turn-banner{font-size:11px;padding:6px 8px}.btn-play,.btn-pickup{padding:12px 14px;font-size:12px;min-height:44px}.game-board{padding:8px;gap:8px}.game-log{padding:8px 10px}.log-entry:first-child{font-size:12px}.turn-banner.my-turn{font-size:13px}}@media (hover: none){.card.clickable:hover{transform:none;box-shadow:0 3px 10px var(--shadow)}.card.clickable.selected{transform:translateY(-12px);box-shadow:0 10px 24px var(--shadow),0 0 0 2px var(--gold)}}.discard-peek{position:absolute;top:0;left:0;width:var(--card-w);height:var(--card-h);overflow:visible}.discard-peek .peek-beneath{position:absolute;top:0;left:0}.discard-peek .peek-three{position:absolute;top:14px;left:18px;z-index:1}.help-btn{position:fixed;bottom:16px;right:16px;width:40px;height:40px;border-radius:50%;background:#c9a84c33;border:1.5px solid rgba(201,168,76,.5);color:var(--gold);font-size:18px;font-weight:700;cursor:pointer;z-index:300;display:flex;align-items:center;justify-content:center;transition:background .2s}.help-btn:hover{background:#c9a84c59}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:400;display:flex;align-items:center;justify-content:center;padding:16px}.modal-box{background:#1a1a1a;border:1px solid rgba(201,168,76,.35);border-radius:16px;padding:28px 28px 24px;max-width:520px;width:100%;max-height:85vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--text-dim);font-size:22px;cursor:pointer;line-height:1;padding:0}.modal-close:hover{color:var(--text-light)}.modal-title{font-size:20px;font-weight:900;color:var(--gold);margin-bottom:18px}.modal-tabs{display:flex;gap:0;border-bottom:1px solid #333;margin-bottom:18px}.modal-tab{background:none;border:none;color:var(--text-dim);font-family:Noto Sans,sans-serif;font-size:13px;padding:8px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.modal-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.cheat-section{margin-bottom:18px}.cheat-section h3{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.cheat-row{display:flex;align-items:baseline;gap:10px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:13px}.cheat-row:last-child{border-bottom:none}.cheat-rank{font-size:15px;font-weight:800;color:var(--gold);min-width:52px}.cheat-desc{color:var(--text-light);line-height:1.4}.dir-step{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:13px;line-height:1.5}.dir-step:last-child{border-bottom:none}.dir-num{font-size:11px;font-weight:700;color:var(--gold);background:#c9a84c1f;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.dir-text{color:var(--text-light)}.shed-inline-link{color:var(--gold);text-decoration:underline}.shed-inline-link:hover{opacity:.8}
