:root{--color-surface:#f7f5f0;--color-surface-2:#edecea;--color-surface-3:#e3e1da;--color-surface-invert:#1c1b18;--color-text-primary:#1c1b18;--color-text-secondary:#6b6960;--color-text-tertiary:#9b9890;--color-text-on-invert:#f7f5f0;--color-text-on-accent:#fff;--color-accent:#2a6b6b;--color-accent-hover:#215555;--color-accent-light:#e4efef;--color-border:#dddbd4;--color-border-strong:#aeaca5;--font-ui:"Outfit", "Avenir Next", "Segoe UI", system-ui, sans-serif;--font-display:"Cormorant Garamond", "Iowan Old Style", Georgia, serif;--font-mono:"Space Mono", ui-monospace, Consolas, monospace;--radius-sm:3px;--radius-md:8px;--radius-lg:14px;--radius-pill:999px;--focus-ring:#2a6b6b66;--bg:var(--color-surface);--surface:var(--color-surface-2);--surface-strong:var(--color-surface-3);--surface-soft:var(--color-surface-2);--text:var(--color-text-secondary);--text-h:var(--color-text-primary);--muted:var(--color-text-tertiary);--border:var(--color-border);--border-strong:var(--color-border-strong);--accent:var(--color-accent);--accent-strong:var(--color-accent-hover);--accent-bg:var(--color-accent-light);--accent-border:#2a6b6b75;--code-bg:var(--color-surface-3);--sans:var(--font-ui);--heading:var(--font-ui);--mono:var(--font-mono);--shadow-sm:0 2px 8px #382b190f, 0 1px 3px #382b190a;--shadow:#382b191f 0 18px 50px -18px, #382b1914 0 8px 18px -12px;--shadow-strong:0 24px 70px #382b1921;--transition-fast:.12s ease;--transition-base:.16s ease;--z-header:100;--z-modal:200;--sudoku-accent:var(--color-accent);--sudoku-accent-contrast:#fff;--sudoku-cell-highlight-strength:22%;font:18px/145% var(--font-ui);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--color-text-secondary);background:var(--color-surface);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (width<=1024px){:root{font-size:16px}}body{background:var(--bg);color:var(--text);margin:0}#root{text-align:left;box-sizing:border-box;flex-direction:column;width:100%;max-width:none;min-height:100svh;margin:0;display:flex}@media (width>=1800px){#root{max-width:1720px;margin:0 auto}}.eyebrow{color:var(--accent-strong);letter-spacing:.14em;text-transform:uppercase;font-size:.76rem;font-weight:700}.lead{color:var(--text);max-width:65ch;font-size:clamp(1.05rem,1.5vw,1.24rem);line-height:1.65}.btn{border:1.5px solid var(--accent);border-radius:var(--radius-pill);min-height:44px;font:500 .95rem/1 var(--sans);letter-spacing:.01em;cursor:pointer;transition:background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base);justify-content:center;align-items:center;gap:8px;padding:0 20px;text-decoration:none;display:inline-flex}.btn:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}.btn--primary{background:var(--accent);color:var(--surface);border-color:var(--accent)}.btn--primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.btn--secondary{color:var(--accent-strong);border-color:color-mix(in srgb, var(--accent) 50%, var(--border));background:0 0}.btn--secondary:hover{background:color-mix(in srgb, var(--accent-bg) 60%, transparent)}.card{border:1px solid var(--border);border-radius:var(--radius-md);background:color-mix(in srgb, var(--surface) 94%, white);box-shadow:var(--shadow);padding:clamp(18px,3vw,28px)}.section-wrapper{box-sizing:border-box;width:100%;max-width:1320px;margin:0 auto}.content-grid{gap:clamp(16px,3vw,32px);display:grid}.board-container{width:100%;max-width:480px}h1,h2,h3{font-family:var(--heading);color:var(--text-h);margin:0;font-weight:500}h1{letter-spacing:-.03em;font-size:clamp(2.4rem,6vw,4.2rem);line-height:1.05}h2{letter-spacing:-.02em;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.12}h3{letter-spacing:-.01em;font-size:1.15rem;line-height:1.3}p{margin:0}code{font-family:var(--mono);background:var(--code-bg);color:var(--text-h);border-radius:4px;padding:4px 8px;font-size:15px;line-height:135%;display:inline-flex}.page-loading{color:var(--text);padding:24px}.vl-container{box-sizing:border-box;width:100%;max-width:1160px;margin:0 auto;padding:0 2rem}.vl-bleed{width:100%}.vl-eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;margin:0;font-size:.6875rem;font-weight:700}.vl-section-label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0;padding-top:2.5rem;padding-bottom:1.25rem;font-size:.625rem;font-weight:700}.vl-mono-tag{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);margin:0;font-size:.625rem;font-weight:700}.vl-section-heading{font-family:var(--font-ui);letter-spacing:-.035em;color:var(--color-text-primary);margin:0;font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;line-height:1.1}.vl-btn{font-family:var(--font-ui);letter-spacing:.015em;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base), color var(--transition-base);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:.9375rem;font-weight:700;line-height:1;text-decoration:none;display:inline-flex}.vl-btn:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}.vl-btn--primary{background:var(--color-text-on-accent);color:var(--color-accent)}.vl-btn--primary:hover{background:var(--color-surface)}.vl-btn--on-invert{background:var(--color-accent);color:var(--color-text-on-accent)}.vl-btn--on-invert:hover{background:var(--color-accent-hover)}.vl-btn-ghost{font-family:var(--font-ui);color:inherit;opacity:.75;cursor:pointer;transition:opacity var(--transition-base);background:0 0;border:none;align-items:center;gap:.4rem;padding:0;font-size:.9375rem;font-weight:500;text-decoration:none;display:inline-flex}.vl-btn-ghost:hover{opacity:1}.vl-btn-ghost:after{content:"→"}.vl-btn-ghost--bare:after{content:none}.vl-hero{background:var(--color-accent);color:var(--color-text-on-accent)}.vl-hero__inner{flex-direction:column;gap:1.25rem;padding:3.5rem 0 3rem;display:flex}.vl-hero__eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin:0;font-size:.6875rem;font-weight:700}.vl-hero__title{font-family:var(--font-ui);letter-spacing:-.04em;margin:0;font-size:clamp(3.5rem,8vw,7rem);font-weight:700;line-height:.93}.vl-hero__line{display:block}.vl-hero__line:nth-child(2){opacity:.6;padding-left:2rem}.vl-hero__line:nth-child(3){opacity:.35;padding-left:4rem}.vl-hero__line:nth-child(4){opacity:.55;padding-left:6rem}.vl-hero__sub{font-family:var(--font-ui);opacity:.72;max-width:44ch;margin:0;font-size:1rem;line-height:1.65}.vl-hero__actions{flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.5rem;display:flex}.vl-hero__inner.vl-hero__inner--split{grid-template-columns:minmax(0,1fr) minmax(0,.85fr);align-items:center;gap:2.5rem;display:grid}.vl-hero__copy{flex-direction:column;gap:1.25rem;min-width:0;display:flex}.vl-stats{grid-template-columns:repeat(var(--vl-stats-count,4), 1fr);border-bottom:1px solid var(--color-border);padding:1.75rem 0;display:grid}.vl-stat{border-left:1px solid var(--color-border);flex-direction:column;gap:.375rem;padding:0 1.5rem;display:flex}.vl-stat:first-child{border-left:none;padding-left:0}.vl-stat__value{font-family:var(--font-ui);letter-spacing:-.04em;color:var(--color-accent);margin:0;font-size:clamp(1.75rem,2.5vw,2rem);font-weight:700;line-height:1}.vl-stat__label{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0;font-size:.625rem;font-weight:700}.vl-grid{grid-template-columns:repeat(var(--vl-grid-cols,4), 1fr);grid-auto-rows:1fr;gap:.75rem;display:grid}.vl-card{background:var(--color-surface-2);border-radius:var(--radius-md);color:var(--color-text-primary);flex-direction:column;justify-content:space-between;gap:.5rem;padding:1.5rem;text-decoration:none;display:flex;position:relative;overflow:hidden}a.vl-card,button.vl-card,.vl-card--interactive{transition:transform .2s}a.vl-card:hover,button.vl-card:hover,.vl-card--interactive:hover{transform:scale(1.01)}a.vl-card:focus-visible,button.vl-card:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}.vl-card--hero{background:var(--color-surface-invert);color:var(--color-text-on-invert);grid-area:span 2/span 2}.vl-card--tall{background:var(--color-accent-light);grid-row:span 2}@media (width>=1025px){.vl-card--small .vl-card__desc{display:none}}.vl-card__tag{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);margin:0;font-size:.625rem;font-weight:700}.vl-card--hero .vl-card__tag{color:var(--color-accent-light)}.vl-card__title{font-family:var(--font-ui);letter-spacing:-.02em;margin:0;font-size:1.0625rem;font-weight:700;line-height:1.15}.vl-card--hero .vl-card__title,.vl-card--tall .vl-card__title{font-size:2.25rem}.vl-card__desc{font-family:var(--font-ui);color:var(--color-text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:.8125rem;line-height:1.55;display:-webkit-box;overflow:hidden}.vl-card--hero .vl-card__desc{color:var(--color-text-on-invert);opacity:.72}.vl-card__body{flex-direction:column;gap:.5rem;display:flex}.vl-card__footer{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:1rem;margin-top:.5rem;padding-top:1rem;display:flex}.vl-card--hero .vl-card__footer{border-top-color:color-mix(in srgb, var(--color-text-on-invert) 18%, transparent)}.vl-card__meta{font-family:var(--font-ui);color:var(--color-text-tertiary);font-size:.75rem}.vl-watermark{font-family:var(--font-display);opacity:.1;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:6rem;line-height:1;position:absolute;top:-.35em;right:.1em}.vl-card--hero .vl-watermark{color:var(--color-text-on-invert);opacity:.12}.vl-cta-strip{background:var(--color-surface-invert);color:var(--color-text-on-invert);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:2rem;padding:3rem 2.5rem;display:flex}.vl-cta-strip__copy{flex-direction:column;gap:.75rem;display:flex}.vl-cta-strip__title{font-family:var(--font-ui);letter-spacing:-.03em;max-width:22ch;margin:0;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700;line-height:1.05}.vl-cta-strip__desc{font-family:var(--font-ui);color:var(--color-text-on-invert);opacity:.72;max-width:48ch;margin:0;font-size:.9375rem;line-height:1.6}.vl-cta-strip__action{flex-shrink:0}@media (width<=1024px){.vl-grid{grid-template-columns:repeat(2,1fr)}.vl-hero__inner.vl-hero__inner--split{grid-template-columns:1fr}}@media (width<=640px){.vl-container{padding:0 1rem}.vl-hero__inner{padding:2.5rem 0}.vl-hero__line:nth-child(2){padding-left:1rem}.vl-hero__line:nth-child(3){padding-left:2rem}.vl-hero__line:nth-child(4){padding-left:3rem}.vl-stats{grid-template-columns:repeat(2,1fr);gap:1.5rem 1rem}.vl-stat{border-left:none;padding:0}.vl-grid{grid-auto-rows:auto;gap:.5rem}.vl-card--hero{grid-column:1/-1}.vl-cta-strip{flex-direction:column;align-items:flex-start;padding:2rem 1.5rem}}@media (prefers-reduced-motion:reduce){a.vl-card:hover,button.vl-card:hover,.vl-card--interactive:hover{transform:none}}.site-footer{border-top:1px solid var(--color-border);margin-top:auto;padding:clamp(2rem,4vw,3rem) 2rem clamp(1.25rem,3vw,2rem)}.site-footer__inner{grid-template-columns:1fr auto auto auto auto;align-items:start;gap:1.5rem 2.5rem;max-width:1160px;margin:0 auto;display:grid}.footer-brand{flex-direction:column;gap:.5rem;display:flex}.footer-brand__link{color:var(--color-text-primary);align-items:center;gap:9px;width:fit-content;text-decoration:none;display:inline-flex}.footer-brand__link:hover .footer-brand__mark,.footer-brand__link:focus-visible .footer-brand__mark{background:var(--color-accent)}.footer-brand__link:focus-visible{border-radius:var(--radius-sm);outline:3px solid var(--focus-ring);outline-offset:4px}.footer-brand__mark{border-radius:var(--radius-md);background:var(--color-text-primary);width:28px;height:28px;color:var(--color-text-on-invert);font-family:var(--font-ui);letter-spacing:-.04em;transition:background-color var(--transition-base);place-items:center;font-size:.68rem;font-weight:700;line-height:1;display:grid}.footer-brand__link{font-family:var(--font-display);font-size:1.3rem;font-weight:600}.footer-brand__tagline{font-family:var(--font-ui);color:var(--color-text-tertiary);max-width:28ch;font-size:.85rem}.footer-nav,.footer-learn,.footer-store,.footer-lang{flex-direction:column;gap:.5rem;display:flex}.footer-nav__link{font-family:var(--font-ui);color:var(--color-text-secondary);white-space:nowrap;transition:color var(--transition-base);font-size:.9rem;font-weight:500;text-decoration:none}.footer-nav__link:hover,.footer-nav__link:focus-visible{color:var(--color-accent)}.footer-nav__link:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px;border-radius:var(--radius-sm)}.footer-nav__separator{border-top:1px solid var(--color-border);margin:.25rem 0;display:block}.footer-nav__link--dev{color:var(--color-text-tertiary);font-size:.82rem}.footer-section-label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0 0 .25rem;font-size:.625rem;font-weight:700}.footer-store__link{border-radius:var(--radius-md);background:var(--color-text-primary);color:var(--color-text-on-invert);font-family:var(--font-ui);letter-spacing:.01em;white-space:nowrap;transition:background-color var(--transition-base);border:none;align-items:center;gap:.5rem;padding:.5rem .875rem;font-size:.8rem;font-weight:700;text-decoration:none;display:inline-flex}.footer-store__link:hover{background:var(--color-accent)}.footer-store__link:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}.footer-store__icon{flex-shrink:0}.footer-lang__switcher{flex-direction:column;gap:.25rem;display:inline-flex}.footer-lang__button{appearance:none;color:var(--color-text-tertiary);cursor:pointer;font-family:var(--font-ui);letter-spacing:.02em;text-align:left;transition:color var(--transition-base);background:0 0;border:none;padding:.25rem 0;font-size:.85rem;font-weight:500;line-height:1;text-decoration:none}.footer-lang__button:hover,.footer-lang__button:focus-visible{color:var(--color-accent)}.footer-lang__button:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px;border-radius:var(--radius-sm)}.footer-lang__button--active{color:var(--color-text-primary);font-weight:700}.site-footer__bottom{border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;max-width:1160px;margin:1.5rem auto 0;padding-top:1rem;display:flex}.footer-legal{font-family:var(--font-mono);color:var(--color-text-tertiary);letter-spacing:.08em;font-size:.6875rem}@media (width<=768px){.site-footer{padding-left:1rem;padding-right:1rem}.site-footer__inner{grid-template-columns:1fr 1fr;row-gap:1.75rem}.footer-brand{grid-column:1/-1}}@media (width<=480px){.site-footer__inner{grid-template-columns:1fr}.footer-brand{grid-column:auto}}.sudoku-board-wrapper{gap:12px;display:grid;container-type:inline-size}.sudoku-board{grid-template-columns:repeat(var(--sudoku-size), minmax(0, 1fr));grid-template-rows:repeat(var(--sudoku-size), minmax(0, 1fr));aspect-ratio:1;border:2px solid var(--text-h);background:color-mix(in srgb, var(--surface,var(--bg)) 80%, var(--text-h) 20%);box-sizing:border-box;width:100%;display:grid}.sudoku-cell{border-right:1px solid color-mix(in srgb, var(--text-h) 40%, transparent);border-bottom:1px solid color-mix(in srgb, var(--text-h) 40%, transparent);background:var(--surface,var(--bg));box-sizing:border-box;place-items:center;min-width:0;min-height:0;display:grid;overflow:hidden}.sudoku-cell--colorized{background:color-mix(in srgb, var(--cell-highlight-color) var(--sudoku-cell-highlight-strength), var(--surface,var(--bg)))}.sudoku-cell--row-separator{border-top:2px solid var(--text-h)}.sudoku-cell--col-separator{border-left:2px solid var(--text-h)}.sudoku-cell__value{color:var(--text-h);justify-content:center;align-items:center;font-size:clamp(1rem,2.2vw,1.7rem);font-weight:600;line-height:1;display:inline-flex}.sudoku-cell:has(.sudoku-cell__value--selected){background:var(--sudoku-accent)}.sudoku-cell__value--selected{color:var(--sudoku-accent-contrast,#fff)}.sudoku-cell__annotations{grid-template-columns:repeat(var(--annotation-cols), minmax(0, 1fr));grid-template-rows:repeat(var(--annotation-rows), minmax(0, 1fr));box-sizing:border-box;width:100%;height:100%;color:var(--text);place-items:center;padding:2px;display:grid}.sudoku-cell__annotation{text-align:center;font-size:clamp(.35rem,2.4cqi,.62rem);line-height:1;overflow:hidden}.sudoku-cell__annotation--selected{background:var(--sudoku-accent);color:var(--sudoku-accent-contrast,#fff);aspect-ratio:1;border-radius:50%;justify-content:center;align-items:center;width:90%;max-width:1.6em;font-weight:700;line-height:1;display:inline-flex}.sudoku-symbol-picker{grid-template-columns:repeat(var(--symbol-count), minmax(0, 1fr));gap:8px;display:grid}.sudoku-symbol-button{appearance:none;border:1px solid color-mix(in srgb, var(--text-h) 45%, transparent);border-radius:var(--radius-sm);background:var(--surface,var(--bg));color:var(--text-h);cursor:pointer;min-width:0;transition:background-color var(--transition-fast), border-color var(--transition-fast);padding:10px 0;font-size:clamp(.95rem,1.6vw,1.2rem);line-height:1}.sudoku-symbol-button:hover{background:color-mix(in srgb, var(--surface,var(--bg)) 86%, var(--text-h) 14%)}.sudoku-symbol-button:focus-visible{outline:2px solid color-mix(in srgb, var(--sudoku-accent) 85%, var(--text-h) 15%);outline-offset:2px}.sudoku-symbol-button--selected{background:var(--sudoku-accent);border-color:var(--sudoku-accent);color:var(--sudoku-accent-contrast,#fff)}.sudoku-symbol-button--selected:hover{background:color-mix(in srgb, var(--sudoku-accent) 82%, black);border-color:color-mix(in srgb, var(--sudoku-accent) 82%, black);color:var(--sudoku-accent-contrast,#fff)}@media (width<=1024px){.sudoku-cell__value{font-size:clamp(1.15rem,3vw,2.05rem)}.sudoku-symbol-button{font-size:clamp(1rem,2.1vw,1.25rem)}}@media (width<=700px){.sudoku-cell__value{font-size:clamp(1.05rem,4.2vw,1.9rem)}}@media (prefers-reduced-motion:reduce){.sudoku-symbol-button{transition:none}}.landing-page{flex-direction:column;display:flex}.landing-body{flex-direction:column;gap:clamp(2.5rem,5vw,4rem);padding-top:clamp(2rem,4vw,3rem);display:flex}.landing-hero__ghost{color:var(--color-text-on-accent)}.landing-board-card{background:var(--color-surface);border-radius:var(--radius-lg);flex-direction:column;gap:.875rem;padding:clamp(.875rem,2vw,1.25rem);display:flex}.landing-board-card__header{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-tertiary);justify-content:space-between;gap:.75rem;font-size:.625rem;font-weight:700;display:flex}.landing-board-card__header strong{color:var(--color-accent)}.landing-proof .vl-stat__value{letter-spacing:-.01em;font-size:1.0625rem;line-height:1.25}.landing-feature{grid-template-columns:1fr 1fr;align-items:start;gap:clamp(1.5rem,4vw,3rem);display:grid}.landing-feature__copy{flex-direction:column;align-items:flex-start;gap:1.25rem;display:flex}.landing-feature__lead{color:var(--color-text-secondary);margin:0;font-size:1rem;line-height:1.7}.landing-section{flex-direction:column;display:flex}.landing-section .vl-section-label{padding-top:0;padding-bottom:.75rem}.landing-section .vl-section-heading{max-width:22ch;margin-bottom:1.5rem}.landing-ad-slot{justify-content:center;display:flex}@media (width<=768px){.landing-feature{grid-template-columns:1fr}}.learn-index-page{flex-direction:column;display:flex}.learn-body{flex-direction:column;gap:clamp(2.5rem,5vw,4rem);padding-top:clamp(2rem,4vw,3rem);display:flex}.learn-section{flex-direction:column;display:flex}.learn-section .vl-section-label{padding-top:0;padding-bottom:1rem}.learn-tier{flex-direction:column;gap:.75rem;display:flex}.learn-tier+.learn-tier{margin-top:2rem}.learn-tier__label{font-family:var(--font-ui);letter-spacing:-.02em;color:var(--color-text-primary);margin:0;font-size:1.0625rem;font-weight:700;line-height:1.2}.article-layout{align-items:flex-start;gap:2rem;max-width:960px;margin:0 auto;padding-top:clamp(2rem,4vw,3.5rem);display:flex}.article-sidebar{flex-shrink:0;padding-top:clamp(24px,5vw,56px);display:none}@media (width>=1024px){.article-sidebar{display:block}}.article-page{box-sizing:border-box;flex:1;width:100%;min-width:0}.article-ad-below{justify-content:center;margin-top:3rem;display:flex}@media (width>=1024px){.article-ad-below{display:none}}.article-breadcrumb{margin-bottom:2.25rem}.article-breadcrumb a{font-family:var(--font-ui);color:var(--color-text-secondary);transition:color var(--transition-base);font-size:.875rem;font-weight:500;text-decoration:none}.article-breadcrumb a:hover{color:var(--color-accent)}.article-breadcrumb a:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px;border-radius:var(--radius-sm)}.article-header{border-bottom:1px solid var(--color-border);flex-direction:column;gap:1rem;margin-bottom:3rem;padding-bottom:2.5rem;display:flex}.article-header__date{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0;font-size:.6875rem;font-weight:700}.article-title{font-family:var(--font-ui);letter-spacing:-.04em;color:var(--color-text-primary);margin:0;font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.02}.article-intro{font-family:var(--font-ui);color:var(--color-text-secondary);max-width:60ch;margin:0;font-size:clamp(1.0625rem,1.5vw,1.1875rem);line-height:1.65}.article-body{flex-direction:column;gap:2.5rem;display:flex}.article-section--text{flex-direction:column;gap:1rem;display:flex}.article-section--text h2{font-family:var(--font-ui);letter-spacing:-.03em;color:var(--color-text-primary);margin:0;font-size:clamp(1.375rem,2.5vw,1.75rem);font-weight:700;line-height:1.15}.article-section--text p{font-family:var(--font-ui);color:var(--color-text-secondary);margin:0;line-height:1.75}.article-section--board{background:var(--color-surface-2);border-radius:var(--radius-md);flex-direction:column;align-items:center;gap:1rem;margin:0;padding:clamp(1rem,3vw,1.75rem);display:flex}.article-board-wrap{width:100%;max-width:420px}.article-section--board figcaption{font-family:var(--font-ui);color:var(--color-text-tertiary);text-align:center;max-width:52ch;font-size:.875rem;line-height:1.6}.article-section--callout{background:var(--color-accent-light);border-left:3px solid var(--color-accent);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:1.125rem 1.375rem}.article-section--callout p{font-family:var(--font-ui);color:var(--color-text-primary);margin:0;font-size:.9375rem;line-height:1.7}.article-related,.article-sources{border-top:1px solid var(--color-border);flex-direction:column;gap:1rem;margin-top:3rem;padding-top:2rem;display:flex}.article-sources{margin-top:2rem}.article-related__title,.article-sources__title{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0;font-size:.625rem;font-weight:700}.article-related__list,.article-sources__list{flex-direction:column;gap:.625rem;margin:0;padding:0;list-style:none;display:flex}.article-related__link,.article-sources__link{font-family:var(--font-ui);color:var(--color-accent);transition:color var(--transition-base);font-weight:500;text-decoration:none}.article-sources__link{font-size:.9375rem;font-weight:400}.article-related__link:hover,.article-sources__link:hover{color:var(--color-accent-hover);text-decoration:underline}.article-related__link:focus-visible,.article-sources__link:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px;border-radius:var(--radius-sm)}.get-app-page{flex-direction:column;display:flex}.get-app-page__ghost{color:var(--color-text-on-accent)}.get-app-page__body{padding-top:clamp(2rem,4vw,3rem)}.get-app-page__note{font-family:var(--font-ui);color:var(--color-text-primary);background:var(--color-accent-light);border-left:3px solid var(--color-accent);border-radius:0 var(--radius-md) var(--radius-md) 0;max-width:60ch;margin:0;padding:1.25rem 1.5rem;font-size:1.0625rem;line-height:1.7}.sudoku-example{flex-direction:column;gap:20px;display:flex}.sudoku-example h1{margin:0}.sudoku-example p{max-width:70ch}.sudoku-example__boards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.sudoku-example article{border:1px solid var(--border);border-radius:var(--radius-sm);background:color-mix(in srgb, var(--bg) 92%, var(--text-h) 8%);flex-direction:column;gap:12px;padding:16px;display:flex}.sudoku-example h2{margin:0}.sudoku-example__dynamic{flex-direction:column;gap:12px;display:flex}.sudoku-dynamic-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:16px;display:grid}.sudoku-dynamic-grid>*{min-width:0}.sudoku-dynamic-form{flex-direction:column;gap:8px;min-width:0;display:flex}.sudoku-dynamic-form label{color:var(--text-h);font-weight:600}.sudoku-dynamic-form input:not([type=checkbox]),.sudoku-dynamic-form textarea{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-h);box-sizing:border-box;font:inherit;padding:10px 12px}.sudoku-dynamic-form textarea{resize:vertical}.sudoku-dynamic-form input[type=checkbox]{width:18px;height:18px;accent-color:var(--text-h);margin:0 0 8px}.sudoku-dynamic-form input:not([type=checkbox]):focus-visible,.sudoku-dynamic-form textarea:focus-visible{outline:2px solid color-mix(in srgb, var(--text-h) 35%, transparent);outline-offset:1px}.sudoku-dynamic-preview{align-items:flex-start;min-width:0;display:flex}.sudoku-dynamic-preview>*,.sudoku-dynamic-preview .sudoku-board-wrapper,.sudoku-dynamic-preview .sudoku-board,.sudoku-dynamic-preview .sudoku-symbol-picker{width:100%;min-width:0;max-width:100%}.sudoku-dynamic-error{text-align:center;border:1px solid color-mix(in srgb, var(--accent) 45%, var(--border) 55%);border-radius:var(--radius-sm);width:100%;min-height:120px;color:color-mix(in srgb, var(--accent) 78%, var(--text-h) 22%);background:color-mix(in srgb, var(--accent) 10%, var(--bg) 90%);box-sizing:border-box;place-items:center;padding:12px;display:grid}.sudoku-color-legend{border:1px solid var(--border);border-radius:var(--radius-sm);background:color-mix(in srgb, var(--bg) 94%, var(--text-h) 6%);margin-top:4px;padding:10px}.sudoku-color-legend__title{color:var(--text-h);margin-bottom:8px;font-weight:600;display:block}.sudoku-color-legend ul{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:6px 10px;margin:0;padding:0;list-style:none;display:grid}.sudoku-color-legend li{align-items:center;gap:8px;display:flex}.sudoku-color-legend__chip{border-radius:var(--radius-pill);border:1px solid color-mix(in srgb, var(--legend-color) 70%, var(--text-h) 30%);background:var(--legend-color);width:12px;height:12px;display:inline-block}@media (width<=1024px){.sudoku-dynamic-grid{grid-template-columns:1fr}}.app-shell{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;display:flex}.skip-to-main{z-index:calc(var(--z-header) + 10);background:var(--accent);color:var(--surface);border-radius:0 0 var(--radius-sm) var(--radius-sm);font:600 .9rem/1 var(--sans);transition:top var(--transition-fast);padding:12px 20px;text-decoration:none;position:absolute;top:-100%;left:50%;transform:translate(-50%)}.skip-to-main:focus{outline:3px solid var(--focus-ring);outline-offset:2px;top:0}.site-header{z-index:var(--z-header);background:color-mix(in srgb, var(--color-surface) 88%, transparent);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);padding:0 2rem;position:sticky;top:0}.site-header__inner{align-items:center;gap:8px;max-width:1160px;height:64px;margin:0 auto;display:flex}@media (width<=640px){.site-header{padding:0 1rem}}.brand-link{color:var(--color-text-primary);flex-shrink:0;align-items:center;gap:9px;text-decoration:none;display:flex}.brand-link:hover .brand-link__text,.brand-link:focus-visible .brand-link__text{color:var(--color-accent)}.brand-mark{border-radius:var(--radius-md);background:var(--color-text-primary);width:30px;height:30px;color:var(--color-text-on-invert);font-family:var(--font-ui);letter-spacing:-.04em;transition:background-color var(--transition-base);place-items:center;font-size:.7rem;font-weight:700;line-height:1;display:grid}.brand-link__text{font-family:var(--font-display);letter-spacing:0;transition:color var(--transition-base);font-size:1.3rem;font-weight:600;line-height:1;display:inline-flex}.brand-link:hover .brand-mark,.brand-link:focus-visible .brand-mark{background:var(--color-accent)}.brand-link:focus-visible{border-radius:var(--radius-sm);outline:3px solid var(--focus-ring);outline-offset:4px}.site-nav{align-items:center;gap:4px;margin-left:20px;display:flex}.site-nav__link{font-family:var(--font-ui);color:var(--color-text-secondary);letter-spacing:.02em;transition:color var(--transition-base);padding:8px 10px;font-size:.875rem;font-weight:500;line-height:1;text-decoration:none}.site-nav__link:hover,.site-nav__link:focus-visible{color:var(--color-text-primary)}.site-nav__link:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px;border-radius:var(--radius-sm)}.site-nav__link--active{color:var(--color-accent)}.header-cta{font-family:var(--font-ui);letter-spacing:.01em;border-radius:var(--radius-md);background:var(--color-text-primary);color:var(--color-text-on-invert);cursor:pointer;transition:background-color var(--transition-base);border:none;flex-shrink:0;justify-content:center;align-items:center;gap:.5rem;margin-left:auto;padding:.625rem 1.25rem;font-size:.875rem;font-weight:700;line-height:1;text-decoration:none;display:inline-flex}.header-cta:hover{background:var(--color-accent)}.header-cta:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}.header-cta__label{display:inline}.header-cta__icon{display:none}.language-switcher{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);flex-shrink:0;align-items:center;gap:2px;padding:3px;display:inline-flex}.language-switcher__button{appearance:none;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;font-family:var(--font-mono);letter-spacing:.08em;transition:background-color var(--transition-base), color var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;padding:6px 8px;font-size:.6875rem;font-weight:700;line-height:1;text-decoration:none;display:inline-flex}.language-switcher__button:hover,.language-switcher__button:focus-visible{color:var(--color-text-primary)}.language-switcher__button:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}.language-switcher__button--active{background:var(--color-text-primary);color:var(--color-text-on-invert)}.language-switcher__button--active:hover,.language-switcher__button--active:focus-visible{color:var(--color-text-on-invert)}.app-layout{flex:1;padding:0 0 5rem}.app-layout__inner{width:100%}.ad-slot{border:1px dashed var(--border-strong);border-radius:var(--radius-sm);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;background:color-mix(in srgb, var(--surface) 84%, var(--surface-strong) 16%);box-sizing:border-box;place-items:center;font-size:.75rem;display:grid}.ad-slot--300x250{width:300px;max-width:100%;height:250px}.ad-slot--160x600{width:160px;height:600px}@media (width<=768px){.site-header__inner{gap:6px}.site-nav{margin-left:12px}.header-cta__label{display:none}.header-cta__icon{display:inline}}@media (width<=640px){.site-nav,.language-switcher{display:none}}
