:root{--background:#f7f3ea;--foreground:#24211d;--muted:#69645b;--panel:#fffdf8;--panel-strong:#fff;--line:#d8d1c4;--line-strong:#24211d;--accent:#bd2f3e;--accent-dark:#7c161e;--accent-soft:#eac2c8;--ink:#24211d;--blue:#356997;--mustard:#e8bf58;--pink:#dd939b;--rose:#c9586b;--cream:#fbf7ea;--ivory:#fbfaf5;--greige:#f0ede2;--khaki:#c8ad6b;--terracotta:#bf7b54;--brown:#6c3f2a;--leaf:#e8bf58;--leaf-light:#fbf7ea;--mist:#f0ede2;--sky:#356997;--red:#bd2f3e;--orange:#bf7b54;--error:#bd2f3e;--shadow:0 14px 34px #24211d12;--soft-shadow:0 8px 22px #24211d0f;--latin-font:Futura, "Futura PT", "Avenir Next", Avenir, Helvetica, Arial, sans-serif;--latin-light-font:"Futura Light", "Futura PT Light", Futura, "Avenir Next", Avenir, Helvetica, Arial, sans-serif;--japanese-font:"Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif}html,body{background:var(--background);min-height:100%;color:var(--foreground);font-family:var(--latin-font);margin:0;font-weight:300}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input{font:inherit}button{border:0}*{box-sizing:border-box}.app-nav{z-index:20;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffdf8f5;justify-content:space-between;align-items:center;gap:18px;padding:16px 34px;display:flex;position:sticky;top:0}.brand-link,.nav-link{color:var(--ink);text-decoration:none}.brand-link{letter-spacing:.01em;align-items:baseline;gap:8px;font-weight:800;display:inline-flex}.nav-links{flex-wrap:wrap;gap:8px;display:flex}.nav-link{color:var(--muted);border:1px solid #0000;border-radius:999px;align-items:center;gap:7px;padding:8px 14px;font-size:.9rem;font-weight:600;display:inline-flex}.nav-link-active,.nav-link:hover{color:var(--ink);background:#eac2c859;border-color:#bd2f3e47}.app-shell{background:linear-gradient(90deg, #3569970e, transparent 18%), var(--background);min-height:100vh;padding:36px 32px 48px}.workspace{width:min(1240px,100%);margin:0 auto}.intro{gap:10px;max-width:980px;margin-bottom:44px;padding-top:14px;display:grid}.page-header{gap:10px;max-width:720px;margin-bottom:24px;display:grid}.page-header h1{color:var(--ink);margin:0;font-size:clamp(2rem,5vw,4.2rem);line-height:1}.page-header p:last-child{color:var(--muted);margin:0;font-size:1.05rem;line-height:1.6}.eyebrow,.section-kicker{color:var(--accent-dark);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.77rem;font-weight:800}.intro h1{max-width:960px;color:var(--ink);letter-spacing:0;margin:0;font-size:5.6rem;font-weight:900;line-height:.98}.intro p:last-child{max-width:620px;color:var(--muted);margin:0;font-size:1.05rem;line-height:1.65}.dictionary-word{color:var(--accent-dark);letter-spacing:0;align-items:baseline;gap:12px;margin:0;font-size:7rem;font-weight:900;line-height:.9;display:flex}.dictionary-word span{color:var(--ink);font-size:.28em;font-weight:800}.dictionary-pronunciation,.dictionary-part{color:var(--muted);font-size:1.05rem;font-family:var(--latin-light-font);margin:0;font-weight:300}.dictionary-pronunciation{color:var(--blue)}.dictionary-part{border:1px solid var(--line);background:var(--ivory);border-radius:999px;width:fit-content;padding:4px 10px;font-style:italic}.dictionary-definition{max-width:620px;color:var(--muted);font-family:var(--latin-light-font);margin:6px 0 0;font-size:1.2rem;font-weight:300;line-height:1.55}.inline-icon{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;flex:none;width:1em;height:1em}.lesson-stack{gap:30px;display:grid}.panel{border:1px solid var(--line);box-shadow:var(--shadow);background:#fffdf8f0;border-radius:18px}.study-panel,.lesson-panel{padding:28px}.study-grid{grid-template-columns:minmax(0,2.55fr) minmax(340px,1.15fr);align-items:start;gap:28px;display:grid}.study-image-column{min-width:0;display:block}.study-column-header{align-items:flex-end;margin-bottom:20px}.study-column-header .status{transform:translateY(5px)}.vocab-rail{height:var(--study-column-height,auto);flex-direction:column;min-height:0;display:flex;position:sticky;top:18px;overflow:hidden}.vocab-rail h3{color:var(--ink);margin:0 0 12px;font-size:1rem}.rail-header{flex:none}.vocab-aligned-header{padding-top:23px}.section-heading-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-heading-row h3{align-items:center;min-height:32px;margin:0;display:flex}.panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.panel-header h2{color:var(--ink);margin:4px 0 0;font-size:1.35rem}.heading-with-icon{align-items:center;gap:10px;display:inline-flex}.heading-with-icon .inline-icon{color:var(--accent);font-size:1.05em}.status{border:1px solid var(--line);min-height:32px;color:var(--muted);background:var(--panel-strong);white-space:nowrap;border-radius:999px;align-items:center;gap:7px;padding:6px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.status.ready{color:var(--blue);background:#35699714;border-color:#35699747}.drop-zone{background:var(--ivory);min-height:380px;color:var(--ink);cursor:pointer;border:1.5px dashed #bcb4a7;border-radius:16px;place-items:center;display:grid;overflow:hidden}.image-stage{aspect-ratio:16/9;background:#fff;border-radius:14px;width:100%;height:auto;position:relative;overflow:hidden;padding:0!important;display:block!important}.image-preview{object-fit:contain;background:#fff;width:100%;height:100%;display:block}.image-label{z-index:2;border:3px solid var(--ink);width:max-content;min-width:76px;max-width:136px;min-height:38px;color:var(--ink);cursor:pointer;opacity:.98;text-align:center;background:#fff;border-radius:18px;place-items:center;font-size:clamp(.95rem,1.08vw,1.18rem);font-weight:900;line-height:1;display:grid;position:absolute;overflow:visible;transform:translate(-50%,-100%);box-shadow:2px 3px #24211d29;padding:3px 10px!important}.image-label span{z-index:2;position:relative}.image-label:hover{border-color:var(--accent);opacity:1;background:#fff;box-shadow:3px 4px #bd2f3e38}.image-label-unmatched{transform:translate(-50%,-50%)}.image-label-matched{transform:translate(-50%,-100%)}.image-label-japanese,.image-label-english{display:block}.image-label-japanese{color:var(--ink);font-family:var(--japanese-font);text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.image-label-english{color:var(--ink);text-overflow:ellipsis;text-transform:lowercase;white-space:nowrap;max-width:100%;margin-top:2px;font-size:.46em;font-weight:800;line-height:1;overflow:hidden}ruby{ruby-align:center;ruby-position:over}rt{color:var(--muted);font-size:.44em;font-weight:800;line-height:1}.image-label-japanese rt{color:var(--ink);font-size:.38em;font-weight:800}.practice-prompt rt{font-size:.22em}.image-label:after{z-index:1;border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);content:"";transform-origin:top;background:#fff;width:16px;height:18px;position:absolute;bottom:-14px;left:50%;transform:translate(-50%)rotate(35deg)skewY(18deg)}.image-label-unmatched:after{display:none}.drop-zone-placeholder{text-align:center;justify-items:center;gap:10px;padding:30px;font-weight:900;display:grid}.upload-icon{fill:none;width:44px;height:44px;stroke:var(--accent);stroke-linecap:round;stroke-linejoin:round;stroke-width:1.7px}.drop-zone small{color:var(--muted);font-size:.85rem;font-weight:600}.file-input{clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}.image-source-actions{gap:8px;margin-top:12px;display:none}.source-action-button{cursor:pointer;align-items:center;gap:7px;font-size:.9rem;display:inline-flex;position:relative;overflow:hidden}.camera-action-button{display:none}.primary-button{color:#fff;background:var(--accent);cursor:pointer;border:1px solid #bd2f3e2e;border-radius:14px;width:100%;min-height:50px;margin-top:16px;font-weight:900}.button-content{justify-content:center;align-items:center;gap:8px;display:inline-flex}.secondary-button,.text-button{cursor:pointer;font-weight:700}.secondary-button{border:1px solid var(--line);min-height:36px;color:var(--accent-dark);background:var(--cream);border-radius:999px;padding:7px 12px}.secondary-button:not(:disabled):hover{color:#fff;background:var(--accent)}.secondary-button:disabled{cursor:not-allowed;opacity:.46}.text-button{color:var(--blue);background:0 0}.text-button:disabled{cursor:not-allowed;opacity:.46;text-decoration:none}.text-button:hover{text-decoration:underline}.save-controls{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.compact-action{min-height:32px;padding:4px 2px;font-size:.78rem}.primary-button:not(:disabled):hover{background:var(--accent-dark)}.primary-button:disabled{cursor:not-allowed;opacity:.52}.detected-strip{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.detected-strip span{border:1px solid var(--line);color:var(--ink);background:var(--cream);border-radius:999px;padding:6px 10px;font-size:.82rem;font-weight:800}.error-message{border-left:4px solid var(--error);color:var(--error);background:#eac2c847;margin:16px 0 0;padding:10px 12px;line-height:1.45}.save-message{border-left:4px solid var(--blue);color:var(--ink);background:#35699714;margin:16px 0 0;padding:10px 12px;line-height:1.45}.scene-summary{border-left:4px solid var(--accent-soft);color:var(--ink);font-family:var(--latin-light-font);margin:0 0 22px;padding:8px 0 8px 14px;font-size:1.08rem;font-weight:300;line-height:1.45}.vocab-rail .scene-summary{margin-bottom:18px}.image-scene-summary{margin-top:14px;margin-bottom:0}.content-block{margin-top:24px}.content-block h3{color:var(--ink);margin:0 0 12px;font-size:1rem}.vocab-list,.exchange-list{gap:18px;display:grid}.vocab-card,.exchange-card{border:1px solid var(--line);background:var(--panel-strong);border-radius:16px}.vocab-list{grid-template-columns:repeat(3,minmax(0,1fr))}.vocab-rail .vocab-list{scrollbar-color:#243b3952 transparent;scrollbar-width:thin;flex:auto;grid-template-columns:1fr;min-height:0;padding-right:6px;overflow-y:auto}.vocab-rail .vocab-list::-webkit-scrollbar{width:8px}.vocab-rail .vocab-list::-webkit-scrollbar-thumb{background:#69645b47;border-radius:999px}.vocab-rail .vocab-list::-webkit-scrollbar-track{background:0 0}.vocab-card{box-shadow:var(--soft-shadow);gap:8px;padding:12px 14px;transition:border-color .16s,box-shadow .16s,transform .16s;display:grid;position:relative}.vocab-select{width:fit-content;color:var(--muted);cursor:pointer;align-items:center;gap:5px;font-size:.72rem;font-weight:900;display:inline-flex}.vocab-select input{width:14px;height:14px;accent-color:var(--blue)}.vocab-card-active{background:#35699714;border-color:#3569976b;transform:translateY(-2px);box-shadow:0 0 0 4px #3569971f,0 12px 28px #24211d1a}.vocab-card h4{color:var(--ink);text-transform:capitalize;margin:0 0 3px;font-size:.95rem}.vocab-card p:not(.japanese-word):not(.reading){font-size:.92rem}.vocab-card p,.exchange-card p{color:var(--muted);font-family:var(--latin-light-font);margin:0;font-weight:300;line-height:1.5}.word-topline,.sentence-topline{justify-content:space-between;align-items:center;gap:8px;display:flex}.audio-controls{flex:none;gap:6px;display:inline-flex}.icon-button{border:1px solid var(--line);width:32px;height:32px;color:var(--ink);background:var(--panel-strong);cursor:pointer;border-radius:10px;place-items:center;font-size:.9rem;font-weight:900;display:inline-grid}.icon-button .inline-icon{width:16px;height:16px}.icon-button:hover{color:#fff;background:var(--blue)}.listen-label{align-items:center;display:none}.japanese-word,.sentence-ja{font-family:var(--japanese-font);font-size:1.32rem;font-weight:900;color:var(--ink)!important;line-height:1.25!important}.reading{font-size:.82rem;font-weight:800;color:var(--rose)!important;margin-top:2px!important}.exchange-card{gap:18px;padding:22px;display:grid}.exchange-header h4{color:var(--ink);margin:0 0 7px;font-size:1.08rem}.dialogue-line{border:1px solid var(--line);border-radius:16px;grid-template-columns:38px minmax(0,1fr);align-items:start;gap:15px;padding:14px;display:grid}.dialogue-line.speaker-a{background:#35699714}.dialogue-line.speaker-b{background:#eac2c852}.speaker-badge{color:#fff;background:var(--blue);border:1px solid #3569973d;border-radius:10px;place-items:center;width:38px;height:38px;font-weight:900;display:inline-grid}.speaker-b .speaker-badge{background:var(--accent)}.dialogue-line p:last-child{margin-top:7px}.exchange-card small{color:var(--blue);font-weight:800;line-height:1.45}.conversation-practice{margin-top:6px;display:block}.conversation-toolbar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.conversation-status{border:1px solid var(--line);width:34px;height:34px;color:var(--muted);background:var(--ivory);border-radius:999px;flex:none;justify-content:center;align-items:center;display:inline-flex}.conversation-status-loading{color:var(--blue);background:#35699714}.conversation-status-ready{color:var(--blue);background:#35699714;border-color:#35699733}.conversation-status .inline-icon{width:17px;height:17px}.loading-spinner{border:2px solid #3569973d;border-top-color:var(--blue);border-radius:50%;width:16px;height:16px;animation:.75s linear infinite status-spin}@keyframes status-spin{to{transform:rotate(360deg)}}.difficulty-control{border:1px solid var(--line);background:var(--ivory);border-radius:999px;gap:4px;padding:4px;display:inline-flex}.difficulty-option{min-height:34px;color:var(--muted);cursor:pointer;text-transform:capitalize;background:0 0;border-radius:999px;padding:6px 12px;font-size:.82rem;font-weight:900}.difficulty-option-active,.difficulty-option:hover{color:#fff;background:var(--accent)}.conversation-practice .content-block{margin-top:0}.conversation-save-message{margin-bottom:16px}.exchange-vocabulary{border-top:1px solid var(--line);flex-wrap:wrap;gap:10px;margin-top:4px;padding-top:16px;display:flex}.exchange-word{border:1px solid var(--line);color:var(--ink);background:var(--cream);font-family:var(--japanese-font);border-radius:999px;align-items:center;gap:8px;padding:8px 8px 8px 13px;font-weight:700;display:inline-flex}.exchange-word>span:nth-child(2){color:var(--muted);font-family:var(--latin-light-font);font-size:.86rem;font-weight:300}.exchange-save-word{width:28px;height:28px;color:var(--blue);cursor:pointer;background:#fff;border-radius:999px;place-items:center;display:inline-grid}.exchange-save-word:hover{color:#fff;background:var(--blue)}.exchange-save-word .inline-icon{width:14px;height:14px}.empty-state{padding:28px}.empty-state h2{color:var(--ink);margin:0 0 8px}.empty-state p{color:var(--muted);margin:0;line-height:1.55}.saved-list{gap:14px;display:grid}.unit-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;display:grid}.unit-card{min-height:190px;color:var(--ink);box-shadow:var(--soft-shadow);gap:18px;padding:22px;text-decoration:none;display:grid}.unit-card h2{margin:4px 0 0;font-size:1.7rem}.unit-card p{color:var(--muted);margin:0;line-height:1.45}.unit-card span{border:1px solid var(--line);width:fit-content;color:var(--blue);background:#35699714;border-radius:999px;align-self:end;padding:7px 10px;font-size:.82rem;font-weight:900}.unit-page-header{justify-content:space-between;align-items:flex-end;gap:20px;max-width:none;display:flex}.page-link-button{color:var(--blue);text-decoration:none}.mode-tabs{border:1px solid var(--line);background:var(--ivory);border-radius:999px;gap:8px;margin-bottom:18px;padding:6px;display:inline-flex}.mode-tab{min-height:38px;color:var(--muted);cursor:pointer;background:0 0;border-radius:999px;padding:8px 14px;font-weight:900}.mode-tab-active,.mode-tab:hover{color:#fff;background:var(--accent)}.saved-vocab-card,.saved-exchange-card{box-shadow:var(--soft-shadow);padding:18px}.saved-vocab-card{grid-template-columns:minmax(160px,.28fr) minmax(0,1fr) auto;align-items:start;gap:18px;display:grid}.saved-vocab-card h2,.saved-exchange-header h2{color:var(--ink);margin:0 0 6px;font-size:1.08rem}.saved-vocab-card small,.saved-exchange-header small{color:var(--muted);margin-top:8px;font-size:.82rem;font-weight:800;display:block}.saved-exchange-card{gap:12px;display:grid}.saved-exchange-header{justify-content:space-between;gap:18px;display:flex}.practice-card{max-width:720px;box-shadow:var(--soft-shadow);gap:20px;padding:28px;display:grid}.practice-prompt{justify-content:space-between;align-items:center;gap:18px;display:flex}.practice-prompt p{color:var(--ink);margin:0;font-size:clamp(3rem,9vw,6rem);font-weight:900;line-height:1}.practice-answer{border-left:4px solid var(--blue);padding-left:16px}.practice-answer h2{color:var(--ink);margin:0 0 6px}.practice-answer p,.practice-hint{color:var(--muted);margin:0;line-height:1.55}.practice-actions{flex-wrap:wrap;gap:12px;display:flex}.practice-next-button{width:auto;min-width:150px;margin-top:0}@media (max-width:860px){.app-nav{align-items:center;gap:12px;padding:12px 18px}.app-shell{padding:22px 18px 30px}.intro{margin-bottom:30px}.lesson-stack{gap:22px}.study-panel,.lesson-panel{padding:18px}.intro h1{font-size:4.8rem}.drop-zone{min-height:280px}.camera-action-button{display:inline-flex}.image-source-actions{flex-wrap:wrap;display:flex}.study-image-column{min-height:0;max-height:none}.image-stage{aspect-ratio:16/9;height:auto}.image-preview{max-height:520px}.study-grid,.conversation-practice{grid-template-columns:1fr}.vocab-rail{height:auto;min-height:0;max-height:none;position:static;overflow:visible}.vocab-aligned-header{padding-top:16px}.vocab-rail .vocab-list{grid-template-columns:repeat(2,minmax(0,1fr));padding-right:0;overflow:visible}.saved-vocab-card{grid-template-columns:1fr}.unit-page-header{flex-direction:column;align-items:flex-start}}@media (max-width:560px){.app-nav{flex-direction:column;align-items:flex-start;padding:12px 14px}.nav-links{gap:4px;width:100%}.nav-link{flex:auto;justify-content:center;padding:8px 9px;font-size:.8rem}.app-shell{padding:12px}.intro{margin-bottom:22px;padding-top:2px}.intro h1{font-size:3rem}.dictionary-word{flex-direction:column;align-items:flex-start;gap:6px;line-height:.94}.dictionary-word span{font-size:.42em}.dictionary-definition{font-size:1rem}.study-panel,.lesson-panel{border-radius:14px;padding:12px}.panel-header{gap:12px;margin-bottom:14px;display:grid}.study-column-header .status{transform:none}.vocab-aligned-header{padding-top:16px}.drop-zone{border-radius:12px;min-height:220px}.image-label{border-width:2px;border-radius:14px;min-width:56px;max-width:94px;min-height:32px;font-size:.86rem;padding:3px 7px!important}.image-label:after{width:12px;height:14px;bottom:-11px}.image-source-actions{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.source-action-button{justify-content:center;min-height:42px}.primary-button{min-height:46px}.scene-summary{font-size:.98rem}.section-heading-row{flex-direction:column;align-items:flex-start}.save-controls{justify-content:flex-start}.vocab-card,.vocab-list,.vocab-rail .vocab-list{grid-template-columns:1fr}.word-topline,.sentence-topline{align-items:flex-start}.conversation-toolbar{justify-content:flex-start}.difficulty-control{width:100%}.difficulty-option{flex:1 1 0}.dialogue-line{grid-template-columns:30px minmax(0,1fr);gap:10px;padding:10px}.speaker-badge{width:30px;height:30px}.exchange-card{gap:14px;padding:14px}.exchange-vocabulary{gap:7px;padding-top:12px}}.nav-hamburger{border:1px solid var(--line);background:var(--panel-strong);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;margin-left:auto;padding:8px;display:none}.hamburger-bar{background:var(--ink);border-radius:2px;width:100%;height:2px;transition:transform .18s,opacity .18s;display:block}.hamburger-bar.open:first-child{transform:translateY(7px)rotate(45deg)}.hamburger-bar.open:nth-child(2){opacity:0}.hamburger-bar.open:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.vocab-filter-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.vocab-search-input{border:1px solid var(--line);min-height:44px;color:var(--ink);background:var(--panel-strong);border-radius:12px;outline:none;flex:200px;padding:0 14px;font-size:.95rem}.vocab-search-input:focus{border-color:#35699780;box-shadow:0 0 0 3px #3569971a}.vocab-filter-tabs{margin-bottom:0}.vocab-card-actions{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.learned-active{color:var(--blue);background:#3569971f;border-color:#35699766}.vocab-card-learned{opacity:.72}.review-stats{color:var(--muted);margin-top:6px;font-size:.78rem;font-weight:700;display:block}.practice-card-correct{background:#3597640f;border-color:#35976480;transition:background .2s,border-color .2s}.practice-card-incorrect{background:#eac2c847;border-color:#bd2f3e80;transition:background .2s,border-color .2s}.practice-card-meta{align-items:center;gap:10px;display:flex}.due-badge{color:var(--accent-dark);background:#eac2c859;border:1px solid #bd2f3e4d;border-radius:999px;padding:3px 10px;font-size:.74rem;font-weight:800}.practice-correct-button,.practice-incorrect-button{cursor:pointer;border-radius:14px;min-height:44px;padding:0 20px;font-weight:900}.practice-correct-button{color:#fff;background:#3d9b63;border:1px solid #3597644d}.practice-correct-button:hover{background:#2f7a4d}.practice-incorrect-button{color:var(--accent-dark);background:#eac2c866;border:1px solid #bd2f3e4d}.practice-incorrect-button:hover{color:#fff;background:var(--accent)}.exchange-header-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.audio-loop-button{white-space:nowrap}.audio-loop-active{color:var(--accent-dark);background:#eac2c866;border-color:#bd2f3e66}.kana-script-toggle{border:1px solid var(--line);background:var(--ivory);border-radius:999px;gap:4px;margin-bottom:20px;padding:4px;display:inline-flex}.kana-chart{gap:10px;display:grid}.kana-row{flex-wrap:wrap;gap:10px;display:flex}.kana-cell{border:1px solid var(--line);background:var(--panel-strong);cursor:pointer;border-radius:14px;flex-direction:column;align-items:center;gap:4px;width:72px;min-height:72px;padding:10px 6px;transition:border-color .14s,background .14s;display:flex}.kana-cell:hover{background:#eac2c840;border-color:#bd2f3e66}.kana-char{color:var(--ink);font-family:var(--japanese-font);font-size:1.5rem;font-weight:700;line-height:1}.kana-romaji{color:var(--muted);font-size:.72rem;font-weight:800}.kana-quiz-controls{flex-wrap:wrap;gap:10px;margin-bottom:18px;display:flex}.kana-quiz-card{max-width:540px}.kana-prompt{flex-direction:column;align-items:flex-start;gap:12px}.kana-question-char{font-family:var(--japanese-font);font-weight:900;line-height:1;font-size:clamp(4rem,12vw,7rem)!important}.kana-question-romaji{font-weight:900;line-height:1;font-size:clamp(3rem,9vw,5rem)!important}.kana-answer-char{font-family:var(--japanese-font);font-size:2.5rem}.kana-score-bar{color:var(--muted);align-items:center;gap:16px;margin-bottom:14px;font-size:.88rem;font-weight:700;display:flex}.kana-accuracy{color:var(--blue)}.progress-stat-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px;display:grid}.progress-stat-card{gap:4px;padding:20px;display:grid}.progress-stat-streak{background:linear-gradient(135deg,#e8bf5826,#bf7b541a);border-color:#e8bf5880}.progress-stat-label{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:800}.progress-stat-value{color:var(--ink);margin:0;font-size:3rem;font-weight:900;line-height:1}.progress-stat-due{color:var(--accent)}.progress-stat-sub{color:var(--muted);margin:0;font-size:.82rem}.progress-chart-panel{margin-bottom:22px;padding:24px}.progress-chart-title{color:var(--ink);margin:0 0 18px;font-size:1.1rem}.progress-bar-chart{align-items:flex-end;gap:10px;height:120px;display:flex}.progress-bar-col{flex-direction:column;flex:1 1 0;align-items:center;gap:4px;height:100%;display:flex}.progress-bar-track{background:#3569971a;border-radius:6px;flex-direction:column;flex:auto;justify-content:flex-end;width:100%;display:flex;overflow:hidden}.progress-bar-fill{background:var(--blue);border-radius:6px;width:100%;min-height:4px;transition:height .4s}.progress-bar-value{color:var(--ink);min-height:1em;font-size:.72rem;font-weight:900}.progress-bar-label{color:var(--muted);font-size:.72rem;font-weight:800}.progress-alltime-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;display:grid}.progress-alltime-card{gap:6px;padding:18px;display:grid}.progress-alltime-value{color:var(--ink);margin:0;font-size:2.2rem;font-weight:900;line-height:1}.history-card{gap:16px;padding:18px;display:grid}.history-card-header{align-items:flex-start;gap:16px;display:flex}.history-thumbnail{border:1px solid var(--line);object-fit:cover;border-radius:10px;flex-shrink:0;width:80px;height:56px}.history-card-meta{flex:1 1 0;min-width:0}.history-scene{color:var(--ink);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 4px;font-size:.95rem;line-height:1.4;display:-webkit-box;overflow:hidden}.history-stats{color:var(--muted);margin:0 0 4px;font-size:.82rem;font-weight:700}.history-date{color:var(--muted);font-size:.78rem}.history-card-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.history-card-body{border-top:1px solid var(--line);gap:16px;padding-top:16px;display:grid}.history-section-title{color:var(--ink);margin:0;font-size:.95rem}.history-vocab-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.history-vocab-item{border:1px solid var(--line);background:var(--panel-strong);border-radius:12px;padding:10px 12px}.history-vocab-english{color:var(--muted);margin:4px 0 0;font-size:.85rem}.history-exchange{gap:10px;display:grid}.history-exchange-title{color:var(--ink);margin:0;font-size:.92rem;font-weight:800}@media (max-width:680px){.nav-hamburger{display:flex}.app-nav{flex-wrap:wrap;gap:0;padding:12px 14px;position:relative}.brand-link{flex:1}.nav-links{flex-direction:column;gap:4px;width:100%;margin-top:12px;display:none}.nav-links.nav-links-open{display:flex}.nav-link{border-radius:12px;justify-content:flex-start;width:100%;padding:12px 14px;font-size:1rem}.vocab-filter-row{flex-direction:column;align-items:stretch}.vocab-search-input{flex:none;width:100%}.history-card-header{flex-direction:column}.history-thumbnail{width:100%;height:120px}.history-card-actions{flex-flow:wrap;align-items:center}.kana-cell{width:58px;min-height:58px;padding:8px 4px}.kana-char{font-size:1.2rem}.progress-stat-grid{grid-template-columns:repeat(2,1fr)}.kana-quiz-controls{flex-direction:column}.practice-actions{flex-wrap:wrap}.exchange-header-actions{flex-direction:row;align-items:center}}
