.shell{max-width:960px;margin:0 auto;padding:0 1.25rem 3rem}.topbar{z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#f6f7f9eb;margin:0 -1.25rem 1.5rem;padding:.85rem 1.25rem;position:sticky;top:0}.topbar-inner{flex-wrap:wrap;align-items:center;gap:1rem;max-width:960px;margin:0 auto;display:flex}.brand{letter-spacing:-.02em;color:var(--text);font-size:1.05rem;font-weight:700;text-decoration:none}.brand:hover{color:var(--accent);text-decoration:none}.brand-sub{color:var(--muted);font-size:.78rem;font-weight:500}.search-wrap{flex:1;min-width:200px;max-width:320px}.search-wrap input{border:1px solid var(--border);background:var(--surface);border-radius:999px;outline:none;width:100%;padding:.55rem .85rem}.search-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.hero{margin-bottom:1.75rem}.hero h1{letter-spacing:-.03em;margin:0 0 .35rem;font-size:1.65rem}.hero p{color:var(--muted);margin:0;font-size:.95rem}.day-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.85rem;display:grid}.day-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);color:inherit;padding:1rem 1rem .9rem;text-decoration:none;transition:border-color .15s,transform .12s;display:block}.day-card:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-2px)}.day-card-num{color:var(--accent);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.day-card h2{margin:.25rem 0 .2rem;font-size:1rem}.day-card-meta{color:var(--muted);font-size:.8rem;line-height:1.35}.day-card.review{background:linear-gradient(135deg,#fafbfc 0%,#f0fdfa 100%)}.breadcrumb{color:var(--muted);margin-bottom:1rem;font-size:.85rem}.breadcrumb a{font-weight:500}.day-head{margin-bottom:1.25rem}.day-head h1{margin:0 0 .35rem;font-size:1.45rem}.day-head p{color:var(--muted);margin:0}.word-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;display:grid}.word-chip{background:var(--surface);border:1px solid var(--border);color:inherit;border-radius:10px;flex-direction:column;align-items:stretch;gap:.3rem;padding:.55rem .75rem;font-size:.92rem;text-decoration:none;display:flex}.word-chip-main{flex-direction:column;align-items:flex-start;gap:.35rem;width:100%;display:flex}.word-chip-ipa-wrap{border-top:1px dashed var(--border);flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;width:100%;padding:.2rem 0 0;display:flex}.word-chip-ipa-label{color:var(--accent);letter-spacing:.02em;font-size:.68rem;font-weight:600}.word-chip-ipa{font-family:var(--ipa-font);color:#334155;letter-spacing:.03em;font-size:.88rem;font-weight:600}.word-chip:hover{border-color:var(--accent);background:var(--accent-soft);text-decoration:none}.word-chip small{color:var(--muted);font-size:.75rem}.word-detail-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);box-shadow:var(--shadow);padding:1.75rem 1.5rem 1.5rem}.word-title-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem 1rem;margin-bottom:.75rem;display:flex}.word-title-block{flex:1;min-width:min(100%,12rem)}.word-title{letter-spacing:-.03em;color:#0f172a;margin:0;font-family:DM Sans,Noto Sans SC,sans-serif;font-size:clamp(2.2rem,8vw,3rem);font-weight:700}.word-ipa-block{border:1px solid var(--border);background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-radius:10px;max-width:100%;margin:.5rem 0 0;padding:.65rem .85rem}.ipa-label{color:var(--accent);letter-spacing:.06em;text-transform:uppercase;font-size:.72rem;font-weight:700}.word-ipa{color:#1e293b;font-size:1.25rem;font-weight:600;font-family:var(--ipa-font);letter-spacing:.04em;margin:.25rem 0 0}.word-ipa-missing{margin:.35rem 0 0}.search-hit-ipa-line{flex-wrap:wrap;align-items:baseline;gap:.35rem;margin-left:.35rem;display:inline-flex}.search-hit-ipa-label{color:var(--accent);font-size:.72rem;font-weight:600}.search-hit-ipa{font-family:var(--ipa-font);color:#334155;font-size:.88rem;font-weight:600}.word-speak-actions{flex-wrap:wrap;align-items:center;gap:.5rem .75rem;display:flex}.auto-speak-chk{font-size:.85rem}.word-gloss{margin:0 0 1.25rem;font-size:1.1rem;line-height:1.65}.word-gloss-en{color:#334155;border-left:3px solid var(--accent);background:#f1f5f9;border-radius:10px;margin:-.5rem 0 1.25rem;padding:.65rem .85rem;font-family:DM Sans,Noto Sans SC,sans-serif;font-size:.98rem;line-height:1.6}.word-extensions{background:linear-gradient(135deg,#fefce8 0%,#fffbeb 100%);border:1px solid #fde68a;border-radius:12px;margin:0 0 1.25rem;padding:.75rem .9rem}.word-extensions-title{text-transform:uppercase;letter-spacing:.06em;color:#a16207;margin-bottom:.45rem;font-size:.72rem;font-weight:700}.word-extensions-body{white-space:pre-wrap;color:#422006;margin:0;font-family:Noto Sans SC,DM Sans,sans-serif;font-size:.9rem;line-height:1.65}.colloc-block{background:var(--accent-soft);border-radius:var(--radius);border:1px solid #0f766e2e;padding:1rem 1.1rem}.colloc-block h3{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.colloc-block p{white-space:pre-wrap;margin:0;font-size:.95rem}.nav-row{border-top:1px solid var(--border);flex-wrap:wrap;gap:.65rem;margin-top:1.5rem;padding-top:1.25rem;display:flex}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;justify-content:center;align-items:center;padding:.55rem 1.1rem;font-size:.9rem;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{color:#fff;filter:brightness(1.05)}.search-dropdown{background:var(--surface);border:1px solid var(--border);width:min(320px,100vw - 2.5rem);max-height:280px;box-shadow:var(--shadow);z-index:20;border-radius:12px;margin-top:.35rem;position:absolute;overflow:auto}.search-dropdown button{text-align:left;border:none;border-bottom:1px solid var(--border);background:0 0;width:100%;padding:.65rem .85rem;display:block}.search-dropdown button:last-child{border-bottom:none}.search-dropdown button:hover{background:var(--accent-soft)}.search-wrap{position:relative}.muted{color:var(--muted);font-size:.9rem}.empty-state{text-align:center;color:var(--muted);padding:2rem}.day-actions{margin-bottom:1rem}.dictation-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.dictation-title{margin:0;font-size:1.35rem}.dictation-sub{color:var(--muted);margin:.25rem 0 0;font-size:.9rem}.dictation-toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.dictation-badge{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:.2rem .55rem;font-size:.75rem;font-weight:600}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{border-color:var(--border)}.dictation-progress-wrap{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.dictation-progress-bar{background:var(--border);border-radius:999px;flex:1;height:6px;overflow:hidden}.dictation-progress-fill{background:linear-gradient(90deg,#0d9488,#14b8a6);border-radius:999px;height:100%;transition:width .2s}.dictation-progress-text{color:var(--muted);text-align:right;min-width:3rem;font-size:.85rem;font-weight:600}.dictation-controls-top{flex-wrap:wrap;align-items:center;gap:1rem 1.25rem;margin-bottom:1.25rem;display:flex}.chk{cursor:pointer;align-items:center;gap:.4rem;font-size:.88rem;display:inline-flex}.chk.block{margin-bottom:.75rem;display:flex}.seg{border:1px solid var(--border);background:var(--surface);border-radius:10px;display:inline-flex;overflow:hidden}.seg-btn{color:var(--muted);background:0 0;border:none;padding:.4rem .85rem;font-size:.85rem}.seg-btn.on{color:#fff;background:#1e293b}.dictation-layout{grid-template-columns:220px 1fr;align-items:start;gap:1.25rem;display:grid}.dictation-layout.immersive{grid-template-columns:1fr}.dictation-side{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);max-height:calc(100vh - 6rem);padding:.65rem 0;position:sticky;top:5.5rem;overflow:auto}.dictation-side-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:0 .75rem .5rem;font-size:.75rem;font-weight:700}.dictation-side-list{margin:0;padding:0;list-style:none}.side-link{text-align:left;cursor:pointer;background:0 0;border:none;border-left:3px solid #0000;flex-direction:column;align-items:flex-start;width:100%;padding:.45rem .75rem;display:flex}.side-link:hover{background:var(--bg)}.side-link.active{background:var(--accent-soft);border-left-color:var(--accent)}.side-lemma{font-family:DM Sans,sans-serif;font-weight:600}.side-ipa-row{flex-wrap:wrap;align-items:baseline;gap:.3rem .45rem;margin-top:.15rem;display:flex}.side-ipa-tag{color:var(--accent);letter-spacing:.03em;font-size:.62rem;font-weight:700}.side-ipa{font-family:var(--ipa-font);color:#0f172a;font-size:.75rem;font-weight:700;line-height:1.3}.side-ipa-missing,.side-gloss{color:var(--muted);font-size:.72rem}.dictation-main{border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);background:var(--surface);box-shadow:var(--shadow);padding:1.25rem 1.25rem 1.5rem}.dictation-row{grid-template-columns:auto 1fr 1fr;align-items:start;gap:1rem;display:grid}@media (width<=820px){.dictation-layout{grid-template-columns:1fr}.dictation-side{max-height:200px;position:static}.dictation-row{grid-template-columns:1fr}.dictation-num{display:none}}.dictation-num{color:var(--muted);padding-top:.5rem;font-size:1.25rem;font-weight:700}.dictation-def{background:#eef1f6;border-radius:12px;min-height:3.5rem;padding:0;font-size:.95rem;line-height:1.55;overflow:hidden}.dictation-def-ipa{background:#ffffffb8;border-bottom:1px solid #94a3b859;flex-wrap:wrap;align-items:baseline;gap:.45rem .65rem;padding:.65rem 1rem;display:flex}.dictation-def-ipa-missing{font-size:.82rem}.dictation-def-body{white-space:pre-wrap;padding:.85rem 1rem}.dictation-input-wrap{flex-direction:column;gap:.5rem;display:flex}.dictation-ipa-label{color:var(--accent);letter-spacing:.04em;flex-shrink:0;font-size:.68rem;font-weight:700}.dictation-ipa-line{font-family:var(--ipa-font);color:#0f172a;letter-spacing:.03em;font-size:1.08rem;font-weight:700}.dictation-reveal-en{color:#0f172a;font-family:DM Sans,sans-serif;font-size:1.35rem;font-weight:700}.dictation-input{border:2px solid #86efac;border-radius:12px;outline:none;width:100%;padding:.75rem 1rem;font-size:1.1rem}.dictation-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dictation-input.ok{border-color:#22c55e}.dictation-input.bad{border-color:#ef4444}.dictation-inline-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.dictation-result.ok{color:#15803d;font-weight:600}.dictation-result.bad{color:#b91c1c;font-size:.88rem}.dictation-ai-box{border:1px dashed var(--border);background:#f8fafc;border-radius:12px;margin-top:1rem;padding:.85rem 1rem}.dictation-ai-pre{white-space:pre-wrap;margin:0;font-family:inherit;font-size:.9rem}.dictation-ai-err{color:#b91c1c;margin:0;font-size:.88rem}.dictation-footer-controls{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:center;align-items:center;gap:.65rem;margin-top:1.5rem;padding-top:1.25rem;display:flex}.btn-play{border-color:var(--accent);color:var(--accent);padding:.55rem 1.35rem;font-weight:600}.dict-nav{min-width:2.5rem;padding-left:.5rem;padding-right:.5rem;font-size:1.25rem;line-height:1}.dictation-hint{text-align:center;margin:1rem 0 0;font-size:.82rem}.modal-backdrop{z-index:100;background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:420px;max-height:min(80vh,520px);padding:1.25rem;overflow:auto;box-shadow:0 24px 60px #0003}.modal.modal-sm{max-width:360px}.modal h2{margin:0 0 .75rem;font-size:1.1rem}.modal-list{margin:0 0 1rem;padding:0;list-style:none}.modal-row{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;flex-direction:column;align-items:flex-start;width:100%;padding:.55rem .25rem;display:flex}.modal-row:hover{background:var(--bg)}.modal-ipa{font-family:var(--ipa-font);color:#334155;font-size:.88rem;font-weight:600}.muted.small{font-size:.8rem}:root{--bg:#f6f7f9;--surface:#fff;--text:#1a1d26;--muted:#5c6473;--accent:#0f766e;--accent-soft:#0f766e1a;--border:#e2e5eb;--radius:14px;--shadow:0 8px 30px #161e2d0f;--ipa-font:"Noto Sans", "Noto Sans SC", "Segoe UI", system-ui, sans-serif;color:var(--text);background:var(--bg);font-family:Noto Sans SC,DM Sans,system-ui,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-height:100vh;margin:0}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}input{font:inherit}
