:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.4;color:#171a1f;background:#f4f3ef;--page: #f4f3ef;--page-glow: rgba(255, 254, 250, .7);--surface: #fffefa;--surface-soft: #f7f6f1;--surface-strong: #ebe8df;--line: #dedbd2;--text: #171a1f;--muted: #68716d;--accent: #2f8a5f;--accent-strong: #176b48;--accent-soft: #e8f4ed;--danger: #c8464f;--danger-soft: #f8e7e8;--danger-border: rgba(200, 70, 79, .28);--gold: #f2d56b;--silver: #e4e7e9;--blue: #b8dcff;--teal: #abe5dd;--topbar-bg: rgba(255, 254, 250, .92);--control-bg: rgba(255, 255, 255, .62);--control-hover: #ffffff;--focus-ring: rgba(47, 138, 95, .28);--app-shadow: rgba(28, 31, 29, .06);--tile-shadow: rgba(23, 26, 31, .08);--tile-name-bg: rgba(255, 254, 250, .94);--soft-line: rgba(23, 26, 31, .08);--selected-ring: rgba(47, 138, 95, .18);--hint-ring: rgba(242, 213, 107, .38);--solved-border: rgba(23, 26, 31, .1);--solved-text: #171a1f;--solved-muted: rgba(23, 26, 31, .78);--solved-tag: rgba(23, 26, 31, .7);--disabled: #9da49f;--danger-text: #8f2830;--modal-backdrop: rgba(23, 26, 31, .44);--modal-shadow: rgba(23, 26, 31, .18);--hover-border: rgba(47, 138, 95, .38);--gold-border: #c79f16;--silver-border: #9ca5aa;--blue-border: #3989d6;--teal-border: #2aa99c;--image-outline: rgba(0, 0, 0, .1);--shadow-border: 0 0 0 1px rgba(0, 0, 0, .06), 0 1px 2px -1px rgba(0, 0, 0, .06), 0 2px 4px rgba(0, 0, 0, .04);--shadow-border-hover: 0 0 0 1px rgba(0, 0, 0, .08), 0 1px 2px -1px rgba(0, 0, 0, .08), 0 2px 4px rgba(0, 0, 0, .06);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{color-scheme:dark;color:#f4f1e9;background:#10120f;--page: #10120f;--page-glow: rgba(29, 32, 25, .78);--surface: #171914;--surface-soft: #1f231d;--surface-strong: #2a2d26;--line: #3a3d35;--text: #f4f1e9;--muted: #a8ada3;--accent: #58bf82;--accent-strong: #8bd8a7;--accent-soft: #173522;--danger: #ff6b73;--danger-soft: #3b1d20;--danger-border: rgba(255, 107, 115, .4);--gold: #e6ca65;--silver: #cbd0d2;--blue: #9bc8f5;--teal: #8fd6ca;--topbar-bg: rgba(23, 25, 20, .92);--control-bg: rgba(255, 255, 255, .05);--control-hover: rgba(255, 255, 255, .1);--focus-ring: rgba(88, 191, 130, .34);--app-shadow: rgba(0, 0, 0, .5);--tile-shadow: rgba(0, 0, 0, .28);--tile-name-bg: rgba(17, 18, 15, .92);--soft-line: rgba(255, 255, 255, .08);--selected-ring: rgba(88, 191, 130, .28);--hint-ring: rgba(230, 202, 101, .3);--solved-border: rgba(0, 0, 0, .16);--solved-text: #171a1f;--solved-muted: rgba(23, 26, 31, .78);--solved-tag: rgba(23, 26, 31, .7);--disabled: #747a70;--danger-text: #ffc0c5;--modal-backdrop: rgba(0, 0, 0, .62);--modal-shadow: rgba(0, 0, 0, .42);--hover-border: rgba(88, 191, 130, .46);--gold-border: #e6ca65;--silver-border: #a9b0b4;--blue-border: #6db1ed;--teal-border: #63c8bc;--image-outline: rgba(255, 255, 255, .1);--shadow-border: 0 0 0 1px rgba(255, 255, 255, .08);--shadow-border-hover: 0 0 0 1px rgba(255, 255, 255, .13)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{min-height:100svh;margin:0;background:linear-gradient(180deg,var(--page-glow),var(--page)),var(--page);overflow-x:hidden}#root{min-height:100svh}button{font:inherit;-webkit-tap-highlight-color:transparent}button:not(:disabled){cursor:pointer}button:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}h1,h2,h3{text-wrap:balance}p,li{text-wrap:pretty}.app-shell{display:flex;flex-direction:column;width:min(100%,520px);min-height:100svh;margin:0 auto;background:var(--surface);box-shadow:0 0 0 1px var(--app-shadow)}.topbar{position:sticky;top:0;z-index:5;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.45rem;min-height:52px;padding:.375rem .75rem;border-bottom:1px solid var(--line);background:var(--topbar-bg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar-side{display:flex;min-width:82px;align-items:center;gap:.35rem}.topbar-actions{justify-content:flex-end}.icon-button.topbar-share-button{display:inline-flex;width:auto;min-width:76px;align-items:center;justify-content:center;gap:.34rem;padding:0 .62rem 0 .5rem;white-space:nowrap;font-size:.76rem;font-weight:830}.icon-button.topbar-share-button svg{flex:0 0 auto}.topbar h1{margin:0;color:var(--text);text-align:center;font-size:1.28rem;font-weight:800;letter-spacing:0;line-height:1}.topbar h1 strong{margin-left:.18rem;color:var(--accent);font-weight:800}.mode-switch{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;padding:.55rem .75rem;border-bottom:1px solid var(--line);background:var(--surface)}.mode-switch button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:.35rem;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--muted);font-size:.76rem;font-weight:800;transition:background-color .14s ease,border-color .14s ease,box-shadow .14s ease,color .14s ease,transform .14s ease}.mode-switch button.is-active{border-color:var(--accent-strong);background:var(--accent-soft);color:var(--accent-strong)}.icon-button,.status-help,.connections-status-help,.modal-close{display:inline-grid;min-width:40px;min-height:40px;place-items:center;border:1px solid transparent;border-radius:8px;color:var(--text);background:var(--control-bg);box-shadow:var(--shadow-border);transition:background-color .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease}.topbar .icon-button{position:relative;min-height:38px;overflow:visible}.topbar .icon-button:not(.topbar-share-button){min-width:38px}.topbar .icon-button:before{content:"";position:absolute;inset:-1px;border-radius:9px}.mode-switch button:active:not(:disabled),.icon-button:active,.status-help:active,.connections-status-help:active,.modal-close:active{transform:scale(.96)}.theme-toggle-icons{position:relative;display:grid;width:19px;height:19px;place-items:center}.theme-icon{grid-area:1 / 1;transition:opacity .3s cubic-bezier(.2,0,0,1),filter .3s cubic-bezier(.2,0,0,1),transform .3s cubic-bezier(.2,0,0,1)}.theme-icon-sun{opacity:0;filter:blur(4px);transform:scale(.25)}.theme-icon-moon{opacity:1;filter:blur(0px);transform:scale(1)}:root[data-theme=dark] .theme-icon-sun{opacity:1;filter:blur(0px);transform:scale(1)}:root[data-theme=dark] .theme-icon-moon{opacity:0;filter:blur(4px);transform:scale(.25)}.status-strip{display:grid;grid-template-columns:minmax(0,1fr) auto 40px;align-items:center;gap:.55rem;padding:.65rem .75rem;border-bottom:1px solid var(--line);background:var(--surface-soft)}.status-strip div{display:inline-flex;min-width:0;align-items:center;gap:.35rem;color:var(--muted);font-size:.8rem;font-weight:700}.status-strip div span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-strip svg{flex:0 0 auto;color:var(--accent)}.mistakes{justify-content:center;color:var(--text)!important}.mistakes strong{color:var(--danger);font-size:1rem}.board{flex:1;padding:.75rem .65rem 0}.solved-stack{display:grid;gap:.5rem;margin-bottom:.6rem}.solved-group{overflow:hidden;border:1px solid var(--solved-border);border-radius:8px;color:var(--solved-text)}.solved-group div{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:.4rem;padding:.55rem .65rem .22rem}.solved-group h2,.solved-group p{margin:0}.solved-group h2{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.94rem;font-weight:800}.solved-group span{color:var(--solved-tag);font-size:.65rem;font-weight:800}.solved-group p{padding:0 .65rem .58rem;color:var(--solved-muted);font-size:.72rem;font-weight:650;line-height:1.25}.solved-group-gold{background:var(--gold)}.solved-group-silver{background:var(--silver)}.solved-group-blue{background:var(--blue)}.solved-group-teal{background:var(--teal)}.tiles-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem}.player-tile{position:relative;display:grid;grid-template-rows:minmax(0,1fr) minmax(2.05rem,auto);min-width:0;aspect-ratio:.72;overflow:hidden;padding:0;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);color:var(--text);box-shadow:var(--shadow-border);transform-origin:center;touch-action:manipulation;user-select:none;-webkit-user-select:none;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease,background-color .12s ease}.player-tile:active{transform:translateY(1px) scale(.96);box-shadow:0 1px 1px #171a1f1f,inset 0 2px 9px #171a1f1f}.player-tile.is-selected{border-color:var(--accent-strong);background:var(--accent-soft);box-shadow:0 0 0 3px var(--selected-ring)}.player-tile.is-selected:active{box-shadow:0 0 0 3px var(--selected-ring),0 1px 1px #171a1f1f,inset 0 2px 9px #171a1f1f}.player-tile.is-hinted:not(.is-selected){border-color:var(--gold-border);box-shadow:0 0 0 3px var(--hint-ring)}.player-tile.is-missed{animation:player-tile-miss-jiggle .36s ease}.portrait{position:relative;display:grid;width:100%;height:100%;min-height:0;align-self:stretch;justify-self:stretch;place-items:center;overflow:hidden;background:var(--surface-strong)}.portrait img{position:absolute;inset:0;display:block;width:100%;height:100%;min-width:100%;min-height:100%;object-fit:cover;object-position:center top;outline:1px solid var(--image-outline);outline-offset:-1px}.initials{color:var(--accent);font-size:1.28rem;font-weight:800}.player-name{display:flex;min-width:0;align-items:center;justify-content:center;padding:.2rem .24rem;border-top:1px solid var(--soft-line);background:var(--tile-name-bg);color:var(--text);text-align:center;overflow-wrap:anywhere;font-size:.66rem;font-weight:760;line-height:1.05}.player-name[data-long-name=true]{font-size:.58rem}@keyframes player-tile-miss-jiggle{0%,to{transform:translate(0)}20%{transform:translate(-3px) rotate(-.7deg)}42%{transform:translate(3px) rotate(.7deg)}64%{transform:translate(-2px) rotate(-.35deg)}82%{transform:translate(2px) rotate(.35deg)}}.tier-board{display:grid;align-content:start;--tier-row-height: clamp(4.65rem, 8.8svh, 5.55rem);--tier-pool-height: clamp(6.85rem, 13.5svh, 8.6rem);--tier-card-width: clamp(4.85rem, 14.5vw, 5.35rem);--tier-card-image-height: clamp(3.45rem, 7.6svh, 4.05rem);gap:.42rem}.tier-brief{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.4rem;padding:clamp(.26rem,.65svh,.36rem) .62rem;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);box-shadow:var(--shadow-border)}.tier-brief-kicker{display:block;margin-bottom:.06rem;color:var(--accent-strong);font-size:.62rem;font-weight:820}.tier-brief h2,.tier-brief p{margin:0}.tier-brief h2{color:var(--text);font-size:.94rem;font-weight:850;line-height:1.08}.tier-brief p{margin-top:.04rem;color:var(--muted);font-size:.68rem;font-weight:680;line-height:1.14}.tier-brief-side{display:inline-flex;align-items:center;gap:.45rem}.tier-brief-stats{display:grid;justify-items:end;gap:.12rem;color:var(--muted);font-size:.66rem;font-weight:800}.tier-brief-stats span,.tier-crowd-button{display:flex;align-items:center;gap:.25rem;white-space:nowrap}.tier-crowd-button{justify-self:end;min-height:40px;padding:0 .16rem;border:0;border-radius:8px;background:transparent;color:inherit;font:inherit;transition:color .14s ease,transform .14s ease}.tier-crowd-button:not(:disabled){color:var(--accent-strong)}.tier-crowd-button:disabled{cursor:default}.tier-brief-stats strong{color:var(--accent-strong);font-size:.82rem;font-weight:900}.tier-brief-help{min-width:40px;min-height:40px;background:var(--surface)}.tier-zone{display:grid;grid-template-columns:3.65rem minmax(0,1fr);gap:0;align-items:stretch;min-height:var(--tier-row-height);overflow:hidden;padding:0;border:2px solid #111111;border-radius:0;background:#1a1a1a;transition:border-color .14s ease,background-color .14s ease,box-shadow .14s ease}.tier-zone.is-targetable{border-color:var(--hover-border);box-shadow:inset 0 0 0 1px var(--hover-border)}.tier-zone-pool{grid-template-columns:minmax(0,1fr);min-height:var(--tier-pool-height);padding:.5rem;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);box-shadow:var(--shadow-border)}.tier-zone-label{display:flex;min-width:0;align-items:center;justify-content:center;gap:.22rem;text-align:center}.tier-zone:not(.tier-zone-pool) .tier-zone-label{min-height:100%;border-right:2px solid #111111;background:var(--tier-color)}.tier-zone-pool .tier-zone-label{justify-content:flex-start;gap:.34rem;text-align:left}.tier-zone-label>span{display:grid;width:100%;min-width:100%;height:100%;min-height:var(--tier-row-height);place-items:center;border:0;border-radius:0;background:var(--tier-color);color:#111;font-size:1.45rem;font-weight:900}.tier-zone-s .tier-zone-label>span{background:var(--tier-color, #ff7f7f);color:#171a1f}.tier-zone-a .tier-zone-label>span{background:var(--tier-color, #ffbf7f);color:#171a1f}.tier-zone-b .tier-zone-label>span{background:var(--tier-color, #ffdf7f);color:#171a1f}.tier-zone-c .tier-zone-label>span{background:var(--tier-color, #ffff7f);color:#171a1f}.tier-zone-d .tier-zone-label>span{background:var(--tier-color, #bfff7f);color:#171a1f}.tier-zone-label h3,.tier-zone-label p{margin:0}.tier-zone-label h3{color:var(--text);font-size:.68rem;font-weight:850;line-height:1.1}.tier-zone-label p{color:var(--muted);font-size:.58rem;font-weight:720;line-height:1.15}.tier-stack{display:grid;gap:0;overflow:hidden;border:2px solid #111111;border-radius:8px;background:#111}.tier-card-list{display:flex;min-width:0;min-height:var(--tier-row-height);flex-wrap:wrap;gap:.34rem;align-items:center;padding:.36rem;background:#1a1a1a}.tier-zone-pool .tier-card-list{min-height:calc(var(--tier-card-image-height) + 1.88rem);flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:.04rem .06rem .28rem;background:transparent;overscroll-behavior-inline:contain;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.tier-player-entry{display:flex;min-width:0;align-items:center;gap:.45rem}.tier-player-entry.has-inline-comparison{flex:1 1 12rem}.tier-zone-pool .tier-player-entry{flex:0 0 var(--tier-card-width)}.tier-inline-comparison{display:grid;min-width:0;flex:1 1 auto;gap:.22rem;color:#ffffffd6}.tier-inline-summary{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:.42rem;font-size:.62rem;font-weight:820;line-height:1}.tier-inline-summary span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tier-inline-summary strong{color:#fff;font-weight:900}.tier-inline-summary em{flex:0 0 auto;padding:.16rem .36rem;border-radius:999px;font-size:.54rem;font-style:normal;font-weight:860;line-height:1}.tier-inline-summary .is-aligned{background:#28a76b2e;color:#aaf0c4}.tier-inline-summary .is-different{background:#ffffff1f;color:#ffffffb8}.tier-inline-bars{display:grid;gap:.12rem}.tier-inline-bar-row{display:grid;grid-template-columns:.72rem minmax(0,1fr) 1.75rem;align-items:center;gap:.28rem}.tier-inline-bar-row span,.tier-inline-bar-row strong{color:#ffffffa3;font-size:.52rem;font-weight:830;line-height:1}.tier-inline-bar-row strong{text-align:right}.tier-inline-bar-row div{height:.28rem;overflow:hidden;border-radius:999px;background:#ffffff1f}.tier-inline-bar-row i{display:block;height:100%;border-radius:inherit;background:var(--tier-color);opacity:.76}.tier-inline-bar-row i[data-your-tier=true]{opacity:1}.tier-empty{display:grid;min-height:calc(var(--tier-row-height) - 1.1rem);flex:1 1 5.5rem;place-items:center;gap:.28rem;border:1px dashed rgba(255,255,255,.25);border-radius:0;color:#ffffff8f;font-size:.72rem;font-weight:760}.tier-empty svg{color:currentColor}.tier-zone-pool .tier-empty{border-color:var(--line);border-radius:8px;color:var(--muted)}.tier-player-card{position:relative;display:grid;grid-template-rows:var(--tier-card-image-height) minmax(1.48rem,auto);width:var(--tier-card-width);min-height:calc(var(--tier-card-image-height) + 1.48rem);flex:0 0 var(--tier-card-width);min-width:0;overflow:hidden;padding:0;border:1px solid #111111;border-radius:8px;background:#f5f5f5;color:var(--text);box-shadow:none;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.tier-player-card:active{transform:scale(.96)}.tier-player-card.is-selected{border-color:var(--accent-strong);box-shadow:0 0 0 3px var(--selected-ring)}.tier-player-card svg{position:absolute;top:.16rem;right:.16rem;padding:.08rem;border-radius:5px;background:var(--tile-name-bg);color:var(--accent-strong)}.tier-card-portrait{position:relative;display:grid;width:100%;height:100%;min-height:0;align-self:stretch;justify-self:stretch;place-items:center;overflow:hidden;background:var(--surface-strong)}.tier-card-portrait img{position:absolute;inset:0;display:block;width:100%;height:100%;min-width:100%;min-height:100%;object-fit:cover;object-position:center top;outline:1px solid var(--image-outline);outline-offset:-1px}.tier-card-name{display:flex;min-width:0;align-items:center;justify-content:center;padding:.18rem .16rem;border-top:1px solid #111111;background:#f5f5f5;color:#111;text-align:center;overflow-wrap:anywhere;font-size:.56rem;font-weight:820;line-height:1.05}.tier-card-name[data-long-name=true]{font-size:.47rem}.tier-comparison-toast{position:fixed;right:max(.75rem,calc((100vw - 520px)/2 + .75rem));bottom:max(1rem,env(safe-area-inset-bottom));left:max(.75rem,calc((100vw - 520px)/2 + .75rem));z-index:16;display:grid;gap:.48rem;padding:.62rem;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);box-shadow:var(--shadow-border),0 16px 34px var(--modal-shadow)}.tier-comparison-head{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.65rem}.tier-comparison-head h2,.tier-comparison-head p{margin:0}.tier-comparison-head h2{color:var(--text);font-size:1rem;font-weight:850}.tier-comparison-head p{color:var(--muted);font-size:.72rem;font-weight:700}.tier-comparison-head svg{color:var(--accent)}.tier-comparison-close{display:inline-grid;width:40px;height:40px;place-items:center;border:1px solid transparent;border-radius:8px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-border);transition:background-color .14s ease,box-shadow .14s ease,transform .14s ease}.tier-comparison-close:active{transform:scale(.96)}.tier-comparison-close svg{color:currentColor}.tier-reaction{display:grid;gap:.34rem;padding:.62rem;border:1px solid transparent;border-radius:8px;background:var(--surface);box-shadow:var(--shadow-border)}.tier-reaction span{width:max-content;padding:.24rem .42rem;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong);text-transform:capitalize;font-size:.62rem;font-weight:850}.tier-reaction p{margin:0;color:var(--text);font-size:.84rem;font-weight:760;line-height:1.32}.tier-comparison-note{margin:0;color:var(--muted);text-align:center;font-size:.68rem;font-weight:760}.live-message{min-height:1.45rem;margin:.72rem .75rem .55rem;color:var(--muted);text-align:center;font-size:.92rem;font-weight:720}.connections-status-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.55rem;margin:0 0 .55rem;padding:.48rem .62rem;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);box-shadow:var(--shadow-border)}.connections-status-copy{display:grid;min-width:0;gap:.06rem}.connections-status-kicker{display:inline-flex;min-width:0;align-items:center;gap:.28rem;color:var(--accent-strong);font-size:.68rem;font-weight:850}.connections-status-kicker svg{flex:0 0 auto}.connections-status-copy p{margin:0;color:var(--text);overflow-wrap:anywhere;font-size:1rem;font-weight:860;line-height:1.12}.connections-status-side{display:inline-flex;align-items:center;gap:.45rem}.connections-mistakes{display:inline-flex;min-height:40px;align-items:center;gap:.22rem;padding:0 .48rem;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted);white-space:nowrap;font-size:.7rem;font-weight:820}.connections-mistakes strong{color:var(--danger);font-size:.92rem;font-weight:900}.connections-mistakes,.connections-mistakes strong,.tier-brief-stats,.tier-brief-stats strong,.tier-crowd-button,.tier-inline-summary strong,.tier-inline-bar-row strong,.tier-comparison-head p,.result-card-header strong,.result-turn{font-variant-numeric:tabular-nums}.connections-status-help{min-width:40px;min-height:40px;background:var(--surface)}.connections-status-hints:not(:disabled) svg{color:var(--accent)}.connections-status-help:disabled{cursor:not-allowed;color:var(--disabled);opacity:.58}.action-dock{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,4fr);gap:.45rem;padding:.45rem .75rem max(.8rem,env(safe-area-inset-bottom))}.tier-actions{display:grid;grid-template-columns:1fr 1.25fr;gap:.65rem;padding:.05rem .75rem max(1rem,env(safe-area-inset-bottom))}.action-dock button,.primary-action,.secondary-action,.connections-submit-button{position:relative;display:inline-grid;min-height:56px;place-items:center;gap:.18rem;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);color:var(--text);font-size:.66rem;font-weight:780;box-shadow:var(--shadow-border);transition:background-color .14s ease,border-color .14s ease,box-shadow .14s ease,color .14s ease,transform .14s ease}.action-dock button:active:not(:disabled),.primary-action:active:not(:disabled),.secondary-action:active:not(:disabled),.connections-submit-button:active:not(:disabled),.tier-crowd-button:active:not(:disabled){transform:scale(.96)}.action-dock svg{color:var(--accent)}.action-dock button:disabled,.connections-submit-button:disabled,.primary-action:disabled,.secondary-action:disabled{cursor:not-allowed;color:var(--disabled);opacity:.58}.action-dock button:disabled svg,.connections-submit-button:disabled svg,.primary-action:disabled svg,.secondary-action:disabled svg{color:var(--disabled)}.action-dock .connections-submit-button{display:inline-flex;align-items:center;justify-content:center;width:auto;margin:0;font-weight:860}.action-dock .connections-submit-button svg{width:22px;height:22px}.action-dock .connections-submit-button,.tier-actions .primary-action,.tier-actions .secondary-action{min-height:64px;gap:.28rem;border-width:1.5px;font-size:.74rem;box-shadow:0 8px 18px var(--tile-shadow)}.action-dock .connections-submit-button svg,.tier-actions .primary-action svg,.tier-actions .secondary-action svg{width:22px;height:22px}.action-dock .connections-submit-button:not(:disabled),.tier-actions .primary-action:not(:disabled){border-color:var(--accent-strong);background:linear-gradient(180deg,rgba(255,255,255,.12),transparent),var(--accent);color:#fffefa}.action-dock .connections-submit-button:not(:disabled) svg,.tier-actions .primary-action:not(:disabled) svg{color:#fffefa}.tier-actions .secondary-action:not(:disabled){background:var(--surface)}.site-footer{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;padding:.75rem .75rem max(.9rem,env(safe-area-inset-bottom));border-top:1px solid var(--line);color:var(--muted);font-size:.72rem;font-weight:750}.site-footer a{color:var(--muted);text-decoration:none}.site-footer a:hover{color:var(--accent-strong);text-decoration:underline}.site-credit{color:var(--muted)}.legal-shell{min-height:100svh}.legal-topbar{display:flex;min-height:58px;align-items:center;padding:.5rem .75rem;border-bottom:1px solid var(--line);background:var(--topbar-bg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.legal-home-link{color:var(--accent-strong);font-weight:850;text-decoration:none}.legal-page{display:grid;gap:1rem;padding:1rem .95rem 1.4rem;color:var(--text)}.legal-page-header{display:grid;gap:.45rem;padding-bottom:.75rem;border-bottom:1px solid var(--line)}.legal-page-header h1{margin:0;font-size:1.55rem;line-height:1.1}.legal-page-header p,.legal-section p,.legal-section li{color:var(--muted);font-size:.88rem;font-weight:650;line-height:1.55}.legal-updated{margin:0;color:var(--accent-strong)!important;font-size:.7rem!important;font-weight:850!important;letter-spacing:.04em;text-transform:uppercase}.legal-section{display:grid;gap:.45rem}.legal-section h2{margin:0;color:var(--text);font-size:1rem;font-weight:850}.legal-section p{margin:0}.legal-section ul{display:grid;gap:.35rem;margin:.1rem 0 0;padding-left:1.1rem}.finish-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.72rem;align-items:center;padding:.82rem;border:1px solid transparent;border-radius:8px;background:var(--surface-soft);box-shadow:var(--shadow-border);user-select:none;-webkit-user-select:none}.finish-card>svg{align-self:start;color:#c79f16}.finish-card-copy{display:grid;min-width:0;gap:.16rem}.finish-card h2{margin:0;color:var(--text);font-size:1.05rem;font-weight:800;line-height:1.12}.finish-card p{max-width:20rem;margin:0;color:var(--muted);font-size:.78rem;font-weight:680;line-height:1.32}.finish-actions{display:flex;grid-column:1 / -1;gap:.55rem;align-items:center}.finish-actions .primary-action,.finish-actions .secondary-action{flex:1 1 0;justify-content:center;min-height:44px;white-space:nowrap}.finish-modal-content{display:grid;gap:.85rem}.finish-modal-content>p{margin:0;color:var(--muted);font-weight:680;line-height:1.4}.finish-modal-content .result-card{width:100%}.finish-modal-actions{margin-top:.08rem}.finish-modal-actions .primary-action{width:100%;flex-basis:100%}.result-card{display:grid;width:min(100%,18rem);gap:.55rem;padding:.75rem;border:1px solid transparent;border-radius:8px;background:var(--surface);box-shadow:var(--shadow-border)}.result-card-header{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.55rem;color:var(--muted);font-size:.73rem;font-weight:760}.result-card-header strong{color:var(--text);font-size:.78rem;text-align:right}.result-grid{display:grid;gap:.38rem}.result-row{display:grid;grid-template-columns:3.1rem 1fr 3rem;align-items:center;gap:.55rem;min-height:1.75rem}.result-turn,.result-row-status{color:var(--muted);font-size:.7rem;font-weight:760}.result-row-status{text-align:right}.result-squares{display:grid;grid-template-columns:repeat(4,1.35rem);justify-content:center;gap:.28rem}.result-square{width:1.35rem;aspect-ratio:1;border:1px solid var(--solved-border);border-radius:5px}.result-square-gold{background:var(--gold)}.result-square-silver{background:var(--silver)}.result-square-blue{background:var(--blue)}.result-square-teal{background:var(--teal)}.primary-action,.secondary-action{display:inline-flex;min-height:42px;padding:0 .95rem;font-size:.78rem}.primary-action{border-color:var(--accent-strong);background:var(--accent);color:#fffefa}.primary-action:disabled{border-color:var(--line);background:var(--surface-soft)}.secondary-action{background:var(--surface-soft)}.modal-backdrop{position:fixed;inset:0;z-index:20;display:grid;place-items:end center;padding:1rem;background:var(--modal-backdrop)}.modal-backdrop-center{place-items:center}.modal-panel{position:relative;width:min(100%,430px);max-height:min(78svh,620px);overflow:auto;padding:1rem;border:1px solid transparent;border-radius:8px;background:var(--surface);color:var(--text);box-shadow:var(--shadow-border),0 18px 45px var(--modal-shadow)}.modal-panel h2{margin:0 2.6rem .75rem 0;font-size:1.35rem;font-weight:800}.modal-close{position:absolute;top:.65rem;right:.65rem;color:var(--text);background:transparent}.rules-copy p,.rules-copy li{color:var(--muted);font-weight:650}.rules-copy ul{margin:.75rem 0 1rem;padding-left:1.2rem}.hint-list{display:grid;gap:.55rem}.hint-row{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:center;padding:.72rem;border:1px solid transparent;border-left-width:5px;border-radius:8px;background:var(--surface-soft);color:var(--text);box-shadow:var(--shadow-border)}.hint-row h3,.hint-row p{margin:0}.hint-row h3{font-size:.95rem;font-weight:800}.hint-row p{color:var(--muted);font-size:.78rem;font-weight:650}.hint-row-gold{border-left-color:var(--gold-border)}.hint-row-silver{border-left-color:var(--silver-border)}.hint-row-blue{border-left-color:var(--blue-border)}.hint-row-teal{border-left-color:var(--teal-border)}.hint-actions{display:flex;gap:.35rem}.hint-actions button{min-height:40px;padding:0 .65rem;border:1px solid transparent;border-radius:8px;color:var(--text);background:var(--surface);font-size:.73rem;font-weight:780;box-shadow:var(--shadow-border);transition:background-color .14s ease,box-shadow .14s ease,color .14s ease,transform .14s ease}.hint-actions button:active:not(:disabled){transform:scale(.96)}.hint-actions button:disabled{opacity:.48}@media(hover:hover){.mode-switch button:not(.is-active):hover,.icon-button:hover,.status-help:hover,.connections-status-help:not(:disabled):hover,.modal-close:hover,.tier-comparison-close:hover,.action-dock button:not(:disabled):hover,.hint-actions button:not(:disabled):hover,.secondary-action:not(:disabled):hover{border-color:var(--hover-border);background:var(--control-hover);box-shadow:var(--shadow-border-hover)}.tier-zone.is-targetable:hover,.tier-player-card:not(:disabled):hover{border-color:var(--hover-border)}.tier-crowd-button:not(:disabled):hover{color:var(--accent)}.action-dock .connections-submit-button:not(:disabled):hover,.primary-action:not(:disabled):hover{border-color:var(--accent-strong);background:linear-gradient(180deg,rgba(255,255,255,.1),transparent),var(--accent-strong);color:#fffefa}.action-dock .connections-submit-button:not(:disabled):hover svg,.primary-action:not(:disabled):hover svg{color:#fffefa}}@media(max-width:390px){.topbar{grid-template-columns:auto minmax(0,1fr) auto;padding-inline:.55rem}.topbar-side{min-width:76px}.topbar h1{font-size:1.16rem}.icon-button,.status-help,.connections-status-help,.modal-close{min-width:40px;min-height:40px}.mode-switch{padding-inline:.55rem}.status-strip{grid-template-columns:minmax(0,1fr) auto;padding-inline:.6rem}.status-help{display:none}.connections-status-card{gap:.44rem;padding:.46rem .54rem}.connections-status-side{justify-content:end}.board{padding:.6rem .45rem 0}.tiles-grid{gap:.36rem}.player-tile{grid-template-rows:minmax(0,1fr) minmax(2.12rem,auto)}.player-name{padding-inline:.18rem;font-size:.6rem}.player-name[data-long-name=true]{font-size:.53rem}.tier-board{--tier-row-height: clamp(4.5rem, 8.2svh, 5.05rem);--tier-pool-height: clamp(6.55rem, 12.8svh, 7.65rem);--tier-card-width: 4.55rem;--tier-card-image-height: 3.18rem;gap:.38rem}.tier-brief{gap:.3rem;padding-block:.26rem}.tier-brief-stats{justify-items:end}.tier-zone-label>span{min-height:var(--tier-row-height)}.tier-card-list{min-height:var(--tier-row-height);padding:.3rem}.tier-player-card{width:var(--tier-card-width);flex-basis:var(--tier-card-width);grid-template-rows:var(--tier-card-image-height) minmax(1.38rem,auto)}.tier-actions{padding-inline:.55rem}.tier-actions .primary-action,.tier-actions .secondary-action{min-height:60px;font-size:.7rem}.action-dock{gap:.36rem;padding-inline:.55rem}.action-dock button{min-height:52px;font-size:.61rem}.action-dock .connections-submit-button{min-height:60px;font-size:.7rem}.hint-row{grid-template-columns:1fr}}@media(min-width:760px){.app-shell{width:min(94vw,540px);min-height:calc(100svh - 2.5rem);margin-block:1.25rem;overflow:hidden;border-radius:8px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
