:root{--screen-bg:radial-gradient(circle at center, #ffffff0d, transparent 44%), linear-gradient(145deg, #1a472a, #133520);--game-area-bg:transparent;--table-bg:#1a472a;--table-bg-dark:#133520;--card-face-bg:#f5f0e8;--card-back-top:#8b0000;--card-back-bot:#6b0000;--card-border:#0000002e;--card-shadow:0 2px 8px #00000059;--card-selected-glow:0 0 0 2px gold, 0 0 18px #ffd70073, 0 4px 12px #0006;--card-w:clamp(46px, 11.5vw, 66px);--card-h:calc(var(--card-w) * 1.508);--card-r:calc(var(--card-w) * .09);--font:system-ui, -apple-system, "Segoe UI", sans-serif;--text-primary:#fff;--text-muted:#ffffff9e;--text-dim:#ffffff40;--gold:gold;--gold-dim:#ffd70026;--panel-bg:#00000047;--panel-border:#ffffff1a;--panel-r:10px;--btn-bg:#ffffff24;--btn-active-bg:#ffffff38;--btn-secondary-text:#fff;--control-bg:#ffffff1f;--control-bg-readonly:#00000038;--control-border:#ffffff2e;--control-text:#fff;--row-bg:#ffffff14;--slot-border:#ffffff26;--safe-top:env(safe-area-inset-top,12px);--safe-bottom:env(safe-area-inset-bottom,12px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-in:cubic-bezier(.64, 0, .78, 0)}[data-theme=minimal-light]{--screen-bg:#f0ede8;--game-area-bg:linear-gradient(145deg, #d4e8d4, #c2dbc2);--table-bg:#d4e8d4;--table-bg-dark:#b7d2b7;--card-face-bg:#fafafa;--card-back-top:#fafafa;--card-back-bot:#e8e5df;--card-border:#1a1a1a29;--card-shadow:0 2px 8px #1a1a1a2e;--card-selected-glow:0 0 0 2px #2f2f2f, 0 0 14px #2f2f2f38, 0 4px 12px #1a1a1a2e;--text-primary:#1a1a1a;--text-muted:#1a1a1a9e;--text-dim:#1a1a1a42;--gold:#2f2f2f;--gold-dim:#2f2f2f1a;--panel-bg:#ffffff9e;--panel-border:#1a1a1a1f;--btn-bg:#1a1a1a14;--btn-active-bg:#1a1a1a24;--btn-secondary-text:#1a1a1a;--control-bg:#ffffffb8;--control-bg-readonly:#1a1a1a0f;--control-border:#1a1a1a24;--control-text:#1a1a1a;--row-bg:#1a1a1a0f;--slot-border:#1a1a1a2e}[data-theme=minimal-dark]{--screen-bg:#0d0d0d;--game-area-bg:linear-gradient(145deg, #0a1f0f, #071407);--table-bg:#0a1f0f;--table-bg-dark:#071407;--card-face-bg:#111;--card-back-top:#111;--card-back-bot:#050505;--card-border:#ffffff29;--card-shadow:0 2px 10px #0000008c;--text-primary:#f7f7f7;--text-muted:#f7f7f79e;--text-dim:#f7f7f747;--gold:#f5c518;--gold-dim:#f5c51824;--panel-bg:#ffffff14;--panel-border:#ffffff1a;--btn-bg:#ffffff1a;--btn-active-bg:#ffffff29;--btn-secondary-text:#f7f7f7;--control-bg:#ffffff17;--control-bg-readonly:#ffffff0d;--control-border:#ffffff29;--control-text:#f7f7f7;--row-bg:#ffffff14;--slot-border:#ffffff29}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--table-bg);width:100%;height:100%;font-family:var(--font);color:var(--text-primary);-webkit-tap-highlight-color:transparent;touch-action:none;overflow:hidden}button,input{font:inherit}button{color:inherit}#app{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.hidden{display:none!important}.safe-top{padding-top:max(var(--safe-top), 10px)}.safe-bottom{padding-bottom:max(var(--safe-bottom), 10px)}.screen{background:var(--screen-bg);flex-direction:column;width:100%;height:100%;display:flex}.screen-menu,.screen-gameover{padding:max(var(--safe-top), 20px) 24px max(var(--safe-bottom), 20px);justify-content:center;align-items:center;gap:48px}.menu-settings-btn{top:max(var(--safe-top), 16px);right:max(var(--safe-right), 16px);font-size:20px;position:absolute}.menu-logo{text-align:center}.menu-logo-icon{justify-content:center;margin-bottom:16px;display:flex}.menu-suit-group{grid-template-columns:repeat(2,1fr);gap:8px;width:82px;height:82px;margin:0 auto;display:grid}.suit-icon{color:currentColor;width:100%;height:100%;display:block}.menu-title{letter-spacing:0;font-size:clamp(28px,8vw,40px);font-weight:700}.menu-sub,.screen-status{color:var(--text-muted);margin-top:6px;font-size:14px}.menu-actions{flex-direction:column;gap:12px;width:100%;max-width:280px;display:flex}.btn{cursor:pointer;width:100%;min-height:52px;transition:transform .15s var(--ease-spring), opacity .15s, background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;border-radius:28px;padding:14px 24px;font-size:16px;font-weight:650}.btn:active{transform:scale(.96)}.btn-primary{background:var(--gold);color:#1a1a1a}.btn-secondary,.btn-ghost{background:var(--btn-bg);color:var(--btn-secondary-text);border:1px solid var(--control-border)}.btn-ghost{color:var(--text-muted);background:0 0}.btn-compact{width:auto;min-height:42px;padding:9px 14px;font-size:13px}.btn:disabled{opacity:.4;pointer-events:none}.icon-btn{border:1px solid var(--control-border);background:var(--btn-bg);width:44px;height:44px;color:var(--btn-secondary-text);border-radius:999px;font-size:32px;line-height:1}.screen-lobby,.screen-settings{padding:max(var(--safe-top), 16px) max(var(--safe-right), 18px) max(var(--safe-bottom), 16px) max(var(--safe-left), 18px);overflow:hidden}.settings-shell{grid-template-rows:auto 1fr;gap:18px;width:100%;max-width:440px;height:100%;margin:0 auto;display:grid}.settings-header{align-items:center;gap:12px;display:flex}.theme-list{flex-direction:column;gap:10px;min-height:0;display:flex;overflow-y:auto}.theme-card{border:1px solid var(--panel-border);background:var(--row-bg);width:100%;min-height:74px;color:var(--text-primary);text-align:left;border-radius:8px;grid-template-columns:60px 1fr 24px;align-items:center;gap:12px;padding:12px;display:grid}.theme-card--active{border-color:var(--gold);background:var(--gold-dim)}.theme-preview{background:var(--theme-preview-bg);border:1px solid var(--theme-preview-border);border-radius:8px;justify-content:center;align-items:center;width:60px;height:44px;display:flex;overflow:hidden}.theme-preview-card{border:1px solid var(--theme-preview-border);background:var(--theme-preview-card);color:#f5c518;border-radius:3px;flex-direction:column;justify-content:center;align-items:center;gap:1px;width:24px;height:34px;font-size:12px;font-weight:800;line-height:1;display:flex;overflow:hidden}.theme-preview-card img{object-fit:cover;width:100%;height:100%;display:block}.theme-preview-suit{width:13px;height:13px}.theme-info,.theme-name,.theme-desc{min-width:0;display:block}.theme-name{font-size:16px;font-weight:700}.theme-desc{color:var(--text-muted);margin-top:3px;font-size:13px}.theme-check{color:var(--gold);text-align:center;font-size:20px;font-weight:800}.screen-waiting{grid-template-rows:auto 1fr auto;height:100%;display:grid}.waiting-header{background:var(--panel-bg);align-items:center;gap:12px;padding:12px 20px;display:flex}.waiting-title{text-align:center;flex:1;font-size:17px;font-weight:650}.waiting-body{flex-direction:column;gap:24px;padding:24px 20px;display:flex;overflow-y:auto}.room-code-block{text-align:center;flex-direction:column;gap:10px;display:flex}.room-code-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px}.room-code-value{color:var(--gold);letter-spacing:.12em;font-size:clamp(36px,14vw,44px);font-weight:800;line-height:1}.btn-copy{align-self:center;max-width:260px}.player-list-label{color:var(--text-muted);margin-bottom:8px;font-size:13px}.waiting-player-list{flex-direction:column;gap:8px;list-style:none;display:flex}.player-slot{border-radius:8px;align-items:center;gap:12px;min-height:50px;padding:12px 16px;display:flex}.player-slot--filled{background:#4ade801f}.player-slot--empty{background:var(--panel-bg)}.slot-icon{text-align:center;width:24px;font-size:16px}.slot-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:16px;font-weight:500;overflow:hidden}.player-slot--empty .slot-name{color:var(--text-muted);font-weight:400}.waiting-footer{padding:16px 20px max(var(--safe-bottom), 16px);background:var(--panel-bg);flex-direction:column;align-items:center;gap:8px;display:flex}.waiting-hint,.waiting-for-host{color:var(--text-muted);text-align:center;font-size:13px}.lobby-shell{grid-template-rows:auto auto 1fr;gap:16px;width:100%;max-width:440px;height:100%;margin:0 auto;display:grid}.lobby-header{align-items:center;gap:12px;display:flex}.screen-title{letter-spacing:0;font-size:clamp(28px,8vw,38px);font-weight:760;line-height:1.08}.lobby-form,.room-panel,.gameover-panel{flex-direction:column;gap:12px;width:100%;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field span,.section-label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700}.field input{border:1px solid var(--control-border);background:var(--control-bg);width:100%;min-height:52px;color:var(--control-text);text-transform:none;touch-action:manipulation;border-radius:10px;outline:none;padding:0 16px;font-size:18px}.field input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim)}.field input:read-only{color:var(--gold);background:var(--control-bg-readonly);border-color:var(--gold)}.field select{border:1px solid var(--control-border);background:var(--control-bg);width:100%;min-height:46px;color:var(--control-text);border-radius:10px;outline:none;padding:0 12px;font-size:16px}.field select:disabled{opacity:.5}#room-code{text-transform:uppercase;letter-spacing:.1em}.lobby-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.room-panel{border-radius:var(--panel-r);background:var(--panel-bg);border:1px solid var(--panel-border);min-height:0;padding:14px}.room-code-row{justify-content:space-between;align-items:center;gap:12px;display:flex}#room-code-text{letter-spacing:.1em;color:var(--gold);margin-top:2px;font-size:clamp(24px,8vw,34px);display:block}.player-list{flex-direction:column;gap:8px;min-height:0;display:flex;overflow:hidden}.player-row{background:var(--row-bg);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;min-height:54px;padding:10px 12px;display:flex}.player-row--local{outline:2px solid var(--gold);background:var(--gold-dim)}.player-row strong,.player-row span{display:block}.player-row strong{font-size:15px}.player-row span{color:var(--text-muted);margin-top:2px;font-size:12px}.seat-btn{border:1px solid var(--control-border);background:var(--btn-bg);min-width:82px;min-height:36px;color:var(--btn-secondary-text);border-radius:999px;padding:0 12px;font-size:12px;font-weight:700}.seat-btn:disabled{opacity:.48}.toggle-row{min-height:44px;color:var(--text-muted);align-items:center;gap:10px;font-size:14px;display:flex}.toggle-row input{width:20px;height:20px;accent-color:var(--gold)}.screen-game{grid-template-rows:auto auto 1fr auto auto auto;height:100%;display:grid}.score-bar{background:var(--panel-bg);justify-content:space-between;align-items:center;gap:8px;padding:8px 16px 10px;display:flex}.team-score{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.team-score:last-child{text-align:right;align-items:flex-end}.team-score--local .team-name{color:var(--gold)}.team-name{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:10px}.team-pts{align-items:center;gap:2px;font-size:20px;font-weight:760;line-height:1.15;display:inline-flex}.team-pts em{color:var(--text-muted);font-size:11px;font-style:normal;font-weight:400}.tokens{align-items:center;gap:1px;margin-left:4px;display:inline-flex}.token-img{object-fit:contain;pointer-events:none;display:block}.token-stick{width:auto;height:18px;margin-inline:-2px}.token-bean{width:auto;height:14px}.progress-track{background:#ffffff1a;border-radius:2px;width:100%;max-width:80px;height:3px;margin-top:3px}.progress-fill{background:var(--gold);width:0;height:100%;transition:width .6s var(--ease-out);border-radius:2px}.match-counter{align-items:center;gap:6px;font-size:22px;font-weight:760;display:flex}.match-sep{color:var(--text-dim);font-weight:300}.game-meta{min-height:30px;color:var(--text-muted);justify-content:space-between;align-items:center;gap:12px;padding:6px 14px;font-size:12px;display:flex}.game-meta span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.game-area{background:var(--game-area-bg);grid-template-rows:auto 1fr;grid-template-columns:auto 1fr auto;gap:4px;padding:4px;display:grid;overflow:hidden}.rival-north{grid-column:1/-1;justify-content:center;align-items:center;height:clamp(54px,12vh,80px);display:flex}.rival-west,.rival-east{flex-direction:column;justify-content:center;align-items:center;width:clamp(42px,10vw,64px);display:flex}.rival-hand-wrap{flex-direction:column;align-items:center;gap:5px;display:flex}.rival-cards{justify-content:center;align-items:center;display:flex}.rival-cards--horizontal{flex-direction:row}.rival-cards--vertical{flex-direction:column}.rival-cards--horizontal .rival-back+.rival-back{margin-left:-22px}.rival-cards--vertical .rival-back+.rival-back{margin-top:-40px}.rival-label{max-width:100px;color:var(--text-muted);text-align:center;text-overflow:ellipsis;white-space:nowrap;font-size:11px;transition:color .25s,text-shadow .25s,transform .25s;overflow:hidden}.rival-hand-wrap--active .rival-label{color:var(--gold);text-shadow:0 0 12px var(--gold-dim);transform:scale(1.08)}.table-zone{grid-template:".north."1fr"west center east"".south."1fr/1fr auto 1fr;place-items:center;min-width:0;display:grid;position:relative}.table-slot{width:calc(var(--card-w) + 8px);height:calc(var(--card-h) + 8px);border-radius:calc(var(--card-r) + 4px);border:1.5px dashed var(--slot-border);justify-content:center;align-items:center;display:flex}#slot-north{grid-area:north}#slot-west{grid-area:west}#slot-east{grid-area:east}#slot-south{grid-area:south}.local-hand{justify-content:center;align-items:flex-end;height:clamp(90px,20vh,130px);padding:0 clamp(20px,6vw,48px);transition:filter .25s;display:flex;position:relative;overflow:visible}.local-hand--active{filter:drop-shadow(0 -2px 12px var(--gold-dim))}.cante-panel{align-items:center;gap:8px;width:100%;padding:6px 12px 0;display:flex;overflow-x:auto}.cante-option{background:var(--btn-bg);color:#fff;border:1px solid #ffffff29;border-radius:999px;flex:none;min-height:36px;padding:0 12px;font-size:13px;font-weight:700}.action-bar{background:var(--panel-bg);justify-content:center;align-items:center;gap:10px;min-height:72px;padding:10px 20px;display:flex}.action-bar .btn{flex:1;max-width:160px}.signal-badge{color:#fff;white-space:nowrap;pointer-events:none;animation:popIn .25s var(--ease-spring);background:#0009;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:650;position:absolute;bottom:-28px;left:50%;transform:translate(-50%)}.game-toast{top:max(var(--safe-top), 14px);z-index:300;color:#fff;text-align:center;background:#000000b8;border-radius:999px;width:min(90vw,360px);padding:10px 14px;font-size:13px;position:absolute;left:50%;transform:translate(-50%)}.overlay-bg{z-index:200;background:#0009;justify-content:center;align-items:center;padding:24px;animation:.25s fadeIn;display:flex;position:absolute;inset:0}.summary-card,.gameover-panel{width:100%;max-width:340px;animation:slideUp .3s var(--ease-out);background:#1e5a33;border:1px solid #ffffff1f;border-radius:16px;flex-direction:column;gap:16px;padding:24px;display:flex}.summary-title{text-align:center;font-size:18px;font-weight:760}.summary-scores{flex-direction:column;gap:14px;display:flex}.summary-team{flex-direction:column;gap:4px;display:flex}.summary-team--winner .s-hand{color:var(--gold)}.s-name{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.s-hand{font-size:16px;font-weight:650}.s-bar-track{background:#ffffff1a;border-radius:2px;height:4px}.s-bar-fill{background:var(--gold);height:100%;transition:width .8s var(--ease-out);border-radius:2px}.s-total,.s-waiting{color:var(--text-muted);font-size:13px}.s-winner,.s-match,.gameover-score{text-align:center;color:var(--gold);font-size:18px;font-weight:760}@media (height<=720px){.screen-game{grid-template-rows:auto auto 1fr auto auto}.game-meta{min-height:26px;padding-block:4px}.local-hand{height:clamp(82px,18vh,110px)}.btn{min-height:46px;padding-block:11px}}.card{width:var(--card-w);height:var(--card-h);cursor:pointer;perspective:600px;-webkit-tap-highlight-color:transparent;touch-action:none;position:absolute}.card--dragging{pointer-events:none}.card-inner{width:100%;height:100%;transform-style:preserve-3d;border-radius:var(--card-r);box-shadow:var(--card-shadow);transition:box-shadow .2s;position:relative;transform:rotateY(180deg)}.card-face{backface-visibility:hidden;border-radius:var(--card-r);border:1px solid var(--card-border);position:absolute;inset:0;overflow:hidden}.card-front{background:var(--card-face-bg)}.card-back{background:linear-gradient(160deg,#8b0000f2,#6b0000f2);transform:rotateY(180deg)}.card-face img{object-fit:cover;object-position:center;pointer-events:none;width:100%;height:100%;display:block}.card--selected .card-inner{box-shadow:var(--card-selected-glow)}.card--disabled{opacity:.55;pointer-events:none!important}.card--table{cursor:default;pointer-events:none;position:relative;bottom:auto!important;left:auto!important;rotate:0deg!important}.rival-back{width:calc(var(--card-w) * .72);height:calc(var(--card-h) * .72);border-radius:calc(var(--card-r) * .72);background:url(/assets/decks/classic/back.PNG) 50%/cover,linear-gradient(160deg,#8b0000e6,#6b0000e6);border:1px solid #600000;flex-shrink:0;box-shadow:0 1px 4px #00000059}.rival-back-surface{border-radius:inherit;width:100%;height:100%;overflow:hidden}.minimal-card-value{color:currentColor;font-family:var(--font);font-size:clamp(30px, calc(var(--card-w) * .62), 44px);font-weight:850;line-height:1}.minimal-card-suit{width:clamp(24px, calc(var(--card-w) * .48), 34px);height:clamp(24px, calc(var(--card-w) * .48), 34px);color:currentColor}.minimal-card-back-grid{opacity:.42;grid-template-columns:repeat(2,1fr);gap:8%;width:72%;height:58%;display:grid}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:translate(-50%)scale(.8)}to{opacity:1;transform:translate(-50%)scale(1)}}
