.update-prompt[data-v-5f9d54ff]{position:fixed;bottom:2rem;left:2rem;right:2rem;background:white;border-radius:12px;box-shadow:0 8px 30px #00000026;z-index:1000;animation:slideUp-5f9d54ff .3s ease-out}.update-content[data-v-5f9d54ff]{display:flex;align-items:center;gap:1rem;padding:1rem}.update-icon[data-v-5f9d54ff]{font-size:2rem;color:var(--brand-teal)}.update-text[data-v-5f9d54ff]{flex:1}.update-text h3[data-v-5f9d54ff]{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.update-text p[data-v-5f9d54ff]{margin:0;font-size:.9rem;color:var(--text-secondary)}.update-actions[data-v-5f9d54ff]{display:flex;gap:.5rem}.btn[data-v-5f9d54ff]{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary[data-v-5f9d54ff]{background:var(--brand-teal);color:#fff}.btn-primary[data-v-5f9d54ff]:hover{background:var(--primary-dark)}.btn-secondary[data-v-5f9d54ff]{background:var(--bg-secondary);color:var(--text-secondary)}.btn-secondary[data-v-5f9d54ff]:hover{background:var(--border-color)}@keyframes slideUp-5f9d54ff{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.update-prompt[data-v-5f9d54ff]{left:1rem;right:1rem;bottom:5rem}.update-content[data-v-5f9d54ff]{flex-direction:column;text-align:center}.update-actions[data-v-5f9d54ff]{width:100%;justify-content:center}}.theme-toggle[data-v-c28a186d]{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:var(--menu-text);box-shadow:var(--shadow)}.theme-toggle[data-v-c28a186d]:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:var(--brand)}.theme-icon[data-v-c28a186d]{font-size:1.4rem;transition:transform .3s ease}.theme-toggle:hover .theme-icon[data-v-c28a186d]{transform:rotate(15deg) scale(1.1)}.background-download-notification[data-v-15171074]{position:fixed;bottom:80px;left:50%;transform:translate(-50%);width:90%;max-width:400px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 20px #0000004d;z-index:9999;overflow:hidden}.notification-content[data-v-15171074]{display:flex;align-items:center;gap:12px;padding:16px}.notification-icon[data-v-15171074]{flex-shrink:0}.spinner-icon[data-v-15171074]{font-size:32px;animation:spin-15171074 2s linear infinite}@keyframes spin-15171074{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notification-text[data-v-15171074]{flex:1}.notification-title[data-v-15171074]{font-weight:600;font-size:14px;color:var(--text-color);margin-bottom:4px}.notification-subtitle[data-v-15171074]{font-size:12px;color:var(--text-secondary);line-height:1.4}.notification-close[data-v-15171074]{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--bg-app);border:1px solid var(--border-color);color:var(--text-color);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.notification-close[data-v-15171074]:hover{background:var(--primary-color);color:#fff}.notification-progress[data-v-15171074]{padding:0 16px 16px;display:flex;align-items:center;gap:12px}.progress-bar[data-v-15171074]{flex:1;height:6px;background:var(--bg-app);border-radius:3px;overflow:hidden}.progress-fill[data-v-15171074]{height:100%;background:linear-gradient(90deg,var(--primary-color),#06a0b5);border-radius:3px;transition:width .3s ease}.progress-text[data-v-15171074]{font-size:12px;font-weight:600;color:var(--primary-color);min-width:40px;text-align:right}.slide-up-enter-active[data-v-15171074],.slide-up-leave-active[data-v-15171074]{transition:all .3s ease}.slide-up-enter-from[data-v-15171074],.slide-up-leave-to[data-v-15171074]{transform:translate(-50%,100px);opacity:0}@media (max-width: 768px){.background-download-notification[data-v-15171074]{bottom:70px;width:95%}}.download-complete-banner[data-v-46d84880]{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:90%;max-width:400px;z-index:9999}.banner-content[data-v-46d84880]{display:flex;align-items:center;gap:12px;padding:16px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:12px;box-shadow:0 4px 20px #10b9814d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.banner-icon[data-v-46d84880]{font-size:24px;flex-shrink:0}.banner-text[data-v-46d84880]{flex:1;display:flex;flex-direction:column;gap:2px}.banner-text strong[data-v-46d84880]{font-size:14px;font-weight:600}.banner-text span[data-v-46d84880]{font-size:12px;opacity:.9}.banner-close[data-v-46d84880]{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.2);border:none;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.banner-close[data-v-46d84880]:hover{background:rgba(255,255,255,.3)}.slide-up-enter-active[data-v-46d84880],.slide-up-leave-active[data-v-46d84880]{transition:all .4s ease}.slide-up-enter-from[data-v-46d84880],.slide-up-leave-to[data-v-46d84880]{transform:translate(-50%,100px);opacity:0}@media (max-width: 768px){.download-complete-banner[data-v-46d84880]{bottom:80px;width:95%}.banner-content[data-v-46d84880]{padding:14px 16px}}.modal-overlay[data-v-d2d2a098]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content[data-v-d2d2a098]{background:white;border-radius:16px;max-width:400px;width:100%;box-shadow:0 20px 40px #0003;animation:modalSlideIn-d2d2a098 .3s ease-out}.modal-header[data-v-d2d2a098]{text-align:center;padding:24px 24px 16px;border-bottom:1px solid #f0f0f0}.modal-icon[data-v-d2d2a098]{font-size:48px;margin-bottom:12px}.modal-header h3[data-v-d2d2a098]{margin:0;font-size:1.4rem;font-weight:600;color:#2c3e50}.modal-body[data-v-d2d2a098]{padding:24px}.modal-description[data-v-d2d2a098]{text-align:center;color:#5a6c7d;margin-bottom:20px;line-height:1.5}.download-progress[data-v-d2d2a098]{margin-top:20px}.progress-bar[data-v-d2d2a098]{width:100%;height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill[data-v-d2d2a098]{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);border-radius:4px;transition:width .3s ease}.progress-text[data-v-d2d2a098]{text-align:center;font-size:.9rem;color:#666;margin:0}.modal-actions[data-v-d2d2a098]{padding:16px 24px 24px;display:flex;gap:12px;flex-direction:column}.btn-primary[data-v-d2d2a098]{background:linear-gradient(135deg,#3498db,#2ecc71);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:1rem}.btn-primary[data-v-d2d2a098]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.btn-secondary[data-v-d2d2a098]{background:transparent;color:#666;border:1px solid #ddd;padding:12px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:.95rem}.btn-secondary[data-v-d2d2a098]:hover{background:#f8f9fa;border-color:#bbb}@keyframes modalSlideIn-d2d2a098{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 480px){.modal-content[data-v-d2d2a098]{margin:10px;max-width:none}.modal-header[data-v-d2d2a098]{padding:20px 20px 12px}.modal-body[data-v-d2d2a098]{padding:20px}.modal-actions[data-v-d2d2a098]{padding:12px 20px 20px}.modal-icon[data-v-d2d2a098]{font-size:40px}.modal-header h3[data-v-d2d2a098]{font-size:1.2rem}}.notification-welcome-overlay[data-v-20da6e19]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn-20da6e19 .3s ease-out}.notification-welcome-content[data-v-20da6e19]{background:linear-gradient(135deg,#057d8a 0%,#045a63 100%);border-radius:20px;padding:40px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;border:2px solid rgba(255,255,255,.1);animation:slideInUp-20da6e19 .4s ease-out}.welcome-header[data-v-20da6e19]{text-align:center;margin-bottom:30px}.welcome-icon[data-v-20da6e19]{font-size:4rem;margin-bottom:16px;animation:bounce-20da6e19 2s infinite}.welcome-header h2[data-v-20da6e19]{font-size:1.8rem;font-weight:800;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3);font-family:Montserrat,sans-serif}.welcome-body[data-v-20da6e19]{margin-bottom:30px}.welcome-intro[data-v-20da6e19]{font-size:1.1rem;color:#ffffffe6;text-align:center;margin-bottom:24px;font-weight:500}.benefits-list[data-v-20da6e19]{margin:24px 0}.benefit-item[data-v-20da6e19]{display:flex;align-items:center;margin-bottom:16px;padding:12px 16px;background:rgba(255,255,255,.1);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.benefit-icon[data-v-20da6e19]{font-size:1.5rem;margin-right:12px;flex-shrink:0}.benefit-text[data-v-20da6e19]{color:#fff;font-weight:500;font-size:1rem}.welcome-note[data-v-20da6e19]{font-size:.95rem;color:#fffc;text-align:center;line-height:1.5;font-style:italic;margin-top:20px}.welcome-actions[data-v-20da6e19]{display:flex;flex-direction:column;gap:12px}.accept-btn[data-v-20da6e19]{background:linear-gradient(135deg,#f97316 0%,#fb923c 100%);color:#fff;border:none;padding:16px 24px;border-radius:16px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 20px #f973164d}.accept-btn[data-v-20da6e19]:hover{transform:translateY(-2px);box-shadow:0 6px 25px #f9731666}.accept-btn[data-v-20da6e19]:active{transform:translateY(0)}.decline-btn[data-v-20da6e19]{background:transparent;color:#ffffffb3;border:2px solid rgba(255,255,255,.3);padding:12px 24px;border-radius:16px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.decline-btn[data-v-20da6e19]:hover{color:#fff;border-color:#ffffff80;background:rgba(255,255,255,.1)}.btn-icon[data-v-20da6e19]{font-size:1.2rem}.btn-text[data-v-20da6e19]{font-family:Montserrat,sans-serif}@keyframes fadeIn-20da6e19{0%{opacity:0}to{opacity:1}}@keyframes slideInUp-20da6e19{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce-20da6e19{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes slideInDown-20da6e19{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes slideOutUp-20da6e19{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}@media (max-width: 768px){.notification-welcome-content[data-v-20da6e19]{padding:30px 20px;margin:10px}.welcome-header h2[data-v-20da6e19]{font-size:1.5rem}.welcome-icon[data-v-20da6e19]{font-size:3rem}.benefit-item[data-v-20da6e19]{padding:10px 12px}.benefit-text[data-v-20da6e19]{font-size:.9rem}}.pwa-update-banner[data-v-22cc3a0d]{position:fixed;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#057d8a 0%,#045a63 100%);border-radius:16px;padding:20px;max-width:400px;width:90%;box-shadow:0 8px 32px #057d8a4d;border:2px solid rgba(255,255,255,.1);z-index:9999;animation:slideInDown-22cc3a0d .4s ease-out;font-family:Montserrat,sans-serif}.update-banner-content[data-v-22cc3a0d]{color:#fff}.update-normal[data-v-22cc3a0d]{display:flex;flex-direction:column;gap:16px}.update-header[data-v-22cc3a0d]{display:flex;align-items:center;gap:12px}.update-icon[data-v-22cc3a0d]{font-size:2rem;animation:bounce-22cc3a0d 2s infinite}.update-info[data-v-22cc3a0d]{flex:1}.update-title[data-v-22cc3a0d]{font-size:1.2rem;font-weight:700;margin:0 0 4px;color:#fff}.update-description[data-v-22cc3a0d]{font-size:.9rem;margin:0;color:#fffc;line-height:1.4}.update-actions[data-v-22cc3a0d]{display:flex;gap:12px;align-items:center}.update-btn[data-v-22cc3a0d]{background:linear-gradient(135deg,#f97316 0%,#fb923c 100%);color:#fff;border:none;padding:12px 20px;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 16px #f973164d}.update-btn[data-v-22cc3a0d]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f9731666}.dismiss-btn[data-v-22cc3a0d]{background:transparent;color:#ffffffb3;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .3s ease}.dismiss-btn[data-v-22cc3a0d]:hover{color:#fff;border-color:#ffffff80;background:rgba(255,255,255,.1)}.update-progress[data-v-22cc3a0d]{display:flex;flex-direction:column;gap:16px}.progress-header[data-v-22cc3a0d]{display:flex;align-items:center;gap:12px}.progress-icon[data-v-22cc3a0d]{font-size:2rem;animation:spin-22cc3a0d 2s linear infinite}.progress-info[data-v-22cc3a0d]{flex:1}.progress-title[data-v-22cc3a0d]{font-size:1.2rem;font-weight:700;margin:0 0 4px;color:#fff}.progress-description[data-v-22cc3a0d]{font-size:.9rem;margin:0;color:#fffc;line-height:1.4}.progress-bar-container[data-v-22cc3a0d]{display:flex;align-items:center;gap:12px}.progress-bar[data-v-22cc3a0d]{flex:1;height:8px;background:rgba(255,255,255,.2);border-radius:4px;overflow:hidden}.progress-fill[data-v-22cc3a0d]{height:100%;background:linear-gradient(90deg,#f97316 0%,#fb923c 100%);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill[data-v-22cc3a0d]:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer-22cc3a0d 2s infinite}.progress-percentage[data-v-22cc3a0d]{font-size:.9rem;font-weight:600;color:#fff;min-width:40px;text-align:right}.close-btn[data-v-22cc3a0d]{position:absolute;top:8px;right:8px;background:transparent;border:none;color:#fff9;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:4px;transition:all .3s ease}.close-btn[data-v-22cc3a0d]:hover{color:#fff;background:rgba(255,255,255,.1)}.btn-icon[data-v-22cc3a0d]{font-size:1rem}.btn-text[data-v-22cc3a0d]{font-family:Montserrat,sans-serif}@keyframes slideInDown-22cc3a0d{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes bounce-22cc3a0d{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}@keyframes spin-22cc3a0d{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer-22cc3a0d{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 768px){.pwa-update-banner[data-v-22cc3a0d]{top:10px;padding:16px;max-width:95%}.update-title[data-v-22cc3a0d],.progress-title[data-v-22cc3a0d]{font-size:1.1rem}.update-actions[data-v-22cc3a0d]{flex-direction:column;gap:8px}.update-btn[data-v-22cc3a0d]{width:100%;justify-content:center}}.error-screen[data-v-40736e58]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:all .3s ease}.error-screen.is-visible[data-v-40736e58]{opacity:1;visibility:visible}.error-content[data-v-40736e58]{background:var(--background);border-radius:16px;padding:2rem;max-width:400px;width:90%;text-align:center;box-shadow:0 20px 40px #0000004d;border:1px solid var(--border);animation:slideUp-40736e58 .3s ease}@keyframes slideUp-40736e58{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.error-icon[data-v-40736e58]{font-size:4rem;margin-bottom:1rem;display:block}.error-title[data-v-40736e58]{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.error-message[data-v-40736e58]{color:#fff;font-size:1rem;line-height:1.5;margin:0 0 1rem}.error-details[data-v-40736e58]{background:var(--surface);border-radius:8px;padding:1rem;margin:1rem 0;border-left:4px solid var(--accent)}.error-details p[data-v-40736e58]{color:#fff;font-size:.9rem;margin:0;line-height:1.4}.error-actions[data-v-40736e58]{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.btn-retry[data-v-40736e58]{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:48px;display:flex;align-items:center;justify-content:center}.btn-retry[data-v-40736e58]:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-retry[data-v-40736e58]:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary[data-v-40736e58]{background:transparent;color:#fff;border:1px solid var(--border);border-radius:8px;padding:.75rem 1.5rem;font-size:.9rem;cursor:pointer;transition:all .2s ease}.btn-secondary[data-v-40736e58]:hover{background:var(--surface);color:var(--text);border-color:var(--accent)}.network-status[data-v-40736e58]{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.5rem;border-radius:6px;background:var(--surface)}.status-indicator[data-v-40736e58]{width:8px;height:8px;border-radius:50%;transition:background-color .3s ease}.status-indicator.online[data-v-40736e58]{background:#10b981}.status-indicator.offline[data-v-40736e58]{background:#ef4444}.status-text[data-v-40736e58]{font-size:.8rem;color:#fff;font-weight:500}@media (max-width: 480px){.error-content[data-v-40736e58]{padding:1.5rem;margin:1rem}.error-icon[data-v-40736e58]{font-size:3rem}.error-title[data-v-40736e58]{font-size:1.25rem}}@font-face{font-family:KFGQPC;src:url("/fonts/KFGQPC Uthmanic Script HAFS Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-Medium.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-SemiBold.ttf) format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-Bold.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Mouse Memoirs;src:url(/fonts/Mouse_Memoirs/MouseMemoirs-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}.arabic-text[data-v-6241a5c7]{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.2em;line-height:1.8;text-align:right;direction:rtl;unicode-bidi:embed}.arabic-word[data-v-6241a5c7]{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.4em;line-height:1.6;text-align:right;direction:rtl;unicode-bidi:embed;font-weight:400}.arabic-verse[data-v-6241a5c7]{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.1em;line-height:1.9;text-align:right;direction:rtl;unicode-bidi:embed;padding:12px;background:var(--lesson-card);border:1px solid var(--lesson-border);border-radius:8px;margin:8px 0}.arabic-large[data-v-6241a5c7]{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.8em;line-height:1.5;text-align:right;direction:rtl;unicode-bidi:embed;font-weight:400}:root[data-theme=light][data-v-6241a5c7]{--bg-app: #ffffff;--bg-surface: #e7f2f3;--bg-elevated:#d4eaed;--border: #c7e5e9;--menu-bg: #057d8a;--menu-text: #ffffff;--text: #0e2a2d;--heading: #0b1c1e;--subtext: #395b60;--accent: #f57c00;--accent-hover: #e96c00;--on-accent: #ffffff;--bg-flagship: #057d8a;--text-flagship:#ffffff;--subtext-flagship: #d6f3f6;--lesson-bg: var(--bg-surface);--lesson-card: var(--bg-elevated);--lesson-border: var(--border);--shadow: 0 6px 18px rgba(0,0,0,.35);--brand-teal: #057d8a;--brand-yellow: #f3d516;--brand-orange: #f8903a;--bg: var(--bg-app);--card: var(--bg-elevated);--muted: var(--subtext);--lock: #737373;--primary: var(--accent);--primary-dark: var(--accent-hover);--secondary: #8b5cf6;--success: var(--accent);--warning: var(--brand-orange);--error: #ef4444;--bg-elev: var(--bg-elevated);--card-border: var(--border);--btn-primary-bg:var(--accent);--btn-primary-fg:var(--on-accent);--btn-secondary-bg:var(--brand-yellow);--btn-secondary-fg:#121212;--btn-ghost-fg:var(--accent);--ok:#00bf63;--ok-contrast:#fff;--error:#e76f51;--error-contrast:#fff}:root[data-theme=dark][data-v-6241a5c7]{--bg-app: #0b1c1e;--bg-surface: #112a2c;--bg-elevated:#16383b;--border: #224a4f;--menu-bg: #0b1c1e;--menu-text: #e0eaeb;--text: #e0eaeb;--heading: #f9fafa;--subtext: #9ccbd0;--accent: #057d8a;--accent-hover: #046b76;--on-accent: #ffffff;--lesson-bg: var(--bg-surface);--lesson-card: var(--bg-elevated);--lesson-border: var(--border);--brand-teal: #057d8a;--brand-yellow: #f3d516;--brand-orange: #f8903a;--bg: var(--bg-app);--card: var(--bg-elevated);--muted: var(--subtext);--lock: #8b8b8b;--primary: var(--accent);--primary-dark: var(--accent-hover);--secondary: #8b5cf6;--success: var(--accent);--warning: var(--brand-orange);--error: #ef4444;--bg-elev: var(--bg-elevated);--card-border: var(--border);--shadow: 0 6px 18px rgba(0,0,0,.35);--btn-primary-bg:var(--accent);--btn-primary-fg:var(--on-accent);--btn-secondary-bg:var(--brand-yellow);--btn-secondary-fg:#121212;--btn-ghost-fg:var(--accent)}.page[data-v-6241a5c7]{padding-top:0;min-height:100vh;background:var(--bg-app);color:var(--text)}:root[data-theme=dark] .page[data-v-6241a5c7]{background:var(--bg-app)}.container[data-v-6241a5c7]{max-width:1100px;margin:0 auto;padding:24px}.title[data-v-6241a5c7]{font-family:Mouse Memoirs,sans-serif;font-size:34px;margin:0 0 8px}.muted[data-v-6241a5c7]{color:var(--text-muted);font-family:Montserrat,sans-serif}.global-progress[data-v-6241a5c7]{margin:20px 0;text-align:center}.progress-stars[data-v-6241a5c7]{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:8px;display:block}.progress-bar[data-v-6241a5c7]{width:100%;height:8px;background:var(--bg-elev);border-radius:4px;overflow:hidden;margin-top:8px;position:relative}.progress-fill[data-v-6241a5c7]{height:100%;background:var(--brand-yellow);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill[data-v-6241a5c7]:after{content:"";position:absolute;top:0;right:0;width:4px;height:100%;background:var(--brand-teal);border-radius:0 4px 4px 0;box-shadow:0 0 8px #057d8a99}.progress-fill[data-v-6241a5c7]:before{content:"✨";position:absolute;right:-8px;top:50%;transform:translateY(-50%);font-size:.8rem;animation:sparkleMove-6241a5c7 2s infinite;filter:drop-shadow(0 0 4px rgba(245,158,11,.8))}.calendar-grid[data-v-6241a5c7]{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:24px}@media (max-width: 1024px){.calendar-grid[data-v-6241a5c7]{grid-template-columns:repeat(4,1fr);gap:18px}}@media (max-width: 768px){.calendar-grid[data-v-6241a5c7]{grid-template-columns:repeat(2,1fr);gap:14px}}.day-card[data-v-6241a5c7]{background:var(--card);border:2px solid var(--border);border-radius:16px;padding:14px;cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1);min-height:140px;display:flex;flex-direction:column;position:relative;box-shadow:0 4px 12px #00000014;text-decoration:none;color:inherit;overflow:visible}@media (max-width: 1024px){.day-card[data-v-6241a5c7]{padding:12px;min-height:120px}}@media (max-width: 768px){.day-card[data-v-6241a5c7]{padding:10px;min-height:105px}}@media (max-width: 375px){.day-card[data-v-6241a5c7]{padding:8px;min-height:95px}}.day-card[data-v-6241a5c7]:focus{outline:2px solid var(--primary);outline-offset:2px}.day-card--current .day-title[data-v-6241a5c7],.day-card--current .star-row-header[data-v-6241a5c7],.day-card--current .card-button[data-v-6241a5c7],.day-card--current .day-card--current[data-v-6241a5c7]>*,.day-card--current .progress-section[data-v-6241a5c7],.day-card--current .star-row[data-v-6241a5c7],.day-card--current .stars[data-v-6241a5c7],.day-card--current .star[data-v-6241a5c7],.day-card--current .card-header[data-v-6241a5c7],.day-card--current .card-footer[data-v-6241a5c7]{position:relative;z-index:2;color:#fff!important}.day-card--completed[data-v-6241a5c7]>*,.day-card--completed .progress-section[data-v-6241a5c7],.day-card--completed .star-row[data-v-6241a5c7],.day-card--completed .stars[data-v-6241a5c7],.day-card--completed .star[data-v-6241a5c7],.day-card--completed .card-header[data-v-6241a5c7],.day-card--completed .card-footer[data-v-6241a5c7]{position:relative;z-index:2;color:#fff!important}.day-card--completed[data-v-6241a5c7]:hover{box-shadow:0 8px 32px #057d8a4d;transform:translateY(-2px) scale(1.01)}.day-card--current[data-v-6241a5c7]{background:linear-gradient(135deg,#FFB347 0%,#FF6B00 100%);border:none;border-radius:22px;box-shadow:0 0 24px #ffb347cc,0 8px 20px #00000026;color:#fff;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);animation:currentDayPulse-6241a5c7 2s infinite}:root[data-theme=dark] .day-card--current[data-v-6241a5c7]{background:linear-gradient(135deg,#FFB347 0%,#FF6B00 100%)}.day-card--current[data-v-6241a5c7]:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#e57b27 0%,#d96619 100%);opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1);border-radius:14px;z-index:1}.day-card--current[data-v-6241a5c7]:hover{box-shadow:0 0 32px #ffb347,0 12px 24px #0003;transform:translateY(-2px) scale(1.01)}.day-card--current:hover .day-title[data-v-6241a5c7],.day-card--current:hover .star-row-header[data-v-6241a5c7],.day-card--current:hover .card-button[data-v-6241a5c7],.day-card--current:hover .day-status-icon[data-v-6241a5c7],.day-card--current:hover .stars[data-v-6241a5c7],.day-card--current:hover .star[data-v-6241a5c7]{color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.6)}.day-card--current[data-v-6241a5c7]:hover:after{opacity:1}.day-card--completed[data-v-6241a5c7]{background:linear-gradient(135deg,#0c8a94 0%,#07505a 100%);border:2px solid #0c8a94;color:#fff;position:relative;overflow:hidden;animation:completedShimmer-6241a5c7 6s infinite}:root[data-theme=dark] .day-card--completed[data-v-6241a5c7]{background:linear-gradient(135deg,#0c8a94 0%,#07505a 100%)}.day-card--locked[data-v-6241a5c7]{background:#eceff1;border:2px solid #eceff1;color:var(--lock);cursor:not-allowed;opacity:.8}:root[data-theme=dark] .day-card--locked[data-v-6241a5c7]{background:#2b2f33;border:2px solid #2b2f33;color:var(--lock)}.day-card--locked[aria-disabled=true][data-v-6241a5c7]{opacity:.7}.card-header[data-v-6241a5c7]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;overflow:visible}.day-title[data-v-6241a5c7]{font-family:Mouse Memoirs,sans-serif;font-size:1.25rem;font-weight:600;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.5)}@media (max-width: 768px){.day-title[data-v-6241a5c7]{font-size:1.125rem}}.day-status-icon[data-v-6241a5c7]{font-size:1.2rem;margin-top:2px;margin-right:2px}.checkmark-badge[data-v-6241a5c7]{position:absolute;top:-8px;right:-8px;background:#f3d516;color:#121212;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;box-shadow:0 2px 8px #0003;animation:checkmarkPop-6241a5c7 .5s cubic-bezier(.68,-.55,.265,1.55);z-index:3}.status-completed[data-v-6241a5c7]{animation:completedBounce-6241a5c7 .6s ease-out}.progress-section[data-v-6241a5c7]{flex:1;overflow:visible}.star-row[data-v-6241a5c7]{margin-bottom:6px;overflow:visible}.star-row[data-v-6241a5c7]:last-child{margin-bottom:0}.star-row-header[data-v-6241a5c7]{font-size:.75rem;font-weight:600;color:inherit;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;line-height:1.2;display:flex;align-items:center;gap:6px}.star-icon[data-v-6241a5c7]{font-size:.9rem}.stars[data-v-6241a5c7]{display:flex;gap:7px;flex-wrap:wrap;line-height:26px;overflow:visible}@media (max-width: 768px){.stars[data-v-6241a5c7]{gap:6px;line-height:24px}}.star[data-v-6241a5c7]{color:#e5e7eb;font-size:1.25rem;margin:0;display:inline-block;-webkit-text-stroke:1px #1b1b1b;filter:none;text-shadow:none;line-height:1;transition:color .3s ease}@media (max-width: 768px){.star[data-v-6241a5c7]{font-size:1.125rem}}.star--filled[data-v-6241a5c7]{color:gold;text-shadow:0 0 8px rgba(255,215,0,.6),0 0 4px rgba(255,215,0,.4);filter:drop-shadow(0 1px 2px rgba(255,215,0,.3))}.star[data-v-6241a5c7]:not(.star--filled){color:#d1d5db;filter:grayscale(100%);opacity:.7}[data-theme=dark] .star[data-v-6241a5c7]:not(.star--filled){color:#ffffff26;filter:grayscale(100%);opacity:.6}.star--animating[data-v-6241a5c7]{animation:starFillSequence-6241a5c7 .5s cubic-bezier(.25,.46,.45,.94) forwards}.star--cascade[data-v-6241a5c7]{animation:starFillIn .4s cubic-bezier(.68,-.55,.265,1.55) forwards}.star-halo[data-v-6241a5c7]{position:absolute;top:50%;left:50%;width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.4),transparent);transform:translate(-50%,-50%) scale(0);pointer-events:none}.star--filled .star-halo[data-v-6241a5c7]{animation:haloExpand-6241a5c7 .8s ease-out}.locked-overlay[data-v-6241a5c7]{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:10;transition:opacity .5s ease}.locked-content[data-v-6241a5c7]{text-align:center}.locked-icon[data-v-6241a5c7]{font-size:2rem;color:var(--lock);position:relative}.locked-icon[data-v-6241a5c7]:after{content:"";position:absolute;top:20%;left:50%;transform:translate(-50%);width:8px;height:8px;background:var(--brand-yellow);border-radius:50%;filter:drop-shadow(0 0 4px rgba(243,213,22,.6));animation:lockGlow 2s infinite alternate}.milestone-badge[data-v-6241a5c7]{position:absolute;top:-8px;right:-8px;z-index:15}.badge[data-v-6241a5c7]{display:inline-block;font-size:1.2rem;margin-left:4px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.badge--streak[data-v-6241a5c7]{animation:flameFlicker-6241a5c7 1s infinite alternate}.badge--stars[data-v-6241a5c7]{animation:starTwinkle-6241a5c7 2s infinite}.card-footer[data-v-6241a5c7]{margin-top:6px}@media (max-width: 768px){.card-footer[data-v-6241a5c7]{margin-top:4px}}@media (max-width: 375px){.card-footer[data-v-6241a5c7]{margin-top:3px}}.card-button[data-v-6241a5c7]{width:100%;padding:12px 16px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Montserrat,sans-serif;min-height:44px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.card-button[data-v-6241a5c7]{min-height:40px;padding:10px 14px}}.card-button--start[data-v-6241a5c7]{background:#006666;color:#fff;font-weight:700;border:none;border-radius:22px;box-shadow:0 2px 8px #0663,0 0 #0666;position:relative;animation:ctaPulse-6241a5c7 2s infinite}.card-button--start[data-v-6241a5c7]:hover{background:#007A7A;transform:translateY(-2px);box-shadow:0 4px 12px #007a7a4d,0 0 20px #007a7a80;animation:ctaPulseHover-6241a5c7 1.5s infinite}.card-button--review[data-v-6241a5c7]{background:transparent;color:var(--brand-teal);border:2px solid var(--brand-teal);position:relative;animation:ctaGlow-6241a5c7 3s infinite ease-in-out}.card-button--review[data-v-6241a5c7]:hover{background:var(--brand-teal);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #057d8a33}.card-button--locked[data-v-6241a5c7]{background:var(--gray-300);color:var(--gray-500);cursor:not-allowed;border:2px solid var(--gray-300);opacity:.6}.card-button--locked[data-v-6241a5c7]:hover{transform:none}@keyframes cardPulse-6241a5c7{0%,to{box-shadow:0 0 20px #ffc10766}50%{box-shadow:0 0 30px #ffc10799}}@keyframes completedBounce-6241a5c7{0%{transform:scale(.8)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes currentSpin-6241a5c7{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes starFill-6241a5c7{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1.1);opacity:1}}@keyframes starPop-6241a5c7{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes starFillSequence-6241a5c7{0%{transform:scale(1);color:#e5e7eb;filter:none}50%{transform:scale(1.12);color:#f3d516;filter:drop-shadow(0 0 4px rgba(243,213,22,.6))}to{transform:scale(1);color:#f3d516;filter:none}}:root[data-theme=dark] .star--animating[data-v-6241a5c7]{animation:starFillSequenceDark-6241a5c7 .5s cubic-bezier(.22,1,.36,1) forwards}@keyframes starFillSequenceDark-6241a5c7{0%{transform:scale(1);color:#ffffff40;filter:none}50%{transform:scale(1.12);color:#f3d516;filter:drop-shadow(0 0 4px rgba(243,213,22,.6))}to{transform:scale(1);color:#f3d516;filter:none}}@media (prefers-reduced-motion: reduce){.star--animating[data-v-6241a5c7]{animation:none;color:#f3d516}:root[data-theme=dark] .star--animating[data-v-6241a5c7]{animation:none;color:#f3d516}}@keyframes starCascade-6241a5c7{0%{transform:scale(.3) rotate(-180deg);opacity:0}50%{transform:scale(1.4) rotate(0);opacity:1}to{transform:scale(1.15) rotate(0);opacity:1}}@keyframes haloExpand-6241a5c7{0%{transform:translate(-50%,-50%) scale(0);opacity:1}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.8}to{transform:translate(-50%,-50%) scale(2);opacity:0}}@keyframes shimmer-6241a5c7{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}@keyframes currentDayPulse-6241a5c7{0%,to{box-shadow:0 0 24px #ffb347cc,0 8px 20px #00000026;transform:scale(1)}50%{box-shadow:0 0 36px #ffb347,0 12px 28px #00000040;transform:scale(1.02)}}@keyframes currentGlow-6241a5c7{0%,to{box-shadow:0 0 24px #7c2d1299,inset 0 2px 4px #0003}50%{box-shadow:0 0 32px #7c2d12cc,inset 0 2px 4px #0003}}@keyframes completedPulse-6241a5c7{0%,to{box-shadow:0 8px 24px #0f766e4d}50%{box-shadow:0 8px 32px #0f766e80}}@keyframes completedShimmer-6241a5c7{0%,to{box-shadow:0 4px 16px #057d8a33}50%{box-shadow:0 4px 20px #057d8a4d,0 0 8px #ffffff1a}}@keyframes borderGlow-6241a5c7{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}@keyframes lockPulse-6241a5c7{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}@keyframes flameFlicker-6241a5c7{0%{transform:scale(1) rotate(-2deg);filter:hue-rotate(0deg)}to{transform:scale(1.1) rotate(2deg);filter:hue-rotate(10deg)}}@keyframes starTwinkle-6241a5c7{0%,to{transform:scale(1) rotate(0);opacity:1}25%{transform:scale(1.2) rotate(90deg);opacity:.8}50%{transform:scale(.9) rotate(180deg);opacity:1}75%{transform:scale(1.1) rotate(270deg);opacity:.9}}@keyframes checkmarkPop-6241a5c7{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}@keyframes progressShine-6241a5c7{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes sparkleMove-6241a5c7{0%,to{transform:translateY(-50%) scale(1);opacity:1}50%{transform:translateY(-50%) scale(1.2);opacity:.8}}@keyframes bounce-6241a5c7{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.progress-point[data-v-6241a5c7]{position:absolute;z-index:2;width:12px;height:12px;display:flex;align-items:center;justify-content:center}.progress-dot[data-v-6241a5c7]{width:8px;height:8px;border-radius:50%;background:var(--card-border);transition:all .3s ease;border:1px solid var(--bg)}.progress-point--word .progress-dot[data-v-6241a5c7]{background:var(--text-muted);opacity:.4}.progress-point--exercise .progress-dot[data-v-6241a5c7]{background:var(--text-muted);opacity:.4;border:2px solid var(--card-border)}.progress-point--completed .progress-dot[data-v-6241a5c7]{background:var(--brand);opacity:1;box-shadow:0 0 8px #00968866;transform:scale(1.2)}.progress-point--current .progress-dot[data-v-6241a5c7]{background:var(--warning);opacity:1;animation:progressPulse-6241a5c7 1.5s infinite;transform:scale(1.3)}@keyframes progressPulse-6241a5c7{0%,to{box-shadow:0 0 6px #ffc10799;opacity:1}50%{box-shadow:0 0 12px #ffc107e6;opacity:.8}}.locked-tooltip[data-v-6241a5c7]{position:fixed;z-index:1000;pointer-events:none;transform:translate(-50%,-100%);margin-top:-10px}.tooltip-content[data-v-6241a5c7]{background:var(--bg-card);border:1px solid var(--card-border);border-radius:8px;padding:12px 16px;box-shadow:0 8px 24px #0003;text-align:center;min-width:160px}.tooltip-icon[data-v-6241a5c7]{font-size:1.2rem;margin-bottom:4px;display:block}.tooltip-text[data-v-6241a5c7]{font-weight:600;color:var(--text);font-size:.9rem;display:block;margin-bottom:4px}.tooltip-subtitle[data-v-6241a5c7]{font-size:.75rem;color:var(--text-muted);margin:0}h1[data-v-6241a5c7],h2[data-v-6241a5c7],h3[data-v-6241a5c7],.title[data-v-6241a5c7]{font-family:Mouse Memoirs,sans-serif}body[data-v-6241a5c7],.body[data-v-6241a5c7]{font-family:Montserrat,sans-serif;font-size:16px;line-height:1.5;margin:0;padding:0}a[data-v-6241a5c7],a[data-v-6241a5c7]:link,a[data-v-6241a5c7]:visited,a[data-v-6241a5c7]:hover,a[data-v-6241a5c7]:active{text-decoration:none!important;color:inherit!important}.muted[data-v-6241a5c7]{color:var(--text-muted)}.btn[data-v-6241a5c7]{border-radius:12px;padding:12px 18px;font-weight:700;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;transition:all .2s ease}.btn[data-v-6241a5c7]:disabled{opacity:.45;pointer-events:none}.btn[data-v-6241a5c7]:hover{filter:brightness(1.05)}.btn-primary[data-v-6241a5c7]{background:var(--btn-primary-bg);color:var(--btn-primary-fg);border:2px solid var(--btn-primary-bg)}.btn-primary[data-v-6241a5c7]:hover{background:#046a75;border-color:#046a75;color:#fff}.btn-secondary[data-v-6241a5c7]{background:var(--btn-secondary-bg);color:var(--btn-secondary-fg);border:2px solid var(--btn-secondary-bg)}.btn-secondary[data-v-6241a5c7]:hover{background:#e6c014;border-color:#e6c014;color:#121212}.btn-ghost[data-v-6241a5c7]{background:transparent;color:var(--btn-ghost-fg);border:1px solid currentColor}.btn-ghost[data-v-6241a5c7]:hover{background:var(--btn-ghost-fg);color:#fff}.btn-destructive[data-v-6241a5c7]{background:var(--error);color:var(--error-contrast)}.header[data-v-6241a5c7]{position:sticky;top:0;z-index:9999999;background:var(--menu-bg);box-shadow:var(--shadow);height:64px;display:flex;align-items:center}.hamburger[data-v-6241a5c7]{margin-left:20px;margin-right:12px;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.1);color:var(--menu-text);border:1px solid rgba(255,255,255,.2);cursor:pointer;font-size:18px}.app-title[data-v-6241a5c7]{font-size:1.5rem;font-weight:400;margin:0;color:var(--menu-text)}.theme-toggle[data-v-6241a5c7]{margin-left:auto;margin-right:20px}.drawer[data-v-6241a5c7]{position:fixed;top:64px;right:0;bottom:0;left:0;z-index:9999998;pointer-events:none;visibility:hidden}.drawer.is-open[data-v-6241a5c7]{visibility:visible}.drawer__backdrop[data-v-6241a5c7]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:9999997;background:rgba(0,0,0,.45);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity .25s ease;pointer-events:auto}.drawer__panel[data-v-6241a5c7]{position:absolute;left:0;top:0;bottom:0;width:min(320px,90vw);background:var(--bg-elev);color:var(--text);border-right:1px solid var(--card-border);box-shadow:0 12px 40px #00000059;transform:translate(-100%);transition:transform .25s ease;z-index:9999998;pointer-events:auto}.drawer.is-open[data-v-6241a5c7]{pointer-events:auto}.drawer.is-open .drawer__panel[data-v-6241a5c7]{transform:translate(0)}.drawer.is-open .drawer__backdrop[data-v-6241a5c7]{opacity:1}.nav__item[data-v-6241a5c7],.nav__item[data-v-6241a5c7]:visited{color:var(--text)!important;text-decoration:none;display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--card-border);cursor:pointer}.nav__item[data-v-6241a5c7]:hover{background:rgba(0,0,0,.06)}:root[data-theme=dark] .nav__item[data-v-6241a5c7]:hover{background:rgba(255,255,255,.06)}.card[data-v-6241a5c7]{background:var(--bg-elev);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow);padding:20px;margin-bottom:1.5rem}.stats-tile[data-v-6241a5c7]{background:var(--bg-elev);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow);padding:16px;text-align:center}.path[data-v-6241a5c7]{stroke:var(--brand);stroke-width:8;filter:drop-shadow(0 0 8px rgba(5,125,138,.35))}.day-node[data-v-6241a5c7]{width:56px;height:56px;border-radius:50%;background:var(--bg-elev);border:3px solid #fff;display:grid;place-items:center;font-weight:700;color:var(--text)}.day-node--active[data-v-6241a5c7]{box-shadow:0 0 0 6px #057d8a26}.day-node+.day-node[data-v-6241a5c7]{margin-top:64px}[data-v-6241a5c7]:focus-visible{outline:3px solid rgba(243,213,22,.7);outline-offset:2px}@media (prefers-reduced-motion: reduce){[data-v-6241a5c7]{transition:none!important;animation:none!important}}.slide-up-enter-active[data-v-6241a5c7],.slide-up-leave-active[data-v-6241a5c7]{transition:all .3s ease}.slide-up-enter-from[data-v-6241a5c7]{transform:translateY(20px);opacity:0}.slide-up-leave-to[data-v-6241a5c7]{transform:translateY(-20px);opacity:0}@keyframes ctaPulse-6241a5c7{0%{box-shadow:0 2px 8px #0663,0 0 #0666}50%{box-shadow:0 2px 8px #0663,0 0 0 8px #0066661a}to{box-shadow:0 2px 8px #0663,0 0 #0666}}@keyframes ctaPulseHover-6241a5c7{0%{box-shadow:0 4px 12px #007a7a4d,0 0 20px #007a7a80}50%{box-shadow:0 6px 16px #007a7a66,0 0 30px #007a7ab3}to{box-shadow:0 4px 12px #007a7a4d,0 0 20px #007a7a80}}@keyframes ctaGlow-6241a5c7{0%{box-shadow:0 0 5px #057d8a4d}50%{box-shadow:0 0 15px #057d8a99,0 0 25px #057d8a4d}to{box-shadow:0 0 5px #057d8a4d}}.modal-overlay[data-v-6241a5c7],.paywall-modal-overlay[data-v-6241a5c7],.ios-modal-overlay[data-v-6241a5c7]{backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important;background:rgba(0,0,0,.4)!important}@supports not (backdrop-filter: blur(10px)){.modal-overlay[data-v-6241a5c7],.paywall-modal-overlay[data-v-6241a5c7],.ios-modal-overlay[data-v-6241a5c7]{background:rgba(0,0,0,.7)!important}}.user-header[data-v-6241a5c7]{display:flex;align-items:center;gap:12px;padding:8px 0}.profile-avatar[data-v-6241a5c7]{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--border);background:var(--bg-surface)}.avatar-image[data-v-6241a5c7]{width:100%;height:100%;object-fit:cover}.avatar-placeholder[data-v-6241a5c7]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--on-accent);font-family:Montserrat,sans-serif;font-weight:600;font-size:.9rem}.user-info[data-v-6241a5c7]{flex:1;min-width:0}.user-name[data-v-6241a5c7]{font-family:Montserrat,sans-serif;font-size:1rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}:root[data-theme=dark] .user-name[data-v-6241a5c7]{color:#fff}.user-progress[data-v-6241a5c7]{display:flex;align-items:center}.progress-text[data-v-6241a5c7]{font-family:Montserrat,sans-serif;font-size:.8rem;color:var(--subtext);background:var(--bg-elevated);padding:2px 8px;border-radius:12px;border:1px solid var(--border)}@media (max-width: 480px){.user-header[data-v-6241a5c7]{gap:8px}.profile-avatar[data-v-6241a5c7]{width:32px;height:32px}.user-name[data-v-6241a5c7]{font-size:.9rem}.progress-text[data-v-6241a5c7]{font-size:.75rem;padding:1px 6px}}:root[data-theme=dark] .avatar-placeholder[data-v-6241a5c7]{background:var(--accent);color:var(--on-accent)}:root[data-theme=dark] .progress-text[data-v-6241a5c7]{background:var(--bg-elevated);border-color:var(--border)}.app-title[data-v-ba527f75]{font-family:Mouse Memoirs,sans-serif;font-size:1.8rem;color:var(--text);margin:0;font-weight:400}#app[data-v-ba527f75]{background-color:var(--bg-app, var(--background));min-height:100vh}.main-content[data-v-ba527f75]{padding-top:calc(60px + env(safe-area-inset-top,0px));min-height:100vh;background-color:var(--bg-app, var(--background))}.main-content[data-v-ba527f75]:has(.auth-view){padding-top:calc(env(safe-area-inset-top,20px) + 1rem)}@supports not (selector(:has(*))){.auth-page .main-content[data-v-ba527f75]{padding-top:calc(env(safe-area-inset-top,20px) + 1rem)}}.drawer__panel[data-v-ba527f75]{display:flex;flex-direction:column;height:100%}.nav__main[data-v-ba527f75]{flex:1;overflow-y:auto}.nav__bottom[data-v-ba527f75]{margin-top:auto;padding:20px 0;border-top:1px solid var(--border)}.nav__item--support[data-v-ba527f75]{opacity:.8;font-size:.9rem}.nav__item--support[data-v-ba527f75]:hover{opacity:1}.nav__item--locked[data-v-ba527f75]{opacity:.7;color:#aaa!important;cursor:not-allowed;transition:all .3s ease}.nav__item--locked[data-v-ba527f75]:hover{opacity:.8;color:#bbb!important;background:rgba(170,170,170,.1)!important}body.dark-mode .nav__item--locked[data-v-ba527f75]{color:#888!important}body.dark-mode .nav__item--locked[data-v-ba527f75]:hover{color:#999!important;background:rgba(136,136,136,.1)!important}body[data-v-ba527f75]{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important;-webkit-touch-callout:none!important;-webkit-tap-highlight-color:transparent!important}[data-v-ba527f75],[data-v-ba527f75]:before,[data-v-ba527f75]:after{-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important;-webkit-user-drag:none!important;-khtml-user-drag:none!important;-moz-user-drag:none!important;-o-user-drag:none!important;user-drag:none!important}[data-v-ba527f75]::selection{background:transparent!important}.fonts-auto-loaded .main-content[data-v-ba527f75]{transition:font-family .3s ease}.fonts-loading[data-v-ba527f75]{font-display:swap}.header[data-v-ba527f75]{position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;padding-top:env(safe-area-inset-top,0px);background-color:var(--bg-app, var(--background));box-shadow:0 2px 8px #0000001a;transition:all .3s ease}[data-theme=light] .header[data-v-ba527f75]{background-color:var(--primary-color, #057d8a);box-shadow:0 2px 8px #00000026}[data-theme=dark] .header[data-v-ba527f75]{background-color:var(--bg-app, #0b1c1e);box-shadow:0 2px 8px #0000004d}body.light-mode .header[data-v-ba527f75]{background-color:var(--primary-color, #057d8a);box-shadow:0 2px 8px #00000026}body.dark-mode .header[data-v-ba527f75]{background-color:var(--bg-app, #0b1c1e);box-shadow:0 2px 8px #0000004d}.hamburger[data-v-ba527f75]{position:relative;z-index:1000001}.drawer[data-v-ba527f75]{z-index:1000000;position:fixed!important;inset:calc(60px + env(safe-area-inset-top,0px)) 0 0 0!important;margin-top:0}.welcome-tutorial-overlay[data-v-ba527f75]{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn-ba527f75 .3s ease-out}.welcome-tutorial-content[data-v-ba527f75]{background:linear-gradient(135deg,#057d8a 0%,#045a63 100%);border-radius:20px;padding:40px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;border:2px solid rgba(255,255,255,.1)}.tutorial-slide[data-v-ba527f75]{text-align:center}.tutorial-slide h2[data-v-ba527f75]{font-size:2rem;font-weight:800;color:#fff;margin-bottom:24px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.tutorial-slide p[data-v-ba527f75]{font-size:1.1rem;color:#ffffffe6;line-height:1.6;margin-bottom:20px}.tutorial-slide p[data-v-ba527f75]:last-of-type{margin-bottom:32px}.tutorial-next-btn[data-v-ba527f75]{background:linear-gradient(135deg,#f97316 0%,#fb923c 100%);color:#fff;border:none;padding:16px 32px;border-radius:16px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #f973164d;min-width:140px}.tutorial-next-btn[data-v-ba527f75]:hover{transform:translateY(-2px);box-shadow:0 12px 32px #f9731666}.tutorial-next-btn[data-v-ba527f75]:active{transform:translateY(0)}@keyframes fadeIn-ba527f75{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.update-modal[data-v-ba527f75]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:10000}.update-modal-content[data-v-ba527f75]{background:white;padding:2rem;border-radius:12px;text-align:center;max-width:400px;width:90%;box-shadow:0 20px 40px #0000004d}.update-modal .update-icon[data-v-ba527f75]{font-size:3rem;color:var(--brand-teal);margin-bottom:1rem;animation:spin-ba527f75 2s linear infinite}.update-modal h3[data-v-ba527f75]{margin:0 0 .5rem;color:var(--text-primary);font-size:1.25rem}.update-modal p[data-v-ba527f75]{margin:0 0 1rem;color:var(--text-secondary)}.progress-bar[data-v-ba527f75]{width:100%;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;margin:1rem 0}.progress-fill[data-v-ba527f75]{height:100%;background:var(--brand-teal);transition:width .3s ease;border-radius:4px}.progress-text[data-v-ba527f75]{font-weight:600;color:var(--brand-teal);font-size:1.1rem}@keyframes spin-ba527f75{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.download-text[data-v-ba527f75]{flex:1}.download-title[data-v-ba527f75]{font-size:12px;font-weight:600;color:#374151;margin-bottom:2px}.download-progress[data-v-ba527f75]{font-size:11px;color:#6b7280;font-weight:500}.download-bar[data-v-ba527f75]{width:60px;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}.download-fill[data-v-ba527f75]{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:2px;transition:width .3s ease}@keyframes slideInRight-ba527f75{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes bounce-ba527f75{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-3px)}60%{transform:translateY(-2px)}}body.dark-mode .offline-download-indicator[data-v-ba527f75]{background:rgba(31,41,55,.95);border-color:#ffffff1a}body.dark-mode .download-title[data-v-ba527f75]{color:#f3f4f6}body.dark-mode .download-progress[data-v-ba527f75]{color:#9ca3af}@media (max-width: 768px){.app-title[data-v-ba527f75]{font-size:1.5rem}.welcome-tutorial-content[data-v-ba527f75]{width:calc(100% - 32px);max-width:95%;margin:0 16px;padding:32px 24px}.tutorial-slide h2[data-v-ba527f75]{font-size:1.6rem;margin-bottom:20px}.tutorial-slide p[data-v-ba527f75]{font-size:1rem;margin-bottom:16px}.tutorial-next-btn[data-v-ba527f75]{padding:14px 28px;font-size:1rem;min-width:120px}.offline-download-indicator[data-v-ba527f75]{top:10px;right:10px;min-width:180px;padding:10px 12px}.download-title[data-v-ba527f75]{font-size:11px}.download-progress[data-v-ba527f75]{font-size:10px}.download-bar[data-v-ba527f75]{width:50px}}@font-face{font-family:KFGQPC;src:url("/fonts/KFGQPC Uthmanic Script HAFS Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-Medium.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-SemiBold.ttf) format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:Montserrat;src:url(/fonts/Montserrat/static/Montserrat-Bold.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Mouse Memoirs;src:url(/fonts/Mouse_Memoirs/MouseMemoirs-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}.arabic-text{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.2em;line-height:1.8;text-align:right;direction:rtl;unicode-bidi:embed}.arabic-word{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.4em;line-height:1.6;text-align:right;direction:rtl;unicode-bidi:embed;font-weight:400}.arabic-verse{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.1em;line-height:1.9;text-align:right;direction:rtl;unicode-bidi:embed;padding:12px;background:var(--lesson-card);border:1px solid var(--lesson-border);border-radius:8px;margin:8px 0}.arabic-large{font-family:KFGQPC,Amiri,Scheherazade New,Arabic Typesetting,serif;font-size:1.8em;line-height:1.5;text-align:right;direction:rtl;unicode-bidi:embed;font-weight:400}:root[data-theme=light]{--bg-app: #ffffff;--bg-surface: #e7f2f3;--bg-elevated:#d4eaed;--border: #c7e5e9;--menu-bg: #057d8a;--menu-text: #ffffff;--text: #0e2a2d;--heading: #0b1c1e;--subtext: #395b60;--accent: #f57c00;--accent-hover: #e96c00;--on-accent: #ffffff;--bg-flagship: #057d8a;--text-flagship:#ffffff;--subtext-flagship: #d6f3f6;--lesson-bg: var(--bg-surface);--lesson-card: var(--bg-elevated);--lesson-border: var(--border);--shadow: 0 6px 18px rgba(0,0,0,.35);--brand-teal: #057d8a;--brand-yellow: #f3d516;--brand-orange: #f8903a;--bg: var(--bg-app);--card: var(--bg-elevated);--muted: var(--subtext);--lock: #737373;--primary: var(--accent);--primary-dark: var(--accent-hover);--secondary: #8b5cf6;--success: var(--accent);--warning: var(--brand-orange);--error: #ef4444;--bg-elev: var(--bg-elevated);--card-border: var(--border);--btn-primary-bg:var(--accent);--btn-primary-fg:var(--on-accent);--btn-secondary-bg:var(--brand-yellow);--btn-secondary-fg:#121212;--btn-ghost-fg:var(--accent);--ok:#00bf63;--ok-contrast:#fff;--error:#e76f51;--error-contrast:#fff}:root[data-theme=dark]{--bg-app: #0b1c1e;--bg-surface: #112a2c;--bg-elevated:#16383b;--border: #224a4f;--menu-bg: #0b1c1e;--menu-text: #e0eaeb;--text: #e0eaeb;--heading: #f9fafa;--subtext: #9ccbd0;--accent: #057d8a;--accent-hover: #046b76;--on-accent: #ffffff;--lesson-bg: var(--bg-surface);--lesson-card: var(--bg-elevated);--lesson-border: var(--border);--brand-teal: #057d8a;--brand-yellow: #f3d516;--brand-orange: #f8903a;--bg: var(--bg-app);--card: var(--bg-elevated);--muted: var(--subtext);--lock: #8b8b8b;--primary: var(--accent);--primary-dark: var(--accent-hover);--secondary: #8b5cf6;--success: var(--accent);--warning: var(--brand-orange);--error: #ef4444;--bg-elev: var(--bg-elevated);--card-border: var(--border);--shadow: 0 6px 18px rgba(0,0,0,.35);--btn-primary-bg:var(--accent);--btn-primary-fg:var(--on-accent);--btn-secondary-bg:var(--brand-yellow);--btn-secondary-fg:#121212;--btn-ghost-fg:var(--accent)}.page{padding-top:0;min-height:100vh;background:var(--bg-app);color:var(--text)}:root[data-theme=dark] .page{background:var(--bg-app)}.container{max-width:1100px;margin:0 auto;padding:24px}.title{font-family:Mouse Memoirs,sans-serif;font-size:34px;margin:0 0 8px}.muted{color:var(--text-muted);font-family:Montserrat,sans-serif}.global-progress{margin:20px 0;text-align:center}.progress-stars{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:8px;display:block}.progress-bar{width:100%;height:8px;background:var(--bg-elev);border-radius:4px;overflow:hidden;margin-top:8px;position:relative}.progress-fill{height:100%;background:var(--brand-yellow);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;right:0;width:4px;height:100%;background:var(--brand-teal);border-radius:0 4px 4px 0;box-shadow:0 0 8px #057d8a99}.progress-fill:before{content:"✨";position:absolute;right:-8px;top:50%;transform:translateY(-50%);font-size:.8rem;animation:sparkleMove 2s infinite;filter:drop-shadow(0 0 4px rgba(245,158,11,.8))}.calendar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:24px}@media (max-width: 1024px){.calendar-grid{grid-template-columns:repeat(4,1fr);gap:18px}}@media (max-width: 768px){.calendar-grid{grid-template-columns:repeat(2,1fr);gap:14px}}.day-card{background:var(--card);border:2px solid var(--border);border-radius:16px;padding:14px;cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1);min-height:140px;display:flex;flex-direction:column;position:relative;box-shadow:0 4px 12px #00000014;text-decoration:none;color:inherit;overflow:visible}@media (max-width: 1024px){.day-card{padding:12px;min-height:120px}}@media (max-width: 768px){.day-card{padding:10px;min-height:105px}}@media (max-width: 375px){.day-card{padding:8px;min-height:95px}}.day-card:focus{outline:2px solid var(--primary);outline-offset:2px}.day-card--current .day-title,.day-card--current .star-row-header,.day-card--current .card-button,.day-card--current .day-card--current>*,.day-card--current .progress-section,.day-card--current .star-row,.day-card--current .stars,.day-card--current .star,.day-card--current .card-header,.day-card--current .card-footer{position:relative;z-index:2;color:#fff!important}.day-card--completed>*,.day-card--completed .progress-section,.day-card--completed .star-row,.day-card--completed .stars,.day-card--completed .star,.day-card--completed .card-header,.day-card--completed .card-footer{position:relative;z-index:2;color:#fff!important}.day-card--completed:hover{box-shadow:0 8px 32px #057d8a4d;transform:translateY(-2px) scale(1.01)}.day-card--current{background:linear-gradient(135deg,#FFB347 0%,#FF6B00 100%);border:none;border-radius:22px;box-shadow:0 0 24px #ffb347cc,0 8px 20px #00000026;color:#fff;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);animation:currentDayPulse 2s infinite}:root[data-theme=dark] .day-card--current{background:linear-gradient(135deg,#FFB347 0%,#FF6B00 100%)}.day-card--current:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#e57b27 0%,#d96619 100%);opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1);border-radius:14px;z-index:1}.day-card--current:hover{box-shadow:0 0 32px #ffb347,0 12px 24px #0003;transform:translateY(-2px) scale(1.01)}.day-card--current:hover .day-title,.day-card--current:hover .star-row-header,.day-card--current:hover .card-button,.day-card--current:hover .day-status-icon,.day-card--current:hover .stars,.day-card--current:hover .star{color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.6)}.day-card--current:hover:after{opacity:1}.day-card--completed{background:linear-gradient(135deg,#0c8a94 0%,#07505a 100%);border:2px solid #0c8a94;color:#fff;position:relative;overflow:hidden;animation:completedShimmer 6s infinite}:root[data-theme=dark] .day-card--completed{background:linear-gradient(135deg,#0c8a94 0%,#07505a 100%)}.day-card--locked{background:#eceff1;border:2px solid #eceff1;color:var(--lock);cursor:not-allowed;opacity:.8}:root[data-theme=dark] .day-card--locked{background:#2b2f33;border:2px solid #2b2f33;color:var(--lock)}.day-card--locked[aria-disabled=true]{opacity:.7}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;overflow:visible}.day-title{font-family:Mouse Memoirs,sans-serif;font-size:1.25rem;font-weight:600;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.5)}@media (max-width: 768px){.day-title{font-size:1.125rem}}.day-status-icon{font-size:1.2rem;margin-top:2px;margin-right:2px}.checkmark-badge{position:absolute;top:-8px;right:-8px;background:#f3d516;color:#121212;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;box-shadow:0 2px 8px #0003;animation:checkmarkPop .5s cubic-bezier(.68,-.55,.265,1.55);z-index:3}.status-completed{animation:completedBounce .6s ease-out}.progress-section{flex:1;overflow:visible}.star-row{margin-bottom:6px;overflow:visible}.star-row:last-child{margin-bottom:0}.star-row-header{font-size:.75rem;font-weight:600;color:inherit;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;line-height:1.2;display:flex;align-items:center;gap:6px}.star-icon{font-size:.9rem}.stars{display:flex;gap:7px;flex-wrap:wrap;line-height:26px;overflow:visible}@media (max-width: 768px){.stars{gap:6px;line-height:24px}}.star{color:#e5e7eb;font-size:1.25rem;margin:0;display:inline-block;-webkit-text-stroke:1px #1b1b1b;filter:none;text-shadow:none;line-height:1;transition:color .3s ease}@media (max-width: 768px){.star{font-size:1.125rem}}.star--filled{color:gold;text-shadow:0 0 8px rgba(255,215,0,.6),0 0 4px rgba(255,215,0,.4);filter:drop-shadow(0 1px 2px rgba(255,215,0,.3))}.star:not(.star--filled){color:#d1d5db;filter:grayscale(100%);opacity:.7}[data-theme=dark] .star:not(.star--filled){color:#ffffff26;filter:grayscale(100%);opacity:.6}.star--animating{animation:starFillSequence .5s cubic-bezier(.25,.46,.45,.94) forwards}.star--cascade{animation:starFillIn .4s cubic-bezier(.68,-.55,.265,1.55) forwards}.star-halo{position:absolute;top:50%;left:50%;width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.4),transparent);transform:translate(-50%,-50%) scale(0);pointer-events:none}.star--filled .star-halo{animation:haloExpand .8s ease-out}.locked-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:10;transition:opacity .5s ease}.locked-content{text-align:center}.locked-icon{font-size:2rem;color:var(--lock);position:relative}.locked-icon:after{content:"";position:absolute;top:20%;left:50%;transform:translate(-50%);width:8px;height:8px;background:var(--brand-yellow);border-radius:50%;filter:drop-shadow(0 0 4px rgba(243,213,22,.6));animation:lockGlow 2s infinite alternate}.milestone-badge{position:absolute;top:-8px;right:-8px;z-index:15}.badge{display:inline-block;font-size:1.2rem;margin-left:4px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.badge--streak{animation:flameFlicker 1s infinite alternate}.badge--stars{animation:starTwinkle 2s infinite}.card-footer{margin-top:6px}@media (max-width: 768px){.card-footer{margin-top:4px}}@media (max-width: 375px){.card-footer{margin-top:3px}}.card-button{width:100%;padding:12px 16px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Montserrat,sans-serif;min-height:44px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.card-button{min-height:40px;padding:10px 14px}}.card-button--start{background:#006666;color:#fff;font-weight:700;border:none;border-radius:22px;box-shadow:0 2px 8px #0663,0 0 #0666;position:relative;animation:ctaPulse 2s infinite}.card-button--start:hover{background:#007A7A;transform:translateY(-2px);box-shadow:0 4px 12px #007a7a4d,0 0 20px #007a7a80;animation:ctaPulseHover 1.5s infinite}.card-button--review{background:transparent;color:var(--brand-teal);border:2px solid var(--brand-teal);position:relative;animation:ctaGlow 3s infinite ease-in-out}.card-button--review:hover{background:var(--brand-teal);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #057d8a33}.card-button--locked{background:var(--gray-300);color:var(--gray-500);cursor:not-allowed;border:2px solid var(--gray-300);opacity:.6}.card-button--locked:hover{transform:none}@keyframes cardPulse{0%,to{box-shadow:0 0 20px #ffc10766}50%{box-shadow:0 0 30px #ffc10799}}@keyframes completedBounce{0%{transform:scale(.8)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes currentSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes starFill{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1.1);opacity:1}}@keyframes starPop{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes starFillSequence{0%{transform:scale(1);color:#e5e7eb;filter:none}50%{transform:scale(1.12);color:#f3d516;filter:drop-shadow(0 0 4px rgba(243,213,22,.6))}to{transform:scale(1);color:#f3d516;filter:none}}:root[data-theme=dark] .star--animating{animation:starFillSequenceDark .5s cubic-bezier(.22,1,.36,1) forwards}@keyframes starFillSequenceDark{0%{transform:scale(1);color:#ffffff40;filter:none}50%{transform:scale(1.12);color:#f3d516;filter:drop-shadow(0 0 4px rgba(243,213,22,.6))}to{transform:scale(1);color:#f3d516;filter:none}}@media (prefers-reduced-motion: reduce){.star--animating{animation:none;color:#f3d516}:root[data-theme=dark] .star--animating{animation:none;color:#f3d516}}@keyframes starCascade{0%{transform:scale(.3) rotate(-180deg);opacity:0}50%{transform:scale(1.4) rotate(0);opacity:1}to{transform:scale(1.15) rotate(0);opacity:1}}@keyframes haloExpand{0%{transform:translate(-50%,-50%) scale(0);opacity:1}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.8}to{transform:translate(-50%,-50%) scale(2);opacity:0}}@keyframes shimmer{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}@keyframes currentDayPulse{0%,to{box-shadow:0 0 24px #ffb347cc,0 8px 20px #00000026;transform:scale(1)}50%{box-shadow:0 0 36px #ffb347,0 12px 28px #00000040;transform:scale(1.02)}}@keyframes currentGlow{0%,to{box-shadow:0 0 24px #7c2d1299,inset 0 2px 4px #0003}50%{box-shadow:0 0 32px #7c2d12cc,inset 0 2px 4px #0003}}@keyframes completedPulse{0%,to{box-shadow:0 8px 24px #0f766e4d}50%{box-shadow:0 8px 32px #0f766e80}}@keyframes completedShimmer{0%,to{box-shadow:0 4px 16px #057d8a33}50%{box-shadow:0 4px 20px #057d8a4d,0 0 8px #ffffff1a}}@keyframes borderGlow{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}@keyframes lockPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}@keyframes flameFlicker{0%{transform:scale(1) rotate(-2deg);filter:hue-rotate(0deg)}to{transform:scale(1.1) rotate(2deg);filter:hue-rotate(10deg)}}@keyframes starTwinkle{0%,to{transform:scale(1) rotate(0);opacity:1}25%{transform:scale(1.2) rotate(90deg);opacity:.8}50%{transform:scale(.9) rotate(180deg);opacity:1}75%{transform:scale(1.1) rotate(270deg);opacity:.9}}@keyframes checkmarkPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}@keyframes progressShine{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes sparkleMove{0%,to{transform:translateY(-50%) scale(1);opacity:1}50%{transform:translateY(-50%) scale(1.2);opacity:.8}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.progress-point{position:absolute;z-index:2;width:12px;height:12px;display:flex;align-items:center;justify-content:center}.progress-dot{width:8px;height:8px;border-radius:50%;background:var(--card-border);transition:all .3s ease;border:1px solid var(--bg)}.progress-point--word .progress-dot{background:var(--text-muted);opacity:.4}.progress-point--exercise .progress-dot{background:var(--text-muted);opacity:.4;border:2px solid var(--card-border)}.progress-point--completed .progress-dot{background:var(--brand);opacity:1;box-shadow:0 0 8px #00968866;transform:scale(1.2)}.progress-point--current .progress-dot{background:var(--warning);opacity:1;animation:progressPulse 1.5s infinite;transform:scale(1.3)}@keyframes progressPulse{0%,to{box-shadow:0 0 6px #ffc10799;opacity:1}50%{box-shadow:0 0 12px #ffc107e6;opacity:.8}}.locked-tooltip{position:fixed;z-index:1000;pointer-events:none;transform:translate(-50%,-100%);margin-top:-10px}.tooltip-content{background:var(--bg-card);border:1px solid var(--card-border);border-radius:8px;padding:12px 16px;box-shadow:0 8px 24px #0003;text-align:center;min-width:160px}.tooltip-icon{font-size:1.2rem;margin-bottom:4px;display:block}.tooltip-text{font-weight:600;color:var(--text);font-size:.9rem;display:block;margin-bottom:4px}.tooltip-subtitle{font-size:.75rem;color:var(--text-muted);margin:0}h1,h2,h3,.title{font-family:Mouse Memoirs,sans-serif}body,.body{font-family:Montserrat,sans-serif;font-size:16px;line-height:1.5;margin:0;padding:0}a,a:link,a:visited,a:hover,a:active{text-decoration:none!important;color:inherit!important}.muted{color:var(--text-muted)}.btn{border-radius:12px;padding:12px 18px;font-weight:700;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;transition:all .2s ease}.btn:disabled{opacity:.45;pointer-events:none}.btn:hover{filter:brightness(1.05)}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-fg);border:2px solid var(--btn-primary-bg)}.btn-primary:hover{background:#046a75;border-color:#046a75;color:#fff}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-fg);border:2px solid var(--btn-secondary-bg)}.btn-secondary:hover{background:#e6c014;border-color:#e6c014;color:#121212}.btn-ghost{background:transparent;color:var(--btn-ghost-fg);border:1px solid currentColor}.btn-ghost:hover{background:var(--btn-ghost-fg);color:#fff}.btn-destructive{background:var(--error);color:var(--error-contrast)}.header{position:sticky;top:0;z-index:9999999;background:var(--menu-bg);box-shadow:var(--shadow);height:64px;display:flex;align-items:center}.hamburger{margin-left:20px;margin-right:12px;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.1);color:var(--menu-text);border:1px solid rgba(255,255,255,.2);cursor:pointer;font-size:18px}.app-title{font-size:1.5rem;font-weight:400;margin:0;color:var(--menu-text)}.theme-toggle{margin-left:auto;margin-right:20px}.drawer{position:fixed;top:64px;right:0;bottom:0;left:0;z-index:9999998;pointer-events:none;visibility:hidden}.drawer.is-open{visibility:visible}.drawer__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:9999997;background:rgba(0,0,0,.45);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity .25s ease;pointer-events:auto}.drawer__panel{position:absolute;left:0;top:0;bottom:0;width:min(320px,90vw);background:var(--bg-elev);color:var(--text);border-right:1px solid var(--card-border);box-shadow:0 12px 40px #00000059;transform:translate(-100%);transition:transform .25s ease;z-index:9999998;pointer-events:auto}.drawer.is-open{pointer-events:auto}.drawer.is-open .drawer__panel{transform:translate(0)}.drawer.is-open .drawer__backdrop{opacity:1}.nav__item,.nav__item:visited{color:var(--text)!important;text-decoration:none;display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--card-border);cursor:pointer}.nav__item:hover{background:rgba(0,0,0,.06)}:root[data-theme=dark] .nav__item:hover{background:rgba(255,255,255,.06)}.card{background:var(--bg-elev);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow);padding:20px;margin-bottom:1.5rem}.stats-tile{background:var(--bg-elev);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow);padding:16px;text-align:center}.path{stroke:var(--brand);stroke-width:8;filter:drop-shadow(0 0 8px rgba(5,125,138,.35))}.day-node{width:56px;height:56px;border-radius:50%;background:var(--bg-elev);border:3px solid #fff;display:grid;place-items:center;font-weight:700;color:var(--text)}.day-node--active{box-shadow:0 0 0 6px #057d8a26}.day-node+.day-node{margin-top:64px}:focus-visible{outline:3px solid rgba(243,213,22,.7);outline-offset:2px}@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}.slide-up-enter-active,.slide-up-leave-active{transition:all .3s ease}.slide-up-enter-from{transform:translateY(20px);opacity:0}.slide-up-leave-to{transform:translateY(-20px);opacity:0}@keyframes ctaPulse{0%{box-shadow:0 2px 8px #0663,0 0 #0666}50%{box-shadow:0 2px 8px #0663,0 0 0 8px #0066661a}to{box-shadow:0 2px 8px #0663,0 0 #0666}}@keyframes ctaPulseHover{0%{box-shadow:0 4px 12px #007a7a4d,0 0 20px #007a7a80}50%{box-shadow:0 6px 16px #007a7a66,0 0 30px #007a7ab3}to{box-shadow:0 4px 12px #007a7a4d,0 0 20px #007a7a80}}@keyframes ctaGlow{0%{box-shadow:0 0 5px #057d8a4d}50%{box-shadow:0 0 15px #057d8a99,0 0 25px #057d8a4d}to{box-shadow:0 0 5px #057d8a4d}}.modal-overlay,.paywall-modal-overlay,.ios-modal-overlay{backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important;background:rgba(0,0,0,.4)!important}@supports not (backdrop-filter: blur(10px)){.modal-overlay,.paywall-modal-overlay,.ios-modal-overlay{background:rgba(0,0,0,.7)!important}}
