:root{color:#1d2522;background:#f4f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,a{font:inherit}.shell{max-width:1184px;margin:0 auto;padding:24px clamp(14px,3vw,32px)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.topbar h1{margin:0;font-size:32px;line-height:1}.topbar p{margin:4px 0 0;color:#5f6b66}.topbar a{color:#fff;background:#1f6f5b;border-radius:6px;padding:10px 14px;text-decoration:none}.play-grid{display:grid;gap:clamp(18px,3vw,32px)}.board-panel{display:grid;grid-template-columns:minmax(0,680px) minmax(280px,360px);gap:clamp(18px,3vw,32px);align-items:start;justify-content:center}.board-shell{position:relative;width:min(100%,680px)}.board-status{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:grid;place-items:center;color:#fff;background:#2e332f}.board-status[hidden]{display:none}.board.cg-wrap{width:100%;max-width:680px;aspect-ratio:1;border:2px solid #2e332f;background:#2e332f;overflow:hidden;box-shadow:0 14px 40px #1d25222e}.board cg-board{border-radius:0}.board coords{font-weight:700}.board cg-board square.fog-hidden{background:linear-gradient(135deg,rgba(20,29,25,.2) 0 25%,transparent 25% 50%,rgba(20,29,25,.16) 50% 75%,transparent 75%),#141d1961;background-size:14px 14px;box-shadow:inset 0 0 0 1px #f4f1ea0a}.board cg-board square.fog-hidden.last-move{background:linear-gradient(135deg,rgba(20,29,25,.16) 0 25%,transparent 25% 50%,rgba(20,29,25,.12) 50% 75%,transparent 75%),#685b3e80;background-size:14px 14px}.promotion-picker{position:absolute;left:50%;top:50%;z-index:3;display:grid;grid-template-columns:repeat(4,56px);gap:6px;padding:8px;background:#f4f1eaf5;border:1px solid #87978e;box-shadow:0 16px 44px #1d252247;transform:translate(-50%,-50%)}.promotion-picker[hidden]{display:none}.promotion-picker button{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:grid;place-items:center;width:56px;aspect-ratio:1;border:1px solid #bdc8bf;background:#fff;color:#1d2522;cursor:pointer}.promotion-picker button:hover,.promotion-picker button:focus-visible{border-color:#1f6f5b;outline:3px solid rgba(31,111,91,.22)}.promotion-piece{font-family:Georgia,Times New Roman,serif;font-size:38px;font-weight:700;line-height:1}.promotion-piece.white{color:#fffdf4;text-shadow:0 1px 1px rgba(23,32,28,.75),0 0 1px rgba(23,32,28,.86)}.promotion-piece.black{color:#202521;text-shadow:0 1px 0 rgba(255,255,255,.34),0 0 1px rgba(255,255,255,.45)}.side-panel{display:grid;gap:18px;min-width:0}.panel-section{display:grid;gap:10px;padding-top:16px;border-top:1px solid rgba(95,107,102,.24)}.panel-section:first-child{padding-top:0;border-top:0}.panel-section[hidden]{display:none}.panel-section h2{margin:0;font-size:15px;line-height:1.2}.game-info,.selection-list,.clocks{display:grid;gap:6px}.game-info div,.selection-list div,.clocks div{display:grid;grid-template-columns:minmax(72px,.8fr) minmax(0,1fr);gap:10px;align-items:baseline;min-height:26px;color:#5f6b66}.game-info span,.selection-list span,.clocks span{font-size:13px}.game-info strong,.selection-list strong,.clocks strong{overflow-wrap:anywhere;color:#1d2522;font-size:14px;font-weight:650}.clocks{gap:8px;margin-bottom:4px}.clocks div{min-height:42px;padding:8px 10px;border:1px solid #d3d9d2;background:#fff}.clocks div.active{border-color:#1f6f5b;box-shadow:inset 4px 0 #1f6f5b}.clocks strong{font-variant-numeric:tabular-nums;font-size:22px;line-height:1;text-align:right}.starts{display:grid;gap:10px}.room-actions{display:grid;gap:8px}.share-room{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.share-room input,.share-room button{min-height:38px;border:1px solid #bdc8bf;border-radius:6px;background:#fff;color:#1d2522}.share-room input{min-width:0;padding:8px 10px;font-size:13px}.share-room button{padding:8px 12px;cursor:pointer}.share-room input:focus,.share-room button:hover,.share-room button:focus-visible{border-color:#1f6f5b;outline:3px solid rgba(31,111,91,.18)}.room-actions a{display:block;min-height:38px;border:1px solid #bdc8bf;border-radius:6px;background:#fff;color:#1d2522;padding:9px 10px;text-align:center;text-decoration:none}.room-actions a:hover,.room-actions a:focus-visible{border-color:#1f6f5b;outline:3px solid rgba(31,111,91,.18)}.debug-shell{max-width:1480px}.debug-page{display:grid;align-self:start;gap:12px}.debug-page[hidden]{display:none}.debug-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.debug-header h2{margin:0;font-size:16px;line-height:1.2}.debug-views,.dev-views{display:grid;gap:12px}.dev-view-card{display:grid;gap:6px}.dev-view-card>strong{font-size:13px;line-height:1.2}.dev-view-card>span{color:#5f6b66;font-size:12px;line-height:1.2}.dev-board{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));width:min(100%,178px);border:1px solid #87978e;background:#87978e}.dev-square{display:grid;place-items:center;aspect-ratio:1;min-width:0;color:#1d2522;font-family:Georgia,Times New Roman,serif;font-size:14px;line-height:1}.dev-square.light{background:#f0dcc0}.dev-square.dark{background:#7f9a78}.dev-square.hidden{background:linear-gradient(135deg,rgba(20,29,25,.2) 0 25%,transparent 25% 50%,rgba(20,29,25,.16) 50% 75%,transparent 75%),#3b453d;background-size:8px 8px}.start-row{display:grid;gap:8px}.start-card,.solo-picks button{display:grid;gap:4px;width:100%;border:1px solid #bdc8bf;border-radius:6px;background:#fff;color:#1d2522;padding:12px;text-align:left;cursor:pointer}.start-card{min-height:72px}.start-card strong{font-size:17px;line-height:1.1}.solo-picks{display:grid;grid-template-columns:1fr 1fr;gap:8px}.solo-picks button{justify-items:center;padding:8px;min-height:40px}.starts button:hover:not(:disabled){border-color:#1f6f5b}.starts button:disabled{cursor:default;opacity:.68}.starts button.selected{border-color:#1f6f5b;box-shadow:inset 4px 0 #1f6f5b}.starts button.resolved{border-color:#254d7a;box-shadow:inset 4px 0 #254d7a}.starts span{color:#5f6b66;letter-spacing:.08em}.bid-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.bid-controls input,.bid-controls button{min-height:38px;border:1px solid #bdc8bf;border-radius:6px;background:#fff;color:#1d2522}.bid-controls input{min-width:0;padding:8px 10px}.bid-controls button{padding:8px 12px;cursor:pointer}.bid-controls button:hover:not(:disabled){border-color:#1f6f5b}.bid-controls button:disabled{cursor:default;opacity:.6}.info-notice{display:block;grid-template-columns:none;min-height:34px;border:1px solid #d3d9d2;border-radius:6px;background:#fff;color:#5f6b66;padding:8px 10px;font-size:13px;line-height:1.35}.info-notice.pending{border-color:#c8bd90;background:#fff8df;color:#675a2a}.info-notice.success{border-color:#9bbdaf;background:#eef8f2;color:#225a46}.replay-controls{display:grid;grid-template-columns:repeat(4,40px);gap:8px}.replay-controls button,.move-list button{border:1px solid #bdc8bf;border-radius:6px;background:#fff;color:#1d2522;cursor:pointer}.replay-controls button{height:36px}.replay-controls button:disabled{cursor:default;opacity:.5}.replay-meta{margin:-8px 0 0;color:#5f6b66;font-size:14px}.move-list{display:grid;gap:6px;max-height:180px;margin:0;padding-left:28px;overflow:auto}.move-list button{padding:6px 8px;text-align:left}.move-list button.active{border-color:#254d7a;box-shadow:inset 4px 0 #254d7a}@media(max-width:780px){.shell{padding-top:16px}.board-panel,.topbar{grid-template-columns:1fr;display:grid}.topbar{align-items:start}.topbar a{justify-self:start}.board-shell,.board.cg-wrap{max-width:min(100%,calc(100vh - 220px))}.side-panel{gap:16px}.debug-views{grid-template-columns:1fr}.dev-board{width:min(100%,260px)}.promotion-picker{grid-template-columns:repeat(4,48px)}.promotion-picker button{width:48px}.promotion-piece{font-size:32px}}@media(min-width:1180px){.debug-shell{padding-block:16px}.debug-shell .topbar{margin-bottom:14px}.debug-shell .play-grid{grid-template-columns:minmax(0,1040px) minmax(176px,210px);align-items:start;justify-content:center}.debug-shell .board-panel{grid-template-columns:minmax(0,min(64vh,620px)) minmax(250px,320px);gap:clamp(14px,2vw,24px)}.debug-shell .board-shell,.debug-shell .board.cg-wrap{max-width:min(100%,64vh,620px)}.debug-shell .side-panel{gap:12px}.debug-shell .panel-section{gap:8px;padding-top:12px}.debug-shell .clocks div{min-height:36px;padding:6px 8px}.debug-shell .clocks strong{font-size:18px}.debug-shell .move-list{max-height:104px}}.replay-page{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 16px;min-height:100vh;box-sizing:border-box}.replay-layout{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;width:100%;max-width:1280px}.replay-pane{display:flex;flex-direction:column;gap:8px;align-items:center}.replay-pane-label{font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:12px;color:#5a6960}.replay-board.cg-wrap{width:100%;max-width:380px;transition:box-shadow .6s ease}.replay-board cg-board square.fog-hidden{transition:background .6s ease,opacity .6s ease}.replay-pane.revealed .replay-pane-label{color:#b07b27}.replay-pane.revealed .replay-board.cg-wrap{box-shadow:0 0 0 2px #b07b278c,0 14px 40px #1d25222e}.replay-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center}.replay-button{font:inherit;padding:6px 12px;border-radius:8px;border:1px solid #c4c8c2;background:#f4f1ea;cursor:pointer;min-width:44px}.replay-button:hover:not(:disabled){background:#ece8de}.replay-button:disabled{opacity:.4;cursor:not-allowed}.replay-ply-label{font-variant-numeric:tabular-nums;margin-left:8px;color:#2e332f}@media(max-width:900px){.replay-layout{grid-template-columns:1fr}}.landing-page{display:flex;flex-direction:column;align-items:stretch;gap:0;padding:0;min-height:100vh;box-sizing:border-box}.site-nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#f4f1eaeb;-webkit-backdrop-filter:saturate(140%) blur(8px);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid #e1ddd2}.site-nav-brand{font-weight:800;letter-spacing:.12em;font-size:14px;color:#1f2521;text-decoration:none}.site-nav-links{display:flex;gap:20px;align-items:center}.site-nav-link{font-size:14px;color:#3f4742;text-decoration:none;font-weight:500}.site-nav-link:hover{color:#1f2521}.landing-hero{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:36px 16px 16px}.landing-hero .landing-title,.landing-hero .landing-subtitle,.landing-hero .landing-tag,.landing-hero .landing-ctas{max-width:720px;margin-left:auto;margin-right:auto}.landing-demo{padding:0 16px 24px;display:flex;flex-direction:column;align-items:center}.site-section{padding:64px 16px;max-width:760px;margin:0 auto;width:100%;box-sizing:border-box}.site-section-heading{font-size:28px;margin:0 0 16px;color:#1f2521;letter-spacing:-.005em}.about-section p{margin:0 0 14px;color:#3f4742;line-height:1.65;font-size:16px}.about-section p:last-child{margin-bottom:0}.site-footer{display:flex;justify-content:space-between;align-items:center;padding:24px;border-top:1px solid #e1ddd2;font-size:13px;color:#5a6960;margin-top:auto}.site-footer a{color:#3f4742;text-decoration:none}.site-footer a:hover{color:#1f2521;text-decoration:underline}.site-footer-sep{margin:0 8px;opacity:.5}@media(max-width:600px){.site-nav{padding:10px 16px}.site-footer{padding:18px 16px;flex-direction:column;gap:6px;align-items:flex-start}}.landing-title{font-size:clamp(36px,5vw,56px);margin:0;letter-spacing:-.01em;color:#1f2521}.landing-subtitle{font-size:clamp(16px,2vw,20px);margin:0;color:#3f4742;max-width:560px}.landing-tag{margin:0;font-size:14px;color:#5a6960}.landing-ctas{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;justify-content:center}.landing-cta-primary,.landing-cta-secondary{font:inherit;font-weight:600;padding:10px 18px;border-radius:10px;cursor:pointer;border:1px solid transparent}.landing-cta-primary{background:#2e332f;color:#f4f1ea}.landing-cta-primary:disabled{background:#c4c8c2;color:#f4f1ea;cursor:not-allowed}.landing-cta-secondary{background:transparent;color:#2e332f;border-color:#c4c8c2}.landing-cta-secondary:hover{background:#ece8de}#landing-replay{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px}.landing-page .replay-page{padding:0;min-height:0}
