*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#fff;min-height:100vh}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-container h1{font-size:2.5rem;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:300px}.login-form input{padding:12px 16px;border:2px solid #333;border-radius:8px;background:#16213e;color:#fff;font-size:1rem}.login-form button{padding:12px 24px;border:none;border-radius:8px;background:#e94560;color:#fff;font-size:1rem;cursor:pointer;transition:background .3s}.login-form button:hover{background:#c73e54}.app{max-width:1000px;margin:0 auto;padding:20px}header{text-align:center;margin-bottom:2rem}header h1{font-size:2rem;margin-bottom:1.5rem}.setup{display:flex;flex-direction:column;gap:1rem;align-items:center}.language-select,.gender-select{display:flex;gap:10px}.language-select button,.gender-select button{padding:12px 24px;border:2px solid #333;border-radius:8px;background:#16213e;color:#fff;font-size:1rem;cursor:pointer;transition:all .3s}.language-select button.active,.gender-select button.active{border-color:#e94560;background:#e94560}.options{margin:10px 0}.options label{display:flex;align-items:center;gap:8px;cursor:pointer}.options input[type=checkbox]{width:20px;height:20px;accent-color:#e94560}.start-btn,.end-btn{padding:14px 32px;border:none;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .3s}.start-btn{background:#e94560;color:#fff;width:100%;max-width:300px}.start-btn:hover{background:#c73e54}.end-btn{background:#333;color:#fff;padding:8px 16px;font-size:.9rem}.logout-btn{background:#666;color:#fff;padding:8px 16px;font-size:.9rem;margin-left:8px}.logout-btn:hover{background:#888}.session-info{display:flex;gap:10px;justify-content:space-between;align-items:center;flex-wrap:nowrap}.session-left{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.session-right{display:flex;gap:8px;align-items:center;flex-shrink:0}.global-volume{display:flex;align-items:center;gap:4px;background:#16213e;padding:4px 8px;border-radius:6px;border:1px solid #333}.global-volume input[type=range]{width:60px;height:4px;accent-color:#e94560}.mode-btn,.end-btn{padding:6px 12px;font-size:.85rem}padding: 12px 16px; background: #16213e; border-radius: 8px; margin-bottom: 1rem; } .session-info button{margin-left:8px}.messages{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem;max-height:400px;overflow-y:auto}.message{padding:12px 16px;border-radius:12px;max-width:80%}.message.assistant{background:#0f3460;align-self:flex-start}.message.user{background:#e94560;align-self:flex-end}.message .text{font-size:150%;line-height:1.6}.message .text ruby{font-size:100%}.message .text rt{font-size:50%}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.85rem}.role-badge{font-weight:700;opacity:.8}.translate-toggle{background:#fff3;border:none;padding:4px 8px;border-radius:4px;color:#fff;font-size:.75rem;cursor:pointer}.translate-toggle:hover{background:#ffffff4d}.audio-player{margin-top:8px}.play-btn{background:#fff3;border:none;padding:8px 16px;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem}.play-btn:hover{background:#ffffff4d}.play-btn.playing{background:#e94560;animation:pulse-red 1.5s infinite}.play-btn.playing:hover{background:#f44}@keyframes pulse-red{0%,to{box-shadow:0 0 #e94560b3}50%{box-shadow:0 0 0 10px #e9456000}}.input-area{display:flex;gap:10px;align-items:center}.input-area input{flex:1;padding:12px 16px;border:2px solid #333;border-radius:8px;background:#16213e;color:#fff;font-size:1rem}.input-area button{padding:12px 20px;border:none;border-radius:8px;background:#0f3460;color:#fff;font-size:1rem;cursor:pointer;transition:background .3s}.input-area button:hover{background:#1a4a7a}.help-text{text-align:center;color:#888;font-size:.9rem;margin-bottom:20px;padding:12px;background:#16213e;border-radius:8px;border:1px solid #333}.audio-loading{margin-top:8px;color:#888;font-size:.85rem}.loading-dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.voice-recorder-section{margin-top:16px;padding:16px;background:#16213e;border-radius:12px;border:1px solid #333}.mode-toggle{display:flex;gap:8px;justify-content:center;margin-bottom:12px;background:#1a1a2e;padding:4px;border-radius:8px}.mode-toggle button{padding:8px 16px;border:none;border-radius:6px;background:transparent;color:#888;font-size:.85rem;cursor:pointer;transition:all .2s;flex:1}.furigana-text ruby{ruby-align:center}.furigana-text rt{font-size:.5em;color:#aaa}.toggle-furigana{background:#ffffff1a;border:none;padding:8px 16px;border-radius:20px;color:#aaa;cursor:pointer;font-size:.85rem;margin-top:8px}.toggle-furigana:hover{background:#fff3;color:#fff}.repeat-mode{max-width:600px}.mode-controls{display:flex;gap:10px;justify-content:center;margin-top:1rem}.mode-btn{background:#16213e;border:2px solid #333;padding:10px 20px;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem}.mode-btn:hover{background:#1a4a7a}.repeat-mode-btn,.lesson-mode-btn,.memory-mode-btn{background:#16213e!important;border:2px solid #e94560!important;color:#fff!important;margin-top:10px;padding:12px 24px;border-radius:8px;font-size:1rem;cursor:pointer;width:100%;max-width:300px;transition:all .3s}.repeat-mode-btn:hover,.lesson-mode-btn:hover,.memory-mode-btn:hover{background:#e94560!important}.memory-mode-btn{border-color:#9b59b6!important}.memory-mode-btn:hover{background:#9b59b6!important}.repeat-main{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.phrase-card{background:#16213e;border-radius:16px;padding:2rem;width:100%;text-align:center}.phrase-display{font-size:2rem;margin-bottom:1rem;min-height:80px;display:flex;align-items:center;justify-content:center}.phrase-display .plain-text,.phrase-jp{font-size:2.5rem;font-weight:500}.transcription-comparison{font-size:1.1rem}.transcription-comparison .expected,.transcription-comparison .heard{font-size:1.2rem}.phrase-controls{margin-top:1rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.play-btn.large{padding:14px 32px;font-size:1.1rem;background:#0f3460}.play-btn.large:hover{background:#1a4a7a}.translate-btn{padding:14px 24px;font-size:1rem;background:#16213e;border:2px solid #333;color:#fff;border-radius:8px;cursor:pointer;transition:all .2s}.translate-btn:hover{background:#1a4a7a;border-color:#0f3460}.translation-display{margin:1rem 0;padding:.75rem 1rem;background:#e945601a;border:1px solid #e94560;border-radius:8px;color:#fff;font-size:1rem}.volume-control{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.5rem 1rem;background:#16213e;border-radius:8px}.volume-control label{font-size:.9rem;color:#aaa}.volume-control input[type=range]{flex:1;min-width:100px}.volume-control span{font-size:.85rem;color:#888;min-width:40px;text-align:right}.recorder-disabled{padding:2rem;background:#16213e;border:2px dashed #333;border-radius:12px;text-align:center;color:#888}.result-card{background:#16213e;border-radius:16px;padding:1.5rem;width:100%;border:2px solid #333;margin-top:1.5rem}.result-card.score-100{border-color:#4ade80;background:#4ade801a}.result-card.score-80{border-color:#60a5fa;background:#60a5fa1a}.result-card.score-50{border-color:#fbbf24;background:#fbbf241a}.result-card.score-0{border-color:#f87171;background:#f871711a}.score-display{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.score-number{font-size:3rem;font-weight:700;color:#e94560}.feedback{font-size:1.2rem;color:#fff}.transcription-comparison{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}.transcription-comparison label{color:#888}.errors-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #333}.errors-section label{display:block;color:#fbbf24;font-weight:600;margin-bottom:.5rem}.errors-section ul{list-style:none;padding:0;margin:0}.errors-section li{color:#ccc;padding:4px 0;padding-left:1.5rem;position:relative}.errors-section li:before{content:"→";position:absolute;left:0;color:#e94560}.result-phrase-section{margin:1rem 0;padding:1rem;background:#ffffff0d;border-radius:8px;text-align:center}.result-phrase-section label{display:block;color:#888;font-size:.8rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:1px}.result-furigana-text{font-size:150%!important;line-height:1.6;margin:.5rem 0}.result-furigana-text ruby{ruby-align:center}.result-furigana-text rt{font-size:50%;color:#888}.result-translation{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);color:#4ade80;font-size:1rem;font-style:italic}.next-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:16px 32px;border:none;border-radius:8px;background:#0f3460;color:#fff;font-size:1.1rem;cursor:pointer;min-height:64px}.next-btn:hover{background:#1a4a7a}.next-btn:disabled{background:#2a3a4a;color:#666;cursor:not-allowed;opacity:.6}.shortcut-hint{color:#888;font-size:.7rem;font-weight:400}.transcription-comparison .expected{color:#4ade80}.transcription-comparison .heard{color:#fbbf24}.repeat-controls{display:flex;gap:1rem;width:100%;justify-content:center;align-items:center}.record-btn.large{padding:20px 48px;font-size:1.3rem}.voice-recorder-wrapper{position:relative;width:100%}.recorder-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:#16213ef2;border:2px dashed #333;border-radius:12px;color:#888;z-index:10}.recorder-overlay p{margin-top:1rem;font-size:.95rem}.loading-typing{display:flex;gap:6px;align-items:center}.loading-typing span{width:10px;height:10px;background:#e94560;border-radius:50%;animation:typingBounce 1.4s infinite ease-in-out both}.loading-typing span:nth-child(1){animation-delay:-.32s}.loading-typing span:nth-child(2){animation-delay:-.16s}.loading-typing span:nth-child(3){animation-delay:0s}@keyframes typingBounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.typing-indicator{display:flex;gap:4px;align-items:center;padding:8px 0}.typing-indicator span{width:8px;height:8px;background:#e94560;border-radius:50%;animation:typingBounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}.typing-indicator span:nth-child(3){animation-delay:0s}.translate-toggle:disabled{opacity:.5;cursor:not-allowed}.jp-text{margin-bottom:8px}.translation-text{padding-top:8px;border-top:1px solid #333;color:#aaa;font-size:.95rem;margin-top:4px}.audio-player-with-progress{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#0f3460;border-radius:8px;margin-top:8px}.audio-player-with-progress .play-btn,.audio-player-with-progress .stop-btn{width:40px;height:40px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;background:#16213e;border:2px solid #333;color:#fff;cursor:pointer;transition:all .2s}.audio-player-with-progress .play-btn:hover,.audio-player-with-progress .stop-btn:hover{background:#1a4a7a;border-color:#0f3460}.audio-player-with-progress .play-btn.playing{background:#e94560;border-color:#e94560}.audio-player-with-progress .stop-btn{font-size:.9rem}.progress-container{flex:1;display:flex;flex-direction:column;gap:4px}.progress-bar{height:6px;background:#16213e;border-radius:3px;cursor:pointer;position:relative;overflow:visible}.progress-fill{height:100%;background:#e94560;border-radius:3px;transition:width .05s linear;position:absolute;left:0;top:0}.progress-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0006;pointer-events:none;z-index:2}.time-display{display:flex;justify-content:space-between;font-size:.75rem;color:#888}.practice-setup{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px;text-align:center}.practice-setup h2{font-size:2rem;margin-bottom:8px;color:#fff}.setup-lesson-title{font-size:1.2rem;color:#e94560;margin-bottom:40px;font-weight:500}.setup-options{background:#16213e;border:2px solid #333;border-radius:12px;padding:24px 32px;margin-bottom:32px;min-width:300px}.setup-toggle{display:flex;align-items:flex-start;gap:12px;cursor:pointer;text-align:left}.setup-toggle input{width:20px;height:20px;margin-top:2px;accent-color:#e94560;cursor:pointer}.toggle-label{font-weight:600;font-size:1.1rem;color:#fff;display:block}.toggle-description{font-size:.85rem;color:#888;display:block;margin-top:4px}.start-practice-btn{background:#e94560;color:#fff;border:none;padding:16px 48px;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s;margin-bottom:16px}.start-practice-btn:hover{background:#c73e54;transform:translateY(-2px)}.cancel-practice-btn{background:transparent;color:#888;border:2px solid #333;padding:12px 32px;border-radius:12px;font-size:1rem;cursor:pointer;transition:all .3s}.cancel-practice-btn:hover{border-color:#e94560;color:#e94560}.setup-section{margin-top:20px;padding-top:20px;border-top:1px solid #333}.setup-section-label{display:block;font-weight:600;color:#fff;margin-bottom:12px;font-size:1.1rem}.setup-voice-select{display:flex;gap:12px;justify-content:center}.setup-voice-select button{padding:10px 20px;border:2px solid #333;border-radius:8px;background:#16213e;color:#aaa;font-size:.95rem;cursor:pointer;transition:all .3s}.setup-voice-select button:hover{border-color:#555;color:#fff}.setup-voice-select button.active{border-color:#e94560;background:#e945601a;color:#fff}.setup-hint{display:block;margin-top:8px;font-size:.8rem;color:#888;font-style:italic}@media (max-width: 480px){.app{padding:12px;max-width:100%}header h1{font-size:1.5rem;margin-bottom:1rem}.login-container h1{font-size:1.8rem}.login-form{max-width:100%;padding:0 16px}.language-select,.gender-select{flex-wrap:wrap;justify-content:center}.language-select button,.gender-select button{padding:10px 16px;font-size:.9rem}.session-info{flex-direction:column;gap:12px;padding:12px}.session-left,.session-right{width:100%;justify-content:center;flex-wrap:wrap;gap:8px}.messages{height:calc(100vh - 280px);min-height:300px}.message{max-width:90%;padding:12px}.message-header{flex-wrap:wrap;gap:8px}.role-badge{font-size:.75rem;padding:3px 8px}.input-area{padding:12px}.input-area input{font-size:16px;padding:12px}.practice-setup{padding:20px 16px;min-height:70vh}.practice-setup h2{font-size:1.5rem}.setup-lesson-title{font-size:1rem}.setup-options{min-width:auto;width:100%;padding:20px}.start-practice-btn{padding:14px 32px;font-size:1.1rem;width:100%}.cancel-practice-btn{width:100%}.lesson-mode{padding:12px}.lesson-header{flex-direction:column;gap:12px;text-align:center}.lesson-header h2{font-size:1.3rem}.lesson-tabs{flex-wrap:wrap;gap:8px}.lesson-tabs button{padding:8px 12px;font-size:.85rem}.vocab-grid{grid-template-columns:1fr}.grammar-card{padding:16px}.lesson-card{padding:12px 16px}.lesson-card-header{flex-direction:column;gap:4px}.lesson-card-stats{flex-wrap:wrap;gap:8px}.stats-grid{grid-template-columns:1fr}.mode-controls{flex-direction:column;gap:8px;width:100%}.mode-btn{width:100%;padding:12px}.audio-player{width:100%}.audio-controls{flex-wrap:wrap}.voice-recorder{padding:12px}.record-btn{width:60px;height:60px}.record-btn:before{width:24px;height:24px}.repeat-mode .target-text{font-size:1.5rem}.score-display{font-size:2.5rem}.furigana-toggle{margin-bottom:12px}.big-button{padding:16px 24px;font-size:1rem}}@media (max-width: 375px){.messages{height:calc(100vh - 260px)}.practice-setup h2{font-size:1.3rem}.setup-options{padding:16px}}@media (max-height: 500px) and (orientation: landscape){.messages{height:calc(100vh - 200px)}.practice-setup{min-height:auto;padding:16px}}@supports (padding: max(0px)){.app{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));padding-top:max(12px,env(safe-area-inset-top));padding-bottom:max(12px,env(safe-area-inset-bottom))}}.checking-pronunciation{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;background:#16213e;border:2px solid #333;border-radius:12px;margin:20px 0}.checking-pronunciation p{color:#aaa;margin-top:12px;font-size:.95rem}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1a1a2e}.loading-content{text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid #333;border-top-color:#7289da;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-content p{color:#888;font-size:1.1rem}.lesson-mode{max-width:900px;margin:0 auto;padding:20px}.lesson-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #333}.lesson-header h2{flex:1;font-size:1.8rem;color:#fff}.back-btn{background:#16213e;border:2px solid #333;color:#fff;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s}.back-btn:hover{background:#1a4a7a;border-color:#0f3460}.start-chat-btn{background:#e94560;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s}.sort-controls{display:flex;gap:8px}.sort-controls button{background:#16213e;border:2px solid #333;color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s}.sort-controls button:hover{background:#1a4a7a;border-color:#0f3460}.sort-controls button.active{background:#e94560;border-color:#e94560;color:#fff}.start-chat-btn:hover{background:#c73e54}.lesson-count{color:#888;font-size:.9rem}.loading{text-align:center;padding:40px;color:#888}.lessons-list{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 200px);overflow-y:auto;padding-right:8px}.lessons-list::-webkit-scrollbar{width:8px}.lessons-list::-webkit-scrollbar-track{background:#1a1a2e;border-radius:4px}.lessons-list::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.lessons-list::-webkit-scrollbar-thumb:hover{background:#e94560}.lesson-card{background:#16213e;border:2px solid #333;border-radius:12px;padding:16px 20px;cursor:pointer;transition:all .3s}.lesson-card:hover{background:#0f3460;border-color:#e94560;transform:translate(4px)}.lesson-card-header{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.lesson-card-header .lesson-date{font-size:.8rem;color:#888}.lesson-card-header .lesson-title{font-size:1.1rem;font-weight:700;color:#fff}.lesson-card-stats{display:flex;gap:16px;font-size:.85rem;color:#aaa;margin-bottom:8px}.lesson-topics{font-size:.8rem;color:#888;font-style:italic}.topic-tag{background:#e9456033;padding:4px 10px;border-radius:12px;font-size:.75rem;color:#e94560}.lesson-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.lesson-tabs button{background:#16213e;border:2px solid #333;color:#fff;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s}.lesson-tabs button.active{border-color:#e94560;background:#e94560}.lesson-tabs button:hover:not(.active){background:#1a4a7a}.toggles-row{display:flex;gap:24px;margin-bottom:16px}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;color:#aaa;font-size:.9rem}.toggle-label input{width:18px;height:18px;accent-color:#e94560}.furigana-toggle{margin-bottom:16px}.furigana-toggle label{display:flex;align-items:center;gap:8px;cursor:pointer;color:#aaa}.furigana-toggle input{width:18px;height:18px;accent-color:#e94560}.lesson-content{background:#16213e;border:2px solid #333;border-radius:12px;padding:24px}.info-card{background:#0f3460;padding:16px;border-radius:8px;margin-bottom:20px;border:1px solid #333}.info-card h3{margin-bottom:12px;color:#e94560}.info-card p{margin-bottom:8px;color:#ccc}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#1a1a2e;padding:20px;border-radius:8px;text-align:center;border:1px solid #333}.stat-number{display:block;font-size:2.5rem;font-weight:700;color:#e94560}.stat-label{font-size:.85rem;color:#888}.quick-start{text-align:center;padding:24px;background:#e945601a;border-radius:12px;border:2px solid #e94560}.quick-start h3{margin-bottom:16px;color:#e94560}.big-button{background:#e94560;color:#fff;border:none;padding:16px 32px;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s}.big-button:hover{background:#c73e54}.vocab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.vocab-card{background:#1a1a2e;padding:16px;border-radius:8px;border:1px solid #333;transition:all .2s}.vocab-card:hover{border-color:#e94560}.vocab-card .jp-word{font-size:1.3rem;margin-bottom:4px;color:#fff}.vocab-card .romaji{font-size:.85rem;color:#888;margin-bottom:8px;font-style:italic}.vocab-card .meaning{font-size:.95rem;color:#ccc}.type-tag{display:inline-block;background:#0f3460;padding:2px 8px;border-radius:4px;font-size:.75rem;color:#aaa;margin-top:8px}.grammar-card{background:#1a1a2e;padding:20px;border-radius:8px;border:1px solid #333;margin-bottom:16px}.grammar-card h4{font-size:1.2rem;color:#e94560;margin-bottom:8px}.grammar-card .romaji{font-size:.9rem;color:#888;margin-bottom:12px;font-style:italic}.grammar-card .explanation{color:#ccc;margin-bottom:16px;line-height:1.6}.grammar-card .explanation p{margin:4px 0}.grammar-card .explanation .table-line{font-family:monospace;font-size:.9rem;white-space:pre-wrap;background:#0f1a30;padding:4px 8px;border-radius:4px}.grammar-card .explanation .table-separator{color:#666}.grammar-table{width:100%;border-collapse:collapse;margin:12px 0;background:#0f1a30;border-radius:8px;overflow:hidden;font-size:.9rem}.grammar-table td{padding:10px 12px;border:1px solid #1a3a5c;vertical-align:top}.grammar-table tr:first-child td{background:#1a3a5c;font-weight:700;color:#fff}.grammar-table tr:nth-child(2n) td{background:#1a3a5c4d}.grammar-card .examples{background:#0f3460;padding:12px;border-radius:8px}.grammar-card .examples h5{margin-bottom:8px;color:#888}.example{padding:8px 0;border-bottom:1px solid #333}.example:last-child{border-bottom:none}.example .jp{display:block;font-size:1.4rem;margin-bottom:6px;color:#fff}.example .en{font-size:1rem;color:#888}.practice-tab h3{margin-bottom:16px;color:#fff}.practice-list{display:flex;flex-direction:column;gap:8px}.practice-item{display:flex;gap:12px;padding:12px;background:#1a1a2e;border-radius:8px;align-items:center;border:1px solid #333}.practice-item .number{color:#e94560;font-size:.9rem;min-width:24px;font-weight:700}.practice-item .phrase{font-size:1.1rem;color:#fff}.practice-item .phrase-content{display:flex;flex-direction:column;gap:4px;flex:1}.practice-item .phrase-jp{font-size:1.1rem;color:#fff}.practice-item .phrase-en{font-size:.9rem;color:#888;font-style:italic}.practice-item .phrase-romaji{font-size:.85rem;color:#666;font-style:italic}ruby{ruby-align:center}rt{font-size:.75em;color:#aaa}ruby.furigana-failed rt{color:#e94560;font-weight:700}@media (max-width: 480px){.lesson-mode{padding:12px}.lesson-header{flex-direction:column;gap:12px;text-align:center;padding-bottom:12px;margin-bottom:16px}.lesson-header h2{font-size:1.2rem;order:-1}.back-btn,.start-chat-btn{width:100%;padding:10px 16px;font-size:.9rem}.lesson-tabs{flex-wrap:wrap;gap:6px;margin-bottom:16px}.lesson-tabs button{padding:8px 12px;font-size:.8rem;flex:1;min-width:80px}.furigana-toggle{margin-bottom:12px;font-size:.9rem}.lesson-content{padding:12px}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:16px}.stat-number{font-size:2rem}.info-card{padding:16px}.quick-start{padding:20px}.big-button{padding:16px 24px;font-size:1rem;width:100%}.vocab-grid{grid-template-columns:1fr;gap:12px}.vocab-card{padding:16px}.jp-word{font-size:1.5rem}.romaji{font-size:.9rem}.grammar-card{padding:16px}.grammar-card h3{font-size:1.3rem}.grammar-table{font-size:.85rem}.grammar-table td{padding:8px}.practice-list{gap:12px}.practice-item{padding:12px;font-size:1rem}.lessons-list{gap:10px;max-height:calc(100vh - 180px)}.lesson-card{padding:12px 16px}.lesson-card-header{flex-direction:column;gap:4px}.lesson-date{font-size:.8rem}.lesson-title{font-size:1rem}.lesson-card-stats{font-size:.8rem;flex-wrap:wrap;gap:8px}.lesson-topics{font-size:.75rem}}@media (max-width: 375px){.lesson-tabs button{font-size:.75rem;padding:6px 10px}.vocab-card{padding:12px}.jp-word{font-size:1.3rem}}@media (max-height: 500px) and (orientation: landscape){.lessons-list{max-height:calc(100vh - 140px)}}@supports (padding: max(0px)){.lesson-mode{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));padding-top:max(12px,env(safe-area-inset-top));padding-bottom:max(12px,env(safe-area-inset-bottom))}}.voice-recorder{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.audio-meter{width:100%;max-width:300px;height:8px;background:#1a1a2e;border-radius:4px;overflow:hidden;border:1px solid #333}.audio-level{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e 50%,#fbbf24 80%,#e94560);transition:width .03s ease-out;border-radius:4px}.audio-level.speaking{background:linear-gradient(90deg,#4ade80,#22c55e,#e94560);box-shadow:0 0 10px #4ade8080}.mode-indicator{font-size:.85rem;color:#888;min-height:20px;text-align:center}.vad-status{display:flex;align-items:center;gap:8px}.voice-detected{color:#4ade80;font-weight:700;animation:pulse .5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.record-button,.record-btn{padding:16px 32px;border:2px solid #e94560;border-radius:50px;background:#16213e;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;min-width:200px;user-select:none;-webkit-user-select:none;touch-action:manipulation}.record-button:hover:not(:active),.record-btn:hover{background:#e9456033;transform:scale(1.02)}.record-button.recording,.record-btn.recording{background:#e94560}.record-button.recording.speaking,.record-btn.speaking{background:linear-gradient(135deg,#e94560,#4ade80);box-shadow:0 0 30px #4ade8099;transform:scale(1.05);transition:all .3s ease-out}.record-button,.record-btn{transition:all .3s ease-out}@keyframes recording-pulse{0%,to{box-shadow:0 0 #e94560b3}50%{box-shadow:0 0 0 15px #e9456000}}.record-button:active{transform:scale(.98)}.instructions{color:#666;font-size:.8rem;text-align:center;margin-bottom:16px}.instructions small{display:block}.mode-toggle{display:flex;gap:8px;background:#16213e;padding:4px;border-radius:8px;border:1px solid #333}.mode-toggle button{padding:8px 16px;border:none;border-radius:6px;background:transparent;color:#888;font-size:.85rem;cursor:pointer;transition:all .2s}.mode-toggle button.active{background:#e94560;color:#fff}.mode-toggle button:hover:not(.active){color:#fff}.record-btn.disabled{opacity:.5;cursor:not-allowed;background:#333}.record-btn.disabled:hover{background:#333;transform:none}@media (max-width: 480px){.voice-recorder{padding:12px;gap:12px}.record-btn{width:60px;height:60px}.record-btn:before{width:24px;height:24px}.recording .record-btn:before{width:20px;height:20px;border-radius:4px}.status{font-size:.85rem}.timer{font-size:1.2rem}.transcription{padding:12px;min-height:60px;font-size:.9rem}.mode-toggle{gap:8px}.mode-toggle button{padding:6px 12px;font-size:.8rem}}@media (max-width: 375px){.record-btn{width:56px;height:56px}.record-btn:before{width:22px;height:22px}}.highlighted-text{display:inline;line-height:1.8}.text-segment{display:inline;padding:2px 1px;border-radius:3px;transition:background-color .1s ease}.text-segment.highlighted{background-color:#e9456066;color:#fff;font-weight:500}.message.assistant .text-segment.highlighted{background-color:#e9456080}.message.user .text-segment.highlighted{background-color:#0f3460b3}.memory-mode-setup,.memory-mode-study,.memory-mode-complete,.memory-mode-loading{min-height:100vh;padding:20px;background:#1a1a2e;color:#fff}.memory-card{max-width:800px;margin:0 auto;background:#16213e;border-radius:16px;padding:30px;box-shadow:0 4px 20px #0000004d}.memory-mode-setup h2{text-align:center;margin-bottom:10px;font-size:1.8rem}.memory-mode-setup .description{text-align:center;font-size:1.1rem;color:#ccc;margin-bottom:5px}.memory-mode-setup .subtitle{text-align:center;font-size:.9rem;color:#888;margin-bottom:30px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:30px}.stat-box{background:#0f3460;padding:20px;border-radius:12px;text-align:center}.stat-box.due{background:#28a74533;border:1px solid #28a745}.stat-box.new{background:#ffc10733;border:1px solid #ffc107}.stat-box.review{background:#17a2b833;border:1px solid #17a2b8}.stat-value{font-size:1.8rem;font-weight:700;margin-bottom:5px}.stat-label{font-size:.85rem;color:#aaa}.lesson-selection{margin-bottom:30px}.lesson-selection h3{margin-bottom:15px;font-size:1.1rem}.lesson-chips{display:flex;flex-wrap:wrap;gap:10px}.lesson-chip{padding:8px 16px;border:2px solid #333;border-radius:20px;background:#1a1a2e;color:#fff;cursor:pointer;transition:all .3s;font-size:.9rem}.lesson-chip:hover{border-color:#e94560}.lesson-chip.selected{background:#e94560;border-color:#e94560}.start-btn{width:100%;max-width:300px;margin:0 auto;display:block;padding:15px 30px;border:none;border-radius:8px;background:#e94560;color:#fff;font-size:1.1rem;cursor:pointer;transition:background .3s}.start-btn:hover:not(:disabled){background:#c73e54}.start-btn:disabled{background:#555;cursor:not-allowed}.hint{text-align:center;color:#888;font-size:.9rem;margin-top:15px}.study-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chips{display:flex;gap:10px}.chip{padding:5px 12px;border-radius:20px;background:#0f3460;font-size:.85rem}.chip.status{background:#9b59b6}.close-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:5px}.progress-bar{height:6px;background:#0f3460;border-radius:3px;margin-bottom:30px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#e94560,#9b59b6);border-radius:3px;transition:width .3s}.question{text-align:center;margin-bottom:40px}.question-label{font-size:.85rem;color:#888;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.question-text{font-size:1.8rem;font-weight:500;color:#fff}.reveal-section{text-align:center;margin-bottom:30px}.reveal-btn{padding:15px 40px;border:2px solid #e94560;border-radius:8px;background:transparent;color:#fff;font-size:1.1rem;cursor:pointer;transition:all .3s}.reveal-btn:hover{background:#e94560}.reveal-hint{color:#888;font-size:.9rem;margin-top:15px}.answer-section{margin-bottom:30px}.answer-box{background:#0f3460;padding:30px;border-radius:12px;margin-bottom:30px;text-align:center}.recorder-section{margin-bottom:30px;text-align:center}.recorder-hint{color:#888;font-style:italic}.assessment{text-align:center}.assessment-label{font-size:1rem;color:#ccc;margin-bottom:20px}.assessment-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.assessment-btn{padding:12px 20px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s;min-width:100px}.assessment-btn.again{background:#dc3545;color:#fff}.assessment-btn.hard{background:#ffc107;color:#000}.assessment-btn.good{background:#28a745;color:#fff}.assessment-btn.easy{background:#17a2b8;color:#fff}.assessment-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.memory-mode-complete{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center}.complete-icon{font-size:4rem;color:#28a745;margin-bottom:20px}.memory-mode-complete h2{font-size:2rem;margin-bottom:10px}.memory-mode-complete p{color:#888;margin-bottom:30px}.memory-mode-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh}.spinner{font-size:1.5rem;color:#e94560}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.memory-card{padding:20px}.question-text{font-size:1.4rem}.assessment-buttons{flex-direction:column}.assessment-btn{width:100%}}.offline-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px}.offline-container{text-align:center;max-width:500px;background:#ffffff0d;border-radius:24px;padding:40px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gif-container{margin-bottom:30px}.error-gif{max-width:300px;max-height:200px;border-radius:16px;box-shadow:0 10px 40px #0000004d}.offline-title{font-size:2.5rem;color:#e94560;margin-bottom:15px;font-weight:700}.offline-message{font-size:1.3rem;color:#fff;margin-bottom:25px;line-height:1.5}.offline-details{background:#0003;border-radius:12px;padding:20px;margin-bottom:25px}.offline-details code{background:#7289da33;color:#7289da;padding:4px 8px;border-radius:6px;font-family:monospace;word-break:break-all}.offline-hint{color:#888;font-size:.9rem;margin-top:10px}.retry-btn{background:linear-gradient(135deg,#7289da,#5b73c7);color:#fff;border:none;padding:15px 40px;font-size:1.1rem;border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:600}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #7289da66}.retry-btn:active{transform:translateY(0)}
