.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d47a1,#1976d2);padding:20px}.login-container{background:#fff;border-radius:12px;padding:40px;box-shadow:0 8px 24px #00000026;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:#0d47a1;margin:0 0 8px;font-size:28px}.login-header p{color:#666;margin:0;font-size:16px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#333;font-size:14px}.form-group input{padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#0d47a1}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;font-size:14px;border-left:4px solid #c62828}.login-button{background:#0d47a1;color:#fff;border:none;padding:14px;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.login-button:hover:not(:disabled){background:#1565c0}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-hint{text-align:center;color:#666;margin-top:8px}.settings-menu{position:relative}.settings-button{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1}.settings-button:hover{transform:rotate(45deg)}.settings-button:active{transform:rotate(45deg) scale(.95)}.settings-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:240px;overflow:hidden;animation:slideDown .2s ease-out;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-dropdown-header{padding:1rem;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#f5f5f5,#e8e8e8)}.settings-dropdown-title{font-weight:600;font-size:.95rem;color:#333}.settings-section{padding:.75rem}.settings-section-label{font-size:.8rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;padding:.5rem}.language-options-list{display:flex;flex-direction:column;gap:.25rem}.language-option-item{background:transparent;border:none;padding:.75rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .15s ease;font-family:inherit;font-size:.95rem;text-align:left;width:100%}.language-option-item:hover{background:#f5f5f5}.language-option-item.active{background:linear-gradient(135deg,#e3f2fd,#bbdefb);font-weight:600}.language-option-flag{font-size:1.5rem;line-height:1}.language-option-name{flex:1;color:#333}.language-option-check{color:#0d47a1;font-weight:700;font-size:1.2rem}.settings-version{padding:.6rem 1rem;border-top:1px solid #e0e0e0;font-size:.75rem;color:#999;text-align:center}@media (max-width: 640px){.settings-dropdown{right:-.5rem;min-width:200px}}.app-header{background:#0d47a1;color:#fff;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.header-left{display:flex;align-items:center;gap:16px}.menu-button{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:8px 12px;border-radius:4px;transition:background .2s}.menu-button:hover{background:#ffffff1a}.app-title{font-size:20px;margin:0;font-weight:600}.header-right{display:flex;align-items:center;gap:16px}.user-email{font-size:14px;opacity:.9}.logout-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.logout-button:hover{background:#ffffff4d}@media (max-width: 600px){.app-header{padding:10px 12px}.header-left{gap:8px}.menu-button{font-size:20px;padding:4px 8px}.app-title{font-size:13px;white-space:nowrap}.header-right{gap:8px}.user-email{display:none}.logout-button{padding:6px 10px;font-size:12px}}.sidebar-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.lesson-sidebar{position:fixed;top:0;left:-400px;width:400px;max-width:90vw;height:100vh;background:#fff;box-shadow:-2px 0 8px #0000001a;transition:left .3s ease;z-index:1000;display:flex;flex-direction:column}.lesson-sidebar.open{left:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background:#0d47a1;color:#fff}.sidebar-header h2{margin:0;font-size:20px}.close-button{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.close-button:hover{background:#ffffff1a}.sidebar-content{flex:1;overflow-y:auto;padding:20px}.vocabulary-trainer-button{width:100%;padding:16px;margin-bottom:20px;background:linear-gradient(135deg,#0d47a1,#1976d2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0d47a133}.vocabulary-trainer-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0d47a14d;background:linear-gradient(135deg,#1565c0,#1e88e5)}.vocabulary-trainer-button:active{transform:translateY(0)}.sidebar-loading,.sidebar-error,.sidebar-empty{text-align:center;padding:40px 20px;color:#666}.sidebar-error{color:#c62828}.sidebar-empty small{display:block;margin-top:8px;color:#999}.lessons-list{display:flex;flex-direction:column;gap:12px}.lesson-item{display:flex;gap:12px;border:1px solid #e0e0e0;border-radius:8px;padding:16px;transition:all .2s}.lesson-item:hover{border-color:#0d47a1;box-shadow:0 2px 8px #0d47a11a}.lesson-info{flex:1;cursor:pointer}.lesson-info h3{margin:0 0 8px;font-size:16px;color:#333}.lesson-meta{display:flex;gap:8px;margin-bottom:8px}.lesson-level,.lesson-topic{font-size:12px;padding:4px 8px;border-radius:4px;background:#e3f2fd;color:#0d47a1;font-weight:500}.lesson-stats{display:flex;gap:12px;margin-bottom:8px}.lesson-stats .stat{font-size:12px;color:#666}.lesson-date{font-size:12px;color:#999}.delete-button{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s;height:fit-content}.delete-button:hover:not(:disabled){background:#ffebee}.delete-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 600px){.lesson-sidebar{width:100vw;right:-100vw}}.lesson-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.lesson-card:hover{box-shadow:0 4px 12px #0d47a126;transform:translateY(-2px);border-color:#0d47a1}.lesson-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.lesson-card-title{margin:0;font-size:1.25rem;font-weight:600;color:#1a1a1a;flex:1;line-height:1.3}.lesson-card-level{background:#0d47a1;color:#fff;padding:4px 12px;border-radius:16px;font-size:.875rem;font-weight:600;white-space:nowrap}.lesson-card-topic{margin-bottom:16px;color:#666;font-size:.9375rem}.topic-label{font-weight:500;color:#333}.lesson-card-stats{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:6px;color:#666;font-size:.875rem}.stat-icon{font-size:1rem}.stat-text{font-weight:500}.lesson-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid #f0f0f0}.lesson-card-date{color:#999;font-size:.8125rem}.lesson-card-cta{color:#0d47a1;font-weight:600;font-size:.9375rem;transition:color .2s ease}.lesson-card:hover .lesson-card-cta{color:#1565c0}@media (max-width: 480px){.lesson-card{padding:16px}.lesson-card-title{font-size:1.125rem}.lesson-card-stats{gap:12px}}.enhanced-audio-player{background:#f8f9fa;border-radius:12px;padding:20px;margin-bottom:24px}.audio-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px}.audio-label{font-weight:600;color:#0d47a1;font-size:.9375rem;flex:1}.cache-indicator{font-size:.75rem;color:#28a745;background:#e8f5e9;padding:4px 8px;border-radius:4px;font-weight:600;white-space:nowrap}.audio-loading,.audio-error{padding:12px;border-radius:6px;text-align:center;font-size:.875rem}.audio-loading{background:#f0f7ff;color:#0d47a1}.audio-error{background:#ffebee;color:#c62828}.audio-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px}.play-pause-btn{width:48px;height:48px;border-radius:50%;background:#0d47a1;color:#fff;border:none;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.play-pause-btn:hover{background:#1565c0;transform:scale(1.05)}.play-pause-btn:active{transform:scale(.95)}.time-display{font-size:.875rem;color:#666;font-family:Courier New,monospace;min-width:100px;text-align:center;flex-shrink:0}.seek-bar{flex:1;height:6px;border-radius:3px;background:#ddd;outline:none;-webkit-appearance:none;cursor:pointer}.seek-bar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#0d47a1;cursor:pointer;transition:all .2s ease}.seek-bar::-webkit-slider-thumb:hover{background:#1565c0;transform:scale(1.2)}.seek-bar::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#0d47a1;cursor:pointer;border:none;transition:all .2s ease}.seek-bar::-moz-range-thumb:hover{background:#1565c0;transform:scale(1.2)}.volume-control{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:120px}.volume-icon{font-size:1.125rem;line-height:1;display:flex;align-items:center}.volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:6px;border-radius:3px;background:#ddd;outline:none;cursor:pointer;background:linear-gradient(to right,#0D47A1 0%,#0D47A1 var(--volume-percent),#ddd var(--volume-percent),#ddd 100%)}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#0d47a1;cursor:pointer;box-shadow:0 1px 3px #0000004d;transition:transform .2s ease}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.volume-slider::-moz-range-track{width:100%;height:6px;border-radius:3px;background:#ddd;border:none}.volume-slider::-moz-range-progress{height:6px;border-radius:3px;background:#0d47a1}.volume-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#0d47a1;cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d;transition:transform .2s ease}.volume-slider::-moz-range-thumb:hover{transform:scale(1.15)}.playback-rate-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.rate-label{font-size:.875rem;color:#666;font-weight:600;margin-right:4px}.rate-btn{padding:6px 12px;border-radius:6px;background:#fff;border:1px solid #ddd;color:#666;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s ease}.rate-btn:hover{border-color:#0d47a1;color:#0d47a1;background:#f0f7ff}.rate-btn.active{background:#0d47a1;color:#fff;border-color:#0d47a1}@media (max-width: 768px){.audio-controls{flex-wrap:wrap}.seek-bar{width:100%;order:3;margin-top:8px}.time-display{order:1;min-width:auto}.volume-control{order:2}}@media (max-width: 480px){.enhanced-audio-player{padding:16px}.play-pause-btn{width:40px;height:40px;font-size:1rem}.volume-slider{width:60px}.playback-rate-controls{gap:6px}.rate-btn{padding:4px 8px;font-size:.75rem}}.lesson-detail{max-width:900px;margin:0 auto;padding:0 0 40px}.lesson-detail-loading,.lesson-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#0d47a1;border-radius:50%;animation:spin .8s linear infinite}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid #ffffff66;border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px}.lesson-detail-header{margin-bottom:32px}.back-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#0d47a1;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease;margin-bottom:20px}.back-btn:hover{background:#f5f5f5;border-color:#0d47a1}.lesson-title-section h1{margin:0 0 16px;font-size:2rem;color:#1a1a1a}.lesson-badges{display:flex;gap:12px;flex-wrap:wrap}.badge{padding:6px 16px;border-radius:20px;font-size:.875rem;font-weight:600}.badge.level{background:#0d47a1;color:#fff}.badge.topic{background:#e3f2fd;color:#0d47a1}.lesson-tabs{display:flex;gap:8px;margin-bottom:24px;overflow-x:auto;padding:4px 0;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#0D47A1 #e3f2fd}.lesson-tabs::-webkit-scrollbar{height:6px}.lesson-tabs::-webkit-scrollbar-track{background:#e3f2fd;border-radius:3px}.lesson-tabs::-webkit-scrollbar-thumb{background:#0d47a1;border-radius:3px}.tab-btn{flex-shrink:0;padding:12px 20px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tab-btn:hover{border-color:#0d47a1;color:#0d47a1;background:#f5f7fa}.tab-btn.active{background:#0d47a1;color:#fff;border-color:#0d47a1;box-shadow:0 2px 8px #0d47a14d}.tab-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lesson-section{background:#fff;border-radius:12px;padding:28px;margin-bottom:24px;box-shadow:0 2px 8px #00000014}.section-heading{margin:0 0 20px;font-size:1.5rem;color:#0d47a1;border-bottom:2px solid #e3f2fd;padding-bottom:12px}.grammar-topic-label{font-size:.875rem;color:#666;margin:-8px 0 16px}.grammar-topic-label strong{color:#0d47a1}.grammar-markdown{line-height:1.7;color:#333;font-size:1rem}.grammar-markdown h2{font-size:1.25rem;color:#0d47a1;margin:1.2rem 0 .6rem}.grammar-markdown h3{font-size:1.1rem;color:#1565c0;margin:1rem 0 .5rem}.grammar-markdown table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.9rem}.audio-player-box{margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px}.audio-player{width:100%;height:40px}.dialog-list{display:flex;flex-direction:column;gap:20px}.dialog-item{display:grid;grid-template-columns:120px 1fr;gap:16px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #0D47A1}.dialog-speaker{font-weight:700;color:#0d47a1;font-size:1rem}.dialog-content{display:flex;flex-direction:column;gap:6px}.dialog-greek{font-size:1.125rem;font-weight:600;color:#1a1a1a}.dialog-ipa{font-size:.9375rem;color:#666;font-style:italic}.dialog-english{font-size:.9375rem;color:#555}.vocabulary-table{overflow-x:auto}.vocab-header{display:grid;grid-template-columns:2fr 2fr 2fr 1.5fr;gap:16px;padding:12px 16px;background:#0d47a1;color:#fff;font-weight:600;border-radius:8px 8px 0 0;align-items:baseline}.vocab-row{display:grid;grid-template-columns:2fr 2fr 2fr 1.5fr;gap:16px;padding:16px;border-bottom:1px solid #e0e0e0}.vocab-row:last-child{border-bottom:none}.vocab-row:hover{background:#f8f9fa}.vocab-col{display:flex;align-items:center}.vocab-greek{font-weight:600;color:#1a1a1a}.article{color:#0d47a1;font-weight:700;margin-right:6px}.vocab-ipa{color:#666;font-style:italic}.vocab-english{color:#333}.vocab-pos{color:#999;font-size:.875rem}.story-content,.story-text{margin-bottom:24px}.story-text h3{margin:0 0 12px;font-size:1.125rem;color:#0d47a1}.story-greek{font-size:1.125rem;line-height:1.8;color:#1a1a1a;font-weight:500}.story-ipa{font-size:1rem;line-height:1.7;color:#666;font-style:italic}.story-english{font-size:1rem;line-height:1.7;color:#333}.story-audio-controls{margin-top:24px}.generate-audio-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;background:#0d47a1;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.generate-audio-btn:hover:not(:disabled){background:#1565c0;transform:translateY(-1px);box-shadow:0 4px 12px #0d47a14d}.generate-audio-btn:disabled{background:#999;cursor:not-allowed;transform:none}.notes-section p{line-height:1.7;color:#555}@media (max-width: 768px){.lesson-title-section h1{font-size:1.5rem}.section-heading{font-size:1.25rem}.lesson-tabs{gap:6px;margin-bottom:20px}.tab-btn{padding:10px 16px;font-size:.875rem}.dialog-item{grid-template-columns:1fr;padding:12px}.dialog-speaker{padding-bottom:8px;border-bottom:1px solid #ddd;margin-bottom:8px}.vocab-header,.vocab-row{grid-template-columns:1fr;gap:8px}.vocab-header{display:none}.vocab-row{padding:12px;display:flex;flex-direction:column;gap:6px}.vocab-col{display:block}.vocab-greek:before{content:"Greek: ";font-weight:600;color:#0d47a1;font-size:.8125rem}.vocab-ipa:before{content:"IPA: ";font-weight:600;color:#0d47a1;font-size:.8125rem}.vocab-english:before{content:"English: ";font-weight:600;color:#0d47a1;font-size:.8125rem}.vocab-pos:before{content:"Type: ";font-weight:600;color:#0d47a1;font-size:.8125rem}}@media (max-width: 480px){.lesson-section{padding:16px;margin-bottom:16px}.lesson-detail{padding:0}.lesson-detail-header{margin-bottom:20px}.back-btn{font-size:.875rem;padding:6px 12px}.lesson-badges{gap:8px}.badge{font-size:.8125rem;padding:4px 12px}.tab-btn{padding:8px 12px;font-size:.8125rem}}.lesson-generation-form{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0d47a11a;margin-bottom:24px}.lesson-generation-form h2{margin:0 0 20px;color:#0d47a1;font-size:20px;font-weight:600}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;color:#0d47a1;font-weight:500;font-size:14px}.required{color:#d32f2f;margin-left:4px}.topic-input,.level-select,.vocab-count-select{width:100%;padding:12px;border:2px solid #e3f2fd;border-radius:8px;font-size:16px;transition:all .2s;font-family:inherit}.topic-input:focus,.level-select:focus,.vocab-count-select:focus{outline:none;border-color:#0d47a1;box-shadow:0 0 0 3px #0d47a11a}.topic-input::placeholder{color:#90a4ae}.form-row{display:grid;grid-template-columns:2fr 1fr;gap:16px}.generate-lesson-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#0d47a1,#1976d2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}.generate-lesson-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0d47a14d}.generate-lesson-btn:active:not(:disabled){transform:translateY(0)}.generate-lesson-btn:disabled{opacity:.6;cursor:not-allowed}.generate-lesson-btn.loading{background:linear-gradient(135deg,#1976d2,#42a5f5)}.spinner{width:18px;height:18px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 600px){.form-row{grid-template-columns:1fr}.lesson-generation-form{padding:20px}}.loading-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-modal{background:#fff;border-radius:16px;padding:48px 40px;max-width:480px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;text-align:center}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.loading-spinner-large{width:80px;height:80px;border:6px solid #e3f2fd;border-top-color:#0d47a1;border-radius:50%;margin:0 auto 24px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{margin:0 0 8px;font-size:1.5rem;color:#0d47a1;font-weight:700}.loading-subtitle{margin:0 0 32px;font-size:.9375rem;color:#666}.loading-steps{display:flex;flex-direction:column;gap:16px;text-align:left}.loading-step{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9fa;border-radius:8px;animation:pulse 2s ease-in-out infinite}.loading-step:nth-child(1){animation-delay:0s}.loading-step:nth-child(2){animation-delay:.2s}.loading-step:nth-child(3){animation-delay:.4s}.loading-step:nth-child(4){animation-delay:.6s}@keyframes pulse{0%,to{background:#f8f9fa}50%{background:#e3f2fd}}.step-icon{font-size:1.5rem;flex-shrink:0}.step-text{font-size:.9375rem;color:#333;font-weight:500}@media (max-width: 480px){.loading-modal{padding:36px 24px}.loading-spinner-large{width:64px;height:64px}.loading-title{font-size:1.25rem}.loading-steps{gap:12px}.loading-step{padding:10px 12px}.step-icon{font-size:1.25rem}.step-text{font-size:.875rem}}.language-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.language-modal{background:#fff;border-radius:24px;padding:3rem 2rem;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.language-modal-header{text-align:center;margin-bottom:2.5rem}.language-modal-title{font-size:1.8rem;font-weight:700;color:#0d47a1;margin:0 0 1rem;line-height:1.3}.language-modal-subtitle{font-size:.95rem;color:#666;line-height:1.6;margin:0}.language-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.language-option{background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border:3px solid transparent;border-radius:16px;padding:2rem 1.5rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-family:inherit}.language-option:hover{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#0d47a1;transform:translateY(-4px);box-shadow:0 8px 20px #0d47a133}.language-option:active{transform:translateY(-2px)}.language-flag{font-size:3rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.language-name{font-size:1.1rem;font-weight:600;color:#333}.language-modal-note{text-align:center;font-size:.85rem;color:#999;line-height:1.6;margin:0;padding-top:1rem;border-top:1px solid #e0e0e0}@media (max-width: 640px){.language-modal{padding:2rem 1.5rem}.language-modal-title{font-size:1.5rem}.language-options{grid-template-columns:1fr}.language-option{padding:1.5rem}}.level-selector{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.level-selector-title{font-size:.9rem;font-weight:600;color:#555;white-space:nowrap}.level-selector-buttons{display:flex;gap:.5rem;flex:1}.level-btn{flex:1;display:flex;flex-direction:column;align-items:center;padding:.6rem .75rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:0}.level-btn:hover{border-color:#90caf9;background:#f3f8ff}.level-btn.active{background:#0d47a1;border-color:#0d47a1;color:#fff}.level-btn-title{font-size:.9rem;font-weight:700}.level-btn-desc{font-size:.7rem;opacity:.75;margin-top:2px;text-align:center}@media (max-width: 480px){.level-selector{flex-direction:column;align-items:flex-start}.level-selector-buttons{width:100%}.level-btn-desc{display:none}}.type-word-card{outline:none}.type-word-input-row{display:flex;gap:.5rem;align-items:center;margin:1rem 0}.article-select{width:72px;flex-shrink:0;padding:.6rem .4rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;color:#0d47a1;font-weight:600;text-align:center;transition:border-color .2s}.article-select:focus{outline:none;border-color:#0d47a1}.article-select:disabled{background:#f5f5f5;cursor:default}.word-input{flex:1;padding:.6rem .75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1.1rem;font-family:inherit;transition:border-color .2s}.word-input:focus{outline:none;border-color:#0d47a1}.word-input:disabled{background:#f5f5f5}.word-input.feedback-correct-input{border-color:#4caf50;background:#f1f8f1}.word-input.feedback-typo-input{border-color:#ff9800;background:#fff8f0}.word-input.feedback-incorrect-input{border-color:#f44336;background:#fff5f5}.type-word-feedback{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.75rem 1rem;border-radius:8px;margin:.5rem 0 1rem;font-size:.95rem}.type-word-feedback.feedback-correct{background:#c8e6c9;color:#1b5e20}.type-word-feedback.feedback-typo{background:#fff3e0;color:#e65100}.type-word-feedback.feedback-incorrect{background:#ffcdd2;color:#b71c1c}.feedback-label{font-weight:600}.correct-answer-display{font-size:1.05rem;font-weight:700;color:inherit}.type-word-reference{font-size:.9rem;color:#555;margin-bottom:.5rem;text-align:center}.fill-gap-card{outline:none}.fill-gap-template{font-size:1.6rem;font-weight:700;color:#0d47a1;letter-spacing:.05em}.gap-blank{color:#bdbdbd;border-bottom:2px solid #90caf9;padding:0 1px;margin:0 1px}.fill-gap-english{font-size:.95rem;color:#555;margin-top:.4rem}.missing-count{font-size:.85rem;color:#777;font-weight:400}.fill-gap-input{width:100%;padding:.6rem .75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1.1rem;font-family:inherit;margin:1rem 0;transition:border-color .2s;box-sizing:border-box}.fill-gap-input:focus{outline:none;border-color:#0d47a1}.fill-gap-input:disabled{background:#f5f5f5}.fill-gap-input.fill-gap-correct{border-color:#4caf50;background:#f1f8f1}.fill-gap-input.fill-gap-incorrect{border-color:#f44336;background:#fff5f5}.fill-gap-feedback{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.fill-gap-feedback.feedback-correct{background:#c8e6c9;color:#1b5e20}.fill-gap-feedback.feedback-incorrect{background:#ffcdd2;color:#b71c1c}.fill-gap-feedback .feedback-label{font-weight:600}.fill-gap-feedback .correct-answer-display{font-size:1.05rem;font-weight:700}.vocabulary-trainer{display:flex;flex-direction:column;height:100%;background:linear-gradient(135deg,#0d47a1,#1976d2);color:#fff;overflow:hidden}.vocab-trainer-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.vocab-close-btn{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.vocab-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.vocab-trainer-header h1{margin:0;font-size:1.25rem;font-weight:600}.vocab-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem 0;background:#0000001a}.vocab-tab{flex:1;padding:.75rem 1.5rem;background:#ffffff1a;border:none;color:#ffffffb3;font-size:1rem;font-weight:500;border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s}.vocab-tab:hover{background:#ffffff26;color:#ffffffe6}.vocab-tab.active{background:#fff;color:#0d47a1;font-weight:600}.vocab-content{flex:1;background:#fff;color:#333;overflow-y:auto;border-radius:0}.vocab-all-words{padding:1.5rem}.vocab-empty{text-align:center;padding:3rem 1rem;color:#666}.vocab-empty p{font-size:1.1rem;margin-bottom:.5rem}.vocab-empty small{color:#999}.vocab-controls{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.vocab-sort-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.vocab-sort-btn{padding:.35rem .85rem;border:2px solid #e0e0e0;border-radius:20px;background:#fff;font-size:.8rem;font-weight:500;color:#666;cursor:pointer;transition:all .15s}.vocab-sort-btn:hover{border-color:#0d47a1;color:#0d47a1}.vocab-sort-btn.active{background:#0d47a1;border-color:#0d47a1;color:#fff}.vocab-rank-badge{font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:10px}.vocab-rank-badge.rank-unseen{background:#f0f0f0;color:#999}.vocab-rank-badge.rank-weak{background:#fce4ec;color:#c62828}.vocab-rank-badge.rank-medium{background:#fff3e0;color:#e65100}.vocab-rank-badge.rank-strong{background:#e8f5e9;color:#2e7d32}.quiz-sync-status{font-size:.85rem;font-weight:500;padding:.4rem 1rem;border-radius:20px;margin-bottom:1rem;display:inline-block}.quiz-sync-syncing{background:#e3f2fd;color:#1565c0}.quiz-sync-saved{background:#e8f5e9;color:#2e7d32}.quiz-sync-offline{background:#f5f5f5;color:#757575}.vocab-search{margin-bottom:1.5rem}.vocab-search-input{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .2s}.vocab-search-input:focus{outline:none;border-color:#0d47a1;box-shadow:0 0 0 3px #0d47a11a}.vocab-list{display:flex;flex-direction:column;gap:.75rem}.vocab-item{background:#f8f9fa;padding:1rem;border-radius:8px;border-left:4px solid #0d47a1;transition:all .2s}.vocab-item:hover{background:#e3f2fd;transform:translate(4px)}.vocab-item-greek{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.vocab-article{color:#666;font-size:.9rem;font-weight:500}.vocab-greek-text{font-size:1.2rem;font-weight:600;color:#0d47a1}.vocab-item-translation{font-size:1rem;color:#333;margin-bottom:.25rem}.vocab-item-ipa{font-size:.9rem;color:#666;font-style:italic;margin-bottom:.5rem}.vocab-item-meta{display:flex;gap:.5rem;flex-wrap:wrap}.vocab-lesson-tag,.vocab-pos-tag{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;background:#0d47a11a;color:#0d47a1;font-weight:500}.vocab-pos-tag{background:#4caf501a;color:#4caf50}.vocab-quiz-start{padding:2rem;text-align:center}.vocab-quiz-start h2{color:#0d47a1;margin-bottom:1rem}.quiz-description{color:#666;font-size:1rem;margin-bottom:2rem;line-height:1.5}.btn-start-quiz{padding:1rem 2rem;background:#0d47a1;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-start-quiz:hover{background:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #0d47a14d}.vocab-quiz-empty{text-align:center;padding:3rem 1rem;color:#666}.vocab-quiz-empty p{font-size:1.1rem;margin-bottom:.5rem}.vocab-quiz-empty small{color:#999}.vocab-quiz-active{padding:1.5rem;max-width:800px;margin:0 auto}.quiz-progress{text-align:center;color:#666;font-size:.9rem;margin-bottom:1.5rem;font-weight:500}.quiz-question-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px #0000001a}.quiz-question-word{text-align:center;margin-bottom:1rem;padding:.3rem;background:#e3f2fd;border-radius:8px}.quiz-article{color:#666;font-size:1.1rem;margin-right:.5rem}.quiz-word-text{font-size:2rem;font-weight:700;color:#0d47a1}.quiz-word-ipa{margin-top:.5rem;font-size:1rem;color:#666;font-style:italic}.quiz-instruction{text-align:center;color:#666;margin-bottom:1.5rem;font-size:1rem}.quiz-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.quiz-option{padding:.8rem;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s;text-align:center}.quiz-option:hover:not(:disabled){background:#e3f2fd;border-color:#0d47a1;transform:translateY(-2px)}.quiz-option.selected{background:#e3f2fd;border-color:#0d47a1;font-weight:600}.quiz-option.correct{background:#c8e6c9;border-color:#4caf50;color:#2e7d32}.quiz-option.incorrect{background:#ffcdd2;border-color:#f44336;color:#c62828}.quiz-option:disabled{cursor:not-allowed}.quiz-actions{text-align:center}.btn-check-answer,.btn-next-question{padding:.75rem 2rem;background:#0d47a1;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-check-answer:disabled{background:#ccc;cursor:not-allowed}.btn-check-answer:hover:not(:disabled),.btn-next-question:hover{background:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #0d47a14d}.quiz-results{padding:2rem;text-align:center;max-width:500px;margin:0 auto}.quiz-results h2{color:#0d47a1;margin-bottom:2rem}.quiz-score-display{background:#e3f2fd;padding:2rem;border-radius:12px;margin-bottom:2rem}.quiz-percentage{font-size:4rem;font-weight:700;color:#0d47a1;margin-bottom:1rem}.quiz-score-text{font-size:1.1rem;color:#666}.quiz-weak-words{background:#fff3e0;border:1px solid #ffb74d;border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.5rem;text-align:left}.quiz-weak-words-title{font-size:.85rem;font-weight:600;color:#e65100;margin-bottom:.5rem}.quiz-weak-words ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.quiz-weak-words li{font-size:.95rem;color:#333}.weak-word-greek{font-weight:600}.weak-word-sep{color:#999}.weak-word-english{color:#555}.weak-word-pct{font-size:.8rem;color:#e65100;font-weight:600}.quiz-result-actions{display:flex;gap:1rem;justify-content:center}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#0d47a1;color:#fff}.btn-primary:hover{background:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #0d47a14d}.btn-secondary{background:#f8f9fa;color:#0d47a1;border:2px solid #0d47a1}.btn-secondary:hover{background:#e3f2fd;transform:translateY(-2px)}@media (max-width: 768px){.vocab-trainer-header{padding:.75rem 1rem}.vocab-trainer-header h1{font-size:1.1rem}.vocab-close-btn{width:36px;height:36px;font-size:1.25rem}.vocab-tabs{padding:.75rem 1rem 0}.vocab-tab{padding:.6rem 1rem;font-size:.9rem}.quiz-word-text{font-size:1.5rem}.quiz-options{grid-template-columns:1fr}.quiz-percentage{font-size:3rem}.quiz-result-actions{flex-direction:column}.vocab-quiz-active{padding:1rem}.quiz-question-card{padding:1.5rem}.vocab-all-words{padding:1rem}}.vocab-loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.grammar-trainer{display:flex;flex-direction:column;height:100vh;background:#f5f7fa;overflow:hidden}.grammar-trainer-header{display:flex;align-items:center;gap:1rem;padding:16px 24px;background:#0d47a1;color:#fff;flex-shrink:0}.grammar-trainer-title{margin:0;font-size:1.25rem;font-weight:700}.grammar-trainer-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.grammar-trainer-close:hover{background:#ffffff4d;transform:scale(1.1)}.grammar-progress-section{padding:12px 24px;background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.grammar-progress-text{font-size:.875rem;color:#555;display:block;margin-bottom:6px}.grammar-progress-bar-bg{height:6px;background:#e3f2fd;border-radius:3px;overflow:hidden}.grammar-progress-bar-fill{height:100%;background:#0d47a1;border-radius:3px;transition:width .3s ease}.grammar-level-filter{display:flex;gap:8px;padding:10px 24px;background:#fff;border-bottom:1px solid #e0e0e0;overflow-x:auto;flex-shrink:0;-webkit-overflow-scrolling:touch}.level-filter-btn{flex-shrink:0;padding:6px 16px;background:#f5f7fa;border:1.5px solid #e0e0e0;border-radius:20px;font-size:.875rem;font-weight:600;color:#555;cursor:pointer;transition:all .2s}.level-filter-btn:hover{border-color:#0d47a1;color:#0d47a1}.level-filter-btn.active{background:#0d47a1;border-color:#0d47a1;color:#fff}.grammar-loading{display:flex;justify-content:center;align-items:center;flex:1}.grammar-split{display:grid;grid-template-columns:320px 1fr;flex:1;overflow:hidden;min-height:0}.grammar-topic-list{overflow-y:auto;border-right:1px solid #e0e0e0;background:#fff}.grammar-section-group{border-bottom:1px solid #f0f0f0}.grammar-section-header{padding:10px 16px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#999;background:#fafafa;border-bottom:1px solid #f0f0f0;position:sticky;top:0;z-index:1}.grammar-topic-row{width:100%;display:flex;align-items:center;gap:8px;padding:10px 16px;background:none;border:none;text-align:left;cursor:pointer;transition:background .15s;border-bottom:1px solid #f5f5f5}.grammar-topic-row:hover{background:#f0f4ff}.grammar-topic-row.selected{background:#e3f2fd;border-left:3px solid #0D47A1}.grammar-topic-row.covered .topic-status-icon{color:#2e7d32;font-weight:700}.grammar-topic-row.upcoming .topic-status-icon{color:#bbb}.topic-status-icon{flex-shrink:0;width:18px;text-align:center;font-size:.875rem}.topic-row-title{flex:1;font-size:.875rem;color:#333;line-height:1.4}.grammar-topic-row.covered .topic-row-title{color:#1a1a1a;font-weight:500}.topic-cefr-badge{flex-shrink:0;font-size:.75rem;font-weight:600;color:#0d47a1;background:#e3f2fd;padding:2px 7px;border-radius:10px}.grammar-content-panel{overflow-y:auto;padding:24px;background:#f5f7fa}.grammar-empty-state{display:flex;justify-content:center;align-items:center;height:200px;color:#999;font-size:.9375rem}.grammar-content-body{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000012}.grammar-content-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid #e3f2fd}.grammar-content-header h2{margin:0;flex:1;font-size:1.375rem;color:#0d47a1}.grammar-content-cefr{flex-shrink:0;background:#0d47a1;color:#fff;font-size:.8125rem;font-weight:700;padding:3px 10px;border-radius:12px;margin-top:2px}.grammar-covered-in{font-size:.875rem;color:#555;margin:0 0 16px}.grammar-lesson-link{background:none;border:none;color:#0d47a1;font-weight:600;cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}.grammar-lesson-link:hover{color:#1565c0}.grammar-content-loading{display:flex;align-items:center;gap:10px;color:#666;font-size:.9rem;padding:16px 0}.grammar-no-content{color:#999;font-style:italic}.grammar-markdown{line-height:1.7;color:#333;font-size:.9375rem}.grammar-markdown h2{font-size:1.2rem;color:#0d47a1;margin:1.2rem 0 .6rem}.grammar-markdown h3{font-size:1.05rem;color:#1565c0;margin:1rem 0 .5rem}.grammar-markdown p{margin:.5rem 0}.grammar-markdown ul,.grammar-markdown ol{padding-left:1.5rem;margin:.5rem 0}.grammar-markdown li{margin:.25rem 0}.grammar-markdown code{background:#f0f4ff;padding:1px 6px;border-radius:4px;font-size:.9em;color:#0d47a1}.grammar-markdown strong{color:#1a1a1a}.grammar-markdown table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.875rem}.grammar-markdown th{background:#0d47a1;color:#fff;padding:8px 12px;text-align:left}.grammar-markdown td{padding:7px 12px;border:1px solid #e0e0e0}.grammar-markdown tr:nth-child(2n) td{background:#f5f8ff}.grammar-content-loading .spinner{width:20px;height:20px;border-width:2px}@media (max-width: 768px){.grammar-split{grid-template-columns:1fr;grid-template-rows:auto 1fr}.grammar-topic-list{border-right:none;border-bottom:1px solid #e0e0e0;max-height:40vh;overflow-y:auto}.grammar-content-panel{padding:16px}.grammar-trainer-title{font-size:1.25rem}}@media (max-width: 480px){.grammar-trainer-header{padding:12px 16px}.grammar-level-filter{padding:8px 16px}.grammar-content-body{padding:16px}}.writing-trainer{display:flex;flex-direction:column;height:100vh;background:#f5f7fa;overflow:hidden}.writing-trainer-header{display:flex;align-items:center;gap:12px;padding:0 20px;height:56px;background:#0d47a1;color:#fff;flex-shrink:0;box-shadow:0 2px 4px #0003}.writing-back-btn{background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1;transition:background .15s}.writing-back-btn:hover{background:#ffffff26}.writing-trainer-title{flex:1;margin:0;font-size:1.1rem;font-weight:600}.writing-new-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.4);color:#fff;font-size:.85rem;font-weight:600;padding:6px 14px;border-radius:20px;cursor:pointer;transition:background .15s;white-space:nowrap}.writing-new-btn:hover{background:#ffffff40}.writing-trainer-body{display:grid;grid-template-columns:280px 1fr;flex:1;overflow:hidden}.writing-sidebar{border-right:1px solid #e0e0e0;overflow-y:auto;background:#fff;padding:8px 0}.writing-sidebar-loading,.writing-sidebar-error{padding:20px 16px;font-size:.9rem;color:#666}.writing-sidebar-error{color:#c62828}.writing-sidebar-empty{padding:24px 16px;text-align:center}.writing-sidebar-empty p{margin:0 0 6px;font-weight:500;color:#444;font-size:.95rem}.writing-sidebar-empty small{color:#888;font-size:.82rem}.writing-submission-item{position:relative;padding:12px 40px 12px 14px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .12s}.writing-submission-item:hover{background:#f0f4ff}.writing-submission-item.selected{background:#e3eeff;border-left:3px solid #0D47A1}.writing-submission-meta{display:flex;align-items:center;gap:6px;margin-bottom:4px}.writing-status-icon{font-size:.85rem}.writing-submission-date{font-size:.78rem;color:#666}.writing-submission-preview{font-size:.82rem;color:#444;line-height:1.4;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.writing-submission-status-label{font-size:.75rem;color:#888}.writing-delete-btn{position:absolute;top:10px;right:8px;background:none;border:none;cursor:pointer;font-size:.9rem;opacity:0;transition:opacity .15s;padding:2px 4px}.writing-submission-item:hover .writing-delete-btn{opacity:1}.writing-panel{overflow-y:auto;padding:28px}.writing-composer{max-width:700px;margin:0 auto}.writing-prompt-box{background:#e8f0fe;border-left:4px solid #0D47A1;padding:12px 16px;border-radius:0 8px 8px 0;font-size:.9rem;color:#333;margin-bottom:20px;line-height:1.5}.writing-prompt-label{font-weight:700;color:#0d47a1}.writing-textarea{width:100%;font-size:1rem;line-height:1.6;padding:14px 16px;border:1.5px solid #c5cae9;border-radius:10px;resize:vertical;font-family:inherit;background:#fff;transition:border-color .15s;box-sizing:border-box}.writing-textarea:focus{outline:none;border-color:#0d47a1;box-shadow:0 0 0 3px #0d47a11a}.writing-textarea:disabled{background:#f5f5f5;color:#aaa}.writing-send-error{color:#c62828;font-size:.88rem;margin:8px 0}.writing-send-btn{display:block;margin-top:16px;padding:12px 32px;background:#0d47a1;color:#fff;border:none;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.writing-send-btn:hover:not(:disabled){background:#1565c0}.writing-send-btn:disabled{opacity:.5;cursor:not-allowed}.writing-detail{max-width:900px;margin:0 auto}.writing-detail-loading{color:#666;font-size:.95rem;padding:20px 0}.writing-pending-message{background:#fff8e1;border-left:4px solid #f9a825;padding:12px 16px;border-radius:0 8px 8px 0;font-size:.9rem;color:#555;margin-bottom:20px}.writing-error-message{background:#ffebee;border-left:4px solid #c62828;padding:12px 16px;border-radius:0 8px 8px 0;font-size:.9rem;color:#c62828;margin-bottom:20px}.writing-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}.writing-comparison-column{background:#fff;border-radius:10px;border:1px solid #e0e0e0;padding:18px;min-height:200px}.writing-column-title{margin:0 0 12px;font-size:.88rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#555}.writing-text-content{margin:0;font-size:.95rem;line-height:1.7;color:#333;white-space:pre-wrap;word-break:break-word;font-family:inherit}.writing-mark-error{background:#ffebee;color:#c62828;text-decoration:line-through;text-decoration-color:#c62828;border-radius:3px;padding:0 2px;font-style:normal}.writing-mark-fixed{background:#e8f5e9;color:#2e7d32;font-weight:600;border-radius:3px;padding:0 2px;font-style:normal}.writing-corrected-placeholder{color:#aaa;font-style:italic;font-size:.9rem;padding:8px 0}.writing-corrections{background:#fff;border-radius:10px;border:1px solid #e0e0e0;padding:20px}.writing-corrections-title{margin:0 0 14px;font-size:1rem;font-weight:700;color:#0d47a1}.writing-no-changes{color:#2e7d32;font-size:.95rem;font-weight:500;margin:0}.writing-corrections-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.writing-correction-item{background:#f5f7ff;border-radius:8px;padding:10px 14px;font-size:.9rem}.writing-correction-original{color:#c62828;font-weight:600;text-decoration:line-through}.writing-correction-corrected{color:#2e7d32;font-weight:600}.writing-correction-explanation{margin:6px 0 0;color:#555;font-size:.85rem;line-height:1.5}@media (max-width: 768px){.writing-trainer-body{grid-template-columns:1fr;grid-template-rows:auto 1fr}.writing-sidebar{border-right:none;border-bottom:1px solid #e0e0e0;max-height:200px;overflow-y:auto}.writing-panel{padding:16px}.writing-comparison{grid-template-columns:1fr}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:var(--secondary-color);padding:var(--spacing-xl) var(--spacing-md);text-align:center;box-shadow:var(--shadow-md)}.app-header h1{font-size:2rem;font-weight:600}.subtitle{font-size:1rem;opacity:.9;font-weight:300}.app-main{flex:1;max-width:800px;width:100%;margin:0 auto;padding:var(--spacing-xl) var(--spacing-md)}.app-main.vocabulary-view,.app-main.full-view{max-width:100%;padding:0;margin:0;height:100vh}.input-section,.action-section,.player-section,.download-section{margin-bottom:var(--spacing-xl)}.text-input-container{background:#fff;border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.text-input{width:100%;min-height:150px;padding:var(--spacing-md);font-size:1rem;border:2px solid var(--border-color);border-radius:var(--radius-sm);resize:vertical;transition:border-color .2s ease}.text-input:focus{border-color:var(--primary-color)}.text-input.near-limit{border-color:var(--warning-color)}.character-counter{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-sm);font-size:.875rem;color:var(--text-light)}.character-counter .warning{color:var(--warning-color);font-weight:600}.warning-text{color:var(--warning-color);font-size:.8rem}.generate-button{width:100%;padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem;font-weight:600;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:transform .2s ease,box-shadow .2s ease}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generate-button:active:not(:disabled){transform:translateY(0)}.generate-button.loading{background:var(--text-light)}.spinner{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mode-switcher{display:flex;gap:12px;margin-bottom:24px;background:#fff;padding:8px;border-radius:12px;box-shadow:0 2px 8px #0d47a11a}.mode-btn{flex:1;padding:12px 20px;border:2px solid transparent;border-radius:8px;background:transparent;color:#0d47a1;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.mode-btn:hover{background:#e3f2fd}.mode-btn.active{background:linear-gradient(135deg,#0d47a1,#1976d2);color:#fff;border-color:#0d47a1}.success-message{background-color:#e8f5e9;color:#2e7d32;padding:var(--spacing-md);border-radius:var(--radius-md);border-left:4px solid #4CAF50;margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.error-message{background-color:#ffebee;color:var(--error-color);padding:var(--spacing-md);border-radius:var(--radius-md);border-left:4px solid var(--error-color);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.audio-player{background:#fff;border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-md)}.controls{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.play-pause-button,.stop-button{width:48px;height:48px;border-radius:50%;background-color:var(--primary-color);color:#fff;font-size:1.25rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.play-pause-button:hover:not(:disabled),.stop-button:hover:not(:disabled){background-color:var(--primary-dark)}.time-display{flex:1;text-align:center;font-family:monospace;font-size:.875rem;color:var(--text-light)}.progress-container{margin-bottom:var(--spacing-md)}.progress-bar{width:100%;height:6px;border-radius:var(--radius-sm);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.progress-bar::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer}.progress-bar::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.volume-container{display:flex;align-items:center;gap:var(--spacing-sm)}.volume-label{font-size:1.25rem}.volume-control{flex:1;height:4px;border-radius:var(--radius-sm);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-color)}.volume-control::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--primary-color);cursor:pointer}.volume-control::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.download-button{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:1rem;font-weight:500;background-color:var(--success-color);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:background-color .2s ease}.download-button:hover:not(:disabled){background-color:#2e7d32}.app-footer{background-color:#fff;padding:var(--spacing-md);text-align:center;color:var(--text-light);font-size:.875rem;border-top:1px solid var(--border-color);margin-top:auto}@media (max-width: 640px){.app-header{padding:var(--spacing-md) var(--spacing-sm)}.app-header h1{font-size:1.5rem}.subtitle{font-size:.875rem}.app-main{padding:var(--spacing-md)}.generate-button{font-size:1rem}.controls{flex-wrap:wrap;justify-content:center}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.section-title{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin-bottom:var(--spacing-lg);border-bottom:2px solid #0D47A1;padding-bottom:var(--spacing-sm)}.generate-section,.latest-lessons-section{margin-bottom:var(--spacing-2xl)}.lesson-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.loading-lessons,.no-lessons{text-align:center;padding:var(--spacing-2xl);color:var(--text-light);font-size:1rem}.no-lessons p{color:#666}.back-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:#0d47a1;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease;margin-bottom:var(--spacing-lg)}.back-button:hover{background:#f5f5f5;border-color:#0d47a1}.placeholder-detail{padding:var(--spacing-2xl);background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center;color:#666}@media (max-width: 768px){.lesson-cards-grid{grid-template-columns:1fr}.section-title{font-size:1.25rem}}@media (max-width: 480px){.app-main{padding:var(--spacing-md) var(--spacing-sm)}}:root{--primary-color: #0D47A1;--primary-light: #5472D3;--primary-dark: #002171;--secondary-color: #FFFFFF;--accent-color: #001489;--error-color: #D32F2F;--warning-color: #F57C00;--success-color: #388E3C;--text-color: #212121;--text-light: #757575;--border-color: #E0E0E0;--bg-light: #F5F5F5;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-color);background-color:var(--bg-light);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}button:disabled{cursor:not-allowed;opacity:.6}button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}input,textarea{font-family:inherit;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--spacing-sm)}input:focus,textarea:focus{outline:2px solid var(--primary-color);outline-offset:1px;border-color:var(--primary-color)}
