:root{--color-bg: #1a1a2e;--color-bg-light: #252541;--color-bg-card: #2d2d4a;--color-primary: #4a9eff;--color-primary-dark: #3a8eef;--color-text: #eee;--color-text-muted: rgba(238, 238, 238, .6);--color-text-faint: rgba(238, 238, 238, .4);--color-border: rgba(255, 255, 255, .1);--header-height: 56px;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;height:100%;display:flex;flex-direction:column}.btn{font-family:inherit;font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:transparent;color:var(--color-text)}.btn:active{transform:scale(.96)}.btn-primary{background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-xl);font-size:1.125rem}.btn-primary:hover{background:var(--color-primary-dark)}.btn-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%}.btn-icon:hover{background:var(--color-bg-light)}.screen{width:100%;height:100%;display:flex;flex-direction:column}.home-screen{align-items:center;justify-content:center}.home-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-xl)}.home-logo{margin-bottom:var(--spacing-lg)}.logo-icon{width:80px;height:80px;background:var(--color-bg-card);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:var(--color-primary)}.home-title{font-size:3rem;font-weight:700;margin-bottom:var(--spacing-xs)}.home-subtitle{font-size:1.25rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.home-description{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:.9375rem;color:var(--color-text-faint);line-height:1.4;margin-bottom:var(--spacing-xl)}.screen-header,.game-header{height:var(--header-height);min-height:var(--header-height);display:flex;align-items:center;padding:0 var(--spacing-xs);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.header-title{flex:1;font-size:1.125rem;font-weight:600;text-align:center}.header-spacer{width:44px}.games-screen{background:var(--color-bg)}.games-toolbar{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-xs)}.size-toggle{display:flex;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--color-border)}.size-toggle-btn{font-family:inherit;font-size:.875rem;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.size-toggle-btn.active{background:var(--color-primary);color:#fff}.size-toggle-btn:hover:not(.active){background:var(--color-bg-light)}.games-list{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.game-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.game-card:hover:not(.disabled){background:var(--color-bg-light);transform:translateY(-2px)}.game-card:active:not(.disabled){transform:scale(.98)}.game-card.disabled{opacity:.5;cursor:not-allowed}.game-card-content{position:relative;z-index:1}.game-card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.game-card-title{font-size:1.125rem;font-weight:600}.game-card-badge{font-size:.75rem;padding:2px 8px;background:var(--color-primary);color:#fff;border-radius:999px;text-transform:capitalize}.game-card-desc{color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.game-card-players{margin-left:auto;font-size:.875rem;color:var(--color-text-faint);white-space:nowrap}.game-card-soon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-bg);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-weight:600;z-index:2}.compact-cards .game-card{padding:var(--spacing-xs) var(--spacing-md)}.compact-cards .game-card-content{display:flex;align-items:center;justify-content:space-between}.compact-cards .game-card-header{margin-bottom:0}.compact-cards .game-card-desc{display:none}.compact-cards .game-card-players{margin:0;white-space:nowrap;flex-shrink:0}.compact-cards .game-card-soon{padding:2px var(--spacing-sm);font-size:.75rem}.archetype-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.archetype-group:not(:first-child){margin-top:var(--spacing-md)}.archetype-header{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border)}.segmented-control{display:flex;gap:2px}.segmented-btn{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.segmented-btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.segmented-btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.segmented-btn:not(:first-child){border-left:none}.segmented-btn-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.game-screen{background:var(--color-bg);position:relative;overflow:hidden}.game-placeholder{font-size:1.25rem;font-weight:600;color:var(--color-text-faint);text-align:center;padding:var(--spacing-xl)}.game-canvas{flex:1;min-height:0;width:100%;display:block;border-radius:0}.game-canvas.drag-mode{cursor:grab}.game-canvas.dragging{cursor:grabbing}.sort-hand-group{position:absolute;bottom:135px;left:50%;transform:translate(-50%);align-items:center;gap:6px;padding:6px 10px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:10;opacity:.85;transition:opacity .2s}.sort-hand-group:hover{opacity:1}.sort-hand-label{font-size:.75rem;color:var(--color-text-muted);margin-right:2px;user-select:none}.sort-hand-group .btn-sort-hand{padding:4px 12px;font-size:.8rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.sort-hand-group .btn-sort-hand:hover{background:var(--color-primary-dark)}.game-score-bar{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px 16px;padding:6px 12px;background:var(--color-bg);border-bottom:1px solid var(--color-border);font-size:1rem;font-weight:600;color:var(--color-text)}.score-entry{white-space:nowrap}.score-bar-separator{color:var(--color-text-muted)}.score-bar-bags{font-weight:400;color:var(--color-text-muted);font-size:.85rem}.score-bar-bid-progress{font-weight:600;font-size:.85rem}.game-help-text{position:absolute;bottom:185px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#000000b3;border-radius:8px;font-size:.85rem;color:#ffffffe6;pointer-events:none;white-space:nowrap}.help-text-title{font-weight:700;color:var(--color-primary)}.help-text-instruction{color:#ffffffb3}.game-over-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.game-over-content{background:var(--color-bg);padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center;max-width:300px}.game-over-title{font-size:1.5rem;margin-bottom:var(--spacing-lg);color:var(--color-primary)}.suit-picker-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.suit-picker-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;min-width:200px}.suit-picker-title{font-size:1.125rem;margin-bottom:var(--spacing-md);color:var(--color-text)}.suit-picker-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.suit-picker-btn{width:64px;height:64px;font-size:2rem;background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;text-shadow:-1px -1px 0 rgba(255,255,255,.3),1px -1px 0 rgba(255,255,255,.3),-1px 1px 0 rgba(255,255,255,.3),1px 1px 0 rgba(255,255,255,.3)}.suit-picker-btn:hover{background:var(--color-bg-light);border-color:var(--color-primary);transform:scale(1.05)}.suit-picker-btn:active{transform:scale(.95)}.rank-picker-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.rank-picker-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;min-width:280px;max-width:90%}.rank-picker-title{font-size:1.125rem;margin-bottom:var(--spacing-md);color:var(--color-text)}.rank-picker-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.rank-picker-btn{width:48px;height:48px;font-size:1.25rem;font-weight:600;background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;color:var(--color-text)}.rank-picker-btn:hover{background:var(--color-bg-light);border-color:var(--color-primary);transform:scale(1.05)}.rank-picker-btn:active{transform:scale(.95)}.rank-picker-cancel{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);cursor:pointer;color:var(--color-text-secondary);font-size:.875rem}.rank-picker-cancel:hover{background:var(--color-bg-light);border-color:var(--color-text-secondary)}.player-picker-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:50}.player-picker-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;min-width:280px;max-width:90%}.player-picker-title{font-size:1.25rem;margin-bottom:var(--spacing-xs);color:var(--color-text)}.player-picker-subtitle{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.player-picker-buttons{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap;margin-bottom:var(--spacing-md)}.player-picker-btn{width:56px;height:56px;font-size:1.5rem;font-weight:600;background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;color:var(--color-text);transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.player-picker-btn:hover{background:var(--color-bg-light);border-color:var(--color-primary);transform:scale(1.05)}.player-picker-btn:active{transform:scale(.95)}.player-picker-cancel{margin-top:var(--spacing-sm)}.menu-overlay{position:fixed;inset:0;z-index:100;display:flex;justify-content:flex-end}.menu-backdrop{position:absolute;inset:0;background:#00000080;opacity:0;transition:opacity var(--transition-normal)}.menu-overlay.open .menu-backdrop{opacity:1}.menu-panel{position:relative;width:280px;max-width:80%;height:100%;background:var(--color-bg);transform:translate(100%);transition:transform var(--transition-normal);display:flex;flex-direction:column}.menu-overlay.open .menu-panel{transform:translate(0)}.menu-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xs) 0 var(--spacing-md);border-bottom:1px solid var(--color-border)}.menu-content{flex:1;padding:var(--spacing-sm);display:flex;flex-direction:column}.menu-item{width:100%;text-align:left;padding:var(--spacing-md);font-size:1rem;color:var(--color-text);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.menu-item:hover{background:var(--color-bg-light)}.menu-divider{height:1px;background:var(--color-border);margin:var(--spacing-sm) 0}.menu-item-exit{color:#ff6b6b}.rules-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md)}.rules-backdrop{position:absolute;inset:0;background:#000000b3;opacity:0;transition:opacity var(--transition-normal)}.rules-overlay.open .rules-backdrop{opacity:1}.rules-modal{position:relative;width:100%;max-width:420px;max-height:80vh;background:var(--color-bg);border-radius:var(--radius-lg);display:flex;flex-direction:column;transform:scale(.9);opacity:0;transition:transform var(--transition-normal),opacity var(--transition-normal)}.rules-overlay.open .rules-modal{transform:scale(1);opacity:1}.rules-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-xs) var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.rules-header h2{font-size:1.125rem;font-weight:600}.rules-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.rules-text p{margin-bottom:var(--spacing-sm);line-height:1.5;color:var(--color-text-muted)}.rules-text p:last-child{margin-bottom:0}.rules-text strong{color:var(--color-text);font-weight:600}.rules-text ul{margin:var(--spacing-xs) 0 var(--spacing-sm);padding-left:var(--spacing-lg)}.rules-text li{margin-bottom:var(--spacing-xs);line-height:1.5;color:var(--color-text-muted)}.menu-section-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);padding:var(--spacing-xs) var(--spacing-md)}.theme-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding:0 var(--spacing-sm)}.theme-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-xs);background:transparent;border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex:1;min-width:60px;max-width:80px}.theme-btn:hover{background:var(--color-bg-light)}.theme-btn.active{border-color:var(--color-primary)}.theme-preview{width:32px;height:32px;border-radius:50%;border:3px solid}.theme-name{font-size:.625rem;color:var(--color-text-muted);text-align:center}.mode-selector{display:flex;gap:var(--spacing-xs);padding:0 var(--spacing-sm)}.mode-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.mode-btn:hover{background:var(--color-bg-light)}.mode-btn.active{border-color:var(--color-primary)}.mode-name{font-size:.875rem;color:var(--color-text)}.audio-toggle{padding:0 var(--spacing-sm)}.audio-toggle-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.audio-toggle-btn:hover{background:var(--color-bg-light)}.audio-toggle-btn.active{border-color:var(--color-primary);background:#4a9eff1a}.audio-toggle-label{font-size:.875rem;color:var(--color-text)}.audio-toggle-state{font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:4px;transition:all var(--transition-fast)}.audio-toggle-btn:not(.active) .audio-toggle-state{background:#ffffff1a;color:var(--color-text-muted)}.audio-toggle-btn.active .audio-toggle-state{background:var(--color-primary);color:#fff}@media(min-width:768px){.games-list{max-width:600px;margin:0 auto;width:100%}.home-content{max-width:500px}.logo-icon{width:100px;height:100px;font-size:3rem}.home-title{font-size:4rem}}.layout-test-screen{background:var(--color-bg);overflow-y:auto;flex:1}.layout-test-controls{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-xs) var(--spacing-md);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-light);border-bottom:1px solid var(--color-border)}.player-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-card);border-radius:var(--radius-sm)}.player-btn.active{background:var(--color-primary);color:#fff}.layout-test-canvas-container{height:calc(100vh - var(--header-height));height:calc(100dvh - var(--header-height));min-height:400px;position:relative;overflow:hidden;flex-shrink:0}.layout-test-canvas{position:absolute;inset:0;width:100%;height:100%}.control-section{display:flex;align-items:center;gap:var(--spacing-xs)}.control-label{font-size:.75rem;color:var(--color-text-muted);min-width:45px}.control-buttons{display:flex;gap:4px}.layout-btn,.mode-btn,.element-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-card);border-radius:var(--radius-sm);font-size:.8125rem}.layout-btn.active,.mode-btn.active,.element-btn.active{background:var(--color-primary);color:#fff}.card-counts-section{display:none;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.count-control{display:flex;align-items:center;gap:var(--spacing-xs)}.count-label{font-size:.75rem;color:var(--color-text-muted);min-width:40px}.count-btn{width:28px;height:28px;padding:0;background:var(--color-bg-card);border-radius:var(--radius-sm);font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center}.count-btn:hover{background:var(--color-bg-light)}.count-value{min-width:28px;text-align:center;font-size:.875rem;font-weight:600;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace}@media(max-width:500px){.layout-test-controls{flex-direction:column;align-items:stretch;padding:var(--spacing-xs);gap:6px}.control-section{display:flex;justify-content:space-between;width:100%}.control-label{min-width:50px;font-size:.75rem}.control-buttons{flex-wrap:wrap;justify-content:flex-end;gap:4px}.player-btn,.layout-btn,.mode-btn,.element-btn{padding:6px 10px;font-size:.75rem}.card-counts-section{flex-wrap:wrap;justify-content:space-around;gap:var(--spacing-xs);padding:var(--spacing-xs)}.count-control{flex:0 0 auto}.count-label{min-width:36px;font-size:.6875rem}.count-btn{width:26px;height:26px}.count-value{min-width:24px;font-size:.8125rem}}.card-test-screen{background:var(--color-bg)}.card-test-controls{display:flex;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-light);border-bottom:1px solid var(--color-border)}.view-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-card);border-radius:var(--radius-sm)}.view-btn.active{background:var(--color-primary);color:#fff}.card-test-canvas-container{flex:1;position:relative;overflow:hidden}.card-test-canvas{position:absolute;inset:0;width:100%;height:100%}.scenarios-screen{background:var(--color-bg);overflow-y:auto}.scenarios-layout{display:flex;flex:1;overflow:hidden}.scenarios-sidebar{width:160px;padding:var(--spacing-md);background:var(--color-bg-light);border-right:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-xs)}.scenarios-section-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.scenarios-game-btn{text-align:left;padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border-radius:var(--radius-sm)}.scenarios-game-btn.active{background:var(--color-primary);color:#fff}.scenarios-list{flex:1;padding:var(--spacing-md);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-sm)}.scenario-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.scenario-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xs)}.scenario-name{font-weight:600;font-size:1rem}.scenario-badge{font-size:.6875rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff}.scenario-badge-interactive{background:var(--color-success, #27ae60)}.scenario-description{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.scenario-actions{display:flex;gap:var(--spacing-xs)}.scenario-play-btn{flex:1}.scenario-screenshot-btn{background:var(--color-bg-light)}.design-guide-screen{background:var(--color-bg)}.guide-content{flex:1;overflow-y:auto;padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-xl) * 2)}.guide-section{max-width:600px;margin:0 auto var(--spacing-xl)}.guide-hero-title{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-md);line-height:1.2}.guide-intro{font-size:1.0625rem;color:var(--color-text);line-height:1.6;margin-bottom:var(--spacing-sm)}.guide-section h2{font-size:1.375rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-primary)}.guide-section h3{font-size:1.0625rem;font-weight:600;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.guide-section p{color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--spacing-md)}.guide-note-inline{font-size:.9375rem;color:var(--color-text-faint);margin-bottom:var(--spacing-sm)}.guide-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-md);margin:var(--spacing-lg) 0}.guide-info-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.guide-info-card-icon{width:48px;height:48px;margin:0 auto var(--spacing-sm);color:var(--color-primary);display:flex;align-items:center;justify-content:center}.guide-info-card-title{font-weight:600;margin-bottom:var(--spacing-xs);font-size:.9375rem}.guide-info-card-desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.guide-comparison{display:flex;gap:var(--spacing-xl);justify-content:center;margin:var(--spacing-lg) 0}.comparison-item{text-align:center}.comparison-visual{width:80px;height:80px;border-radius:var(--radius-sm);margin-bottom:var(--spacing-xs);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700}.comparison-visual.raster{background:var(--color-bg-card);color:var(--color-text-muted);filter:blur(1.5px)}.comparison-visual.vector{background:var(--color-primary);color:#fff}.comparison-label{font-size:.75rem;display:block}.comparison-label.bad{color:#ff6b6b}.comparison-label.good{color:#4ecdc4}.tool-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-md) 0}.tool-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md)}.tool-card-icon{color:var(--color-primary);flex-shrink:0}.tool-card-info{flex:1;min-width:0}.tool-card-name{font-weight:600;margin-bottom:2px;font-size:.9375rem}.tool-card-desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.tool-card-price{font-weight:600;color:var(--color-primary);white-space:nowrap;font-size:.875rem}.tool-card-link{color:var(--color-primary);text-decoration:none;font-size:.8125rem;white-space:nowrap}.tool-card-link:hover{text-decoration:underline}.guide-recommendation{background:#4a9eff1a;border-left:4px solid var(--color-primary);padding:var(--spacing-md);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:var(--spacing-lg) 0;line-height:1.6;color:var(--color-text-muted)}.guide-recommendation strong{color:var(--color-text)}.guide-specs-box{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-md);margin:var(--spacing-md) 0}.spec-row{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0}.spec-row:not(:last-child){border-bottom:1px solid var(--color-border)}.spec-label{color:var(--color-text-muted)}.spec-value{font-weight:600;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:.875rem}.guide-tips{list-style:none;margin:var(--spacing-md) 0}.guide-tips li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-sm);color:var(--color-text-muted);line-height:1.5}.guide-tips li:before{content:"✓";position:absolute;left:0;color:var(--color-primary);font-weight:700}.guide-export-steps{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-md) 0}.export-step{display:flex;align-items:center;gap:var(--spacing-md)}.export-step-number{width:28px;height:28px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.export-step-text{color:var(--color-text-muted);line-height:1.4}.guide-asset-table{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-md) 0}.asset-row{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-md)}.asset-row.recommended{border:1px solid var(--color-primary)}.asset-row-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);flex-wrap:wrap}.asset-name{font-weight:600}.asset-count{font-size:.75rem;color:var(--color-primary);background:#4a9eff26;padding:2px 8px;border-radius:999px}.asset-badge{font-size:.6875rem;background:var(--color-primary);color:#fff;padding:2px 8px;border-radius:999px;margin-left:auto}.asset-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.4}.guide-note{background:#4ecdc41a;border-left:4px solid #4ecdc4;padding:var(--spacing-md);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:var(--spacing-lg) 0;line-height:1.6;color:var(--color-text-muted)}.guide-note strong{color:var(--color-text)}.code-inline{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:.875em;background:var(--color-bg-card);padding:2px 6px;border-radius:4px}.guide-footer{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.guide-footer p{color:var(--color-text)}@media(max-width:480px){.guide-content{padding:var(--spacing-md)}.guide-hero-title{font-size:1.5rem}.guide-card-grid{grid-template-columns:1fr}.tool-card{flex-direction:column;align-items:flex-start}.tool-card-price{margin-top:var(--spacing-xs)}.guide-comparison{gap:var(--spacing-md)}.comparison-visual{width:60px;height:60px;font-size:2rem}}.toast-container{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:300;display:flex;flex-direction:column;gap:var(--spacing-xs);pointer-events:none}.toast{background:var(--color-bg-card);color:var(--color-text);padding:12px 20px;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:500;box-shadow:0 4px 12px #0000004d;opacity:0;transform:translateY(-10px);transition:opacity .3s ease,transform .3s ease;white-space:nowrap;pointer-events:auto}.toast-visible{opacity:1;transform:translateY(0)}.toast-hidden{opacity:0;transform:translateY(-10px)}.toast-info{border-left:4px solid var(--color-primary)}.toast-success{border-left:4px solid #4ecdc4}.toast-warning{border-left:4px solid #ffe66d}.card-request-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.card-request-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;min-width:280px;max-width:90%}.card-request-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-text)}.card-request-message{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--spacing-lg);line-height:1.5}.card-request-cards{display:flex;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.card-request-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem;font-weight:500;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.card-request-btn:hover{background:var(--color-primary-dark)}.card-request-btn:active{transform:scale(.96)}.knock-choice-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.knock-choice-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;min-width:240px;max-width:300px}.knock-choice-title{font-size:1.25rem;margin-bottom:var(--spacing-sm);color:var(--color-text)}.knock-choice-message{font-size:.9rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.knock-choice-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.knock-choice-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.knock-choice-btn-knock{background:var(--color-primary);color:#fff}.knock-choice-btn-knock:hover{background:var(--color-primary-hover);transform:scale(1.02)}.knock-choice-btn-discard{background:var(--color-bg-card);color:var(--color-text)}.knock-choice-btn-discard:hover{background:var(--color-bg-light);border-color:var(--color-border)}.knock-choice-btn-knock.disabled{background:var(--color-bg-card);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.knock-choice-btn-knock.disabled:hover{background:var(--color-bg-card);transform:none}.feedback-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md)}.feedback-backdrop{position:absolute;inset:0;background:#000000b3;opacity:0;transition:opacity var(--transition-normal)}.feedback-overlay.open .feedback-backdrop{opacity:1}.feedback-modal{position:relative;width:100%;max-width:420px;max-height:90vh;background:var(--color-bg);border-radius:var(--radius-lg);display:flex;flex-direction:column;transform:scale(.9);opacity:0;transition:transform var(--transition-normal),opacity var(--transition-normal);overflow:hidden}.feedback-overlay.open .feedback-modal{transform:scale(1);opacity:1}.feedback-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-xs) var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.feedback-header h2{font-size:1.125rem;font-weight:600}.feedback-content{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.feedback-hint{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted)}.feedback-categories{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.feedback-category-btn{flex:1;padding:var(--spacing-sm);background:var(--color-bg-card);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;color:var(--color-text);transition:all var(--transition-fast)}.feedback-category-btn:hover{background:var(--color-bg-light)}.feedback-category-btn.active{border-color:var(--color-primary)}.feedback-title-input{width:100%;padding:var(--spacing-sm);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:.9375rem;margin-bottom:var(--spacing-xs);outline:none;transition:border-color var(--transition-fast)}.feedback-title-input:focus{border-color:var(--color-primary)}.feedback-textarea{width:100%;padding:var(--spacing-sm);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:.9375rem;resize:vertical;min-height:100px;margin-bottom:var(--spacing-sm);outline:none;transition:border-color var(--transition-fast)}.feedback-textarea:focus{border-color:var(--color-primary)}.feedback-textarea::placeholder,.feedback-title-input::placeholder{color:var(--color-text-faint)}.feedback-submit{align-self:flex-end}@supports (padding-top: env(safe-area-inset-top)){.screen-header,.game-header{padding-top:env(safe-area-inset-top);height:calc(var(--header-height) + env(safe-area-inset-top))}.game-canvas{padding-bottom:env(safe-area-inset-bottom)}.sort-hand-group{bottom:calc(135px + env(safe-area-inset-bottom))}.menu-panel{padding-top:env(safe-area-inset-top)}}.bid-modal-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.bid-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;min-width:260px;max-width:340px}.bid-modal-title{font-size:1.25rem;margin-bottom:var(--spacing-sm);color:var(--color-text)}.bid-modal-message{font-size:.9rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.bid-modal-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);justify-content:center;margin-bottom:var(--spacing-md)}.bid-modal-option{width:40px;height:40px;font-size:.95rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast)}.bid-modal-option:hover{border-color:var(--color-primary);background:var(--color-bg-light)}.bid-modal-option.selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.bid-modal-confirm{padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem;border:2px solid transparent;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--spacing-md)}.bid-modal-confirm:hover{background:var(--color-primary-hover);transform:scale(1.02)}.bid-modal-bot-bids{display:flex;flex-direction:column;gap:var(--spacing-xs)}.bid-modal-bot-entry{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-card);border-radius:var(--radius-sm)}.bid-modal-bot-name{font-size:.85rem;color:var(--color-text-muted)}.bid-modal-bot-value{font-size:.95rem;font-weight:600;color:var(--color-text)}.round-summary-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.round-summary-modal{background:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--radius-lg);min-width:280px;max-width:400px;text-align:center}.round-summary-title{font-size:1.25rem;margin-bottom:var(--spacing-md);color:var(--color-text)}.round-summary-teams,.round-summary-players{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.round-summary-team{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.round-summary-team-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.round-summary-team-name{font-weight:600}.round-summary-delta.positive{color:var(--color-success, #22c55e);font-weight:600}.round-summary-delta.negative{color:var(--color-error, #ef4444);font-weight:600}.round-summary-stats{display:flex;gap:var(--spacing-md);font-size:.85rem;color:var(--color-text-muted)}.round-summary-bags{color:var(--color-warning, #f59e0b)}.round-summary-nil-row{display:flex;flex-direction:column;gap:2px;margin-top:var(--spacing-xs);font-size:.85rem}.round-summary-nil-success{color:var(--color-success, #22c55e);font-weight:600}.round-summary-nil-failure{color:var(--color-error, #ef4444);font-weight:600}.round-summary-player{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm)}.round-summary-player-name{font-weight:500}.round-summary-btn{margin-top:var(--spacing-sm);width:100%}
