:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;--app-scale: 1;--app-base-font: clamp(14px, 11px + 1.2vw, 18px);--font-3xs: calc(11px * var(--app-scale));--font-2xs: calc(12px * var(--app-scale));--font-xs: calc(13px * var(--app-scale));--font-sm: calc(14px * var(--app-scale));--font-md: calc(15px * var(--app-scale));--font-lg: calc(16px * var(--app-scale));--font-xl: calc(18px * var(--app-scale));--font-2xl: calc(20px * var(--app-scale));--font-3xl: calc(28px * var(--app-scale));--card-width: calc(68px * var(--app-scale));--card-height: calc(96px * var(--app-scale));--card-small-width: calc(48px * var(--app-scale));--card-small-height: calc(72px * var(--app-scale));--card-back-width: calc(42px * var(--app-scale));--card-back-height: calc(60px * var(--app-scale));--card-large-width: calc(72px * var(--app-scale));--card-large-height: calc(104px * var(--app-scale))}html{font-size:var(--app-base-font)}body{margin:0;min-height:var(--app-vh-stable, 100vh)}.app{padding:.75rem}.row{display:flex;gap:8px;align-items:center}.hand{display:flex;gap:6px;flex-wrap:wrap}.table{display:flex;gap:8px;padding:8px;min-height:100px;border:1px dashed #ccc;border-radius:12px}.badge{padding:2px 8px;border-radius:999px;background:#eee}.button{padding:8px 12px;border:none;border-radius:10px;background:#000;color:#fff;cursor:pointer}.button.secondary{background:#444}.grid{display:grid;gap:12px}.tabs{display:flex;gap:8px;margin-top:8px}.tab{padding:8px 12px;border-radius:999px;border:1px solid #ddd;background:#fff;font-weight:600;cursor:pointer;transition:all .15s ease}.tab.active{background:#111;color:#fff;border-color:#111}.tab:active{transform:translateY(1px)}.board{display:grid;gap:12}.opponents{display:flex;justify-content:center;gap:32}.opponent-slot{display:flex;gap:6}.card-back{width:var(--card-back-width);height:var(--card-back-height);border-radius:.5rem;background:linear-gradient(135deg,#7b8bff,#a1b1ff);border:1px solid rgba(0,0,0,.15);box-shadow:0 2px 6px #0000001f}.table-center{display:flex;align-items:center;justify-content:center;gap:24;min-height:110px}.table-cards{display:flex;gap:8;min-height:80px;align-items:center}.card{width:var(--card-width);height:calc(var(--card-height) * .833);border-radius:.625rem;background:#fff;border:1px solid rgba(0,0,0,.15);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001f;-webkit-user-select:none;user-select:none}.card:hover{transform:translateY(-.25rem)}.card .rank{font-weight:800}.card .suit{font-size:calc(var(--font-xl) * 1.1);line-height:1;margin-top:.125rem}.card .suit.red{color:#d33}.card.on-table{transform:rotate(-2deg)}.trump{display:flex;flex-direction:column;align-items:center;gap:6}.trump-title{font-size:var(--font-2xs);opacity:.7}.trump-card{transform:rotate(8deg)}.trump-card.ghost{background:#f5f5f5;color:#aaa}.room-row{display:grid;grid-template-columns:1fr auto auto;gap:12;align-items:center;padding:10px 12px;border:1px solid #e7e7e7;border-radius:12px;background:#fff}.room-title{min-width:0}.room-name{font-weight:700}.room-sub{font-size:var(--font-2xs);opacity:.7}.room-meta{display:flex;gap:8;align-items:center;justify-content:flex-end}.room-actions{display:flex;gap:8}.badge.warn{background:#fff7e6;border:1px solid #fde1a8}.controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.combo-panel{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.combo-title{font-size:var(--font-2xs);color:var(--muted);font-weight:600}.input{flex:1 1 auto;padding:10px 12px;border:1px solid #ddd;border-radius:10px}:root{--bg: #ffffff;--fg: #111111;--muted: #666;--card: #ffffff;--border: #e7e7e7;--primary: #111111;--primary-fg: #ffffff}html[data-theme=dark]{--bg: #0f1115;--fg: #f3f3f3;--muted: #9aa3ad;--card: #12141a;--border: #222733;--primary: #f3f3f3;--primary-fg: #0f1115}body,.app{background:var(--bg);color:var(--fg)}.menu-wrap{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center}.menu-title{font-size:var(--font-3xl);font-weight:800;margin:0 0 6px}.menu-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.btn-xl{padding:14px 20px;border-radius:14px;border:1px solid var(--border);background:var(--card);color:var(--fg);font-weight:800;font-size:var(--font-lg)}.btn-xl.primary{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}.btn-xl.ghost{background:transparent;border-style:dashed}.menu-note{font-size:var(--font-2xs);opacity:.7}.page-wrap{display:grid;gap:12px;padding:12px}.page-title{font-size:var(--font-2xl);font-weight:800;margin:2px 0 6px}.link-btn{background:none;border:none;color:var(--muted);text-decoration:underline;padding:6px 0}.rules{display:grid;gap:14px;line-height:1.45;font-size:var(--font-sm)}.rules section{display:grid;gap:6px;border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--card)}.rules h3{margin:0;font-size:var(--font-md);font-weight:700}.rules ul{margin:0;padding-left:18px;display:grid;gap:4px}.lobby-wrap{display:grid;gap:12px}.lobby-toolbar{display:flex;gap:8px;align-items:center}.search-row{display:flex;gap:8px;flex:1}.icon-btn{border:1px solid var(--border);background:var(--card);border-radius:10px;padding:8px 10px}.rooms-grid{display:grid;gap:10px;grid-template-columns:1fr}.room-card{border:1px solid var(--border);background:var(--card);border-radius:14px;padding:12px;display:grid;gap:10px}.room-head{display:flex;flex-direction:column;gap:4px}.room-name{font-weight:800}.room-variant{font-size:var(--font-2xs);color:var(--muted)}.room-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.button.full{width:100%}.input{flex:1 1 auto;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--card);color:var(--fg)}.button{padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--fg);font-weight:700}.button.primary{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}.create-form{display:grid;gap:16px}.settings-section{display:grid;gap:12px}.section-title{margin:0;font-size:var(--font-lg);font-weight:800}.settings-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.settings-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:var(--card);display:grid;gap:10px}.settings-card legend{font-weight:700}.settings-note{margin:0;font-size:var(--font-2xs);color:var(--muted)}.options-row{display:flex;flex-wrap:wrap;gap:8px}.option-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--border);border-radius:999px;cursor:pointer}.option-chip input{display:none}.option-chip.active{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}.option-tile{display:grid;gap:4px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;cursor:pointer;background:var(--card)}.option-tile input{display:none}.option-tile.active{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 20%,transparent)}.option-title{font-weight:700}.option-desc{font-size:var(--font-2xs);color:var(--muted)}.switch{display:flex;align-items:center;gap:8px;font-weight:700;cursor:pointer}.switch input{width:18px;height:18px}.form-summary{border:1px solid var(--border);border-radius:14px;padding:12px;background:var(--card);display:grid;gap:6px}.summary-title{font-weight:700}.summary-text{font-size:var(--font-xs);color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--muted);font-size:var(--font-2xs)}.badge.strong{color:var(--fg);font-weight:700}.card{width:var(--card-width);height:var(--card-height);border-radius:.625rem;border:1px solid var(--border);background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 6px #00000014;transition:transform .15s ease,box-shadow .15s ease}.card-rank{font-weight:800;font-size:var(--font-xl);line-height:1}.card-suit{font-size:var(--font-xl);opacity:.9}.table-area{position:relative;display:grid;gap:12px}.pairs{display:flex;flex-wrap:wrap;gap:12px;min-height:112px}.pair{display:flex;gap:12px;align-items:center}.cover-slot{width:var(--card-width);height:var(--card-height);border:1px dashed var(--border);border-radius:.625rem;opacity:.5}.trump-panel{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:var(--card);border-radius:14px;padding:8px 10px;width:fit-content}.trump-title{font-weight:700}.drop-zone{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;outline:2px dashed transparent;pointer-events:none}.drop-zone.drop-active{outline-color:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 20%,transparent)}.playing-card{width:var(--card-width);height:var(--card-height);border-radius:12px;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);background:linear-gradient(180deg,#fff,#f1f4ff);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 6px 18px #0000002e;padding:10px;transition:transform .15s ease,box-shadow .15s ease}.playing-card.face.red{color:#c12c3a}.playing-card.face.black{color:#162333}.playing-card.back{background:linear-gradient(135deg,#2f3a4b,#1b222d);border:1px solid rgba(0,0,0,.45);box-shadow:inset 0 0 0 2px #ffffff0f,0 8px 18px #00000059}.playing-card.back:before{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border-radius:10px;background:repeating-linear-gradient(45deg,#ffffff2e 0,#ffffff2e 6px,#fff0 6px,#fff0 12px)}.playing-card.muted{opacity:.65}.pc-corner{position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:var(--font-xs);font-weight:700}.pc-corner-top{top:8px;left:8px}.pc-corner-bottom{bottom:8px;right:8px;transform:rotate(180deg)}.pc-center{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.pc-center img{max-width:60px;width:72%;object-fit:contain;filter:drop-shadow(0 4px 6px rgba(0,0,0,.18))}.pc-symbol{font-size:calc(var(--font-3xl) * .9);line-height:1}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:var(--card);font-size:var(--font-2xs);font-weight:600}.hand{display:grid;gap:12px;padding:12px;border:1px solid var(--border);border-radius:16px;background:var(--card)}.hand.deal-anim .hand-card{animation:deal .35s ease both}.hand-hint{font-size:var(--font-2xs);color:var(--muted)}.hand-cards{display:flex;flex-wrap:wrap;gap:8px}.hand-card{border:none;background:none;padding:0;cursor:pointer;position:relative}.hand-card.selected:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:12px;border:2px solid var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 25%,transparent)}.hand-card:disabled{opacity:.5;cursor:not-allowed}.hand-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.chip{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);cursor:pointer;font-size:var(--font-2xs)}.chip:disabled{opacity:.5;cursor:not-allowed}@keyframes deal{0%{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}.game-page{display:flex;flex-direction:column;gap:12px;padding:12px}.game-settings{display:flex;flex-direction:column;gap:10px;border:1px solid var(--border);border-radius:16px;padding:12px;background:var(--card);box-shadow:0 6px 20px #00000014}.settings-title{font-size:var(--font-xl);font-weight:800}.settings-pills{display:flex;flex-wrap:wrap;gap:8px}.game-settings .controls{padding-top:4px}.game-table{display:grid;gap:12px;padding:12px;border:1px solid var(--border);border-radius:18px;background:var(--card);box-shadow:0 10px 24px #0000001f}.table-header{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;justify-content:space-between}.table-meta-left{display:flex;flex-wrap:wrap;gap:8px}.table-meta-right{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;margin-left:auto}.table-player{display:inline-flex;align-items:center;gap:8px;font-size:var(--font-sm);color:var(--muted);font-weight:600}.table-player.active{color:var(--fg)}.player-timer{padding:2px 8px;border-radius:8px;border:1px solid var(--border);font-size:var(--font-2xs);background:color-mix(in srgb,var(--primary) 12%,var(--card))}.table-board{position:relative;display:flex;flex-direction:column;gap:14px;border:1px dashed var(--border);border-radius:16px;padding:16px 12px;min-height:140px;background:color-mix(in srgb,var(--card) 85%,transparent);transition:border-color .2s ease,background .2s ease}.table-board.drop-active{border-color:color-mix(in srgb,var(--primary) 35%,var(--border));background:color-mix(in srgb,var(--primary) 10%,var(--card))}.board-row{display:flex;gap:12px;justify-content:center}.board-slot{display:flex;flex-direction:column;gap:10px;align-items:center}.slot-top,.slot-bottom{min-height:var(--card-height);display:flex;align-items:center;justify-content:center}.card-placeholder{width:var(--card-width);height:var(--card-height);border-radius:12px;border:1px dashed var(--border);opacity:.4}.board-empty{text-align:center;color:var(--muted);font-size:var(--font-sm);padding:12px 0}.board-stack{display:grid;gap:8px}.stack-row{display:flex;gap:10px;align-items:center}.stack-name{min-width:72px;font-weight:600;font-size:var(--font-xs);color:var(--muted)}.stack-cards{display:flex;gap:6px;flex-wrap:wrap}.drop-hint{position:absolute;left:12px;right:12px;bottom:8px;text-align:center;font-size:var(--font-2xs);color:var(--muted)}.hand-wrap{border:1px solid var(--border);border-radius:16px;padding:12px;background:var(--card);display:grid;gap:8px;box-shadow:0 6px 20px #00000014}.hand-title{margin:0;font-size:var(--font-lg);font-weight:700}.scoreboard{border:1px solid var(--border);border-radius:16px;background:var(--card);box-shadow:0 6px 20px #00000014;overflow:hidden}.scoreboard table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.scoreboard th,.scoreboard td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:center}.scoreboard th:first-child,.scoreboard td:first-child{text-align:left;font-weight:700}.scoreboard th{background:color-mix(in srgb,var(--card) 85%,transparent);color:var(--muted);font-size:var(--font-2xs);text-transform:uppercase;letter-spacing:.05em}.scoreboard tr:last-child td{border-bottom:0}.hand{display:grid;gap:12px;padding:12px;border:1px solid var(--border);border-radius:18px;background:var(--card);outline:none;transition:box-shadow .2s ease}.hand.dragging{box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 25%,transparent)}.hand-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.hand-hint{font-weight:700;font-size:var(--font-sm)}.hand-meta{display:flex;gap:8px;flex-wrap:wrap}.hand-feedback{font-size:var(--font-xs);color:var(--muted);min-height:18px}.hand-feedback.error{color:#d33;animation:shake .18s linear 2}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.hand-cards{display:flex;flex-wrap:wrap;gap:10px}.hand-card{border:none;background:transparent;padding:0;cursor:pointer;position:relative;transition:transform .15s ease}.hand-card.selected{transform:translateY(-8px)}.hand-card:focus-visible{outline:2px solid var(--primary);outline-offset:4px}.hand-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end}.card.hidden{background:repeating-linear-gradient(45deg,#00000014,#00000014 6px,#0000 6px,#0000 12px);color:var(--muted)}.card.muted{opacity:.7}.card.red .card-rank,.card.red .card-suit{color:#c23838}.game-page{display:flex;flex-direction:column;gap:14px;padding:12px;max-width:440px;margin:0 auto}.game-settings{display:grid;gap:8px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--card)}.settings-head{display:flex;flex-direction:column;gap:2px}.settings-title{font-weight:700;font-size:var(--font-lg)}.settings-sub{font-size:var(--font-2xs);color:var(--muted)}.settings-pills{display:flex;gap:8px;flex-wrap:wrap}.meta-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);font-size:var(--font-2xs);font-weight:600}.game-table{display:grid;gap:12px;padding:12px;border-radius:16px;border:1px solid var(--border);background:var(--card);box-shadow:0 6px 20px #0f121640}.table-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.table-meta-left{display:flex;flex-direction:column;gap:6px}.table-meta-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:1}.players-list{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.table-player{display:flex;align-items:center;gap:8px;font-weight:600;padding:4px 8px;border-radius:10px}.table-player.active{background:var(--card);background:color-mix(in srgb,var(--primary) 18%,transparent)}.player-name{white-space:nowrap}.player-timer{padding:2px 8px;border-radius:8px;border:1px solid var(--border);background:var(--card);background:color-mix(in srgb,var(--primary) 12%,transparent);font-size:var(--font-2xs);font-weight:700}.table-board{display:grid;gap:10px;border-radius:14px;border:1px dashed var(--border);background:var(--card);background:color-mix(in srgb,var(--card) 85%,transparent);padding:12px;min-height:120px;position:relative}.table-board.drop-active{border-color:var(--primary);background:var(--card);background:color-mix(in srgb,var(--primary) 8%,var(--card))}.lane{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.lane::-webkit-scrollbar{height:4px}.lane::-webkit-scrollbar-thumb{background:var(--muted);background:color-mix(in srgb,var(--primary) 25%,transparent);border-radius:999px}.card-image{width:64px;height:92px;border-radius:12px;overflow:hidden;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);box-shadow:0 6px 14px #00000040;flex:0 0 auto;background:#f8f9ff;transition:transform .18s ease,box-shadow .18s ease}.card-image img{width:100%;height:100%;object-fit:cover}.card-image.back{filter:saturate(.2) brightness(.9)}.card-image.muted{opacity:.65}.card-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-lg)}.drop-hint{position:absolute;inset:auto 12px 12px 12px;padding:8px 12px;border-radius:10px;background:#0000008c;color:#fff;font-size:var(--font-2xs);text-align:center}.reveal-indicator{font-size:var(--font-2xs);color:var(--muted);text-align:right}.hand-wrap{display:grid;gap:8px}.hand{display:grid;gap:10px}.hand-header{display:flex;justify-content:space-between;gap:8px;align-items:center;font-size:var(--font-2xs);color:var(--muted)}.hand-cards{display:flex;gap:10px;overflow-x:auto;padding:8px 2px}.hand-card{border:none;background:transparent;padding:0;border-radius:14px;transition:transform .18s ease,box-shadow .18s ease}.hand-card.selected{transform:translateY(-8px);box-shadow:0 10px 18px #00000059}.hand-card.incompatible{opacity:.4}.hand-actions{display:flex;gap:10px;flex-wrap:wrap}.scoreboard{border:1px solid var(--border);border-radius:14px;background:var(--card);overflow:hidden}.scoreboard table{width:100%;border-collapse:collapse}.scoreboard th,.scoreboard td{padding:10px;text-align:center;border-bottom:1px solid var(--border)}.scoreboard th:first-child,.scoreboard td:first-child{text-align:left}.scoreboard tr:last-child td{border-bottom:none}
