:root{color:#171512;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#ece7dd;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(135deg,#ece7ddf2,#ced6cdf0),radial-gradient(circle at 24px 24px,#264e451f 2px,#0000 3px) 0 0/48px 48px;min-width:320px;min-height:100vh;margin:0}button{font:inherit}.shell{width:min(1180px,100% - 32px);margin:0 auto;padding:28px 0}.topbar{justify-content:space-between;align-items:end;gap:24px;margin-bottom:22px;display:flex}.eyebrow{color:#36554d;text-transform:uppercase;letter-spacing:0;margin:0 0 4px;font-size:.76rem;font-weight:800}h1,h2,p{margin-top:0}h1{color:#191713;letter-spacing:0;margin-bottom:0;font-size:clamp(2.3rem,7vw,5.4rem);line-height:.95}.game-tabs{background:#ffffff73;border:1px solid #19171329;border-radius:8px;flex-wrap:wrap;gap:8px;padding:6px;display:flex}.tab{color:#2b2924;cursor:pointer;background:0 0;border:0;border-radius:6px;min-height:40px;padding:0 16px;font-weight:750}.tab.active{color:#fffdf7;background:#1f4d43}.game-layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:24px;display:grid}.board-stage{overflow:hidden}.rank-file{color:#615a4d;text-align:center;text-transform:uppercase;grid-template-columns:repeat(8,1fr);width:min(76vh,100%);max-width:720px;margin-left:auto;margin-right:auto;font-size:.72rem;font-weight:800;display:grid}.top-files{margin-bottom:8px}.chess-board,.mini-board{aspect-ratio:1;border:12px solid #302b21;border-radius:8px;grid-template-columns:repeat(8,1fr);width:min(76vh,100%);max-width:720px;margin:0 auto;display:grid;position:relative;overflow:hidden;box-shadow:0 28px 80px #1f1d1647}.square{aspect-ratio:1;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;border:0;place-items:center;width:100%;display:grid;position:relative}.square.light{background:#e8d7b7}.square.dark{background:#517061}.square.selected{outline-offset:-4px;outline:4px solid #ffc857}.square.last:before,.square.target:before{content:"";background:#ffc85742;border-radius:8px;position:absolute;inset:10%}.square.target:after{content:"";aspect-ratio:1;background:#1c2c2657;border-radius:999px;width:28%;position:absolute}.square.drag-source .piece{opacity:.28}.piece{z-index:1;pointer-events:none;-webkit-text-stroke:1px currentColor;place-items:center;width:74%;height:74%;font-family:Georgia,Times New Roman,serif;font-size:clamp(1.8rem,5.8vw,3.8rem);font-weight:900;line-height:1;display:grid}.dragged-piece{z-index:20;opacity:.96;pointer-events:none;width:min(9vh,74px);position:fixed;transform:translate(-50%,-50%)scale(1.08)}.white-piece{color:#f8f1df;text-shadow:0 2px #d2c09a,0 4px 8px #1419166b,1px 0 #6c6048,-1px 0 #6c6048,0 -1px #6c6048}.black-piece{color:#20201d;text-shadow:0 2px #000,0 5px 10px #14191680,1px 0 #f1dfb8,-1px 0 #f1dfb8,0 -1px #f1dfb8}.sketch-layer{z-index:4;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.sketch-layer line{stroke:#e85932db;stroke-width:1.7px;stroke-linecap:round;marker-end:url(#sketch-arrowhead)}.sketch-layer line.draft{opacity:.62}.sketch-layer marker path{fill:#e85932db}.coord{z-index:2;color:#19171380;font-size:.66rem;font-weight:850;position:absolute}.square.dark .coord{color:#fff9eb99}.coord.rank{top:5px;left:6px}.coord.file{bottom:5px;right:6px}.side-panel{background:#fffcf5c7;border:1px solid #19171324;border-radius:8px;padding:20px;box-shadow:0 20px 56px #201d151f}.panel-head{align-items:center;gap:12px;margin-bottom:18px;display:flex}.panel-head svg{color:#b84f32}.panel-head h2{margin:0 0 2px;font-size:1.2rem}.panel-head p,.body-copy,.empty{color:#665f54;margin:0;line-height:1.5}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px;display:grid}.stats-grid div{background:#fffaf0;border:1px solid #1917131f;border-radius:8px;min-height:72px;padding:12px}.stats-grid span{color:#71695c;text-transform:uppercase;font-size:.74rem;font-weight:800;display:block}.stats-grid strong{margin-top:6px;font-size:1.02rem;display:block}.actions{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.multiplayer-box{background:#fffaf0;border:1px solid #1917131f;border-radius:8px;gap:12px;margin:0 0 18px;padding:12px;display:grid}.multiplayer-box>div:first-child{gap:3px;display:grid}.multiplayer-box strong{color:#1f332d;font-size:.98rem}.multiplayer-box span{color:#665f54;font-size:.84rem;line-height:1.35}.multiplayer-actions{flex-wrap:wrap;gap:8px;display:flex}.icon-button{color:#fffdf7;cursor:pointer;background:#2c3c37;border:1px solid #19171324;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 14px;font-weight:800;display:inline-flex}.icon-button:disabled{cursor:not-allowed;opacity:.48}.icon-button.active-mode{background:#b84f32}.icon-button.subtle{color:#2b2924;background:#f3ead7}.promotion-picker{background:#fffaf0;border:1px solid #1917131f;border-radius:8px;margin-bottom:18px;padding:12px}.promotion-picker>span{color:#665f54;text-transform:uppercase;margin-bottom:10px;font-size:.78rem;font-weight:850;display:block}.promotion-picker div{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.promotion-picker button{color:#2b2924;cursor:pointer;background:#f3ead7;border:1px solid #1917131f;border-radius:8px;min-width:0;padding:8px 4px;font-size:.75rem;font-weight:850}.promotion-picker .piece{width:42px;height:42px;margin:0 auto 6px;font-size:2rem}.move-list{background:#231f19;border-radius:8px;gap:6px;min-height:120px;max-height:340px;padding:12px;display:grid;overflow:auto}.move-row{grid-template-columns:36px minmax(0,1fr) minmax(0,1fr);align-items:center;gap:6px;display:grid}.move-number,.move-pill{border-radius:6px;min-width:0;min-height:30px;font-size:.88rem;font-weight:800}.move-number{color:#baa989;place-items:center;display:grid}.move-pill{color:#f8edd6;cursor:pointer;background:#ffffff14;border:0;justify-content:flex-start;align-items:center;padding:0 10px;display:flex}.move-pill.active{color:#231f19;background:#ffc857}.move-pill.placeholder{cursor:default;background:0 0}.move-list .empty{color:#d5c5a8}.compact-layout{align-items:center}.checkers-board{border-color:#3f2b22}.checker-square{aspect-ratio:1;touch-action:none;-webkit-user-select:none;user-select:none;border:0;place-items:center;width:100%;min-width:0;min-height:0;padding:0;display:grid}.checker-light{background:#e5d9c4}.checker-dark{background:#6d473d}.checker-square.selected{outline-offset:-4px;outline:4px solid #ffc857}.checker-piece{aspect-ratio:1;border-radius:999px;place-items:center;width:68%;display:grid;box-shadow:inset 0 -8px #0000002e,0 8px 12px #0000002e}.checker-square.drag-source .checker-piece{opacity:.28}.dragged-checker{z-index:20;opacity:.96;pointer-events:none;width:min(8vh,62px);position:fixed;transform:translate(-50%,-50%)scale(1.08)}.checker-piece.red{background:#bd3f31}.checker-piece.cream{background:#f4e5be}.checker-piece svg{color:#262018}.mill-board{aspect-ratio:1;background:#e6d4ad;border:12px solid #302b21;border-radius:8px;width:min(76vh,100%);max-width:720px;margin:0 auto;position:relative;box-shadow:0 28px 80px #1f1d163d}.mill-lines{width:84%;height:84%;position:absolute;inset:8%;overflow:visible}.mill-lines rect,.mill-lines line{fill:none;stroke:#4b3a2b;stroke-width:1.5px;vector-effect:non-scaling-stroke}.mill-point{aspect-ratio:1;cursor:pointer;background:#f9eed4;border:2px solid #3f2b22;border-radius:999px;width:9%;padding:0;position:absolute;transform:translate(-50%,-50%);box-shadow:0 6px 12px #1e18122e}.mill-point.occupied.red{background:#bd3f31;box-shadow:inset 0 -7px #0000002e,0 8px 14px #1e18123d}.mill-point.occupied.cream{background:#f8e6bd;box-shadow:inset 0 -7px #00000024,0 8px 14px #1e181238}.mill-point.selected,.mill-point.removable{outline-offset:3px;outline:4px solid #ffc857}.blackjack-table{align-items:stretch}.felt{background:linear-gradient(135deg,#1f5743eb,#174038f5),repeating-linear-gradient(45deg,#ffffff0d 0 2px,#0000 2px 12px);border:12px solid #302b21;border-radius:8px;align-content:space-between;gap:28px;min-height:520px;padding:30px;display:grid;box-shadow:0 28px 80px #1f1d163d}.hand-title{color:#fff5df;justify-content:space-between;font-weight:900;display:flex}.cards{flex-wrap:wrap;gap:12px;margin-top:10px;display:flex}.card{aspect-ratio:.7;color:#161411;background:#fffaf0;border-radius:8px;flex-direction:column;justify-content:space-between;width:86px;padding:12px;font-size:1.2rem;font-weight:950;display:flex;box-shadow:0 10px 22px #120e0b47}.card.diamonds,.card.hearts{color:#b7352b}.card.back{color:#fff7e5;background:linear-gradient(135deg,#1f4d43,#b84f32),repeating-linear-gradient(45deg,#fff3 0 3px,#0000 3px 9px);place-items:center;display:grid}.tic-board,.connect-board,.snake-board,.sudoku-board,.mine-board,.twenty-board,.battle-board{aspect-ratio:1;border:12px solid #302b21;border-radius:8px;width:min(76vh,100%);max-width:720px;margin:0 auto;overflow:hidden;box-shadow:0 28px 80px #1f1d163d}.tic-board{background:#302b21;grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:8px;display:grid}.tic-cell{color:#1f2f2a;cursor:pointer;background:#fffaf0;border:0;border-radius:6px;place-items:center;width:100%;min-width:0;height:100%;min-height:0;padding:0;font-size:clamp(2.8rem,14vw,7.5rem);font-weight:950;line-height:1;display:grid;overflow:hidden}.tic-cell.win{color:#fffdf7;background:#b84f32}.connect-board{aspect-ratio:7/6;background:#214f80;grid-template-rows:repeat(6,minmax(0,1fr));grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;padding:14px;display:grid}.connect-slot{cursor:pointer;background:#d6e0dc;border:0;border-radius:999px;place-items:center;width:100%;min-width:0;height:100%;min-height:0;padding:0;display:grid;overflow:hidden;box-shadow:inset 0 5px 12px #0d1f306b}.connect-slot.win{outline-offset:-4px;outline:4px solid #ffc857}.connect-disc{aspect-ratio:1;border-radius:999px;width:82%;box-shadow:inset 0 -8px #00000029,0 5px 10px #0003}.connect-disc.red{background:#bd3f31}.connect-disc.gold{background:#f0b53f}.snake-board{background:#1b2f2a;grid-template-columns:repeat(16,1fr);gap:2px;padding:10px;display:grid}.snake-cell{background:#d9e3d4;border-radius:3px}.snake-cell.head{background:#ffc857}.snake-cell.body{background:#5fb06e}.snake-cell.apple{background:#b84f32}.direction-pad{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:18px;display:grid}.direction-pad button{color:#2b2924;cursor:pointer;background:#fffaf0;border:1px solid #19171324;border-radius:8px;min-height:38px;font-weight:800}.direction-pad button:first-child,.direction-pad button:last-child{grid-column:2}.sudoku-board{background:#302b21;grid-template-columns:repeat(9,1fr);gap:1px;display:grid}.sudoku-board input{aspect-ratio:1;color:#214039;width:100%;min-width:0;font:inherit;text-align:center;background:#fffaf0;border:1px solid #b7aa93;border-top:0;border-left:0;border-radius:0;font-size:clamp(1rem,5vw,2.35rem);font-weight:850}.sudoku-board input:nth-child(3n){border-right:3px solid #302b21}.sudoku-board input:nth-child(n+19):nth-child(-n+27),.sudoku-board input:nth-child(n+46):nth-child(-n+54){border-bottom:3px solid #302b21}.sudoku-board input.fixed{color:#191713;background:#dfd3bd}.sudoku-board input.wrong{color:#fffdf7;background:#b84f32}.mine-board{background:#302b21;grid-template-rows:repeat(10,minmax(0,1fr));grid-template-columns:repeat(10,minmax(0,1fr));gap:2px;padding:10px;display:grid}.mine-cell{color:#223f38;cursor:pointer;background:#d6e0dc;border:0;border-radius:4px;place-items:center;width:100%;min-width:0;height:100%;min-height:0;padding:0;font-size:clamp(.9rem,3.8vw,2rem);font-weight:950;line-height:1;display:grid;overflow:hidden;box-shadow:inset 0 -5px #0000001f}.mine-cell.revealed{box-shadow:none;cursor:default;background:#fffaf0}.mine-cell.flagged{color:#fffdf7;background:#1f4d43}.mine-cell.mine{color:#fffdf7;background:#b84f32}.mine-cell.near-1{color:#1f5f98}.mine-cell.near-2{color:#287346}.mine-cell.near-3{color:#b84f32}.mine-cell.near-4,.mine-cell.near-5,.mine-cell.near-6,.mine-cell.near-7,.mine-cell.near-8{color:#302b21}.twenty-board{background:#6f6558;grid-template-rows:repeat(4,minmax(0,1fr));grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:14px;display:grid}.twenty-cell{color:#3a3128;background:#b8ad9f;border-radius:6px;place-items:center;width:100%;min-width:0;height:100%;min-height:0;font-size:clamp(1.5rem,8vw,4.7rem);font-weight:950;line-height:1;display:grid;overflow:hidden}.twenty-cell.tile-2,.twenty-cell.tile-4{background:#f1e4ca}.twenty-cell.tile-8,.twenty-cell.tile-16,.twenty-cell.tile-32,.twenty-cell.tile-64{color:#fffdf7;background:#d98245}.twenty-cell.tile-128,.twenty-cell.tile-256,.twenty-cell.tile-512{color:#fffdf7;background:#bd3f31;font-size:clamp(1.2rem,6.2vw,3.8rem)}.twenty-cell.tile-1024,.twenty-cell.tile-2048{color:#fffdf7;background:#1f4d43;font-size:clamp(1rem,5.4vw,3.1rem)}.battle-board{background:#19364e;grid-template-rows:repeat(8,minmax(0,1fr));grid-template-columns:repeat(8,minmax(0,1fr));gap:4px;padding:10px;display:grid}.battle-cell{color:#d9eef9;cursor:pointer;background:#2e78a2;border:0;border-radius:4px;place-items:center;width:100%;min-width:0;height:100%;min-height:0;padding:0;font-size:clamp(1.1rem,4vw,2.4rem);font-weight:950;display:grid;box-shadow:inset 0 -5px #0000001f}.battle-cell.shot{color:#19364e;box-shadow:none;background:#b9d5df}.battle-cell.hit,.battle-cell.ship{color:#fffdf7;background:#b84f32}@media (width<=920px){.topbar,.game-layout{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.game-layout{display:grid}.side-panel{order:-1}}@media (width<=560px){.shell{width:min(100% - 20px,1180px);padding-top:18px}.game-tabs{width:100%}.tab{flex:1;padding:0 8px}.chess-board,.mini-board,.mill-board,.tic-board,.connect-board,.snake-board,.sudoku-board,.mine-board,.twenty-board,.battle-board{border-width:7px}.piece{width:74%;font-size:clamp(.92rem,8vw,2rem)}.coord{display:none}.stats-grid{grid-template-columns:1fr}.felt{min-height:430px;padding:18px}.card{width:68px;padding:9px}.connect-board{gap:5px;padding:8px}.snake-board,.mine-board{padding:6px}.twenty-board{gap:6px;padding:8px}.battle-board{padding:6px}}
