.race-page{box-sizing:border-box;color:#222;background:#f8f9fb;min-height:100vh;padding:16px 16px 136px}.race-header{margin-bottom:16px}.race-header-top{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.race-home-button{color:#333;cursor:pointer;background:#e9ecef;border:none;border-radius:999px;padding:8px 14px;font-size:.95rem}.race-badge{text-align:center;color:#fff;background:#212529;border-radius:999px;min-width:56px;padding:8px 14px;font-weight:700}.race-title{margin:0 0 6px;font-size:clamp(1.2rem,4.5vw,1.8rem);line-height:1.3}.race-subtitle{color:#666;margin:0;font-size:clamp(.9rem,3.5vw,1rem)}.race-subtitle-separator{margin:0 6px}.race-instruction{background:#fff7db;border:1px solid #f2d98c;border-radius:10px;margin-top:12px;padding:10px 12px;font-size:.95rem;line-height:1.5}.race-table-section{margin-top:12px}.race-table-wrapper{background:#fff;border-radius:14px;overflow-x:auto;box-shadow:0 2px 10px #0000000f}.race-table{border-collapse:collapse;width:100%;min-width:760px}.race-table th,.race-table td{vertical-align:middle;background:#fff;border-bottom:1px solid #e9ecef;padding:10px 8px}.race-table thead th{z-index:1;white-space:nowrap;background:#f6f7f9;font-size:.95rem;position:sticky;top:0}.highlight-row td{background-color:#fff3f3}.num-cell{text-align:center;white-space:nowrap;font-size:1.2rem;font-weight:700}.waku-num{text-align:center;color:#fff;-webkit-text-stroke-color:#000;-webkit-text-stroke-width:1px;white-space:nowrap;font-size:1.2rem;font-weight:700}.mark-cell{text-align:center}.mark-button{cursor:pointer;background:#fff;border:1px solid #ced4da;border-radius:10px;width:56px;min-height:44px;font-size:1.15rem;font-weight:700}.mark-button.is-active{background:#ffe8e8;border-color:#e08c8c}.clothes-cell{text-align:center}.silk-image{width:72px;max-width:100%;height:auto;margin:0 auto;display:block}.silk-placeholder{color:#777;word-break:break-all;min-width:72px;font-size:.85rem}.horse-name-cell{min-width:140px;font-weight:600}.race-bottom-bar{padding:12px 14px calc(12px + env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;background:#fffffff5;border-top:1px solid #e5e7eb;grid-template-columns:minmax(74px,1fr) minmax(190px,1.55fr) minmax(74px,1fr);gap:10px;display:grid;position:fixed;bottom:0;left:0;right:0}.puzzle-action-stack{flex-direction:column;gap:6px;min-width:0;display:flex}.difficulty-selector{background:#f1f3f5;border-radius:12px;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;padding:3px;display:grid}.difficulty-option{color:#333;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;justify-content:center;align-items:center;gap:6px;min-width:0;min-height:34px;padding:5px 8px;font-size:.82rem;font-weight:700;transition:background-color .18s,color .18s,box-shadow .18s;display:inline-flex}.difficulty-option.is-selected{color:#222;background:#fff;box-shadow:inset 0 0 0 1px #28a74542}.difficulty-option:focus{outline:none}.difficulty-option:focus-visible{outline-offset:1px;outline:2px solid #28a7453d}.difficulty-check{color:#0000;box-sizing:border-box;background:#fff;border:1.5px solid #cfd4da;border-radius:999px;flex:none;place-items:center;width:18px;height:18px;font-size:.72rem;font-weight:800;line-height:1;transition:background-color .18s,border-color .18s,color .18s,transform .18s;display:inline-grid}.difficulty-option.is-selected .difficulty-check{color:#fff;background:#28a745;border-color:#28a745;transform:scale(1.02)}.bottom-nav-button{cursor:pointer;border:none;border-radius:12px;min-height:48px;font-size:.95rem;font-weight:700}.bottom-nav-button.primary{color:#fff;background:#28a745}.bottom-nav-button.primary.is-disabled,.bottom-nav-button:disabled{opacity:.5;cursor:not-allowed}.bottom-nav-button.secondary{color:#333;background:#e9ecef}.race-empty{text-align:center;padding:32px 16px}.race-empty button{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:10px;margin-top:12px;padding:10px 16px}@media (width<=640px){.race-page{padding:12px 12px 132px}.race-table{min-width:680px}.race-table th,.race-table td{padding:8px 6px;font-size:.9rem}.num-cell,.waku-num{font-size:1rem}.mark-button{width:48px;min-height:42px;font-size:1rem}.silk-image{width:60px}.race-bottom-bar{padding:10px 10px calc(10px + env(safe-area-inset-bottom,0px));grid-template-columns:minmax(64px,.8fr) minmax(168px,1.8fr) minmax(64px,.8fr);gap:8px}.bottom-nav-button{min-height:46px;font-size:.88rem}.difficulty-option{min-height:28px;padding:3px 4px;font-size:.74rem}.difficulty-check{width:16px;height:16px;font-size:.62rem}}.puzzle-page{box-sizing:border-box;color:#222;background:#f8f9fb;min-height:100vh;padding:16px 12px 92px}.puzzle-header{margin-bottom:16px}.puzzle-header-row{grid-template-columns:minmax(92px,1fr) auto minmax(92px,1fr);align-items:center;gap:12px;margin-bottom:12px;display:grid}.puzzle-home-button{color:#333;cursor:pointer;background:#e9ecef;border:none;border-radius:999px;justify-self:start;padding:8px 14px;font-size:.95rem}.puzzle-badge{text-align:center;color:#fff;background:#212529;border-radius:999px;min-width:72px;padding:8px 14px;font-weight:700}.puzzle-target-horse{background:#fff;border-radius:999px;grid-column:2;justify-content:center;justify-self:center;align-items:center;gap:10px;min-width:0;padding:8px 14px;display:flex;box-shadow:0 1px 6px #00000012}.puzzle-target-hat{background:#fff;border:1px solid #d8dee5;border-radius:10px;flex:none;place-items:center;width:56px;height:34px;display:grid;position:relative;overflow:hidden}.puzzle-target-hat-fill{clip-path:polygon(6% 90%,5% 46%,14% 22%,33% 7%,53% 8%,68% 36%,98% 45%,105% 58%,85% 90%,51% 80%,42% 73%);position:absolute;inset:2px}.puzzle-target-hat img{object-fit:contain;pointer-events:none;width:calc(100% - 4px);height:calc(100% - 4px);display:block;position:absolute;inset:2px}.puzzle-target-num{text-align:center;min-width:1.4em;font-size:1.14rem;font-weight:800}.puzzle-target-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:min(42vw,260px);font-size:1.06rem;font-weight:800;overflow:hidden}.puzzle-title{margin:0 0 8px;font-size:clamp(1.2rem,4.5vw,1.8rem)}.puzzle-description{color:#666;margin:0;font-size:.95rem;line-height:1.5}.puzzle-main{flex-direction:column;gap:20px;display:flex}.puzzle-top-area,.puzzle-bottom-area,.puzzle-reference-area{justify-content:center;display:flex}.image-set{justify-content:center;place-items:center;gap:4px;display:grid}.image-set img{object-fit:cover;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:manipulation;background-color:#f8f9fb;background-image:linear-gradient(45deg,#e6eaee 25%,#0000 25%),linear-gradient(-45deg,#e6eaee 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#e6eaee 75%),linear-gradient(-45deg,#0000 75%,#e6eaee 75%);background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px;width:100%;height:100%}.top-image-set{grid-template-columns:repeat(var(--grid-size), var(--top-cell-size));grid-auto-rows:var(--top-cell-size)}.bottom-image-set{grid-template-columns:repeat(var(--grid-size), var(--bottom-cell-size));grid-auto-rows:var(--bottom-cell-size)}.bottom-image-sets{flex-wrap:wrap;justify-content:center;gap:clamp(12px,4vw,28px);display:flex}.piece-selected{outline-offset:-2px;outline:3px solid #e53935}.puzzle-reference-area{margin-top:4px}.reference-card{background:#fff;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:10px 14px;display:flex;box-shadow:0 2px 8px #0000000f}.reference-label{color:#666;font-size:.9rem;font-weight:700}.horse-image{background-color:#f8f9fb;background-image:linear-gradient(45deg,#e6eaee 25%,#0000 25%),linear-gradient(-45deg,#e6eaee 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#e6eaee 75%),linear-gradient(-45deg,#0000 75%,#e6eaee 75%);background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px;border-radius:8px;width:clamp(110px,32vw,170px)}.reference-fallback{color:#777;place-items:center;min-width:120px;min-height:80px;display:grid}.puzzle-bottom-bar{padding:8px 14px calc(8px + env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;background:#fffffff5;border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:12px;display:flex;position:fixed;bottom:0;left:0;right:0}.puzzle-status{color:#666;font-weight:700}.puzzle-status.is-solved{color:#198754}.puzzle-next-button{color:#fff;cursor:pointer;background:#1f6feb;border:none;border-radius:12px;min-height:40px;padding:0 16px;font-size:.92rem;font-weight:700}.puzzle-empty{text-align:center;padding:40px 16px}.puzzle-empty button{color:#fff;cursor:pointer;background:#1f6feb;border:none;border-radius:10px;margin-top:12px;padding:10px 16px}@media (width<=480px){.puzzle-page{padding:12px 8px 90px}.puzzle-description{font-size:.9rem}.puzzle-header-row{grid-template-columns:minmax(78px,1fr) auto minmax(78px,1fr);gap:8px}.puzzle-home-button{flex:none;padding:7px 10px;font-size:.86rem}.puzzle-target-horse{gap:6px;padding:6px 10px}.puzzle-target-hat{width:46px;height:29px}.puzzle-target-num{font-size:1rem}.puzzle-target-name{max-width:34vw;font-size:.94rem}.puzzle-bottom-bar{padding:7px 10px calc(7px + env(safe-area-inset-bottom,0px))}.puzzle-next-button{min-height:38px;padding:0 12px;font-size:.9rem}}.result-container{text-align:center;box-sizing:border-box;background:#f8f9fb;min-height:100vh;padding:2rem 1rem 6rem}.result-title{margin-bottom:2rem;font-size:clamp(1.3rem,4vw,2rem);line-height:1.4}.winner .hat-bg{border-radius:999px;width:100px;height:50px;position:relative;left:50%;overflow:hidden;transform:translate(-50%)}.runner .hat-bg{border-radius:999px;width:80px;height:40px;position:relative;left:50%;overflow:hidden;transform:translate(-50%)}.winner{margin-bottom:3rem;position:relative}.winner .icon{margin-bottom:.5rem;font-size:3rem}.winner .horse-info{margin-bottom:1rem}.horse-num{font-size:2rem;font-weight:700}.horse-name,.jockey-name{font-size:1.2rem;line-height:1.4}.horse-image-large{border-radius:8px;width:min(25rem,80vw);height:auto;box-shadow:0 2px 6px #0003}.runners{flex-flow:row-reverse wrap;justify-content:center;gap:2rem;margin-bottom:2rem;display:flex}.runner{text-align:center}.runner .icon{margin-bottom:.3rem;font-size:2.5rem}.horse-image-small{border-radius:6px;width:min(15rem,40vw);height:auto;box-shadow:0 1px 4px #0003}.loading{color:#888;margin-top:.5rem;font-size:1rem}.no-marked{color:#555;margin:2rem 0;font-size:1.2rem}.button-back{color:#fff;cursor:pointer;background:#28a745;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:1rem;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0003}.button-back:hover{background:#218838}.button-nav-after{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:8px;padding:10px 16px;font-size:1rem;position:fixed;bottom:20px;right:20px;box-shadow:0 2px 6px #0003}.button-nav-before{color:#fff;cursor:pointer;background-color:#6c757d;border:none;border-radius:8px;padding:10px 16px;font-size:1rem;position:fixed;bottom:20px;left:20px;box-shadow:0 2px 6px #0003}.result-debug{text-align:left;background:#fff;border-radius:8px;max-width:900px;margin:2rem auto 0;padding:.8rem 1rem}.result-debug pre{font-size:.8rem;overflow-x:auto}@media (width<=768px){.result-container{padding:1rem .75rem 7rem}.winner .icon{font-size:2.5rem}.runner .icon{font-size:2rem}.horse-num{font-size:1.6rem}.horse-name,.jockey-name{font-size:1rem}.button-nav-before,.button-nav-after,.button-back{font-size:.9rem}}@media (width<=480px){.runners{flex-direction:column;align-items:center;gap:1.2rem}.horse-image-small{width:min(14rem,70vw)}.button-nav-before{bottom:74px;left:10px}.button-nav-after{bottom:74px;right:10px}.button-back{bottom:14px}}:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}
