:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--paper:#f7f3e8;--paper-strong:#fffdf7;--mist:#eef4f1;--ink:#1b211f;--ink-soft:#2f3936;--muted:#66706b;--line:#d8d0bd;--line-strong:#b8ad96;--teal:#247c73;--teal-dark:#15564f;--rust:#b94f35;--gold:#f0bd3f;--green-soft:#dbeee9;--rust-soft:#f4ded6;--shadow:0 16px 34px #211c121a;--font-ui:system-ui, -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", "YuGothic", sans-serif;--font-jp:"Hiragino Sans", "Yu Gothic", "YuGothic", "Noto Sans CJK JP", system-ui, sans-serif}*{box-sizing:border-box}html{background:var(--paper);min-height:100%}body{min-height:100%;color:var(--ink);font-family:var(--font-ui);letter-spacing:0;background:linear-gradient(#fffdf7db,#eef4f1d1 58%,#f7f3e8f0),repeating-linear-gradient(90deg,#247c730b 0 1px,#0000 1px 4.5rem);margin:0}button,input,textarea{font:inherit}button{cursor:pointer}a{color:inherit}.app-shell{flex-direction:column;min-height:100vh;display:flex}.topbar{z-index:10;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f7f3e8eb;border-bottom:1px solid #b8ad9699;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem max(1rem,50vw - 560px);display:flex;position:sticky;top:0}.brand{align-items:center;gap:.65rem;min-width:max-content;text-decoration:none;display:inline-flex}.brand img{border-radius:8px;width:2.25rem;height:2.25rem;box-shadow:0 6px 16px #1b211f2e}.brand-text{line-height:1.05;display:grid}.brand-main{font-size:.95rem;font-weight:700}.brand-sub{color:var(--muted);text-transform:uppercase;font-size:.72rem;font-weight:600}.nav{scrollbar-width:none;gap:.35rem;display:flex;overflow-x:auto}.nav::-webkit-scrollbar{display:none}.nav a{min-height:2.25rem;color:var(--muted);white-space:nowrap;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:0 .7rem;font-size:.88rem;font-weight:600;text-decoration:none;display:inline-flex}.nav a[aria-current=page]{color:var(--ink);border-color:var(--line-strong);background:#fffdf7c2}.main{width:min(1120px,100%);margin:0 auto;padding:1.1rem 1rem 2.5rem}.play-layout,.portal-layout{grid-template-columns:minmax(0,1fr) 18rem;align-items:start;gap:1rem;display:grid}.game-panel,.portal-panel,.side-panel,.text-panel{box-shadow:var(--shadow);background:#fffdf7e6;border:1px solid #b8ad96ad;border-radius:8px}.game-panel,.portal-panel{padding:1rem;scroll-margin-top:5.5rem}.game-head{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:.8rem;display:grid}.eyebrow{color:var(--teal-dark);letter-spacing:0;text-transform:uppercase;margin:0 0 .35rem;font-size:.78rem;font-weight:700}h1,h2,h3,p{margin-top:0}h1{margin-bottom:.25rem;font-size:1.65rem;font-weight:700;line-height:1.18}h2{margin-bottom:.7rem;font-size:1.2rem;font-weight:700;line-height:1.24}h3{margin-bottom:.45rem;font-size:1rem;font-weight:700}.lead{max-width:42rem;color:var(--muted);margin-bottom:0;line-height:1.68}.today-badge{background:var(--green-soft);min-height:2rem;color:var(--teal-dark);white-space:nowrap;border-radius:999px;align-items:center;padding:0 .7rem;font-size:.84rem;font-weight:700;display:inline-flex}.game-panel.is-done .today-badge{display:none}.metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;margin:1rem 0 .75rem;display:grid}.metric{background:#f7f3e89e;border:1px solid #d8d0bddb;border-radius:8px;min-width:0;padding:.65rem .7rem}.metric span{color:var(--muted);margin-bottom:.18rem;font-size:.75rem;font-weight:600;display:block}.metric strong{font-family:var(--font-jp);font-variant-numeric:tabular-nums;font-size:1.24rem;font-weight:700;line-height:1.05;display:block}.timer-track{background:#eee6d4;border:1px solid #b8ad96b8;border-radius:999px;height:.5rem;margin-bottom:.85rem;overflow:hidden}.timer-bar{transform-origin:0;background:linear-gradient(90deg, var(--teal), var(--gold), var(--rust));width:100%;height:100%}.grid-wrap{container-type:inline-size}.board-area{position:relative}.start-panel{color:var(--ink);background:#eef4f1b8;border:1px solid #b8ad96c2;border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;margin:.8rem 0;padding:.68rem .75rem;display:flex}.start-panel h2{margin-bottom:0;font-size:1rem}.start-panel p{color:#fffdf7c7;margin-bottom:0;line-height:1.55}.start-kicker{text-transform:uppercase;margin-bottom:.08rem;font-size:.72rem;font-weight:700;color:var(--teal-dark)!important}.start-button{min-width:6.5rem;min-height:2.4rem}.board-start-panel{z-index:2;width:min(22rem,100% - 1.5rem);margin:0;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 14px 28px #211c122e}.kanji-grid{grid-template-columns:repeat(8,minmax(0,1fr));gap:.35rem;width:100%;max-width:34rem;margin:0 auto;display:grid}.kanji-cell{aspect-ratio:1;border:1px solid var(--line);min-width:0;color:var(--ink);font-family:var(--font-jp);background:#fffaf0;border-radius:7px;place-items:center;font-size:1.36rem;font-weight:600;line-height:1;transition:border-color .12s,background-color .12s,transform .12s,box-shadow .12s;display:grid}button.kanji-cell:hover,button.kanji-cell:focus-visible{border-color:var(--teal);outline:none;transform:translateY(-1px);box-shadow:0 0 0 3px #247c7333}.kanji-cell.is-placeholder{color:#66706b5c;background-color:#f8f0df;background-image:linear-gradient(135deg,#d8d0bd66 25%,#0000 25%),linear-gradient(315deg,#d8d0bd66 25%,#0000 25%),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:.9rem .9rem;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box}.kanji-cell.is-answer{border-color:var(--rust);background:var(--rust-soft);box-shadow:inset 0 -4px #b94f3559}.kanji-cell.is-selected{border-color:var(--teal);background:var(--green-soft)}.kanji-cell.is-miss{border-color:var(--rust);animation:.18s ease-in-out 2 miss}.result-panel{border-top:1px solid #b8ad96bd;justify-content:space-between;align-items:center;gap:.85rem;margin:1rem 0;padding-top:1rem;display:flex}.result-main{gap:.1rem;display:grid}.result-main strong{color:var(--ink);font-size:1.55rem;font-weight:700;line-height:1.15}.result-share{min-width:10rem}.result-panel.is-timeout .result-share{min-width:8.25rem}@keyframes miss{0%{transform:translate(0)}33%{transform:translate(-3px)}66%{transform:translate(3px)}to{transform:translate(0)}}.actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem;margin-top:1rem;display:flex}.button-row{flex-wrap:wrap;gap:.5rem;display:flex}.btn{border:1px solid var(--line-strong);background:var(--paper-strong);min-height:2.55rem;color:var(--ink);border-radius:8px;justify-content:center;align-items:center;padding:0 .9rem;font-weight:700;text-decoration:none;display:inline-flex}.btn.primary{border-color:var(--teal-dark);background:var(--teal);color:#fffdf7}.btn:disabled{cursor:not-allowed;opacity:.58}.status-line{min-height:1.55rem;color:var(--muted);margin:0;font-size:.9rem;font-weight:600}.share-fallback{gap:.4rem;margin-top:.75rem;display:grid}.share-fallback span{color:var(--muted);font-size:.78rem;font-weight:700}.share-fallback textarea{resize:vertical;border:1px solid var(--line-strong);width:100%;color:var(--ink);background:#fffaf0;border-radius:8px;padding:.65rem .7rem;line-height:1.45}.side-panel,.portal-panel,.text-panel{padding:1rem}.daily-card{background:#eef4f1b8;border:1px solid #b8ad96c2;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:1rem;margin-top:1rem;padding:.9rem;display:grid}.daily-card h2,.daily-card p{margin-bottom:0}.daily-card>div:first-child{gap:.38rem;display:grid}.daily-card-actions{justify-items:end;gap:.65rem;display:grid}.portal-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;margin-top:1rem;display:grid}.stats-list{gap:.55rem;margin:0;padding:0;list-style:none;display:grid}.stats-list li{border-bottom:1px solid #d8d0bdbd;justify-content:space-between;align-items:center;gap:.7rem;min-height:2.75rem;padding:.65rem 0;display:flex}.stats-list li:last-child{border-bottom:0}.list-title{font-weight:700}.list-meta{color:var(--muted);white-space:nowrap;font-size:.82rem;font-weight:600}.panel-stack{gap:1rem;display:grid}.text-panel{max-width:50rem}.text-panel p{color:var(--muted);line-height:1.75}.text-panel ul{color:var(--muted);margin:.75rem 0 0;padding-left:1.2rem;line-height:1.75}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.noscript{border:1px solid var(--line);background:var(--paper-strong);border-radius:8px;width:min(38rem,100% - 2rem);margin:3rem auto;padding:1rem}@media (width>=760px){.kanji-cell{font-size:1.86rem}}@media (width<=860px){.topbar{flex-direction:row;align-items:center;gap:.7rem;padding-block:.55rem}.nav{margin:0;padding:0}.play-layout,.portal-layout{grid-template-columns:1fr}.side-panel{box-shadow:none}}@media (width<=700px){.topbar{justify-content:flex-start;padding:.48rem .65rem}.brand-sub,.nav{display:none}.brand img{width:1.9rem;height:1.9rem}.brand-main{font-size:.86rem}}@media (width<=520px){.main{padding:.45rem .5rem 1.8rem}.topbar{justify-content:flex-start;padding:.42rem .5rem}.brand img{width:1.8rem;height:1.8rem}.brand-main{font-size:.84rem}.brand-sub{display:none}.nav a{min-height:1.8rem;padding:0 .5rem;font-size:.76rem}.nav{display:none}.game-panel,.portal-panel,.side-panel,.text-panel{padding:.72rem}.game-head{grid-template-columns:minmax(0,1fr);align-items:center;gap:.45rem}.today-badge,.eyebrow,.lead{display:none}h1{margin-bottom:0;font-size:1.1rem}.metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem}.metric{padding:.55rem .45rem}.metric strong{font-size:1.05rem}.kanji-grid{gap:.26rem}.daily-card{grid-template-columns:1fr;gap:.75rem;margin-top:.75rem;padding:.72rem}.daily-card-actions{justify-items:start}.daily-card-actions .btn{width:auto;min-width:7.5rem}.portal-stats{gap:.35rem}.kanji-cell{border-radius:6px;font-size:1.18rem}.start-panel{margin:.5rem 0 .45rem;padding:.48rem .55rem}.board-start-panel{width:min(20rem,100% - 1rem);margin:0}.start-button{width:auto;min-width:5.5rem;min-height:2.1rem}.result-panel{margin:.72rem 0 .25rem;padding-top:.72rem}.result-panel.is-timeout{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.65rem;display:grid}.result-panel.is-timeout .result-main strong{white-space:nowrap;font-size:1.18rem}.result-panel.is-timeout .result-share{width:auto;min-width:7.5rem;min-height:2.25rem}.actions{flex-direction:column;align-items:stretch;gap:.45rem;margin-top:.8rem}.button-row,.btn{width:100%}.start-button{width:auto}.status-line{min-height:1.25rem;font-size:.82rem}}
