@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap";:root{--ink: #0b1529;--ink-soft: #3a5174;--surface: #f8fbff;--surface-alt: #e7f0fb;--accent: #3b82f6;--accent-strong: #2563eb;--accent-warm: #60a5fa;--accent-soft: #8ec5ff;--shadow: rgba(12, 34, 69, .16);font-family:Nunito,Segoe UI,sans-serif;color:var(--ink);background:linear-gradient(160deg,#d7ebff,#eaf4ff 45%,#cfe4ff)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,rgba(255,255,255,.75),transparent 55%)}body:before,body:after{content:"";position:fixed;z-index:-1;width:420px;height:420px;border-radius:50%;filter:blur(0px);opacity:.35}body:before{top:-160px;right:-120px;background:radial-gradient(circle,rgba(59,130,246,.5),transparent 70%)}body:after{bottom:-200px;left:-140px;background:radial-gradient(circle,rgba(142,197,255,.55),transparent 70%)}.app{max-width:960px;margin:0 auto;padding:48px 24px}.app__header{margin-bottom:32px}.app__header h1{margin:0 0 8px;font-size:2.5rem}.translation-shell{display:flex;flex-direction:column;gap:18px}.translation-header h1{margin:0;font-size:2rem}.translation-stats{margin:4px 0 0;color:var(--ink-soft);font-weight:600}.translation-tabs{display:flex;flex-wrap:wrap;gap:10px}.translation-tab{border:none;border-radius:999px;padding:10px 16px;font-weight:700;color:var(--ink-soft);background:#2563eb1f;cursor:pointer}.translation-tab.active{color:#fff;background:linear-gradient(120deg,#2563eb,#60a5fa);box-shadow:0 12px 20px #2563eb38}.translation-tab__count{margin-left:6px;background:#ffffffb3;color:var(--accent-strong);padding:2px 8px;border-radius:999px;font-size:.75rem}.translation-loading,.translation-empty,.translation-error{margin:0;font-weight:600;color:var(--ink-soft)}.translation-error{color:#b91c1c}.translation-card{border-radius:20px;padding:18px;background:#fff;box-shadow:0 18px 32px #2563eb26;display:flex;flex-direction:column;gap:14px}.translation-card__header{display:flex;justify-content:space-between;align-items:center}.translation-card__header-actions{display:flex;align-items:center;gap:8px}.translation-card__audio{border:none;border-radius:999px;padding:6px 12px;font-weight:700;color:#fff;background:linear-gradient(120deg,#0ea5e9,#38bdf8);cursor:pointer}.translation-card__explain{border:none;border-radius:999px;padding:8px 14px;font-weight:700;color:#fff;background:linear-gradient(120deg,#2563eb,#60a5fa);cursor:pointer}.translation-card__explain:disabled{opacity:.6;cursor:not-allowed}.translation-card__title{margin:0;font-weight:800}.translation-card__subtitle{margin:4px 0 0;color:var(--ink-soft);font-size:.85rem}.translation-card__journal{margin:4px 0 0;color:var(--ink-soft);font-size:.75rem;opacity:.8;font-style:italic;line-height:1.3}.translation-card__star{border:none;border-radius:999px;padding:6px 12px;font-weight:700;color:var(--accent-strong);background:#2563eb1f;cursor:pointer}.translation-card__prompt{font-size:1.1rem;font-weight:700;color:var(--ink);background:var(--surface-alt);padding:12px 14px;border-radius:14px}.translation-card__context{display:grid;gap:10px;padding:10px 12px;border-radius:12px;background:#2563eb14}.translation-card__context-block{display:flex;flex-direction:column;gap:6px}.translation-card__context-title{margin:0;font-size:.8rem;font-weight:800;color:var(--ink-soft)}.translation-card__context-list{margin:0;padding-left:18px;display:grid;gap:4px}.translation-card__context-item{color:var(--ink);font-size:.86rem;line-height:1.35}.translation-card__label{font-size:.85rem;font-weight:700;color:var(--ink-soft)}.translation-card__input{border:1px solid rgba(37,99,235,.2);border-radius:14px;padding:10px 12px;font-family:inherit;font-size:.95rem;resize:vertical}.translation-card__answer{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:14px;background:#8ec5ff33;color:var(--ink)}.translation-card__answer strong{font-size:1rem}.translation-card__explanation{border-radius:14px;background:#3b82f614;padding:12px 14px;color:var(--ink);line-height:1.5}.tasks-shell{display:flex;flex-direction:column;gap:20px}.tasks-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.tasks-header h1{margin:0;font-size:2rem}.tasks-date{margin:6px 0 0;color:var(--ink-soft);font-weight:600}.tasks-summary{padding:8px 14px;border-radius:999px;background:#2563eb1f;color:var(--accent-strong);font-weight:700}.tasks-loading,.tasks-empty,.tasks-error{margin:0;font-weight:600;color:var(--ink-soft)}.tasks-error{color:#b91c1c}.tasks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.tasks-card{border-radius:18px;padding:16px;background:#fff;box-shadow:0 16px 28px #2563eb1f;display:flex;flex-direction:column;gap:12px}.tasks-card.is-complete{box-shadow:0 18px 32px #10b9812e}.tasks-card__header{display:flex;align-items:center;justify-content:space-between;gap:10px}.tasks-card__label{margin:0;font-size:1rem;font-weight:800}.tasks-card__meta{display:flex;justify-content:space-between;color:var(--ink-soft);font-weight:600}.tasks-tag{padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700;color:var(--accent-strong);background:#3b82f61f}.tasks-tag.is-complete{color:#047857;background:#10b98126}.tasks-bar{height:8px;border-radius:999px;background:#3b82f61f;overflow:hidden}.tasks-bar__fill{height:100%;background:linear-gradient(120deg,#2563eb,#60a5fa);transition:width .3s ease}.translation-card__explanation h1,.translation-card__explanation h2,.translation-card__explanation h3{margin:0 0 8px;font-size:1rem}.translation-card__explanation ul{margin:6px 0 0 18px;padding:0}.translation-card__actions{display:flex;align-items:center;justify-content:flex-start;gap:12px}.translation-card__primary{border:none;border-radius:999px;padding:10px 18px;font-weight:700;color:#fff;background:linear-gradient(120deg,#2563eb,#60a5fa);cursor:pointer;box-shadow:0 12px 20px #2563eb40}.translation-card__ratings{display:flex;flex-wrap:wrap;gap:8px}.shadowing-card{gap:16px}.shadowing-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.shadowing-status{font-weight:700;color:var(--ink-soft)}.shadowing-recording{background:linear-gradient(120deg,#dc2626,#f97316);color:#fff}.shadowing-result{border-radius:14px;background:#3b82f614;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.shadowing-result__label{font-weight:700;color:var(--ink-soft)}.shadowing-result__text{font-weight:600}.shadowing-compare{display:flex;flex-wrap:wrap;gap:6px}.shadowing-token{padding:4px 8px;border-radius:999px;font-weight:700;font-size:.9rem}.shadowing-token--match{background:#22c55e33;color:#166534}.shadowing-token--mismatch{background:#ef44442e;color:#b91c1c}.translation-card__rating{border:none;border-radius:999px;padding:8px 14px;font-weight:700;color:var(--ink-soft);background:#2563eb1a;cursor:pointer}@media (max-width: 720px){.translation-card__actions{flex-direction:column;align-items:stretch}.translation-card__ratings{justify-content:space-between}}.card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 8px 24px #0f172a14}.text-error{color:#dc2626;font-weight:600}.app-shell{min-height:100vh;display:flex;flex-direction:column;gap:18px;padding:24px;width:min(1120px,100%);margin:0 auto;animation:appFadeIn .6s ease both}@keyframes appFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-radius:24px;background:#f8fcffd9;box-shadow:0 16px 32px #2563eb1f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-header__profile{display:flex;align-items:center;gap:12px}.app-header__avatar{width:44px;height:44px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#b6d7ff 45%,#6ea9ff);box-shadow:inset 0 0 0 2px #fffc}.app-header__text{display:flex;flex-direction:column;gap:2px}.app-header__title{font-size:1.2rem;font-weight:800;letter-spacing:.02em}.app-header__subtitle{font-size:.85rem;color:var(--ink-soft)}.app-header__actions{display:flex;align-items:center;gap:12px}.streak-widget{display:flex;align-items:center;gap:8px;background:#fff;padding:6px 12px;border-radius:999px;box-shadow:0 4px 12px #2563eb14;font-weight:700;color:#f97316;font-size:.95rem;cursor:help;transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.streak-widget:hover{transform:scale(1.05)}.streak-widget__icon{font-size:1.2rem;filter:drop-shadow(0 0 4px rgba(249,115,22,.4))}.streak-widget__count{line-height:1}.app-header__logout{border:none;border-radius:999px;padding:8px 16px;font-weight:700;background:#2563eb1f;color:var(--accent-strong);cursor:pointer}.app-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:12px 16px;border-radius:20px;background:#fffc;box-shadow:0 12px 24px #2563eb1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-control{display:flex;flex-direction:column;gap:6px;font-size:.8rem;color:var(--ink-soft)}.app-control label{font-weight:700}.app-control select{border:1px solid rgba(37,99,235,.2);border-radius:14px;padding:8px 12px;font-size:.95rem;font-family:inherit;background:#fff;color:var(--ink)}.app-control select:disabled{opacity:.6;cursor:not-allowed}.app-control__error{font-weight:600;color:#b91c1c}.app-main{flex:1;border-radius:26px;padding:20px;background:#f8fbffeb;box-shadow:0 24px 48px #2563eb1f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;padding:10px 12px;border-radius:20px;background:#ffffffd9;box-shadow:0 18px 36px #2563eb1f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-tab{border:none;border-radius:16px;padding:10px 14px;font-size:.95rem;font-weight:700;color:var(--ink-soft);background:#2563eb14;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.app-tab:hover{transform:translateY(-1px);box-shadow:0 8px 16px #2563eb29}.app-tab.active{color:#fff;background:linear-gradient(120deg,#2563eb,#60a5fa);box-shadow:0 14px 24px #2563eb47}@media (max-width: 900px){.app-shell,.app-main{padding:16px}}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:32px 20px}.auth-card{width:min(420px,100%);background:var(--surface);border-radius:24px;padding:28px;box-shadow:0 24px 50px var(--shadow);display:flex;flex-direction:column;gap:14px}.auth-kicker{letter-spacing:.2em;text-transform:uppercase;font-size:.75rem;margin:0;color:var(--accent-strong)}.auth-card h1{margin:0;font-size:clamp(1.8rem,3vw,2.4rem)}.auth-subtitle{margin:0;color:var(--ink-soft)}.auth-error{color:#b91c1c;font-weight:600;margin:0}.auth-success{color:#15803d;font-weight:600;margin:0}.auth-field{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--ink-soft)}.auth-field input{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:12px;font-size:1rem;font-family:inherit}.auth-submit{border:none;border-radius:999px;padding:12px 18px;font-weight:600;background:var(--accent-strong);color:#fff;cursor:pointer;box-shadow:0 12px 24px #0f766e4d}.auth-submit:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.auth-toggle{border:none;background:transparent;color:var(--accent-strong);cursor:pointer;font-weight:600}.auth-actions{display:flex;flex-direction:column;gap:8px}.chat-shell{max-width:920px;margin:0 auto;padding:calc(32px + env(safe-area-inset-top)) 20px calc(28px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:20px;min-height:100dvh}.characters-shell{max-width:980px;margin:0 auto;padding:calc(28px + env(safe-area-inset-top)) 20px calc(32px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:20px;min-height:100dvh}.characters-header{display:flex;align-items:flex-end;justify-content:space-between}.characters-kicker{letter-spacing:.22em;text-transform:uppercase;font-size:.75rem;font-weight:600;margin:0 0 12px;color:var(--accent-strong)}.characters-header h1{margin:0 0 8px;font-size:clamp(2rem,3vw,3rem)}.characters-subtitle{margin:0;color:var(--ink-soft)}.characters-error{color:#b91c1c;font-weight:600;margin:0}.characters-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:20px}.characters-panel{background:var(--surface);border-radius:24px;padding:20px;box-shadow:0 20px 40px var(--shadow);border:1px solid rgba(15,23,42,.06)}.characters-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.characters-list-header h2{margin:0}.characters-list-header span{color:var(--ink-soft);font-size:.9rem}.characters-list{display:flex;flex-direction:column;gap:16px;max-height:520px;overflow-y:auto;padding-right:6px}.characters-muted{color:var(--ink-soft);margin:0}.character-card{border-radius:20px;padding:16px;background:var(--surface-alt);display:flex;flex-direction:column;gap:12px}.character-card__header{display:flex;gap:12px;align-items:center}.character-card__avatar{width:48px;height:48px;border-radius:16px;background:#0f172a1a;display:grid;place-items:center;overflow:hidden;font-weight:700;color:var(--ink)}.character-card__avatar img{width:100%;height:100%;object-fit:cover}.character-card__meta{margin:0;color:var(--ink-soft);font-size:.85rem}.character-card__personality{margin:0}.character-card__appearance{margin:0;color:var(--ink-soft);font-size:.9rem}.character-card__footer{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}.character-card__tag{display:inline-flex;padding:4px 10px;border-radius:999px;background:#0f172a1a;font-size:.75rem;margin-right:6px}.character-card__actions{display:flex;gap:8px}.character-card__actions button{border:none;border-radius:999px;padding:6px 12px;font-size:.85rem;cursor:pointer;background:#e2e8f0;color:#0f172a}.character-card__actions button.danger{background:#fee2e2;color:#b91c1c}.character-form{display:flex;flex-direction:column;gap:16px}.character-form__header{display:flex;justify-content:space-between;align-items:center}.character-form__header h2{margin:0}.character-form__header .ghost{border:none;background:transparent;color:var(--accent-strong);cursor:pointer}.character-form__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.character-form__grid label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--ink-soft)}.character-form__grid label.full{grid-column:1 / -1}.character-form__avatar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.character-form__avatar-preview{width:72px;height:72px;border-radius:18px;background:#0f172a14;display:grid;place-items:center;overflow:hidden;font-weight:700;color:var(--ink)}.character-form__avatar-preview img{width:100%;height:100%;object-fit:cover}.character-form__avatar-actions{display:flex;flex-direction:column;gap:6px}.character-form__avatar-actions small{color:var(--ink-soft)}.character-form__grid input,.character-form__grid select,.character-form__grid textarea{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:10px 12px;font-size:.95rem;font-family:inherit}.character-form__divider{text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--ink-soft)}.character-form__actions{display:flex;justify-content:flex-end}.character-form__actions button{border:none;border-radius:999px;padding:10px 18px;font-weight:600;background:var(--accent-strong);color:#fff;cursor:pointer}@media (max-width: 900px){.characters-layout{grid-template-columns:1fr}.characters-list{max-height:none}}.chat-header{display:flex;justify-content:space-between;align-items:flex-end;gap:24px}.chat-header__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.chat-kicker{letter-spacing:.2em;text-transform:uppercase;font-size:.8rem;font-weight:600;margin:0 0 12px;color:var(--accent-strong)}.chat-header h1{margin:0 0 8px;font-size:clamp(2rem,3vw,3rem);color:var(--ink)}.chat-end-button{border:none;border-radius:999px;padding:10px 18px;font-weight:700;background:#0f172a14;color:var(--ink);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 10px 20px #0f172a1f}.chat-toggle-button{border:1px solid rgba(15,23,42,.12);border-radius:999px;padding:8px 14px;font-weight:600;background:#fffc;color:var(--ink-soft);cursor:pointer}.chat-toggle-button:hover{color:var(--ink);border-color:#0f172a33}.chat-end-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 24px #0f172a29}.chat-end-button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none}.chat-subtitle{margin:0;color:var(--ink-soft);font-size:1.05rem}.chat-notice{color:#0f766e;font-weight:600;margin:0 0 12px}.chat-window{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:24px;padding:20px;box-shadow:0 20px 40px var(--shadow);border:1px solid rgba(15,23,42,.06);min-height:360px;display:flex;flex-direction:column;flex:1;min-height:0}.chat-error{color:#b91c1c;font-weight:600;margin:0 0 12px}.chat-messages{display:flex;flex-direction:column;gap:16px;max-height:520px;overflow-y:auto;padding-right:8px;flex:1}.chat-bubble{max-width:78%;padding:14px 16px 12px;border-radius:20px;display:flex;flex-direction:column;gap:8px;line-height:1.5;box-shadow:0 12px 24px #0f172a0f;animation:bubble-rise .35s ease-out}.chat-bubble--assistant{align-self:flex-start;background:var(--surface-alt);color:var(--ink)}.chat-bubble--user{align-self:flex-end;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-warm) 120%);color:#fff}.chat-bubble__text{margin:0;white-space:pre-wrap}.chat-bubble__header{display:flex;align-items:center;gap:10px}.chat-bubble__avatar{width:32px;height:32px;border-radius:999px;background:#0f172a1a;display:grid;place-items:center;overflow:hidden;font-weight:700;font-size:.85rem;color:var(--ink);flex-shrink:0}.chat-bubble__avatar img{width:100%;height:100%;object-fit:cover}.chat-bubble__name{margin:0;font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;opacity:.7}.chat-bubble__translation{margin:0;font-size:.95rem;opacity:.8}.chat-bubble__audio-actions{display:flex;gap:10px}.chat-bubble__audio-button{border:none;background:#0f172a14;color:var(--ink);padding:6px 12px;border-radius:999px;font-weight:600;cursor:pointer}.chat-bubble__audio-button:hover{background:#0f172a29}.chat-bubble__collect-button{border:none;background:#0ea5a41f;color:var(--accent-strong);padding:6px 12px;border-radius:999px;font-weight:600;cursor:pointer;align-self:flex-start;transition:transform .2s ease,box-shadow .2s ease}.chat-bubble__collect-button:hover{transform:translateY(-1px);box-shadow:0 10px 18px #0f766e2e}.chat-bubble__edit-field{border:1px solid rgba(15,23,42,.12);border-radius:12px;padding:10px 12px;font-family:inherit;font-size:.95rem;resize:vertical;background:#ffffffe6}.chat-bubble__actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;align-self:flex-start;padding:4px 6px;border-radius:999px;background:#ffffff80}.chat-bubble__icon-button{border:none;border-radius:999px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;background:#0f172a14;color:var(--ink);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.chat-bubble__icon-button svg{width:18px;height:18px}.chat-bubble__icon-button:hover{background:#0f172a29;transform:translateY(-1px);box-shadow:0 8px 16px #0f172a1f}.chat-bubble--user .chat-bubble__icon-button{background:#ffffff2e;color:#fff}.chat-bubble--user .chat-bubble__icon-button:hover{background:#ffffff47;box-shadow:0 8px 16px #0f172a2e}.chat-bubble--user .chat-bubble__actions{background:#ffffff24}.chat-bubble__meta{font-size:.75rem;opacity:.7;align-self:flex-end}.chat-input{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:stretch;position:sticky;bottom:calc(12px + env(safe-area-inset-bottom))}.chat-input__field{border:none;border-radius:20px;padding:16px 18px;font-size:1rem;font-family:inherit;resize:none;box-shadow:inset 0 0 0 1px #0f172a1f;background:#ffffffe6}.chat-characters{margin:18px 0}.chat-characters__panel{background:#ffffffb3;border:1px solid rgba(15,23,42,.06);border-radius:18px;padding:16px;box-shadow:0 12px 24px #0f172a0f}.chat-characters__panel h2{margin:0 0 10px;font-size:1rem;color:var(--ink)}.chat-characters__muted{margin:0;color:var(--ink-soft)}.chat-characters__list{list-style:none;padding:0 6px 0 0;margin:0;display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.chat-characters__item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:14px;background:#0f172a0a}.chat-characters__meta{min-width:0;display:flex;align-items:center;gap:12px}.chat-characters__drag{border:none;background:#0f172a14;color:var(--ink-soft);width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;cursor:grab;flex-shrink:0}.chat-characters__drag:active{cursor:grabbing}.chat-characters__drag svg{width:18px;height:18px}.chat-characters__text{min-width:0}.chat-characters__name{margin:0;font-weight:700;color:var(--ink)}.chat-characters__desc{margin:4px 0 0;color:var(--ink-soft);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:520px}.chat-characters__button{border:none;border-radius:999px;padding:8px 14px;font-weight:700;background:#0f172a14;color:var(--ink-soft);cursor:pointer;flex-shrink:0}.chat-story{margin:0 0 18px}.chat-story__panel{background:#ffffffbf;border:1px solid rgba(15,23,42,.06);border-radius:18px;padding:16px;box-shadow:0 12px 24px #0f172a0f;display:flex;flex-direction:column;gap:12px}.chat-story__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-story__header h2{margin:0;font-size:1rem}.chat-story__header select{border:1px solid rgba(15,23,42,.12);border-radius:999px;padding:6px 12px;font-size:.9rem;font-family:inherit;background:#fff;color:var(--ink-soft)}.chat-story__content{display:flex;flex-direction:column;gap:8px}.chat-story__label{margin:0;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}.chat-story__text{margin:0;color:var(--ink);white-space:pre-wrap}.chat-story__muted{margin:0;color:var(--ink-soft)}.chat-story__error{margin:0;color:#b91c1c;font-weight:600}.chat-context{margin:0 0 18px}.chat-context__panel{background:#ffffffbf;border:1px solid rgba(15,23,42,.06);border-radius:18px;padding:16px;box-shadow:0 12px 24px #0f172a0f;display:flex;flex-direction:column;gap:12px}.chat-context__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-context__header h2{margin:0;font-size:1rem}.chat-context__button{border:1px solid rgba(15,23,42,.12);border-radius:999px;padding:6px 12px;font-size:.9rem;font-weight:600;background:#fff;color:var(--ink-soft);cursor:pointer}.chat-context__button:disabled{opacity:.6;cursor:not-allowed}.chat-context__field{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:10px 12px;font-size:.95rem;font-family:inherit;resize:vertical;background:#ffffffe6}.chat-context__hint{margin:0;font-size:.85rem;color:var(--ink-soft)}.chat-input__field:focus{outline:none;box-shadow:inset 0 0 0 2px #0ea5a473}.chat-input__button{border:none;border-radius:20px;padding:0 26px;font-size:1rem;font-weight:600;background:#0f766e;color:#fff;cursor:pointer;box-shadow:0 12px 24px #0f766e59;transition:transform .2s ease,box-shadow .2s ease}.chat-input__button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 16px 28px #0f766e66}.chat-input__button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none}.journal-shell{display:flex;flex-direction:column;gap:24px;padding:36px 40px 48px}.journal-header{display:flex;justify-content:space-between;align-items:center;gap:24px}.journal-story-filter{display:flex;flex-direction:column;gap:6px;font-size:.75rem;color:var(--ink-soft);min-width:200px}.journal-story-filter label{font-weight:600}.journal-story-filter select{border:1px solid rgba(15,23,42,.12);border-radius:999px;padding:6px 12px;font-size:.9rem;font-family:inherit;background:#fff;color:var(--ink-soft)}.journal-story-filter__error{color:#b91c1c;font-weight:600}.journal-kicker{margin:0 0 6px;text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:var(--ink-soft);font-weight:700}.journal-subtitle{margin:0;color:var(--ink-soft)}.journal-error{color:#b91c1c;font-weight:600;margin:0}.journal-content{display:grid;grid-template-columns:minmax(240px,320px) 1fr;gap:24px}.journal-list{background:#ffffffb3;border:1px solid rgba(15,23,42,.06);border-radius:18px;padding:16px;box-shadow:0 12px 24px #0f172a0f}.journal-list h2,.journal-detail h2{margin:0;font-size:1rem;color:var(--ink)}.journal-detail__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.journal-detail__download{border:none;background:var(--accent);color:#fff;padding:6px 14px;border-radius:999px;font-size:.85rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.journal-detail__download:hover{background:var(--accent-strong);transform:translateY(-1px)}.journal-detail__download:active{transform:translateY(0)}.journal-muted{margin:0;color:var(--ink-soft)}.journal-list__items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.journal-card{border:none;text-align:left;width:100%;padding:12px;border-radius:14px;background:#0f172a0a;cursor:pointer;display:flex;flex-direction:column;gap:8px}.journal-card.active{background:#0ea5a41f}.journal-card__summary{margin:0;font-weight:600;color:var(--ink)}.journal-card__meta{font-size:.75rem;color:var(--ink-soft)}.journal-detail{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:18px;padding:16px;box-shadow:0 20px 40px var(--shadow);border:1px solid rgba(15,23,42,.06)}.journal-messages{display:flex;flex-direction:column;gap:12px;max-height:520px;overflow-y:auto}.journal-message{background:#0f172a0a;border-radius:14px;padding:12px 14px}.journal-message__header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.journal-message__name{font-weight:700;color:var(--ink)}.journal-message__time{font-size:.75rem;color:var(--ink-soft)}.journal-message__text{margin:0;white-space:pre-wrap;color:var(--ink)}.journal-message__audio-actions{display:flex;gap:10px;margin-top:6px}.journal-message__audio-button{border:none;background:#0f172a14;color:var(--ink);padding:6px 12px;border-radius:999px;font-weight:600;cursor:pointer}.journal-message__audio-button:hover{background:#0f172a29}.journal-message__translate-toggle{border:none;background:transparent;padding:0;font-size:.85rem;font-weight:600;color:var(--ink-soft);cursor:pointer;margin-top:6px}.journal-message__translate-toggle:hover{color:var(--ink)}.journal-message__translation{margin:6px 0 0;font-size:.95rem;opacity:.8;color:var(--ink)}.story-shell{max-width:1040px;margin:0 auto;padding:calc(28px + env(safe-area-inset-top)) 20px calc(32px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:20px;min-height:100dvh}.story-header h1{margin:0 0 8px;font-size:clamp(2rem,3vw,3rem)}.story-kicker{letter-spacing:.22em;text-transform:uppercase;font-size:.75rem;font-weight:600;margin:0 0 12px;color:var(--accent-strong)}.story-subtitle{margin:0;color:var(--ink-soft)}.story-error{color:#b91c1c;font-weight:600;margin:0}.story-notice{color:#0f766e;font-weight:600;margin:0}.story-layout{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:20px}.story-panel{background:var(--surface);border-radius:24px;padding:20px;box-shadow:0 20px 40px var(--shadow);border:1px solid rgba(15,23,42,.06);display:flex;flex-direction:column;gap:16px}.story-panel__header{display:flex;justify-content:space-between;align-items:center;gap:12px}.story-panel__header span{color:var(--ink-soft);font-size:.9rem}.story-form,.story-edit{display:flex;flex-direction:column;gap:12px}.story-form label,.story-edit label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--ink-soft)}.story-form input,.story-form textarea,.story-edit input,.story-edit textarea{border:1px solid rgba(15,23,42,.12);border-radius:14px;padding:10px 12px;font-size:.95rem;font-family:inherit}.story-form button,.story-card__actions button{border:none;border-radius:999px;padding:10px 18px;font-weight:600;background:var(--accent-strong);color:#fff;cursor:pointer}.story-card__actions button.ghost{background:transparent;color:var(--accent-strong)}.story-card__actions button.danger{background:#fee2e2;color:#b91c1c}.story-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;max-height:540px;overflow-y:auto}.story-card{border-radius:18px;padding:16px;background:var(--surface-alt);display:flex;flex-direction:column;gap:12px}.story-card h3{margin:0 0 6px}.story-card__description,.story-card__progress{margin:0;color:var(--ink-soft);white-space:pre-wrap}.story-card__actions{display:flex;gap:10px;flex-wrap:wrap}.story-muted{margin:0;color:var(--ink-soft)}.vocab-shell{max-width:980px;margin:0 auto;padding:calc(28px + env(safe-area-inset-top)) 20px calc(32px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:20px;min-height:100dvh}.vocab-header{display:flex;flex-direction:column;gap:10px}.vocab-header h1{margin:0;font-size:clamp(2rem,3vw,2.6rem)}.vocab-stats{margin:0;color:var(--ink-soft);font-weight:600}.vocab-add-button{align-self:flex-start;border:none;border-radius:999px;padding:10px 18px;font-weight:700;background:linear-gradient(120deg,var(--accent-strong),var(--accent));color:#fff;cursor:pointer;box-shadow:0 16px 26px #0f766e40}.vocab-add-form{background:#fffc;border:1px solid rgba(15,23,42,.06);border-radius:18px;padding:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;box-shadow:0 16px 32px #0f172a14}.vocab-add-form input,.vocab-add-form select{border:1px solid rgba(15,23,42,.12);border-radius:12px;padding:10px 12px;font-size:.95rem;font-family:inherit;background:#fff}.vocab-add-form button{grid-column:1 / -1;border:none;border-radius:12px;padding:10px 14px;font-weight:700;background:var(--accent-strong);color:#fff;cursor:pointer}.vocab-tabs{display:flex;flex-wrap:wrap;gap:10px}.vocab-tab{border:1px solid rgba(15,23,42,.08);background:#fffc;color:var(--ink-soft);border-radius:999px;padding:8px 14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.vocab-tab.active{background:var(--accent-strong);color:#fff;box-shadow:0 10px 22px #0f766e4d}.vocab-tab__count{background:#0f172a1f;color:inherit;border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:700}.vocab-tab.active .vocab-tab__count{background:#fff3}.vocab-error{color:#b91c1c;font-weight:600;margin:0}.vocab-loading,.vocab-empty{margin:0;color:var(--ink-soft)}.vocab-search{display:flex;align-items:center;gap:8px;background:#ffffffd9;border:1px solid rgba(15,23,42,.08);border-radius:12px;padding:8px 12px;box-shadow:0 12px 24px #0f172a0f}.vocab-search__input{border:none;flex:1;font-size:.95rem;font-family:inherit;background:transparent;outline:none}.vocab-search__clear{border:none;background:#0f172a14;border-radius:999px;padding:4px 8px;cursor:pointer;font-weight:700}.vocab-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.vocab-item{background:#ffffffe6;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:12px 14px;box-shadow:0 18px 32px #0f172a14}.vocab-item--due{border-color:#f9731666;box-shadow:0 18px 36px #f9731626}.vocab-item__row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:12px;align-items:center;cursor:pointer}.vocab-item__korean{font-weight:700;font-size:1.05rem}.vocab-item__vietnamese{color:var(--ink-soft)}.vocab-item__actions{display:flex;gap:8px}.vocab-item__star,.vocab-item__delete{border:none;border-radius:999px;padding:6px 10px;font-weight:700;cursor:pointer}.vocab-item__star{background:#0f172a14;color:var(--ink)}.vocab-item__delete{background:#ef44441f;color:#b91c1c}.vocab-item__details{margin-top:12px;display:grid;gap:12px}.vocab-item__review-info p{margin:0;color:var(--ink-soft);font-size:.9rem}.vocab-item__rating-buttons{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.vocab-item__rating-buttons button{border:none;border-radius:999px;padding:6px 12px;font-weight:700;cursor:pointer;background:#0f172a14}.vocab-item__memory textarea{width:100%;border:1px solid rgba(15,23,42,.12);border-radius:12px;padding:10px 12px;font-family:inherit;font-size:.95rem;resize:vertical}.vocab-item__memory button{margin-top:8px;border:none;border-radius:999px;padding:8px 14px;font-weight:700;background:var(--accent-strong);color:#fff;cursor:pointer}.vocab-flashcard{background:#fffffff2;border-radius:24px;padding:24px;box-shadow:0 24px 50px #0f172a1a;border:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:16px;align-items:center}.vocab-flashcard__progress{font-weight:700;color:var(--ink-soft)}.vocab-flashcard__card{width:min(520px,100%);min-height:240px;border-radius:20px;background:linear-gradient(160deg,#0ea5a41f,#f973161f);border:1px solid rgba(15,23,42,.08);padding:20px;display:flex;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.vocab-flashcard__card:hover{transform:translateY(-2px);box-shadow:0 16px 28px #0f172a1f}.vocab-flashcard__text{margin:0;font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700}.vocab-flashcard__text--answer{color:var(--accent-strong)}.vocab-flashcard__hint{margin:12px 0 0;font-size:.9rem;color:var(--ink-soft)}.vocab-flashcard__memory{margin-top:12px;font-size:.95rem;color:var(--ink-soft)}.vocab-flashcard__actions{display:flex;gap:12px}.vocab-flashcard__star{border:none;border-radius:999px;padding:8px 14px;font-weight:700;background:#0f172a14;cursor:pointer}.vocab-flashcard__ratings{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:min(520px,100%)}.rating-btn{border:none;border-radius:14px;padding:10px 12px;font-weight:700;cursor:pointer}.rating-btn--again{background:#fee2e2;color:#b91c1c}.rating-btn--hard{background:#ffedd5;color:#c2410c}.rating-btn--good{background:#d1fae5;color:#047857}.rating-btn--easy{background:#e0f2fe;color:#0369a1}.vocab-collect-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:grid;place-items:center;z-index:40;padding:20px}.vocab-collect-popup{width:min(520px,100%);background:#fff;border-radius:22px;padding:20px;box-shadow:0 24px 50px #0f172a33;border:1px solid rgba(15,23,42,.08);display:flex;flex-direction:column;gap:14px}.vocab-collect-popup__header{display:flex;align-items:center;justify-content:space-between}.vocab-collect-popup__header h3{margin:0}.vocab-collect-popup__close{border:none;background:#0f172a14;border-radius:999px;padding:6px 10px;cursor:pointer}.vocab-collect-popup__field{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--ink-soft)}.vocab-collect-popup__field input,.vocab-collect-popup__field textarea,.vocab-collect-popup__field select{border:1px solid rgba(15,23,42,.12);border-radius:12px;padding:10px 12px;font-size:.95rem;font-family:inherit}.vocab-collect-popup__actions{display:flex;justify-content:flex-end;gap:10px}.vocab-collect-popup__actions button{border:none;border-radius:999px;padding:8px 14px;font-weight:700;cursor:pointer}.vocab-collect-popup__actions button:last-child{background:var(--accent-strong);color:#fff}.vocab-collect-popup__error{margin:0;color:#b91c1c;font-weight:600}.vocab-collect-popup__success{margin:0;font-weight:700;color:var(--accent-strong)}@media (max-width: 720px){.chat-shell{padding:calc(24px + env(safe-area-inset-top)) 16px calc(20px + env(safe-area-inset-bottom))}.chat-header{flex-direction:column;align-items:flex-start}.chat-messages{max-height:none}.chat-bubble{max-width:92%}.chat-input{grid-template-columns:1fr}.chat-input__button{width:100%;padding:14px 0}.journal-shell{padding:calc(24px + env(safe-area-inset-top)) 16px calc(20px + env(safe-area-inset-bottom))}.journal-content{grid-template-columns:1fr}.journal-header{flex-direction:column;align-items:flex-start}.journal-story-filter{width:100%}.story-layout{grid-template-columns:1fr}.vocab-shell{padding:calc(24px + env(safe-area-inset-top)) 16px calc(20px + env(safe-area-inset-bottom))}.vocab-add-form{grid-template-columns:1fr}.vocab-item__row{grid-template-columns:1fr;align-items:flex-start}}.vocab-memory-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.vocab-memory-editor{display:flex;flex-direction:column;width:100%;max-width:1000px;max-height:90vh;background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg)}.vocab-memory-editor__header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--surface-active);border-bottom:1px solid var(--border)}.vocab-memory-editor__header h3{margin:0;font-size:1.1rem;color:var(--ink)}.vocab-memory-editor__vocab-badge{display:flex;align-items:center;gap:10px;padding:6px 14px;background:#9333ea26;border:1px solid rgba(147,51,234,.3);border-radius:999px}.vocab-memory-editor__korean{color:var(--accent);font-weight:700;font-size:.95rem}.vocab-memory-editor__vietnamese{color:var(--ink-muted);font-size:.85rem}.vocab-memory-editor__close-btn{margin-left:auto;background:none;border:none;color:var(--ink-muted);font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .15s}.vocab-memory-editor__close-btn:hover{background:#ef44441a;color:#ef4444}.vocab-memory-editor__main{flex:1;display:grid;grid-template-columns:1fr 360px;min-height:0;overflow:hidden}.vocab-memory-editor__editor-section{display:flex;flex-direction:column;padding:20px;border-right:1px solid var(--border);overflow-y:auto}.vocab-memory-editor__label{display:block;margin-bottom:8px;font-weight:600;font-size:.9rem;color:var(--ink-muted)}.vocab-memory-editor__textarea{width:100%;min-height:150px;padding:14px;background:var(--surface-active);border:1px solid var(--border);border-radius:12px;color:var(--ink);font-size:.95rem;font-family:inherit;line-height:1.6;resize:vertical;transition:border-color .15s}.vocab-memory-editor__textarea:focus{outline:none;border-color:var(--accent)}.vocab-memory-editor__textarea::placeholder{color:var(--ink-muted)}.vocab-memory-editor__linked-section{margin-top:20px}.vocab-memory-editor__linked-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.vocab-memory-editor__linked-item{background:var(--surface-active);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:10px;padding:12px}.vocab-memory-editor__linked-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:.8rem}.vocab-memory-editor__linked-char{background:#9333ea26;color:var(--accent);padding:2px 8px;border-radius:999px;font-weight:600}.vocab-memory-editor__linked-date{color:var(--ink-muted)}.vocab-memory-editor__unlink-btn{margin-left:auto;background:#ef44441a;border:none;color:#ef4444;width:24px;height:24px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .15s}.vocab-memory-editor__unlink-btn:hover{background:#ef444433}.vocab-memory-editor__linked-content{margin:0;color:var(--ink);font-size:.9rem;line-height:1.5}.vocab-memory-editor__tip{margin-top:auto;padding-top:16px;color:var(--ink-muted);font-size:.8rem}.vocab-memory-editor__search-section{display:flex;flex-direction:column;padding:16px;background:var(--surface-active);overflow-y:auto}.vocab-memory-editor__search-title{margin:0 0 12px;font-size:1rem;color:var(--ink)}.vocab-memory-editor__search-box{display:flex;gap:8px;margin-bottom:12px}.vocab-memory-editor__search-input{flex:1;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--ink);font-size:.9rem}.vocab-memory-editor__search-input:focus{outline:none;border-color:var(--accent)}.vocab-memory-editor__search-input::placeholder{color:var(--ink-muted)}.vocab-memory-editor__search-btn{padding:10px 16px;background:var(--accent);border:none;border-radius:10px;color:#fff;font-size:1rem;cursor:pointer;transition:background .15s}.vocab-memory-editor__search-btn:hover:not(:disabled){background:var(--accent-strong)}.vocab-memory-editor__search-btn:disabled{opacity:.6;cursor:not-allowed}.vocab-memory-editor__ai-search-btn{width:100%;padding:12px;background:linear-gradient(135deg,var(--accent) 0%,#6366f1 100%);border:none;border-radius:10px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;margin-bottom:12px;transition:transform .15s,box-shadow .15s}.vocab-memory-editor__ai-search-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #9333ea4d}.vocab-memory-editor__ai-search-btn:disabled{opacity:.7;cursor:not-allowed}.vocab-memory-editor__search-error{padding:10px 14px;background:#ef44441a;border-radius:8px;color:#ef4444;font-size:.85rem;margin-bottom:12px}.vocab-memory-editor__results{flex:1;min-height:0;display:flex;flex-direction:column}.vocab-memory-editor__results-header{display:flex;align-items:center;justify-content:space-between;color:var(--accent);font-size:.9rem;font-weight:600;margin-bottom:10px}.vocab-memory-editor__results-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.vocab-memory-editor__result-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;transition:border-color .15s}.vocab-memory-editor__result-item:hover{border-color:var(--accent)}.vocab-memory-editor__result-item--linked{opacity:.6;background:#9333ea0d}.vocab-memory-editor__result-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:.75rem;color:var(--ink-muted)}.vocab-memory-editor__result-char{background:#9333ea26;color:var(--accent);padding:2px 6px;border-radius:999px;font-weight:600}.vocab-memory-editor__result-date{color:var(--ink-muted)}.vocab-memory-editor__result-content{margin:0 0 6px;color:var(--ink);font-size:.85rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.vocab-memory-editor__result-translation{margin:0 0 8px;color:var(--ink-muted);font-size:.8rem;font-style:italic}.vocab-memory-editor__link-btn{width:100%;padding:8px;background:#9333ea1a;border:1px solid rgba(147,51,234,.2);border-radius:8px;color:var(--accent);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.vocab-memory-editor__link-btn:hover:not(:disabled){background:#9333ea33}.vocab-memory-editor__link-btn:disabled{opacity:.6;cursor:default;background:#22c55e1a;border-color:#22c55e33;color:#22c55e}.vocab-memory-editor__no-results{text-align:center;padding:24px;color:var(--ink-muted);font-size:.85rem}.vocab-memory-editor__no-results p{margin:4px 0}.vocab-memory-editor__actions{display:flex;gap:12px;padding:16px 20px;background:var(--surface-active);border-top:1px solid var(--border)}.vocab-memory-editor__cancel-btn{flex:1;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--ink);font-size:.95rem;cursor:pointer;transition:background .15s}.vocab-memory-editor__cancel-btn:hover{background:var(--surface-active)}.vocab-memory-editor__save-btn{flex:2;padding:12px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:10px;color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s}.vocab-memory-editor__save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #22c55e4d}.vocab-memory-editor__save-btn:disabled{opacity:.6;cursor:not-allowed}.vocab-item__memory-preview{background:var(--surface-active);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:10px 12px;margin-bottom:10px}.vocab-item__memory-preview p{margin:0 0 6px;color:var(--ink);font-size:.9rem;line-height:1.5}.vocab-item__linked-count{display:inline-block;background:#9333ea1a;color:var(--accent);padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600}.vocab-item__edit-memory-btn{width:100%;padding:10px;background:#9333ea1a;border:1px solid rgba(147,51,234,.2);border-radius:10px;color:var(--accent);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.vocab-item__edit-memory-btn:hover{background:#9333ea33}.vocab-memory-editor__toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface-active);border:1px solid var(--border);border-bottom:none;border-radius:12px 12px 0 0}.vocab-memory-editor__toolbar-label{font-size:.9rem;color:var(--ink-muted);font-weight:600}.vocab-memory-editor__toolbar-actions{display:flex;align-items:center;gap:6px}.vocab-memory-editor__format-btn{background:var(--surface);color:var(--ink-muted);border:1px solid var(--border);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .15s}.vocab-memory-editor__format-btn:hover{background:var(--surface-active);color:var(--ink)}.vocab-memory-editor__format-btn[data-active=true]{background:var(--accent);color:#fff;border-color:var(--accent)}.vocab-memory-editor__mobile-search-btn{background:linear-gradient(135deg,var(--accent) 0%,#6366f1 100%);color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer}.vocab-memory-editor__editor-container{flex:1;min-height:200px;max-height:400px;overflow-y:auto;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:0 0 12px 12px;position:relative}.vocab-memory-editor__editor-container--drop-target{background:#9333ea0d;border-color:var(--accent)}.vocab-memory-editor__drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#9333ea26;border:2px dashed var(--accent);border-radius:12px;pointer-events:none}.vocab-memory-editor__drop-overlay span{background:var(--accent);color:#fff;padding:12px 24px;border-radius:10px;font-weight:600}.tiptap-editor{min-height:100px;outline:none;color:var(--ink);font-size:.95rem;line-height:1.7}.tiptap-editor p{margin:0 0 12px}.tiptap-editor.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--ink-muted);pointer-events:none;height:0}.tiptap-editor ::selection{background:#9333ea4d}.message-node-wrapper{margin:12px 0}.vocab-memory-editor__message-block{background:var(--surface-active);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:10px;padding:12px;cursor:grab;transition:border-color .15s,box-shadow .15s}.vocab-memory-editor__message-block:hover{border-color:var(--accent);box-shadow:0 4px 12px #9333ea26}.vocab-memory-editor__message-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.vocab-memory-editor__drag-handle{cursor:grab;color:var(--ink-muted);font-size:.9rem;padding:2px 4px;border-radius:4px;-webkit-user-select:none;user-select:none;letter-spacing:-2px}.vocab-memory-editor__drag-handle:hover{background:#9333ea26;color:var(--accent)}.vocab-memory-editor__drag-handle:active{cursor:grabbing}.vocab-memory-editor__char-badge{background:#9333ea26;color:var(--accent);padding:3px 8px;border-radius:999px;font-size:.75rem;font-weight:600}.vocab-memory-editor__date-badge{color:var(--ink-muted);font-size:.7rem}.vocab-memory-editor__msg-id{color:var(--ink-muted);font-size:.7rem;background:#94a3b826;border:1px solid rgba(148,163,184,.25);padding:2px 6px;border-radius:6px}.vocab-memory-editor__remove-msg-btn{margin-left:auto;background:#ef44441a;border:none;color:#ef4444;font-size:.8rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}.vocab-memory-editor__remove-msg-btn:hover{background:#ef444433}.vocab-memory-editor__message-text{color:var(--ink);font-size:.9rem;line-height:1.5;padding:8px 10px;background:var(--surface);border-radius:8px}.memory-image{max-width:100%;height:auto;border-radius:8px;margin:8px 0;cursor:pointer;transition:transform .15s,box-shadow .15s}.memory-image:hover{box-shadow:0 4px 12px #9333ea33}.ProseMirror-selectednode .vocab-memory-editor__message-block{outline:2px solid var(--accent);outline-offset:2px}.memory-image.ProseMirror-selectednode{outline:3px solid var(--accent);outline-offset:2px}.vocab-memory-editor__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--ink-muted)}.vocab-memory-editor__spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}.vocab-memory-editor__search-loading{display:flex;flex-direction:column;align-items:center;padding:24px;color:var(--ink-muted)}@keyframes spin{to{transform:rotate(360deg)}}.vocab-memory-editor__re-search-btn{width:100%;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--ink-muted);font-size:.85rem;cursor:pointer;margin-bottom:12px;transition:all .15s}.vocab-memory-editor__re-search-btn:hover{background:var(--surface-active);color:var(--ink)}.vocab-memory-editor__drag-hint{color:var(--ink-muted);font-size:.75rem;font-weight:400}.vocab-memory-editor__vocab-target{display:block;color:var(--accent);font-size:.85rem;font-weight:600;margin-bottom:12px}.vocab-memory-editor__search-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.vocab-memory-editor__result-item{cursor:grab}.vocab-memory-editor__result-item--dragging{opacity:.5;transform:scale(.98)}.vocab-memory-editor__mobile-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:flex-end}.vocab-memory-editor__modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009}.vocab-memory-editor__modal-content{position:relative;width:100%;max-height:80vh;background:var(--surface);border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.vocab-memory-editor__modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.vocab-memory-editor__modal-header h4{margin:0;font-size:1rem;color:var(--ink)}.vocab-memory-editor__modal-close{background:none;border:none;color:var(--ink-muted);font-size:1.2rem;cursor:pointer;padding:4px}.vocab-memory-editor__modal-content .vocab-memory-editor__search-content{padding:16px;max-height:60vh;overflow-y:auto}@media (max-width: 768px){.vocab-memory-editor__main{grid-template-columns:1fr}.vocab-memory-editor__editor-section{border-right:none;border-bottom:1px solid var(--border)}.vocab-memory-editor__search-section{display:none}.vocab-memory-overlay{padding:0;align-items:flex-end}.vocab-memory-editor{max-width:none;max-height:95vh;border-radius:16px 16px 0 0}.vocab-memory-editor--mobile .vocab-memory-editor__main{display:flex;flex-direction:column}}@keyframes bubble-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.chat-bubble,.chat-input__button{animation:none;transition:none}}
