@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600&family=Noto+Sans+JP:wght@400;600&display=swap";:root{--font-app: "Inter", "Noto Sans JP", system-ui, -apple-system, "Segoe UI", sans-serif;color-scheme:light;--bg: #faf9f7;--ink: #1d1f1f;--muted: #5a5f5f;--card: #ffffff;--accent: #d96b4a;--accent-2: #e7c48a;--chapter-bg: #2d3436;--chapter-section-bg: #e8f2fc;--subchapter-bg: #f5f3f0;--shadow: none}*{box-sizing:border-box}body{margin:0;font-family:var(--font-app);background:var(--bg);color:var(--ink)}#app{min-height:100vh;display:flex;flex-direction:column}.hero{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;padding:2rem 6vw 1.2rem;gap:1.5rem;border-bottom:1px solid rgba(0,0,0,.08);background:#fff}.eyebrow{text-transform:uppercase;letter-spacing:.24em;font-size:.7rem;margin:0 0 .6rem;color:var(--accent);font-weight:600}h1{font-size:clamp(1.8rem,3vw + 1rem,2.8rem);margin:0 0 .4rem}.subtitle{margin:0;color:var(--muted)}.controls{display:grid;gap:.75rem;min-width:min(320px,90vw)}.control{display:grid;gap:.35rem;font-size:.85rem;color:var(--muted)}.control input[type=search]{padding:.65rem .8rem;border-radius:999px;border:1px solid rgba(0,0,0,.1);font-size:.95rem;background:#fff}.toggle{display:flex;align-items:center;gap:.6rem;font-size:.85rem}.toggle input{accent-color:var(--accent)}.mode-selector{display:flex;gap:.3rem}.mode-btn{padding:.4rem .7rem;background:#0000000a;border:1px solid rgba(0,0,0,.1);border-radius:6px;font:inherit;font-size:.8rem;color:var(--muted);cursor:pointer;transition:all .15s}.mode-btn:hover{background:#00000014}.mode-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.mode-btn--active:hover{background:var(--accent)}.stage{flex:1;padding:1.5rem 6vw 3rem;max-width:1000px;margin:0 auto;width:100%}[data-view=flashcards] .stage.stage--wide{max-width:1200px}[data-view=flashcards] .hero{gap:.5rem;padding-top:1.5rem;padding-bottom:.75rem;align-items:flex-start}[data-view=flashcards] .hero>div:first-of-type{min-width:0;flex:1 1 200px;max-width:100%}[data-view=flashcards] .hero h1.flashcards-heading__line1{font-size:clamp(1.1rem,1.3vw + .85rem,1.45rem);margin:0;line-height:1.3;font-weight:600;color:var(--ink)}[data-view=flashcards] .flashcards-heading__row2{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;width:100%;min-width:0;margin:.2rem 0 0}[data-view=flashcards] .flashcards-heading__line2{margin:0;flex:1;min-width:0;font-size:.82rem;line-height:1.35;font-weight:400;color:var(--ink)}[data-view=flashcards] .flashcards-heading__line2[hidden]{display:none}[data-view=flashcards] .flashcards-heading__shown{flex-shrink:0;margin-left:auto;font-size:.8rem;line-height:1.35;font-weight:400;color:var(--muted);text-align:right}[data-view=flashcards] [data-flashcard-shown-count][hidden]{display:none!important}[data-view=flashcards] .hero>.controls{flex:1 1 280px;min-width:0;max-width:100%;align-self:stretch}[data-view=flashcards] .controls{min-width:0;gap:.5rem}[data-view=flashcards] .control--search{width:100%;max-width:100%;display:block;margin:0}[data-view=flashcards] .control--search[hidden]{display:none!important}[data-view=flashcards] .control--search input[type=search]{width:100%;box-sizing:border-box;padding:.36rem .65rem;border-radius:6px;font-size:.88rem;line-height:1.25}[data-view=flashcards] .control[data-flashcard-toolbar]{width:100%;display:block;margin:0}[data-view=flashcards] .control[data-flashcard-toolbar] .mode-selector{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;width:100%;gap:.3rem}[data-view=flashcards] .control[data-flashcard-toolbar] .mode-selector [data-two-per-row-toggle]{margin-left:auto}.status,.empty{padding:1rem;background:#ffffffb3;border-radius:12px;color:var(--muted);border:1px dashed rgba(0,0,0,.12);margin-bottom:1rem}.content-list{display:flex;flex-direction:column;gap:0}.content-list--two-cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}@media (max-width: 640px){.content-list--two-cols{grid-template-columns:1fr}}.subchapter-header{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1.2rem;background:var(--subchapter-bg);border:none;border-bottom:1px solid rgba(0,0,0,.06);font:inherit;text-align:left;cursor:pointer;transition:background .15s}.subchapter-header:hover{background:#ebe8e4}.subchapter-header--expanded{background:#d96b4a1a;border-left:4px solid var(--accent);padding-left:calc(1.2rem - 4px)}.subchapter-header__left{display:flex;align-items:center;gap:.8rem;min-width:0}.subchapter-header__num{font-size:1rem;font-weight:600;color:var(--accent);min-width:1.5rem;text-align:center}.subchapter-header__title{display:flex;flex-wrap:wrap;align-items:baseline;gap:.3rem .8rem;min-width:0}.subchapter-header__jp{font-size:1.05rem;font-weight:500}.subchapter-header__en{font-size:.9rem;color:var(--muted)}.subchapter-header__right{display:flex;align-items:center;gap:.8rem;flex-shrink:0}.subchapter-header__count{font-size:.8rem;color:var(--muted);background:#0000000d;padding:.2rem .6rem;border-radius:999px}.subchapter-header__arrow{font-size:.9rem;color:var(--accent);width:1rem;text-align:center}.words-container{display:flex;flex-direction:column;gap:.6rem;padding:1rem;background:#fff;border-left:4px solid var(--accent);border-bottom:1px solid rgba(0,0,0,.06)}.card{background:var(--card);border-radius:16px;padding:.1rem .2rem;box-shadow:0 1px 3px #0000000a;display:flex;flex-direction:column;gap:.4rem;border:1px solid rgba(0,0,0,.06);transform:translateY(8px);opacity:0;animation:rise .4s ease forwards;animation-delay:calc(var(--i) * .02s)}.card__body{display:grid;grid-template-columns:1fr 120px;grid-template-rows:auto auto;column-gap:.55rem;row-gap:.3rem;align-items:start;min-height:0}.card__word{grid-column:1;grid-row:1;display:flex;flex-direction:column;gap:.2rem;min-width:0;min-height:0;word-wrap:break-word;overflow-wrap:break-word;padding:.35rem 0 0 .55rem}.card__body__spacer{grid-column:1;grid-row:2;margin:0;padding:0;min-height:0;height:0;overflow:hidden;pointer-events:none;visibility:hidden}.card__jp{font-size:1.6rem;font-weight:600;line-height:1.2}.card__reading{color:var(--muted);font-size:.95rem}.card__en{font-size:1.05rem;margin-top:.1rem}.card__right{grid-column:2;grid-row:1 / -1;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;flex-shrink:0;min-height:0;min-width:0;align-self:stretch}.card__meta{font-size:.75rem;color:var(--muted);text-align:right;white-space:nowrap}.card__image{flex:0 1 auto;display:flex;align-items:flex-start;justify-content:center;width:100%;height:8rem;min-height:8rem;padding:0;border-radius:8px;background:var(--card);overflow:hidden;line-height:0}.card__image img{display:block;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;object-position:top center;border-radius:0;background:var(--card)}.card__image--placeholder{flex:0 1 auto;height:8rem;min-height:8rem;width:100%;border-radius:8px;background:#e4e4e6;border:none;box-sizing:border-box}.study-card__image.card__image--placeholder{background:#e4e4e6;border:none}.card__bottom{grid-column:1;grid-row:2;display:flex;flex-direction:column;gap:.2rem;padding:.3rem 0 .2rem .6rem;border-top:1px solid rgba(0,0,0,.06);box-sizing:border-box;height:2rem;min-height:2rem;max-height:2rem;overflow:hidden;flex-shrink:0}.card__bottom:has(.card__expanded-content:not([hidden])){height:auto;max-height:none;min-height:2rem;overflow:visible}.card__toggles{display:flex;flex-wrap:wrap;gap:.25rem;flex-shrink:0}.card__toggle-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .45rem;background:#0000000a;border:1px solid rgba(0,0,0,.1);border-radius:6px;font:inherit;font-size:.75rem;color:var(--muted);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.card__toggle-btn:hover{background:#00000014;border-color:#0003}.card__toggle-btn--active,.card__toggle-btn--active:hover{background:#d96b4a1f;border-color:var(--accent);color:var(--accent)}.card__toggle-icon{font-weight:600;font-size:.85rem;line-height:1}.card__expanded-areas{display:flex;flex-direction:column;gap:.2rem;flex:1 1 0;min-height:0;overflow-y:auto;overflow-x:hidden}.card__bottom:has(.card__expanded-content:not([hidden])) .card__expanded-areas{flex:0 1 auto;max-height:min(50vh,18rem);overflow-y:auto}.card__expanded-content{padding:.2rem 0 0;border-top:1px dashed rgba(0,0,0,.08)}.card__section-text{font-size:.9rem;line-height:1.5;color:var(--ink)}.field{display:flex;flex-direction:column;gap:.2rem}.field__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.field__value{font-size:.95rem;line-height:1.5}.field__value strong{color:#000;background:#d96b4a1f;padding:0 .2em;border-radius:4px}@keyframes rise{to{transform:translateY(0);opacity:1}}.card--flashcard{perspective:1000px;background:transparent;border:none;box-shadow:none}.card__flip-container{position:relative;width:100%;cursor:pointer;transition:transform .5s ease;transform-style:preserve-3d}.card--no-transition .card__flip-container{transition:none}.card--flipped .card__flip-container{transform:rotateY(180deg)}.card__face{background:var(--card);border-radius:16px;padding:.1rem .2rem;border:1px solid rgba(0,0,0,.06);backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column}.card__face--front{position:relative}.card__face--back{position:absolute;top:0;left:0;right:0;transform:rotateY(180deg);background:linear-gradient(135deg,#fef9f3,#fff);border-color:var(--accent)}.card--flipped .card__face--front{position:absolute;top:0;left:0;right:0}.card--flipped .card__face--back{position:relative}.card__en--large{font-size:1.4rem;font-weight:500}@media (max-width: 720px){.hero{padding:1.5rem 5vw 1rem}[data-view=flashcards] .hero{padding:1.25rem 5vw .65rem;gap:.45rem}.stage{padding:1rem 4vw 2rem}.subchapter-header{padding:.8rem 1rem}.subchapter-header__title{flex-direction:column;gap:.15rem}.words-container{padding:.8rem}.card{padding:.1rem .15rem}.card__body{column-gap:.45rem;row-gap:.25rem}.card__jp{font-size:1.3rem}.card__en{font-size:.95rem}.card__reading{font-size:.85rem}.card__meta{font-size:.65rem}}.view{display:flex;flex-direction:column;min-height:100vh}.menu-list{display:flex;flex-direction:column;gap:0;padding:0 6vw 2rem;max-width:800px;margin:0 auto;width:100%;border-top:1px solid rgba(0,0,0,.15)}.menu-item{display:block;padding:.55rem 0;margin:0;background:transparent;border-radius:0;border:none;border-bottom:1px solid rgba(0,0,0,.15);text-decoration:none;color:#111;transition:background .12s ease}.menu-item:hover{background:#00000008}.menu-item__title{font-size:1rem;font-weight:600;margin:0;color:#000;line-height:1.35}.menu-item__desc{margin:0;margin-top:.1rem;color:#111;font-size:.875rem;line-height:1.35;font-weight:400}.menu-list__subheading{margin:0;padding:.5rem 0;border-bottom:1px solid rgba(0,0,0,.15);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:#000}[data-view=main-menu] .subtitle{color:#111}.back-link{display:inline-block;margin-bottom:.5rem;color:var(--accent);text-decoration:none;font-size:.9rem;transition:opacity .2s}.back-link:hover{opacity:.7}.chapter-list{padding:2rem 6vw;max-width:800px;margin:0 auto;width:100%;border-top:1px solid rgba(0,0,0,.15)}.topic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;width:100%;max-width:1200px;margin:0 auto}.topic-section{margin-bottom:10px}.topic-section h2{margin:10px 0 8px;font-size:16px;display:flex;align-items:flex-end;gap:.6rem;flex-wrap:wrap}.topic-section__en{font-size:16px;font-weight:600}.topic-section__jp-wrap{display:inline-flex;flex-direction:column;align-items:center;line-height:1.05}.topic-section__hir{font-size:11px;color:var(--muted)}.topic-section__jp{font-size:16px;font-weight:600}[data-view=topic] .stage{max-width:1200px;padding:14px 14px 30px}[data-view=topic] .hero{padding:24px 14px 10px;max-width:1200px;width:100%;box-sizing:border-box;margin:0 auto;gap:12px 16px;display:grid;grid-template-columns:1fr auto;align-items:start;justify-content:stretch;border-bottom:none;background:transparent}[data-view=topic] h1{margin:0 0 6px;font-size:20px;line-height:1.2;display:flex;align-items:flex-end;gap:.6rem;flex-wrap:wrap}.topic-page-title__en{font-size:20px;font-weight:600}.topic-page-title__jp-wrap{display:inline-flex;flex-direction:column;align-items:center;line-height:1.05}.topic-page-title__hir{font-size:12px;color:var(--muted)}.topic-page-title__jp{font-size:20px;font-weight:600}[data-view=topic] .subtitle{margin:0;font-size:14px}[data-view=topic] .controls{min-width:0;gap:.35rem;margin-left:auto;justify-self:end;text-align:right}[data-view=topic] .control{gap:.2rem;font-size:13px}[data-view=topic] .mode-btn{font-size:13px;padding:6px 10px;border-radius:8px}.topic-card{background:#fff;border:1px solid #e6e6e6;border-radius:0;box-shadow:0 1px #00000008;display:flex;align-items:center;gap:6px;padding:3px 7px 3px 2px;min-height:58px;overflow:hidden;margin:2px 4px}.topic-card--flash{perspective:1000px;display:block;padding:0;overflow:hidden;background:transparent;border-color:transparent;box-shadow:none}.topic-card__flip{position:relative;width:100%;min-height:58px;transition:transform .5s ease;transform-style:preserve-3d;cursor:pointer}.topic-card--flash.topic-card--no-transition .topic-card__flip{transition:none}.topic-card--flipped .topic-card__flip{transform:rotateY(180deg)}.topic-card__face{position:relative;width:100%;min-height:58px;display:flex;align-items:center;gap:6px;padding:3px 7px 3px 2px;background:#fff;border:1px solid #e6e6e6;border-radius:0;box-shadow:0 1px #00000008;backface-visibility:hidden;-webkit-backface-visibility:hidden}.topic-card__face--front{position:relative}.topic-card__face--back{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotateY(180deg)}.topic-card--flash.topic-card--flipped .topic-card__face--front{position:absolute;top:0;right:0;bottom:0;left:0}.topic-card--flash.topic-card--flipped .topic-card__face--back{position:relative}.topic-card__icon{width:48px;height:48px;flex:0 0 48px;object-fit:contain;display:block}.topic-card__icon--missing{background:#e4e4e6;border:none;box-shadow:none;border-radius:4px;box-sizing:border-box;flex-shrink:0}.topic-card__meta{min-height:48px;max-height:48px;min-width:0;display:flex;flex-direction:column;justify-content:center;row-gap:3px;line-height:1.15;flex:1 1 auto;overflow:hidden}.topic-card__en,.topic-card__jp{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:clip}.topic-card__hir{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:clip}.chapter-section{margin-bottom:0}[data-view=chapter-list] .chapter-header{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;margin-top:1rem;margin-bottom:.25rem;padding:.75rem 1rem;background:var(--chapter-section-bg);color:#111;border-radius:8px;border:none}[data-view=chapter-list] .chapter-section:first-child .chapter-header{margin-top:0}[data-view=chapter-list] .chapter-header__line1{font-size:1.05rem;font-weight:600;color:#111;line-height:1.35}[data-view=chapter-list] .chapter-header__line2{font-size:.95rem;font-weight:400;color:#111;line-height:1.35}.subchapter-list{display:flex;flex-direction:column;gap:0;margin-left:0}.subchapter-item{display:block;padding:.2rem .15rem;background:transparent;border-radius:0;border:none;border-bottom:1px solid rgba(0,0,0,.12);text-decoration:none;color:#111;transition:background .12s ease}.subchapter-item:hover{background:#00000008}.subchapter-item__left{display:flex;align-items:flex-start;gap:.45rem;width:100%;min-width:0}.subchapter-item__num{flex-shrink:0;font-weight:600;color:#111;font-size:.8rem;min-width:1.1rem;line-height:1.2;padding-top:.08rem}.subchapter-item__text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.subchapter-item__name-line{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-width:0}.subchapter-item__labels{display:flex;flex-direction:column;gap:.05rem;min-width:0;flex:1}.subchapter-item__hir{font-size:.65rem;line-height:1.15;color:var(--muted)}.subchapter-item__jp{font-size:.9rem;font-weight:600;line-height:1.2;color:#111}.subchapter-item__en{color:#111;font-size:.75rem;line-height:1.2}.subchapter-item__count{flex-shrink:0;color:#111;font-size:.72rem;line-height:1.2;white-space:nowrap;align-self:center}@media (max-width: 768px){.menu-list{padding:0 4vw 1.5rem}[data-view=topic] .hero{padding:16px 6px 8px;grid-template-columns:1fr}[data-view=topic] .stage{padding:10px 4px 24px}.topic-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.topic-card{margin:1px 2px}.chapter-list{padding:1.5rem 4vw}.subchapter-list{margin-left:0}.subchapter-item{padding:.18rem .1rem}}[data-view=flashcards] [data-study-progress][hidden]{display:none!important}[data-view=flashcards] .control--study-progress{color:var(--ink);font-size:.9rem}.study-progress-line{display:block;white-space:nowrap;line-height:1.3}.study-card{max-width:600px;margin:2rem auto;background:var(--card);border-radius:12px;padding:2rem;box-shadow:0 4px 12px #0000001a}.study-card__front,.study-card__back{margin-bottom:1.5rem}.study-card__content{display:flex;flex-direction:column;gap:1rem;align-items:center;text-align:center}.study-card__japanese{font-size:2.5rem;font-weight:600;color:var(--ink);margin-bottom:.5rem}.study-card__reading{font-size:1.2rem;color:var(--muted);margin-bottom:1rem}.study-card__english{font-size:1.8rem;font-weight:600;color:var(--accent);margin-bottom:1rem}.study-card__image{width:200px;height:200px;margin:1rem auto;border-radius:8px;overflow:hidden;background:var(--card)}.study-card__image img{display:block;width:100%;height:100%;object-fit:contain;background:var(--card)}.study-card__examples{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.1);width:100%}.study-card__example{font-size:1rem;line-height:1.6;margin-bottom:.75rem;color:var(--ink)}.study-card__example--jp{font-size:1.1rem}.study-card__reveal{width:100%;padding:1rem;font-size:1rem;font-weight:600;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s;margin-bottom:1rem}.study-card__reveal:hover{background:#c55a3a}.study-card__buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-top:1rem}.study-btn{padding:.75rem 1rem;font-size:.9rem;font-weight:600;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s;background:var(--bg);color:var(--ink)}.study-btn:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.study-btn--again{background:#e74c3c;color:#fff;border-color:#e74c3c}.study-btn--again:hover{background:#c0392b}.study-btn--hard{background:#f39c12;color:#fff;border-color:#f39c12}.study-btn--hard:hover{background:#e67e22}.study-btn--good{background:#27ae60;color:#fff;border-color:#27ae60}.study-btn--good:hover{background:#229954}.study-btn--easy{background:#3498db;color:#fff;border-color:#3498db}.study-btn--easy:hover{background:#2980b9}@media (max-width: 768px){.study-card{margin:1rem;padding:1.5rem}.study-card__japanese{font-size:2rem}.study-card__english{font-size:1.5rem}.study-card__image{width:150px;height:150px}.study-card__buttons{grid-template-columns:repeat(2,1fr)}.study-btn{padding:.6rem .8rem;font-size:.85rem}}
