*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background:#edf4fb;color:#172033}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-frame{min-height:100vh}.app-shell{max-width:1040px;min-height:100vh;margin:0 auto;padding:24px 16px 96px}.page-stack{display:flex;flex-direction:column;gap:18px}.hero-band{display:flex;flex-direction:column;gap:14px;padding:24px;background:#fff;border:1px solid #d9e5f2;border-radius:8px;box-shadow:0 18px 48px #30527a1a}.hero-band h1,.section-header h1,.section-header h2,.chat-placeholder h1{margin:0;line-height:1.15;letter-spacing:0}.hero-band p,.chat-placeholder p{margin:0;color:#58677d;line-height:1.65}.eyebrow{margin:0;color:#2f76bd;font-size:13px;font-weight:700}.search-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;min-height:48px;gap:10px;padding:6px 6px 6px 14px;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px}.search-bar input{min-width:0;border:0;outline:0;color:#172033;background:transparent}.search-bar button,.feature-card,.grade-row button,.text-button,.back-button{min-height:44px;border:0;border-radius:8px;font-weight:700}.search-bar button{padding:0 14px;color:#fff;background:#2f76bd}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.stats-grid div,.stats-grid button,.section-block,.empty-state,.chat-placeholder{background:#fff;border:1px solid #d9e5f2;border-radius:8px}.stats-grid div,.stats-grid button{padding:14px 10px;text-align:center}.stats-grid button{min-height:82px;color:inherit}.stats-grid button.active{background:#e8f3ff;border-color:#2f76bd;box-shadow:inset 0 0 0 1px #2f76bd}.stats-grid strong{display:block;color:#2f76bd;font-size:24px}.stats-grid span,.feature-card small,.grade-row small{color:#627084;font-size:13px}.section-block{padding:16px}.section-header{display:flex;flex-direction:column;gap:6px}.subtle-text{margin:0;color:#627084;line-height:1.6}.section-header.compact{flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.text-button{display:inline-flex;align-items:center;gap:6px;padding:0 12px;color:#2f76bd;background:#e8f3ff}.grade-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}.grade-row button{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:12px;color:#172033;background:#f7fbff;border:1px solid #d9e5f2}.action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.feature-card{display:flex;align-items:center;gap:12px;padding:16px;color:#172033;text-align:left;background:#fff;border:1px solid #d9e5f2}.feature-card:last-child{grid-column:1 / -1}.feature-card span:last-child{display:flex;min-width:0;flex-direction:column;gap:4px}.feature-icon,.assistant-avatar{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;color:#2f76bd;background:#e8f3ff;border-radius:8px}.feature-icon{width:44px;height:44px}.tip-row{display:flex;align-items:flex-start;gap:10px;color:#58677d}.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:20;display:grid;grid-template-columns:repeat(4,1fr);max-width:1040px;margin:0 auto;padding:8px 10px 10px;background:#fffffff5;border-top:1px solid #d9e5f2;box-shadow:0 -12px 30px #30527a1a}.nav-item{display:flex;min-height:54px;align-items:center;justify-content:center;flex-direction:column;gap:4px;color:#627084;background:transparent;border:0;border-radius:8px;font-size:12px}.nav-item.active{color:#2f76bd;background:#e8f3ff}.empty-state,.chat-placeholder{padding:24px;color:#58677d;line-height:1.6}.empty-state button{display:block;min-height:44px;margin-top:14px;padding:0 14px;color:#fff;background:#2f76bd;border:0;border-radius:8px;font-weight:700}.back-button{display:inline-flex;width:fit-content;align-items:center;gap:6px;padding:0 12px;color:#2f76bd;background:#fff;border:1px solid #d9e5f2}.chat-placeholder{display:flex;align-items:flex-start;flex-direction:column;gap:12px}.assistant-avatar{width:56px;height:56px}.chat-header{display:flex;align-items:center;gap:14px;padding:18px;background:#fff;border:1px solid #d9e5f2;border-radius:8px}.chat-header h1{margin:0 0 4px;line-height:1.15}.context-banner{padding:12px 14px;color:#245f99;background:#e8f3ff;border:1px solid #c9d9eb;border-radius:8px;line-height:1.5}.chat-panel{display:flex;min-height:360px;flex-direction:column;gap:12px;padding:16px;overflow-y:auto;background:#fff;border:1px solid #d9e5f2;border-radius:8px;box-shadow:0 14px 34px #30527a14}.chat-bubble{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;max-width:82%;align-items:flex-start}.chat-bubble.user{align-self:flex-end}.chat-bubble.assistant{align-self:flex-start}.chat-bubble-icon{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;color:#2f76bd;background:#e8f3ff;border-radius:8px}.chat-bubble.user .chat-bubble-icon{color:#fff;background:#2f76bd}.chat-bubble p{min-width:0;margin:0;padding:12px 14px;color:#172033;white-space:pre-wrap;overflow-wrap:anywhere;line-height:1.65;background:#f7fbff;border:1px solid #d9e5f2;border-radius:8px}.chat-bubble-content{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:start}.chat-speech-button{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;color:#2f76bd;background:#fff;border:1px solid #c9d9eb;border-radius:8px}.chat-speech-button:disabled{cursor:not-allowed;opacity:.55}.chat-bubble.user p{color:#fff;background:#2f76bd;border-color:#2f76bd}.chat-bubble.pending .chat-bubble-icon svg{animation:spin .9s linear infinite}.quick-chip-row{display:flex;flex-wrap:wrap;gap:8px}.quick-chip-row button{min-height:40px;padding:0 12px;color:#2f76bd;background:#fff;border:1px solid #c9d9eb;border-radius:999px;font-weight:800}.quick-chip-row button:disabled{cursor:not-allowed;opacity:.6}.chat-error{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;color:#a13232;background:#ffe5e5;border-radius:8px}.chat-error button{min-height:36px;padding:0 12px;color:#a13232;background:#fff;border:1px solid #e49595;border-radius:8px;font-weight:800}.chat-input-bar{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"field actions";gap:10px;align-items:stretch;padding:12px;background:#fff;border:1px solid #d9e5f2;border-radius:8px}.chat-input-field{grid-area:field;display:flex;min-width:0;flex-direction:column;gap:6px}.chat-input-actions{grid-area:actions;display:flex;align-items:stretch;gap:10px}.chat-input-bar textarea{width:100%;min-height:52px;max-height:140px;padding:10px 12px;color:#172033;resize:vertical;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px}.chat-shortcut-hint{margin:0;color:#627084;font-size:12px;line-height:1.4}.chat-input-bar button{display:inline-flex;min-height:52px;align-items:center;justify-content:center;gap:6px;padding:0 14px;color:#fff;background:#2f76bd;border:0;border-radius:8px;font-weight:900}.chat-input-actions button{min-width:82px}.chat-input-bar button:disabled{cursor:not-allowed;opacity:.55}.chat-input-bar .voice-input-button{color:#2f76bd;background:#f7fbff;border:1px solid #c9d9eb}.chat-input-bar .voice-input-button.listening{color:#9a5b00;background:#fff1d2;border-color:#f6d174}@keyframes spin{to{transform:rotate(360deg)}}.grade-filter{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.grade-filter button{display:flex;min-height:48px;align-items:center;justify-content:space-between;gap:6px;padding:0 10px;color:#172033;background:#fff;border:1px solid #d9e5f2;border-radius:8px;font-weight:700}.grade-filter button.active{color:#fff;background:#2f76bd;border-color:#2f76bd}.grade-filter small{color:inherit;opacity:.75}.pagination-panel{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px;color:#3d4b61;background:#fff;border:1px solid #d9e5f2;border-radius:8px}.pagination-panel>div{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.page-size-options,.pagination-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.page-size-options button,.pagination-actions button{min-height:38px;padding:0 12px;color:#2f76bd;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px;font-weight:800}.page-size-options button.active{color:#fff;background:#2f76bd;border-color:#2f76bd}.pagination-actions button:disabled{cursor:not-allowed;opacity:.5}.pagination-summary{justify-content:flex-end}.pagination-summary span{color:#627084}.word-grid{display:grid;grid-template-columns:1fr;gap:14px}.word-card,.result-item{background:#fff;border:1px solid #d9e5f2;border-radius:8px;box-shadow:0 12px 32px #30527a14}.word-card{display:flex;flex-direction:column;gap:14px;padding:16px;transition:transform .18s ease,border-color .18s ease}.word-card.flipped{border-color:#f4b04f}.word-card-main,.word-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.word-title-row h2,.result-item h2{margin:0;color:#172033;font-size:26px;letter-spacing:0;overflow-wrap:anywhere}.phonetic{margin:4px 0 0;color:#627084;font-size:14px}.icon-button{display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;color:#8a97a8;background:#f7fbff;border:1px solid #d9e5f2;border-radius:8px}.icon-button.selected{color:#f4a825;background:#fff6dc;border-color:#f6d174}.status-pill{flex:0 0 auto;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:700}.status-pill.new{color:#627084;background:#eef3f8}.status-pill.reviewing{color:#9a5b00;background:#fff1d2}.status-pill.mastered{color:#14764a;background:#dff6e8}.word-card-face{min-height:72px}.card-hint,.meaning,.sentence{margin:0;line-height:1.6}.meaning{font-size:20px;font-weight:800}.sentence{margin-top:6px;color:#58677d}.sentence-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:start}.sentence-speak-button{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;color:#2f76bd;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px}.sentence-speak-button:disabled{cursor:not-allowed;opacity:.55}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tag-row span{padding:4px 8px;color:#2f76bd;background:#e8f3ff;border-radius:999px;font-size:12px}.word-actions,.result-actions{display:flex;flex-wrap:wrap;gap:8px}.word-actions button,.result-actions button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:6px;padding:0 12px;color:#2f76bd;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px;font-weight:700}.result-list{display:flex;flex-direction:column;gap:12px}.result-item{display:grid;grid-template-columns:1fr auto;gap:16px;padding:16px}.result-item p{margin:6px 0 0;line-height:1.55}.result-actions{align-content:start}mark{color:#9a5b00;background:#fff1b8;border-radius:4px;padding:0 2px}.segmented-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:6px;background:#fff;border:1px solid #d9e5f2;border-radius:8px}.segmented-tabs button{min-height:44px;color:#627084;background:transparent;border:0;border-radius:8px;font-weight:800}.segmented-tabs button.active{color:#fff;background:#2f76bd}.notice,.form-message{padding:12px 14px;border-radius:8px;line-height:1.5}.notice,.form-message.success{color:#14764a;background:#dff6e8}.voice-notice{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.voice-notice strong{display:block}.voice-notice p{margin:4px 0 0}.voice-notice button{flex:0 0 auto;min-height:38px;padding:0 12px;color:#14764a;background:#fff;border:1px solid #8ed6aa;border-radius:8px;font-weight:800}.voice-guide{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.voice-guide article{padding:14px;background:#fff;border:1px solid #d9e5f2;border-radius:8px}.voice-guide h2{margin:0 0 8px;font-size:17px}.voice-guide p{margin:0;color:#58677d;line-height:1.6}.form-message.error{color:#a13232;background:#ffe5e5}.import-box{display:flex;flex-direction:column;gap:12px;padding:18px;background:#f7fbff;border:1px dashed #9fbce0;border-radius:8px}.import-box input{display:none}.import-actions{display:flex;flex-wrap:wrap;gap:10px}.import-box button,.form-actions button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;width:fit-content;padding:0 14px;color:#fff;background:#2f76bd;border:0;border-radius:8px;font-weight:800}.import-box .secondary-button{color:#2f76bd;background:#e8f3ff}.import-box p{margin:0;color:#627084}.import-help{display:grid;gap:6px}.word-form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.word-form label{display:flex;flex-direction:column;gap:7px;color:#3d4b61;font-weight:800}.word-form .wide{grid-column:1 / -1}.word-form input,.word-form select,.word-form textarea{width:100%;min-height:44px;padding:10px 12px;color:#172033;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px}.word-form textarea{min-height:86px;resize:vertical}.form-actions{display:flex;flex-wrap:wrap;grid-column:1 / -1;gap:10px}.form-actions button[type=button]{color:#2f76bd;background:#e8f3ff}.dictionary-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}.dictionary-list article{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:12px;background:#f7fbff;border:1px solid #d9e5f2;border-radius:8px}.dictionary-list strong{display:block;color:#172033;overflow-wrap:anywhere}.dictionary-list small{color:#627084;font-weight:700}.dictionary-list p{margin:4px 0 0;color:#58677d}.row-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.row-actions button{display:inline-flex;min-height:40px;align-items:center;justify-content:center;gap:6px;padding:0 10px;color:#2f76bd;background:#fff;border:1px solid #c9d9eb;border-radius:8px;font-weight:800}.quiz-card,.result-card{max-width:720px;margin:0 auto;padding:22px;background:#fff;border:1px solid #d9e5f2;border-radius:8px;box-shadow:0 18px 48px #30527a1a}.quiz-progress{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;color:#627084;margin-bottom:18px}.quiz-progress strong{color:#2f76bd}.quiz-card h1,.result-card h1{margin:0;font-size:30px;letter-spacing:0;overflow-wrap:anywhere}.quiz-prompt{margin:10px 0 18px;color:#58677d;font-size:18px;line-height:1.6}.option-list{display:grid;gap:10px}.option-list button{display:flex;min-height:54px;align-items:center;gap:12px;padding:10px 14px;color:#172033;text-align:left;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px;font-weight:800}.option-list button span{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;flex:0 0 auto;color:#2f76bd;background:#e8f3ff;border-radius:999px}.option-list button.selected{border-color:#2f76bd;box-shadow:inset 0 0 0 1px #2f76bd}.option-list button.correct{color:#14764a;background:#dff6e8;border-color:#6cc58c}.option-list button.wrong{color:#a13232;background:#ffe5e5;border-color:#e49595}.feedback{display:flex;align-items:center;gap:8px;margin-top:14px;padding:12px;border-radius:8px;font-weight:800}.feedback.correct{color:#14764a;background:#dff6e8}.feedback.wrong{color:#a13232;background:#ffe5e5}.primary-action{display:inline-flex;min-height:48px;align-items:center;justify-content:center;margin-top:16px;padding:0 18px;color:#fff;background:#2f76bd;border:0;border-radius:8px;font-weight:900}.primary-action:disabled,.option-list button:disabled{cursor:not-allowed}.primary-action:disabled{opacity:.5}.quiz-setup{display:grid;gap:16px}.quiz-setup label,.field-label{display:flex;flex-direction:column;gap:7px;color:#3d4b61;font-weight:800}.quiz-setup select{min-height:44px;padding:10px 12px;color:#172033;background:#f7fbff;border:1px solid #c9d9eb;border-radius:8px}.check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}.check-grid label{display:flex;min-height:48px;align-items:center;flex-direction:row;gap:8px;padding:10px 12px;background:#f7fbff;border:1px solid #d9e5f2;border-radius:8px}.check-grid input{width:18px;height:18px}.quiz-ready{color:#58677d}.result-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}.result-stats div{padding:14px 10px;text-align:center;background:#f7fbff;border:1px solid #d9e5f2;border-radius:8px}.result-stats strong{display:block;color:#2f76bd;font-size:22px}.result-stats span{color:#627084;font-size:13px}.wrong-list{padding:14px;background:#fff8ee;border:1px solid #f4d5a2;border-radius:8px}.wrong-list h2{margin:0 0 8px;font-size:18px}.wrong-list p{margin:6px 0 0;color:#6b4a1e;line-height:1.5}@media(min-width:760px){.app-shell{padding:36px 24px 116px}.hero-band{padding:32px}.action-grid{grid-template-columns:repeat(3,1fr)}.feature-card:last-child{grid-column:auto}.grade-row{grid-template-columns:repeat(6,1fr)}.word-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:420px){.app-shell{padding-right:12px;padding-left:12px}.hero-band{padding:18px}.stats-grid{grid-template-columns:repeat(2,1fr)}.action-grid,.grade-row,.grade-filter{grid-template-columns:1fr}.pagination-panel,.pagination-panel>div,.pagination-summary,.voice-notice{align-items:stretch;flex-direction:column}.voice-notice button{width:100%}.voice-guide{grid-template-columns:1fr}.page-size-options,.pagination-actions{width:100%}.page-size-options button,.pagination-actions button{flex:1}.result-item{grid-template-columns:1fr}.word-form,.dictionary-list article{grid-template-columns:1fr}.row-actions{justify-content:flex-start}.check-grid,.result-stats{grid-template-columns:1fr}.chat-bubble{max-width:100%}.chat-input-bar{grid-template-columns:1fr;grid-template-areas:"field" "actions"}.chat-input-actions{justify-content:stretch}.chat-input-actions button{flex:1}.quiz-card,.result-card{padding:18px}}
