.welcome-screen{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#1a3a35,#2d8e7e 40%,#1e6b5a);animation:welcomeFadeIn .6s ease-out;overflow-y:auto}.welcome-screen.fade-out{animation:welcomeFadeOut .5s ease-in forwards}@keyframes welcomeFadeIn{0%{opacity:0}to{opacity:1}}@keyframes welcomeFadeOut{0%{opacity:1}to{opacity:0}}.welcome-content{text-align:center;padding:2rem 1.5rem;max-width:400px;width:100%}.welcome-logo{width:150px;height:150px;margin:0 auto 1.5rem;border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 4px 24px #0000004d,0 0 40px #d4a84333;animation:welcomeFloat 3s ease-in-out infinite}.welcome-logo img{width:100%;height:100%;object-fit:contain}@keyframes welcomeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.welcome-title{font-family:"Noto Serif Ethiopic",serif;font-size:1.8rem;font-weight:700;color:#fff;margin-bottom:.4rem;letter-spacing:.5px}.welcome-subtitle{font-size:.95rem;color:#ffffffbf;margin-bottom:2rem;line-height:1.4}.welcome-features{display:flex;flex-direction:column;gap:.9rem;margin-bottom:2.2rem}.welcome-feature{display:flex;align-items:center;gap:.75rem;text-align:left;color:#ffffffe6;font-size:.95rem;padding:.6rem 1rem;background:#ffffff14;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.welcome-feature-icon{font-size:1.1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#d4a84333;border-radius:8px;flex-shrink:0;color:#d4a843}.welcome-audio{display:flex;align-items:center;gap:12px;margin:1rem 0;padding:10px 16px;background:#ffffff1a;border-radius:24px;border:1px solid rgba(212,168,67,.3)}.welcome-play-btn{width:40px;height:40px;border-radius:50%;border:none;background:#d4a843;color:#1a3a35;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.welcome-play-btn:active{transform:scale(.95)}.welcome-audio-label{font-family:"Noto Serif Ethiopic",serif;font-size:.85rem;color:#ffffffd9}.welcome-enter-btn{display:inline-block;padding:.85rem 2.5rem;font-family:"Noto Serif Ethiopic",serif;font-size:1.1rem;font-weight:600;color:#1a3a35;background:linear-gradient(135deg,#d4a843,#e8c45a);border:none;border-radius:30px;cursor:pointer;box-shadow:0 4px 16px #d4a84366;transition:transform .2s,box-shadow .2s}.welcome-enter-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #d4a84380}.welcome-enter-btn:active{transform:translateY(0)}.welcome-version{margin-top:1.5rem;font-size:.75rem;color:#ffffff59}.welcome-footer{margin-top:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.welcome-social{display:flex;gap:1rem;align-items:center}.welcome-social a{color:#ffffff80;transition:color .2s;display:flex}.welcome-social a:hover{color:#d4a843}.welcome-geezword{font-size:.8rem;color:#fff6;text-decoration:none;transition:color .2s}.welcome-geezword:hover{color:#d4a843}:root{--primary: #2D8E7E;--primary-light: #3AA08E;--primary-dark: #1E6B5A;--accent: #D4A843;--accent-light: #E8C45A;--bg: #F2F0EC;--bg-card: #ffffff;--text: #2c2c2c;--text-light: #666666;--geez-color: #1a1a1a;--border: #ddd8d0;--premium-bg: #fff8e8;--radius: 8px;--cat-sirate: #4CAF50;--cat-hawariat: #E8913A;--cat-ezli: #8BC34A}*{margin:0;padding:0;box-sizing:border-box}body{font-family:"Noto Serif Ethiopic",Nyala,serif;background-color:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}.header{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;padding:12px 16px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #00000026}.header-content{max-width:800px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.header-title{display:flex;flex-direction:column}.header-geez{font-size:1.3rem;font-weight:700;color:var(--accent-light)}.header-subtitle{font-size:.75rem;font-weight:400;opacity:.8;font-family:system-ui,sans-serif}.language-selector{display:flex;gap:4px;flex-wrap:wrap}.lang-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:#ffffffb3;padding:4px 10px;border-radius:16px;font-size:.8rem;cursor:pointer;transition:all .2s;font-family:"Noto Serif Ethiopic",system-ui,sans-serif}.lang-btn:hover{border-color:#fff9;color:#fff}.lang-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.home{max-width:1100px;margin:0 auto}.desktop-layout{display:none;min-height:calc(100vh - 120px)}.desktop-layout .sidebar{display:block;width:280px;min-width:280px;background:var(--bg-card);border-right:1px solid var(--border);overflow-y:auto;max-height:calc(100vh - 80px);position:sticky;top:80px}.content{flex:1;padding:16px;overflow-y:auto}.mobile-screen{display:block;padding:8px}.lesson-topnav{display:flex;align-items:center;gap:8px;padding:8px 4px;margin-bottom:8px;position:sticky;top:0;z-index:50;background:var(--bg)}.lesson-topnav-back{width:40px;height:40px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.lesson-topnav-back:active{background:var(--primary-dark)}.lesson-topnav-title{flex:1;font-size:.8rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-topnav-count{font-size:.75rem;color:var(--text-light);font-family:system-ui,sans-serif;flex-shrink:0}.lesson-topnav-arrow{width:40px;height:40px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.lesson-topnav-arrow:active{background:var(--primary-dark)}.lesson-topnav-arrow:disabled{opacity:.3;cursor:default}.category-topnav{display:flex;align-items:center;gap:8px;padding:8px 4px;margin-bottom:8px}.category-topnav-back{width:40px;height:40px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.category-topnav-back:active{background:var(--primary-dark)}.category-topnav-title{flex:1;font-size:1rem;font-weight:600;color:var(--text)}.category-list{display:flex;flex-direction:column}.category-group{border-bottom:2px solid var(--border)}.group-header{padding:12px 16px 8px;background:var(--primary)}[data-group=sirate-kidase] .group-header{background:#d4a843}[data-group=kidase-hawariat] .group-header{background:#e8913a}.group-title{font-size:1rem;font-weight:700;color:#fff;font-family:"Noto Serif Ethiopic",serif}.category-btn{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;transition:background .15s;font-family:"Noto Serif Ethiopic",serif}.category-btn:hover{background:#e8f5f2}.category-btn.active{background:var(--primary-light);color:#fff}.melody-badge{display:inline-block;padding:3px 12px;border-radius:12px;font-size:.85rem;font-weight:600;background:#d4f0e8;color:var(--primary-dark)}.category-btn.active .melody-badge{background:#fff3;color:#fff}.category-count{font-size:.7rem;font-family:system-ui,sans-serif;color:var(--text-light);margin-left:auto}.category-btn.active .category-count{color:#ffffffb3}.category-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--accent)}.category-geez-title{font-size:1.3rem;font-weight:700;color:var(--primary)}.sections-list{display:flex;flex-direction:column;gap:12px}.role-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px 4px 8px;border-radius:16px;font-size:.9rem;font-weight:600;font-family:"Noto Serif Ethiopic",serif;margin-bottom:8px}.role-icon{display:inline-flex;align-items:center;line-height:1}.role-badge.role-priest{background:#fff3e0;color:#b8860b}.role-badge.role-deacon{background:#e8f5e9;color:#2e7d32}.role-badge.role-people{background:#e0f2f1;color:#1e6b5a}.liturgy-section{background:var(--bg-card);border-radius:var(--radius);padding:16px;border:1px solid var(--border);transition:box-shadow .2s}.liturgy-section:hover{box-shadow:0 2px 8px #00000014}.liturgy-section.premium{background:var(--premium-bg);border-color:var(--accent)}.liturgy-section.special{border-left:3px solid var(--accent)}.liturgy-section.selected{border:3px solid #d32f2f;background:#fff5f5;box-shadow:0 0 0 3px #d32f2f1a,0 4px 12px #d32f2f33}.premium-badge{display:inline-block;background:var(--accent);color:#fff;font-size:.65rem;font-family:system-ui,sans-serif;padding:2px 8px;border-radius:10px;margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.text-container{margin-bottom:12px}.section-header-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.sequence-number{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:#2d8e7e1f;color:#2d8e7e99;font-size:.65rem;font-weight:600;font-family:system-ui,sans-serif;flex-shrink:0}.geez-text{font-size:1.15rem;font-weight:600;color:var(--geez-color);line-height:1.8;margin-bottom:6px}.middle-text{font-size:.95rem;color:var(--primary);line-height:1.6;margin-bottom:6px}.english-text{font-size:.95rem;color:var(--text);line-height:1.6}.text-word{transition:background-color .25s ease,color .25s ease;border-radius:3px;padding:4px 3px;cursor:pointer;display:inline-block}.text-word:hover{background-color:#2d8e7e1a}.text-word.word-active{background-color:#2d8e7e33;color:var(--primary-dark)}.audio-player-wrapper{margin-top:8px;display:flex;flex-direction:column;gap:6px}.audio-player{display:flex;align-items:center;gap:10px;background:#1a2a2a;padding:10px 12px;border-radius:20px}.play-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--primary);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.play-btn:hover{background:var(--primary-light)}.nav-btn{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:#fff9;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s,background .2s;padding:0}.nav-btn:hover{color:var(--accent-light);background:#ffffff1a}.progress-bar{flex:1;height:4px;background:#fff3;border-radius:2px;cursor:pointer;position:relative}.progress-fill{height:100%;background:var(--primary-light);border-radius:2px;transition:width .1s linear}.breakpoint-marker{position:absolute;top:-2px;width:2px;height:8px;background:#fff;border:1px solid rgba(0,0,0,.2);border-radius:1px;transform:translate(-50%);z-index:1;pointer-events:none}.time-display{font-size:.7rem;color:#fff9;font-family:system-ui,sans-serif;white-space:nowrap;min-width:70px;text-align:right}.audio-actions{display:flex;align-items:center;gap:8px;padding:6px 4px;transition:all .2s}.audio-actions-recording{background:#fef2f2;border:2px solid #d32f2f;border-radius:12px;padding:8px 12px;animation:recording-glow 2s ease-in-out infinite}@keyframes recording-glow{0%,to{border-color:#d32f2f;box-shadow:0 0 #d32f2f33}50%{border-color:#f44336;box-shadow:0 0 8px 2px #d32f2f26}}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;border:none;font-size:.8rem;font-family:system-ui,sans-serif;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;white-space:nowrap}.action-btn:hover{transform:scale(1.02)}.action-btn:active{transform:scale(.98)}.action-btn-record{background:#fef2f2;color:#d32f2f;border:1px solid #f5c6c6}.action-btn-record:hover{background:#fde8e8}.action-btn-recording{background:#d32f2f;color:#fff}.action-btn-recording:hover{background:#b71c1c}.action-btn-practice{background:#d4a8431a;color:var(--accent);border:1px solid rgba(212,168,67,.3)}.action-btn-practice:hover{background:#d4a84333}.recording-indicator{display:flex;align-items:center;gap:6px;margin-left:auto}.recording-dot{width:10px;height:10px;border-radius:50%;background:#d32f2f;animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.recording-indicator-text{font-size:.8rem;font-family:system-ui,sans-serif;font-weight:600;color:#d32f2f}.rec-playback{background:#fef2f2;border:1px solid #f5c6c6;border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.rec-playback-header{display:flex;align-items:center;justify-content:space-between}.rec-playback-label{font-size:.75rem;color:#d32f2f;font-family:system-ui,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.rec-playback-actions{display:flex;gap:4px}.rec-action-btn{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s}.rec-action-btn:hover{color:#d32f2f;background:#d32f2f1a}.rec-action-delete:hover{color:#d32f2f}.rec-playback-controls{display:flex;align-items:center;gap:10px}.rec-playback-controls .progress-bar{background:#d32f2f26}.rec-playback-controls .time-display{color:#999}.rec-play-btn{background:#d32f2f}.rec-play-btn:hover{background:#b71c1c}.rec-fill{background:#d32f2f}.share-btn{width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s,background .2s}.share-btn:hover{color:var(--primary-dark);background:#2d8e7e1a}.section-actions{position:relative;display:flex;justify-content:flex-end;margin-top:4px}.section-share-btn{width:28px;height:28px;font-size:16px}.share-menu{position:absolute;right:0;top:100%;z-index:50;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001f;min-width:160px;padding:4px 0;animation:shareMenuIn .15s ease-out}@keyframes shareMenuIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.share-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;font-size:.9rem;color:var(--text);cursor:pointer;font-family:inherit;transition:background .15s}.share-menu-item:hover{background:#2d8e7e14}.share-menu-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}.delete-btn{width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--text-light);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s,background .2s}.delete-btn:hover{color:#d32f2f;background:#d32f2f1a}.practice-enter-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.practice-enter-btn:hover{background:var(--accent-light)}.practice-panel{background:var(--bg-card);border:2px solid var(--accent);border-radius:var(--radius);padding:12px 16px;display:flex;flex-direction:column;gap:12px}.practice-header{display:flex;align-items:center;gap:8px}.practice-title{font-size:.75rem;font-weight:700;font-family:system-ui,sans-serif;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.practice-piece{font-size:.75rem;font-family:system-ui,sans-serif;color:var(--text-light);margin-left:auto}.practice-exit{width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--text-light);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s}.practice-exit:hover{color:#d32f2f;background:#d32f2f1a}.practice-progress-wrapper{display:flex;align-items:center;gap:10px}.practice-progress{height:6px}.piece-highlight{position:absolute;top:-3px;height:12px;background:#c4922a33;border:1px solid var(--accent);border-radius:3px;z-index:0;pointer-events:none}.practice-controls{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.practice-btn{padding:8px 16px;border:none;border-radius:20px;font-size:.8rem;font-family:system-ui,sans-serif;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;display:flex;align-items:center;gap:4px}.practice-btn:hover{transform:scale(1.02)}.practice-btn:active{transform:scale(.98)}.practice-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.listen-btn{background:var(--primary);color:#fff}.listen-btn:hover{background:var(--primary-light)}.record-practice-btn{background:#d32f2f;color:#fff}.record-practice-btn:hover{background:#b71c1c}.record-active-btn{background:#d32f2f;color:#fff;animation:pulse-record 1s ease-in-out infinite}.skip-btn{background:#dce8e4;color:var(--text)}.skip-btn:hover{background:#c8dcd6}.compare-btn{background:var(--accent);color:#fff}.compare-btn:hover{background:var(--accent-light)}.retry-btn{background:#dce8e4;color:var(--text)}.retry-btn:hover{background:#c8dcd6}.next-btn{background:#2e7d32;color:#fff}.next-btn:hover{background:#388e3c}.practice-nav{display:flex;align-items:center;justify-content:center;gap:12px}.practice-nav .nav-btn:disabled{opacity:.3;cursor:not-allowed}.practice-nav-label{font-size:.7rem;font-family:system-ui,sans-serif;color:var(--text-light)}.recording-error{display:block;color:#c33;font-size:.7rem;font-family:system-ui,sans-serif;margin-top:4px}.header-actions{display:flex;align-items:center;gap:8px}.dev-mode-toggle{padding:3px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.5);background:#ffffff26;color:#fff;font-size:.7rem;font-weight:700;font-family:monospace;cursor:pointer;letter-spacing:.5px;transition:background .2s}.dev-mode-toggle:hover{background:#ffffff4d}.sign-in-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);padding:6px 14px;border-radius:var(--radius);font-size:.8rem;font-family:system-ui,sans-serif;cursor:pointer;white-space:nowrap;transition:background .2s}.sign-in-btn:hover{background:#ffffff4d}.user-menu{display:flex;align-items:center;gap:6px}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.upgrade-btn{background:var(--accent);color:#fff;border:none;padding:5px 12px;border-radius:var(--radius);font-size:.75rem;font-family:system-ui,sans-serif;cursor:pointer;font-weight:600;white-space:nowrap}.upgrade-btn:hover{background:var(--accent-light);color:var(--text)}.manage-btn,.logout-btn{background:none;border:1px solid var(--border);color:var(--text-light);padding:4px 10px;border-radius:var(--radius);font-size:.7rem;font-family:system-ui,sans-serif;cursor:pointer;white-space:nowrap}.manage-btn:hover,.logout-btn:hover{background:var(--bg)}.liturgy-section.locked{position:relative}.locked-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:6px;background:#f2f0ecd9;border-radius:var(--radius);z-index:2;font-family:system-ui,sans-serif;font-size:.8rem;color:var(--primary);font-weight:600}.lock-icon{font-size:1rem}.text-container.blurred{filter:blur(3px);-webkit-user-select:none;user-select:none}.upgrade-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.upgrade-prompt{background:#fff;border-radius:12px;padding:28px 24px;max-width:380px;width:100%;position:relative;font-family:system-ui,sans-serif;box-shadow:0 8px 32px #0003}.upgrade-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.1rem;color:var(--text-light);cursor:pointer;padding:4px}.upgrade-title{font-size:1.2rem;color:var(--primary);margin:0 0 8px}.upgrade-desc{font-size:.85rem;color:var(--text-light);margin:0 0 12px;line-height:1.4}.upgrade-features{list-style:none;padding:0;margin:0 0 20px}.upgrade-features li{font-size:.8rem;color:var(--text);padding:4px 0}.upgrade-features li:before{content:"✓";color:var(--accent);font-weight:700}.upgrade-cta{width:100%;background:var(--accent);color:#fff;border:none;padding:12px;border-radius:var(--radius);font-size:.95rem;font-weight:600;font-family:system-ui,sans-serif;cursor:pointer}.upgrade-cta:hover{background:var(--accent-light);color:var(--text)}.success-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#2e7d32;color:#fff;padding:12px 24px;border-radius:var(--radius);font-family:system-ui,sans-serif;font-size:.85rem;font-weight:500;z-index:200;box-shadow:0 4px 12px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.feedback-wrapper{position:relative}.feedback-header-btn{background:none;border:none;color:#fffc;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s,background .2s}.feedback-header-btn:hover{color:#fff;background:#ffffff26}.feedback-dropdown{position:absolute;top:100%;right:0;margin-top:8px;width:280px;background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 32px #00000040;z-index:200;font-family:system-ui,sans-serif;animation:slideDown .15s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.feedback-title{margin:0 0 12px;font-size:1rem;color:var(--primary)}.feedback-rating{display:flex;align-items:center;gap:8px;margin-bottom:12px}.feedback-label{font-size:.8rem;color:var(--text-light)}.feedback-stars{display:flex;gap:2px}.star-btn{background:none;border:none;font-size:1.4rem;cursor:pointer;color:#ccc;padding:0 2px;line-height:1}.star-btn.active{color:var(--accent)}.feedback-textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;font-size:.8rem;font-family:system-ui,sans-serif;resize:vertical;margin-bottom:12px;box-sizing:border-box}.feedback-textarea:focus{outline:none;border-color:var(--primary-light)}.feedback-submit{width:100%;background:var(--primary);color:#fff;border:none;padding:10px;border-radius:var(--radius);font-size:.85rem;font-weight:500;font-family:system-ui,sans-serif;cursor:pointer}.feedback-submit:hover{background:var(--primary-light)}.feedback-submit:disabled{opacity:.5;cursor:not-allowed}.feedback-thanks{text-align:center;color:#2e7d32;font-weight:600;font-size:.9rem;padding:20px 0}.loading,.error,.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:16px;color:var(--text-light);font-family:system-ui,sans-serif}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error button{background:var(--primary);color:#fff;border:none;padding:8px 20px;border-radius:var(--radius);cursor:pointer;font-family:system-ui,sans-serif}.ai-fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00000040;z-index:300;transition:background .2s,transform .2s}.ai-fab:hover{background:var(--primary-light);transform:scale(1.05)}.ai-fab:active{transform:scale(.95)}.ai-panel{position:fixed;bottom:88px;right:24px;width:340px;max-height:480px;background:var(--bg-card);border-radius:16px;box-shadow:0 8px 32px #0003;z-index:300;display:flex;flex-direction:column;animation:aiPanelIn .2s ease-out;overflow:hidden}@keyframes aiPanelIn{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ai-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--primary);color:#fff;border-radius:16px 16px 0 0}.ai-panel-title{font-size:.9rem;font-weight:600;font-family:"Noto Serif Ethiopic",serif}.ai-panel-remaining{font-size:.7rem;font-family:system-ui,sans-serif;opacity:.8}.ai-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;min-height:200px;max-height:320px}.ai-welcome{text-align:center;color:var(--text-light);font-size:.85rem;font-family:system-ui,sans-serif;padding:24px 12px}.ai-message{padding:10px 14px;border-radius:12px;font-size:.85rem;line-height:1.5;max-width:85%;word-wrap:break-word}.ai-message-user{background:var(--primary);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.ai-message-assistant{background:#e8f5f2;color:var(--text);align-self:flex-start;border-bottom-left-radius:4px}.ai-message-system{background:#fff3e0;color:#b8860b;align-self:center;text-align:center;font-size:.8rem;max-width:90%}.ai-thinking{opacity:.7;font-style:italic}.ai-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--bg)}.ai-input-bar input{flex:1;border:1px solid var(--border);border-radius:20px;padding:8px 14px;font-size:.85rem;font-family:"Noto Serif Ethiopic",system-ui,sans-serif;outline:none;background:var(--bg-card)}.ai-input-bar input:focus{border-color:var(--primary-light)}.ai-input-bar input:disabled{opacity:.5}.ai-send-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.ai-send-btn:hover{background:var(--primary-light)}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:767px){.ai-panel{right:8px;left:8px;bottom:84px;width:auto;max-height:60vh}.ai-fab{bottom:16px;right:16px;width:48px;height:48px}}@media(min-width:768px){.mobile-screen{display:none}.desktop-layout{display:flex}.content{padding:20px 24px}.header{padding:16px 24px}.header-geez{font-size:1.5rem}.geez-text{font-size:1.3rem}.middle-text,.english-text{font-size:1rem}.lang-btn{padding:6px 14px;font-size:.85rem}.category-geez-title{font-size:1.5rem}}.app-footer{text-align:center;padding:1rem;border-top:1px solid rgba(255,255,255,.08);background:var(--bg-dark, #0f1f1d)}.app-footer-links{display:flex;align-items:center;justify-content:center;gap:.75rem}.app-footer-links a{color:#ffffff59;display:flex;align-items:center;transition:color .2s;text-decoration:none}.app-footer-links a:hover{color:#d4a843}.app-footer-site{font-size:.75rem}
