:root{--font-sans: "Avenir Next", "Hiragino Sans", "Noto Sans JP", "Yu Gothic", sans-serif;--font-display: "Optima", "Avenir Next", "Hiragino Sans", sans-serif;--font-mono: "SFMono-Regular", "IBM Plex Mono", monospace;--bg-top: #e5f2f0;--bg-bottom: #f5f8f7;--surface: rgba(255, 255, 255, .78);--surface-strong: rgba(255, 255, 255, .92);--line: rgba(25, 74, 77, .12);--line-strong: rgba(25, 74, 77, .18);--ink-strong: #123236;--ink: #24474b;--ink-soft: #5e777a;--teal: #217b7f;--teal-strong: #175b5f;--teal-soft: #d9eded;--shadow: rgba(28, 67, 70, .12);--radius-xl: 28px;--radius-lg: 22px;--radius-md: 16px;--shell-wide: 1180px;--shell-detail: 860px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);color:var(--ink);background:radial-gradient(circle at top left,rgba(136,206,205,.35),transparent 28%),radial-gradient(circle at 88% 10%,rgba(198,232,226,.78),transparent 24%),linear-gradient(180deg,var(--bg-top),var(--bg-bottom))}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}::selection{background:#217b7f2e}.site-shell{min-height:100vh}.shell{width:min(calc(100% - 32px),var(--shell-wide));margin:0 auto}.shell--detail{max-width:var(--shell-detail)}.site-header{position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#f0f7f6d1;border-bottom:1px solid rgba(18,50,54,.06)}.site-header__inner,.site-footer__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 0}.brand-mark{display:inline-flex;align-items:center;gap:14px}.brand-mark__badge{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#2d9094,#185c60);color:#effaf9;font-family:var(--font-display);font-weight:800;letter-spacing:.05em;box-shadow:0 12px 32px #185c6038}.brand-mark__body{display:grid;gap:2px}.brand-mark__name{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--ink-strong);letter-spacing:.02em}.brand-mark__tagline{font-size:.82rem;color:var(--ink-soft)}.site-nav{display:flex;flex-wrap:wrap;gap:10px}.site-nav a,.secondary-button,.tab-button,.ghost-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;border-radius:999px;border:1px solid var(--line);background:#ffffffb3;color:var(--ink)}.page{padding:40px 0 96px}.hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(300px,.95fr);gap:24px;align-items:stretch}.hero-copy,.panel{border:1px solid var(--line);border-radius:var(--radius-xl);background:var(--surface);box-shadow:0 24px 60px var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.hero-copy{padding:34px}.hero-preview,.panel{padding:24px}.eyebrow{margin:0 0 10px;color:var(--teal);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700}h1,h2,h3{margin:0;color:var(--ink-strong)}h1{font-family:var(--font-display);font-size:clamp(2.8rem,5vw,4.8rem);line-height:.96;letter-spacing:-.04em}h2{font-family:var(--font-display);font-size:clamp(1.35rem,2.2vw,2rem);line-height:1.05;letter-spacing:-.03em}h3{font-size:1.1rem}.hero-lead,.hero-subcopy,.summary-copy,.prompt-guidance,.modal-copy,.empty-state p,.scene-card p,.phrase-link small,.thinking-panel p,.explain-section p,.explain-section li,.lesson-header p:last-child{line-height:1.75}.hero-lead{margin:22px 0 0;max-width:42rem;font-size:1.05rem;color:var(--ink)}.hero-subcopy{margin:14px 0 0;color:var(--ink-soft);font-size:1rem}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.primary-button,.secondary-button,.text-link,.floating-kana-button{transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.primary-button{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;border-radius:999px;background:linear-gradient(135deg,#2d9094,#185c60);color:#effaf9;border:1px solid transparent;box-shadow:0 16px 36px #185c603d}.secondary-button,.text-link,.tab-button,.ghost-button,.floating-kana-button{cursor:pointer}.secondary-button--accent{border-color:#217b7f3d;background:linear-gradient(135deg,#2d90942e,#185c601a);color:var(--teal-strong);box-shadow:0 12px 24px #185c601a}.primary-button:hover,.secondary-button:hover,.text-link:hover,.tab-button:hover,.ghost-button:hover,.floating-kana-button:hover,.scene-chip:hover,.scene-card:hover,.phrase-link:hover{transform:translateY(-1px)}.step-list{margin:18px 0 0;padding-left:20px;color:var(--ink-soft);line-height:1.8}.scene-strip,.scene-header,.scene-layout,.scene-switcher,.practice-stack,.section-stack{margin-top:28px}.section-heading{margin-bottom:18px}.chip-row{display:flex;flex-wrap:wrap;gap:10px}.chip-row--tight{justify-content:flex-end}.scene-chip{display:inline-flex;align-items:center;gap:10px;min-height:42px;padding:0 14px;border-radius:999px;border:1px solid var(--line);background:#ffffffb8;color:var(--ink)}.scene-chip.is-active{border-color:#217b7f57;background:var(--teal-soft);color:var(--teal-strong)}.scene-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:18px}.scene-card{display:grid;gap:14px;min-height:210px}.scene-card__top{display:flex;align-items:center;justify-content:space-between;gap:16px}.scene-card__label{font-size:1.1rem;font-weight:700;color:var(--ink-strong)}.scene-card__count{color:var(--ink-soft);font-size:.85rem}.scene-card strong{margin-top:auto;color:var(--teal-strong)}.scene-header{display:grid;gap:12px}.scene-layout{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:28px;align-items:start}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.phrase-list{display:grid;gap:14px}.phrase-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 14px;border-radius:14px;border:1px dashed rgba(33,123,127,.28);background:#d9eded70;color:var(--teal-strong);font-weight:700;cursor:pointer}.phrase-toggle--secondary{background:#ffffffb8;border-style:solid;border-color:var(--line);color:var(--ink)}.phrase-link{display:grid;grid-template-columns:40px minmax(0,1fr);gap:14px;align-items:start;padding:16px;border-radius:var(--radius-md);border:1px solid var(--line);background:#ffffff8f}.phrase-link.is-active{border-color:#217b7f47;background:#d9ededb8}.phrase-link__index{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:12px;background:#1232360f;color:var(--teal-strong);font-weight:700}.phrase-link__body{display:grid;gap:7px}.phrase-link strong{color:var(--ink-strong);line-height:1.45;font-size:.98rem}.phrase-link small{color:var(--ink-soft)}.prompt-panel h2{max-width:18ch;font-size:clamp(2rem,4vw,3.3rem);line-height:.98}.prompt-panel{scroll-margin-top:140px}.prompt-guidance{margin:0;color:var(--ink-soft)}.practice-state{display:grid;gap:14px;margin-top:22px;padding-top:22px;border-top:1px solid rgba(18,50,54,.08)}.practice-state__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.countdown-meter{position:relative;overflow:hidden;width:100%;height:10px;margin:0 0 18px;border-radius:999px;background:#12323614}.countdown-meter__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(135deg,#2d9094,#185c60);transition:width .9s linear}.text-link{min-height:0;padding:0;border:0;background:transparent;color:var(--teal-strong);font-weight:700}.answer-panel{border-color:var(--line-strong);background:var(--surface-strong)}.tab-row{display:inline-flex;padding:4px;border-radius:999px;background:#1232360d}.kana-tab-row{margin-top:18px}.tab-button{min-height:38px;border-color:transparent;background:transparent}.tab-button.is-active{background:#fff;color:var(--teal-strong);box-shadow:0 8px 18px #185c601f}.answer-stack{display:grid;gap:12px}.answer-line{margin:0;padding:14px 16px;border-radius:var(--radius-md);background:#d9eded8a;color:var(--ink-strong);font-size:clamp(1.05rem,2vw,1.34rem);font-weight:600;letter-spacing:.01em}.answer-line--standard{font-size:clamp(1.2rem,2.5vw,1.7rem)}.summary-copy{margin:0 0 12px;color:var(--ink-soft)}.practice-stack{display:grid;gap:22px}.section-stack{display:grid;gap:18px}.explain-section{padding-top:18px;border-top:1px solid rgba(18,50,54,.08)}.explain-section:first-child{padding-top:0;border-top:0}.explain-section p,.explain-section ul{margin:12px 0 0}.explain-section ul{padding-left:20px}code{padding:.14rem .4rem;border-radius:8px;background:#217b7f1f;color:var(--teal-strong);font-family:var(--font-mono);font-size:.95em}.floating-kana-button{position:fixed;right:22px;bottom:22px;z-index:35;min-height:52px;padding:0 18px;border-radius:999px;border:1px solid rgba(24,92,96,.14);background:#ffffffe0;box-shadow:0 18px 36px #185c602e;color:var(--teal-strong);font-weight:700}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#0e272b6b;z-index:60}.modal-card{position:relative;z-index:70;width:min(760px,100%);max-height:min(88vh,760px);overflow:auto;padding:24px;border-radius:var(--radius-xl);background:#f5faf9f5;border:1px solid rgba(255,255,255,.34);box-shadow:0 28px 70px #0e272b47}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.modal-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.install-banner{position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:34;display:none;align-items:center;justify-content:space-between;gap:16px;padding:16px;border:1px solid rgba(24,92,96,.12);border-radius:24px;background:#f7fbfaf5;box-shadow:0 24px 56px #0e272b33;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.install-banner__main{display:flex;align-items:center;gap:14px;min-width:0}.install-banner__icon{flex:0 0 auto;width:56px;height:56px;border-radius:14px;border:1px solid rgba(24,92,96,.12);box-shadow:0 10px 24px #0e272b1f;background:#fff}.install-banner__copy{display:grid;gap:6px;min-width:0}.install-banner__copy strong{color:var(--ink-strong);font-size:1rem}.install-banner__copy p:last-child{margin:0;color:var(--ink-soft);line-height:1.6;font-size:.94rem}.install-banner__actions{display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;justify-content:flex-end}.install-modal{width:min(560px,100%)}.install-steps{margin-top:20px}.install-step-list{margin-top:14px}.kana-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-top:20px}.kana-grid--with-labels{grid-template-columns:56px repeat(5,minmax(0,1fr))}.kana-grid--combo{grid-template-columns:56px repeat(3,minmax(0,1fr))}.kana-subsection{margin-top:26px;padding-top:20px;border-top:1px solid rgba(18,50,54,.08)}.kana-subsection__header{display:grid;gap:8px}.kana-axis{display:inline-grid;place-items:center;min-height:42px;color:var(--ink-soft);font-size:.88rem;font-weight:700;letter-spacing:.04em;text-transform:lowercase}.kana-axis--row{justify-items:start;padding-left:6px}.kana-axis--corner{opacity:0}.kana-cell{display:inline-grid;place-items:center;min-height:52px;border-radius:14px;border:1px solid rgba(18,50,54,.08);background:#fff;color:var(--ink-strong);font-size:1.1rem;font-weight:700}.kana-cell.is-active{background:linear-gradient(135deg,#2d9094,#185c60);color:#effaf9;border-color:transparent}.kana-cell--empty{visibility:hidden}.lesson-header{display:grid;gap:12px}.empty-state{text-align:center}.site-footer{padding-bottom:24px}.site-footer__inner{justify-content:center;color:var(--ink-soft);font-size:.9rem}@media(max-width:960px){.hero,.scene-layout{grid-template-columns:1fr}.practice-stack{order:1}.phrase-list-panel{order:2}.scene-header{align-items:flex-start;flex-direction:column}.chip-row--tight{justify-content:flex-start}.phrase-list-panel{overflow:hidden}.phrase-list{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;margin:0 -4px;padding-inline:4px;scroll-snap-type:x proximity}.phrase-toggle,.phrase-link{flex:0 0 min(320px,86vw);scroll-snap-align:start}}@media(max-width:720px){.shell{width:min(calc(100% - 22px),var(--shell-wide))}.site-header__inner,.site-footer__inner{align-items:flex-start;flex-direction:column}.hero-copy,.hero-preview,.panel,.modal-card{padding:18px}.install-banner{display:grid}h1{font-size:clamp(2.4rem,13vw,3.6rem)}.panel-header{flex-direction:column}.phrase-list{flex-direction:row}.phrase-link{grid-template-columns:36px minmax(0,1fr);gap:12px;padding:14px}.phrase-link__index{width:36px;height:36px}.prompt-panel h2{max-width:none;font-size:clamp(1.7rem,8vw,2.4rem)}.install-banner__actions{justify-content:stretch}.install-banner__actions .primary-button,.install-banner__actions .ghost-button{flex:1 1 160px}.practice-state{margin-top:18px;padding-top:18px}.floating-kana-button{right:14px;bottom:14px}}
