.start-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background-color:var(--color-bg);position:relative;overflow:hidden}.start-content{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;max-width:480px;padding:0 var(--space-4);margin-top:var(--space-16)}.start-hero{position:fixed;top:0;left:50%;transform:translate(-50%) translateY(-13%);width:500px;max-width:90vw;z-index:0;pointer-events:none}.start-hero img{width:100%;height:auto}.start-brand{font-size:var(--text-display);line-height:var(--line-height-display);letter-spacing:var(--letter-display);font-weight:var(--font-bold);color:var(--color-ink);margin-bottom:var(--space-2);position:relative;z-index:1}.start-tagline{font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);color:var(--color-ink);margin-bottom:var(--space-1);position:relative;z-index:1}.start-date{font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);color:var(--color-ink);margin-bottom:var(--space-8);position:relative;z-index:1}.start-button{display:inline-flex;align-items:center;justify-content:center;width:var(--button-width);height:var(--button-height);padding:var(--button-padding-y) var(--button-padding-x);border-radius:var(--radius-full);background-color:var(--color-ink);color:var(--color-white);font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);border:none;cursor:pointer;transition:opacity var(--duration-fast) ease;position:relative;z-index:1}.start-button:hover{opacity:.9}.start-button:active{opacity:.8}.board-container{width:var(--board-size);aspect-ratio:1;margin:0 auto;border-radius:0}.board-disabled{pointer-events:none}.board-container [data-piece]{transition-timing-function:cubic-bezier(.4,0,.2,1)!important;filter:drop-shadow(0 1px 1px rgba(0,0,0,.05))}.board-container [data-piece]:hover{filter:drop-shadow(0 1px 2px rgba(0,0,0,.08));cursor:grab}.board-container [data-piece][style*="cursor: grabbing"],.board-container [data-piece]:active{filter:drop-shadow(0 2px 4px rgba(0,0,0,.12));transform:scale(1.05);cursor:grabbing}.daily-header{display:flex;justify-content:space-between;align-items:last baseline;padding:var(--space-16) 0 var(--space-4);color:var(--color-ink);width:100%;max-width:var(--board-size);margin:0 auto;gap:var(--space-6)}.hdr-left{display:flex;flex-direction:column;gap:0}.hdr-wordmark{margin:0;font-size:var(--text-title);line-height:1;letter-spacing:var(--letter-title);font-weight:var(--font-bold);transform:translateY(2px);text-decoration:none;color:inherit}.hdr-wordmark:hover{text-decoration:none}.hdr-date{margin:0;font-size:var(--text-body);line-height:1.2;letter-spacing:var(--letter-body);font-weight:var(--font-bold)}.hdr-center{display:flex;flex-direction:column;gap:0}.hdr-metaLine{margin:0;font-size:var(--text-body);line-height:1.2;letter-spacing:var(--letter-body);font-weight:var(--font-bold)}.hdr-strikes{display:flex;align-items:center;gap:var(--space-2);transform:translateY(var(--optical-strikes-nudge, -2px))}.strike-icon{width:28px;height:28px}@media(max-width:600px){.daily-header{padding:var(--space-8) 0 var(--space-2);gap:var(--space-4)}.hdr-wordmark{font-size:2rem}.hdr-date,.hdr-metaLine{font-size:1rem}.strike-icon{width:22px;height:22px}}.daily-page{min-height:100vh;min-height:100dvh;background-color:var(--color-bg);position:relative}.page-content{width:100%;max-width:var(--max-width);margin:0 auto}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;gap:var(--space-4);color:var(--color-ink)}.retry-button{padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);background-color:var(--color-ink);color:var(--color-white);font-size:var(--text-body);font-weight:var(--font-bold);cursor:pointer;border:none}.daily-footer{text-align:center;padding:var(--space-6) 0;display:none}.daily-footer span{font-size:var(--text-sm);color:var(--color-text-muted)}.toast{position:fixed;bottom:var(--space-4);left:var(--space-4);right:var(--space-4);max-width:calc(var(--max-width) - var(--space-8));margin:0 auto;height:72px;display:flex;align-items:center;justify-content:center;background-color:var(--color-surface);border-radius:var(--radius-toast);font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);color:var(--color-accent-orange);animation:toast-slide-up .3s var(--easing-out)}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.action-row{display:none}.gameover-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;min-height:100dvh;background-color:var(--color-bg)}.gameover-content{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:var(--space-4);text-align:center;width:100%;max-width:480px}.gameover-brand{position:absolute;top:var(--space-16);left:50%;transform:translate(-50%);font-size:var(--text-title);line-height:var(--line-height-title);letter-spacing:var(--letter-title);font-weight:var(--font-bold);color:var(--color-ink);text-decoration:none}.gameover-brand:hover{text-decoration:none}.gameover-icon{margin-bottom:var(--space-4)}.gameover-icon img{width:auto;height:auto;max-width:200px}.gameover-title{font-size:var(--text-title);line-height:var(--line-height-title);letter-spacing:var(--letter-title);font-weight:var(--font-bold);color:var(--color-ink);margin-bottom:var(--space-6)}.gameover-subtitle{font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);color:var(--color-ink);margin-bottom:var(--space-2)}.gameover-countdown{font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);color:var(--color-ink);font-variant-numeric:tabular-nums;margin-bottom:var(--space-10)}.gameover-buttons{display:flex;flex-direction:column;gap:var(--space-4);align-items:center}.gameover-button{display:inline-flex;align-items:center;justify-content:center;width:var(--button-width);height:var(--button-height);padding:var(--button-padding-y) var(--button-padding-x);border-radius:var(--radius-full);font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);cursor:pointer;transition:all var(--duration-fast) ease}.gameover-button--primary{background-color:var(--color-ink);color:var(--color-white);border:none}.gameover-button--primary:hover{opacity:.9}.gameover-button--secondary{background-color:transparent;color:var(--color-ink);border:1.2px solid var(--color-ink)}.gameover-button--secondary:hover{background-color:#2b2c300d}.gameover-solution{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-4)}.solution-buttons{display:flex;gap:var(--space-4);justify-content:center;margin-top:var(--space-6);padding-bottom:var(--space-8)}.gameover-board-view{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-4)}.board-view-buttons{display:flex;gap:var(--space-4);justify-content:center;margin-top:var(--space-6);padding-bottom:var(--space-8)}.countdown-container{display:flex;flex-direction:column;align-items:center;margin-top:var(--space-6);gap:var(--space-1)}.countdown-label{font-size:var(--text-small);line-height:var(--line-height-small);letter-spacing:var(--letter-body);color:var(--color-muted);font-weight:var(--font-medium)}.countdown-time{font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-mono);font-weight:var(--font-bold);color:var(--color-ink);font-variant-numeric:tabular-nums}@media(max-width:600px){.gameover-brand{top:var(--space-8)}.gameover-title{font-size:2rem;line-height:2.25rem}.solution-buttons,.board-view-buttons{flex-direction:column;align-items:center}}.settings-page{padding-bottom:var(--space-8)}.settings-header{margin-bottom:var(--space-6)}.settings-header h1{font-size:var(--text-2xl);font-weight:var(--font-bold)}.settings-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.settings-section h2{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.settings-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.recovery-display{display:flex;gap:var(--space-3);align-items:center}.recovery-code{flex:1;background:var(--color-bg);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-lg);letter-spacing:.05em}.settings-button{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:var(--font-medium);background:var(--color-surface-elevated);border:1px solid var(--color-border);color:var(--color-text);transition:background var(--duration-fast) ease}.settings-button:hover:not(:disabled){background:var(--color-border)}.settings-button:disabled{opacity:.5;cursor:not-allowed}.settings-button--primary{background:var(--color-accent);border-color:var(--color-accent);color:#000}.settings-button--primary:hover:not(:disabled){background:var(--color-accent-hover)}.restore-form{display:flex;gap:var(--space-3)}.restore-input{flex:1;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:var(--text-base);color:var(--color-text);text-transform:uppercase;letter-spacing:.05em}.restore-input::placeholder{color:var(--color-text-muted);text-transform:none}.restore-input:focus{outline:none;border-color:var(--color-accent)}.back-button{width:100%;margin-top:var(--space-4);padding:var(--space-3) var(--space-6);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-weight:var(--font-medium);transition:background var(--duration-fast) ease}.support-page{padding-bottom:var(--space-8)}.support-header{margin-bottom:var(--space-6)}.support-header h1{font-size:var(--text-2xl);font-weight:var(--font-bold)}.support-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;margin-bottom:var(--space-4)}.support-text{color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.support-button{display:inline-block;padding:var(--space-4) var(--space-8);background:var(--color-accent);color:#000;font-weight:var(--font-semibold);font-size:var(--text-lg);border-radius:var(--radius-md);text-decoration:none;transition:background var(--duration-fast) ease}.support-button:hover{background:var(--color-accent-hover);text-decoration:none}.back-button{width:100%;padding:var(--space-3) var(--space-6);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-weight:var(--font-medium);transition:background var(--duration-fast) ease}.back-button:hover{background:var(--color-border)}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background-color:var(--color-bg)}.page{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-4)}.page-content{width:100%;max-width:var(--max-width);display:flex;flex-direction:column}.loading-state,.error-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);text-align:center;color:var(--color-ink)}.retry-button{padding:var(--space-3) var(--space-6);background:var(--color-ink);border:none;border-radius:var(--radius-full);color:var(--color-white);font-size:var(--text-body);font-weight:var(--font-bold);cursor:pointer;transition:opacity var(--duration-fast) ease}.retry-button:hover{opacity:.9}@font-face{font-family:Sendo;src:url(/fonts/NeueHaasGrotDisp-65Medium-Web.woff2?v=2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Sendo;src:url(/fonts/NeueHaasGrotDisp-75Bold-Web.woff2?v=2) format("woff2");font-weight:700;font-style:normal;font-display:swap}:root{--color-bg: #ffffff;--color-ink: #2b2c30;--color-surface: #fcfcf4;--color-white: #ffffff;--color-accent-orange: #ff5623;--color-accent-green: #22c55e;--color-text: var(--color-ink);--color-text-secondary: #6b6b6b;--color-text-muted: #999999;--color-border: #e0e0e0;--color-error: var(--color-accent-orange);--color-board-light: #ece9e4;--color-board-dark: #b3aaa3;--color-board-highlight: rgba(0, 0, 0, .12);--color-board-selected: rgba(0, 0, 0, .18);--color-move-dot: rgba(0, 0, 0, .2);--color-check: rgba(255, 86, 35, .9);--font-brand: "Sendo", "Neue Haas Grotesk Display Pro", system-ui, sans-serif;--font-sans: "Sendo", system-ui, sans-serif;--text-display: 6rem;--line-height-display: 6.25rem;--letter-display: -.04em;--text-title: 3rem;--line-height-title: 3.25rem;--letter-title: -.03em;--text-body: 1.25rem;--line-height-body: 1.5rem;--letter-body: -.01em;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--button-width: 204px;--button-height: 50px;--button-padding-x: 1rem;--button-padding-y: .8125rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-toast: 1.625rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--easing-out: cubic-bezier(.16, 1, .3, 1);--easing-in-out: cubic-bezier(.65, 0, .35, 1);--max-width: 834px;--board-size: min(100vw - 2rem, 802px);--header-top: 64px}@keyframes shake{10%,90%{transform:translate3d(-.5px,0,0)}20%,80%{transform:translate3d(1px,0,0)}30%,50%,70%{transform:translate3d(-2px,0,0)}40%,60%{transform:translate3d(2px,0,0)}}.animate-shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both;transform:translateZ(0);perspective:1000px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-brand);font-size:var(--text-body);font-weight:var(--font-bold);line-height:var(--line-height-body);letter-spacing:var(--letter-body);color:var(--color-ink);background-color:var(--color-bg);min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-4)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-display{font-size:var(--text-display);line-height:var(--line-height-display);letter-spacing:var(--letter-display);font-weight:var(--font-bold)}.text-title{font-size:var(--text-title);line-height:var(--line-height-title);letter-spacing:var(--letter-title);font-weight:var(--font-bold)}.text-body{font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold)}:focus-visible{outline:2px solid var(--color-accent-orange);outline-offset:2px}button{font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;cursor:pointer;border:none;background:none;color:inherit}a{color:var(--color-ink);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;width:var(--button-width);height:var(--button-height);padding:var(--button-padding-y) var(--button-padding-x);border-radius:var(--radius-full);font-size:var(--text-body);line-height:var(--line-height-body);letter-spacing:var(--letter-body);font-weight:var(--font-bold);transition:all var(--duration-fast) ease;cursor:pointer}.btn--primary{background-color:var(--color-ink);color:var(--color-white);border:none}.btn--primary:hover{opacity:.9}.btn--secondary{background-color:transparent;color:var(--color-ink);border:1.2px solid var(--color-ink)}.btn--secondary:hover{background-color:#2b2c300d}
