:root,[data-theme=light]{--primary:#6777ef;--primary-light:#95a0f4;--primary-dark:#5463d4;--primary-glow:rgba(103,119,239,0.25);--primary-soft:rgba(103,119,239,0.1);--primary-softer:rgba(103,119,239,0.06);--bg:#eef1f8;--bg-elevated:#fff;--bg-input:#f8f9fe;--bg-header:hsla(0,0%,100%,0.82);--text:#4a5568;--text-strong:#1a202c;--text-muted:#5f6b7a;--text-on-primary:#fff;--border:rgba(103,119,239,0.14);--border-strong:rgba(103,119,239,0.28);--shadow-sm:0 2px 8px rgba(26,32,44,0.04);--shadow-md:0 8px 32px rgba(103,119,239,0.12);--shadow-lg:0 20px 60px rgba(103,119,239,0.16);--hero-gradient:linear-gradient(135deg,#6777ef,#95a0f4 55%,#b8c0f8);--mesh:radial-gradient(ellipse 80% 60% at 10% -10%,rgba(103,119,239,0.18),transparent 55%),radial-gradient(ellipse 60% 50% at 90% 0%,rgba(149,160,244,0.14),transparent 50%)}[data-theme=dark]{--primary:#7b8af0;--primary-light:#95a0f4;--primary-dark:#6777ef;--primary-glow:rgba(123,138,240,0.3);--primary-soft:rgba(123,138,240,0.15);--primary-softer:rgba(123,138,240,0.08);--bg:#0f1117;--bg-elevated:#1a1d27;--bg-input:#222633;--bg-header:rgba(15,17,23,0.88);--text:#b0bac9;--text-strong:#eef1f8;--text-muted:#9aa5b4;--text-on-primary:#fff;--border:rgba(123,138,240,0.12);--border-strong:rgba(123,138,240,0.22);--shadow-sm:0 2px 8px rgba(0,0,0,0.25);--shadow-md:0 8px 32px rgba(0,0,0,0.35);--shadow-lg:0 20px 60px rgba(0,0,0,0.45);--hero-gradient:linear-gradient(135deg,#34395e,#5463d4 50%,#95a0f4);--mesh:radial-gradient(ellipse 80% 60% at 10% -10%,rgba(123,138,240,0.12),transparent 55%),radial-gradient(ellipse 60% 50% at 90% 0%,rgba(103,119,239,0.08),transparent 50%)}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:DM Sans,system-ui,sans-serif;font-size:1rem;line-height:1.65;color:var(--text);background:var(--bg);background-image:var(--mesh);background-attachment:fixed;transition:background .3s ease,color .3s ease;-webkit-font-smoothing:antialiased}.sr-only{white-space:nowrap}.skip-link{position:absolute;top:-4rem;left:1rem;z-index:9999;padding:.75rem 1rem;background:var(--primary);color:#fff;border-radius:10px;font-weight:600;text-decoration:none}.skip-link:focus,.skip-link:focus-visible{top:1rem;outline:3px solid var(--primary-light);outline-offset:2px}:focus-visible{outline:3px solid var(--primary);outline-offset:2px}a:focus:not(:focus-visible),button:focus:not(:focus-visible){outline:none}a{color:var(--primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-dark)}img{max-width:100%}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-container{width:100%;max-width:1080px;margin:0 auto;padding:0 1.25rem}.app-container--wide{max-width:820px}.app-container--narrow{max-width:560px}.app-body{flex:1;padding-top:calc(64px + 1.5rem);padding-bottom:3rem}@media (max-width:768px){.app-body{padding-bottom:calc(1.5rem + 62px + env(safe-area-inset-bottom, 0px))}}@media (orientation:landscape) and (max-height:520px){.app-body{padding-bottom:calc(1.5rem + 62px + env(safe-area-inset-bottom, 0px))}}.site-header{position:fixed;top:0;left:0;right:0;height:64px;z-index:200;background:var(--bg-header);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:background .3s ease}.site-header__inner{height:100%;display:flex;align-items:center;gap:1.5rem;min-width:0}@media (max-width:768px){.site-header__inner{gap:.75rem}}@media (orientation:landscape) and (max-height:520px){.site-header__inner{gap:.75rem}}.site-logo{display:flex;align-items:center;gap:.65rem;font-weight:700;font-size:1.15rem;letter-spacing:-.02em;flex-shrink:0}.site-logo,.site-logo:hover{color:var(--text-strong)}.site-logo__icon{width:36px;height:36px;border-radius:10px;background:var(--hero-gradient);justify-content:center;color:#fff;font-size:.95rem;box-shadow:0 4px 12px var(--primary-glow)}.site-logo__icon,.site-nav{display:flex;align-items:center}.site-nav{gap:.35rem;list-style:none;margin:0;padding:0}@media (max-width:768px){.site-nav{display:none}}@media (orientation:landscape) and (max-height:520px){.site-nav{display:none}}.site-nav__link{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;border-radius:999px;font-size:.875rem;font-weight:500;color:var(--text);white-space:nowrap;transition:all .2s ease}@media (max-width:1024px){.site-nav__link{padding:.4rem .65rem;font-size:.8rem}}.site-nav__link:hover{color:var(--primary);background:var(--primary-softer)}.site-nav__link.active,.site-nav__link.router-link-exact-active{color:var(--primary);background:var(--primary-soft);font-weight:600}.site-nav__link--button{border:none;background:transparent;cursor:pointer;font-family:inherit}.site-nav__dropdown{position:relative}.site-nav__submenu{position:absolute;top:calc(100% + .45rem);left:0;min-width:220px;margin:0;padding:.4rem;list-style:none;border:1px solid var(--border);border-radius:16px;background:var(--bg-elevated);box-shadow:var(--shadow-md);z-index:300}.site-nav__submenu-item{display:flex;align-items:center;gap:.5rem;padding:.65rem .85rem;border-radius:10px;color:var(--text);font-size:.875rem;font-weight:500;text-decoration:none;transition:background .2s ease,color .2s ease}.site-nav__submenu-item.router-link-active,.site-nav__submenu-item:hover{color:var(--primary);background:var(--primary-softer)}.site-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border);border-radius:999px;background:var(--bg-elevated);color:var(--text);cursor:pointer;font-size:.95rem;transition:all .2s ease}.icon-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-softer)}.icon-btn:focus-visible{outline:3px solid var(--primary);outline-offset:2px}.user-menu{position:relative}.user-menu__trigger{display:flex;align-items:center;gap:.5rem;padding:.3rem .5rem .3rem .3rem;border:1px solid var(--border);border-radius:999px;background:var(--bg-elevated);cursor:pointer;color:var(--text);font-size:.85rem;font-weight:500;transition:all .2s ease}.user-menu__trigger:hover{border-color:var(--primary)}.user-menu__avatar{width:30px;height:30px;border-radius:50%;background:var(--hero-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;overflow:hidden}.user-menu__avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-menu__panel{position:absolute;top:calc(100% + .6rem);right:0;min-width:210px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);padding:.4rem;list-style:none;margin:0;z-index:300}.user-menu__label{padding:.5rem .75rem .35rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.user-menu__guest{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem .5rem;gap:.5rem}.user-menu__guest-name{font-size:.875rem;font-weight:600;color:var(--text-strong)}.user-menu__soon-badge{background:var(--primary-soft);font-size:.65rem;text-transform:uppercase;letter-spacing:.04em}.user-menu__code-badge,.user-menu__soon-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:999px;color:var(--primary);font-weight:700;white-space:nowrap}.user-menu__code-badge{background:var(--primary-softer);font-family:Consolas,Monaco,monospace;font-size:.7rem;letter-spacing:.08em}.user-menu__notice{display:flex;align-items:flex-start;gap:.5rem;margin:.25rem .5rem .5rem;padding:.65rem .75rem;border-radius:10px;background:var(--primary-softer);color:var(--text);font-size:.78rem;line-height:1.45}.user-menu__notice i{color:var(--primary);margin-top:.1rem;flex-shrink:0}.user-menu__item{display:flex;align-items:center;gap:.55rem;padding:.6rem .75rem;border-radius:10px;color:var(--text);font-size:.875rem;cursor:pointer;transition:background .15s ease}.user-menu__item:hover{background:var(--primary-softer);color:var(--primary)}.user-menu__item--danger{color:#e53e3e}.user-menu__item--danger:hover{background:rgba(229,62,62,.08);color:#e53e3e}.user-menu__item--disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.user-menu__item--button{width:100%;border:none;background:transparent;font-family:inherit;text-align:left}.user-menu__sep{height:1px;background:var(--border);margin:.3rem .5rem}@media (max-width:768px){.hide-mobile{display:none}}@media (orientation:landscape) and (max-height:520px){.hide-mobile{display:none}}@media (max-width:1024px){.hide-mobile{display:none}}.mobile-nav{display:none}@media (max-width:768px){.mobile-nav{display:flex;align-items:stretch;justify-content:space-around;position:fixed;left:0;right:0;bottom:0;z-index:220;min-height:62px;padding-bottom:env(safe-area-inset-bottom,0);background:var(--bg-header);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);box-shadow:0 -4px 24px rgba(15,23,42,.06)}}@media (orientation:landscape) and (max-height:520px){.mobile-nav{display:flex;align-items:stretch;justify-content:space-around;position:fixed;left:0;right:0;bottom:0;z-index:220;min-height:62px;padding-bottom:env(safe-area-inset-bottom,0);background:var(--bg-header);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);box-shadow:0 -4px 24px rgba(15,23,42,.06)}}.mobile-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;min-width:0;padding:.45rem .35rem .55rem;color:var(--text-muted);font-size:.68rem;font-weight:600;text-decoration:none;transition:color .2s ease,background .2s ease}.mobile-nav__item i{font-size:1.05rem;line-height:1}.mobile-nav__item span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav__item--active,.mobile-nav__item:hover{color:var(--primary);background:var(--primary-softer)}.mobile-nav__item--active i{transform:scale(1.05)}.hero{background:var(--hero-gradient);border-radius:24px;padding:2.5rem 2rem;margin-bottom:2rem;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}.hero:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%23fff' fill-opacity='.06' fill-rule='evenodd'/%3E%3C/svg%3E");opacity:.5}.hero__content{position:relative;z-index:1}.hero__eyebrow{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:.5rem}.hero__title{margin:0 0 .5rem;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;letter-spacing:-.03em;line-height:1.2;color:#fff}.hero__desc{margin:0 0 1.5rem;color:#fff;font-size:1rem;max-width:480px}.hero__stats{display:flex;gap:1.5rem;flex-wrap:wrap}.hero__stat{display:flex;flex-direction:column}.hero__stat strong{font-size:1.5rem;font-weight:700;line-height:1;color:#fff}.hero__stat span{font-size:.8rem;color:#fff;margin-top:.2rem}.last-read-banner{position:relative;margin-bottom:1.25rem;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden}.last-read-banner__link{display:flex;align-items:center;gap:1rem;padding:1rem 3rem 1rem 1.1rem;color:inherit;transition:background .2s ease}.last-read-banner__link:hover{background:var(--primary-softer);color:inherit}.last-read-banner__icon{width:44px;height:44px;border-radius:10px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}.last-read-banner__body{min-width:0;flex:1;display:flex;flex-direction:column;gap:.15rem}.last-read-banner__eyebrow{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--primary)}.last-read-banner__title{font-size:1rem;font-weight:700;color:var(--text-strong)}.last-read-banner__meta,.last-read-banner__title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.last-read-banner__meta{font-size:.82rem;color:var(--text-muted)}.last-read-banner__action{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;font-weight:600;color:var(--primary);white-space:nowrap;flex-shrink:0}@media (max-width:768px){.last-read-banner__action{display:none}}@media (orientation:landscape) and (max-height:520px){.last-read-banner__action{display:none}}.last-read-banner__clear{position:absolute;top:.65rem;right:.65rem;width:28px;height:28px;border:none;border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.last-read-banner__clear:hover{background:var(--primary-softer);color:var(--primary)}.surah-list{display:flex;flex-direction:column;gap:.65rem}.surah-item{display:grid;grid-template-columns:52px 1fr auto auto;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;color:inherit;transition:all .22s ease;box-shadow:var(--shadow-sm)}.surah-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px);color:inherit}.surah-item__no{width:44px;height:44px;border-radius:10px;background:var(--primary-softer);color:var(--primary);font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .22s ease}.surah-item:hover .surah-item__no{background:var(--hero-gradient);color:#fff}.surah-item__info{min-width:0}.surah-item__latin{font-weight:600;font-size:1rem;color:var(--text-strong);letter-spacing:-.01em}.surah-item__latin,.surah-item__translate{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.surah-item__translate{font-size:.85rem;color:var(--text-muted);margin-top:.1rem}.surah-item__arabic{font-size:1.5rem;color:var(--text-strong);line-height:1.4;flex-shrink:0}@media (max-width:520px){.surah-item__arabic{display:none}}.surah-item__badge{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:999px;background:var(--primary-soft);color:var(--primary-dark);font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}@media (max-width:520px){.surah-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem}.surah-item__no{width:36px;height:36px;font-size:.8rem;flex-shrink:0}.surah-item__info{flex:1;min-width:0}.surah-item__latin{font-size:.925rem}.surah-item__translate{font-size:.78rem}.surah-item__badge{flex-shrink:0;align-self:center;font-size:.68rem;padding:.12rem .45rem}.surah-item__arabic{display:none}}.next-surah-nav{display:grid;grid-template-columns:52px 1fr auto auto;align-items:center;gap:1rem;margin-top:1.25rem;padding:1rem 1.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;color:inherit;transition:all .22s ease;box-shadow:var(--shadow-sm);text-decoration:none}.next-surah-nav:focus-visible,.next-surah-nav:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px);color:inherit}.next-surah-nav--ready{border-color:var(--border-strong)}.next-surah-nav__icon{width:44px;height:44px;border-radius:10px;background:var(--primary-softer);color:var(--primary);font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .22s ease}.next-surah-nav:focus-visible .next-surah-nav__icon,.next-surah-nav:hover .next-surah-nav__icon{background:var(--hero-gradient);color:#fff}.next-surah-nav__info{min-width:0}.next-surah-nav__label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.15rem}.next-surah-nav__latin{font-weight:600;font-size:1rem;color:var(--text-strong);letter-spacing:-.01em}.next-surah-nav__latin,.next-surah-nav__translate{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.next-surah-nav__translate{font-size:.85rem;color:var(--text-muted);margin-top:.1rem}.next-surah-nav__arabic{font-size:1.5rem;color:var(--text-strong);line-height:1.4;flex-shrink:0}@media (max-width:520px){.next-surah-nav__arabic{display:none}}.next-surah-nav__badge{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:999px;background:var(--primary-soft);color:var(--primary-dark);font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}@media (max-width:520px){.next-surah-nav{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem}.next-surah-nav__icon{width:36px;height:36px;font-size:.8rem}.next-surah-nav__info{flex:1;min-width:0}.next-surah-nav__latin{font-size:.925rem}.next-surah-nav__translate{font-size:.78rem}.next-surah-nav__badge{flex-shrink:0;align-self:center;font-size:.68rem;padding:.12rem .45rem}}.surah-banner{background:var(--bg-elevated);border:1px solid var(--border);border-radius:24px;padding:2rem;margin-bottom:1.75rem;text-align:center;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.surah-banner:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:120px;height:3px;border-radius:999px;background:var(--hero-gradient)}.surah-banner__back{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;font-weight:500;color:var(--text-muted);margin-bottom:1.25rem;transition:color .2s ease}.surah-banner__back:hover{color:var(--primary)}.surah-banner__arabic{font-size:clamp(2rem,6vw,2.75rem);color:var(--text-strong);line-height:1.5;margin-bottom:.5rem}.surah-banner__latin{margin:0 0 .75rem;font-size:1.25rem;font-weight:700;color:var(--text-strong);letter-spacing:-.02em}.surah-banner__meta{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem}.surah-banner__pill{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .85rem;border-radius:999px;background:var(--primary-softer);color:var(--primary);font-size:.8rem;font-weight:600}.ayah-flow{display:flex;flex-direction:column;gap:1rem}.ayah-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;padding:1.5rem;transition:all .25s ease;box-shadow:var(--shadow-sm)}.ayah-card--active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow),var(--shadow-md)}.ayah-card--memorized{border-color:rgba(47,158,68,.35);background:linear-gradient(180deg,var(--bg-elevated),rgba(47,158,68,.05))}.ayah-card--last-read{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft),var(--shadow-sm)}.ayah-card__top{display:flex;align-items:center;gap:.65rem;margin-bottom:1.25rem}.ayah-card__marker{width:36px;height:36px;border-radius:50%;background:var(--hero-gradient);color:#fff;font-size:.75rem;font-weight:700;box-shadow:0 3px 10px var(--primary-glow)}.ayah-card__marker,.ayah-card__play{display:flex;align-items:center;justify-content:center;flex-shrink:0}.ayah-card__play{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--bg-elevated);color:var(--primary);cursor:pointer;font-size:.85rem;transition:all .2s ease;margin-left:auto}.ayah-card__play:hover{border-color:var(--primary);background:var(--primary-soft)}.ayah-card__play--playing{background:var(--hero-gradient);border-color:transparent;color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.ayah-card__arabic{text-align:right;margin-bottom:1rem}.ayah-card__divider{height:1px;background:linear-gradient(90deg,transparent,var(--border-strong),transparent);margin:1rem 0}.ayah-card__latin{text-align:right;font-size:.875rem;font-style:italic;color:var(--text-muted);margin-bottom:.65rem;line-height:1.7}.ayah-card__translate{text-align:right;margin:0;font-size:.95rem;color:var(--text);line-height:1.75}.ayah-actions{display:flex;align-items:center;justify-content:center;gap:.3rem;flex:1;min-width:0;flex-wrap:wrap}.ayah-actions__btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .55rem;border:1px solid var(--border);border-radius:999px;background:var(--bg-elevated);color:var(--text-muted);font-family:inherit;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.ayah-actions__btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-softer)}.ayah-actions__btn:disabled{opacity:.6;cursor:wait}.ayah-actions__btn--active{border-color:var(--primary);color:var(--primary);background:var(--primary-softer)}.ayah-actions__btn--favorite.ayah-actions__btn--active{border-color:#e53e3e;color:#e53e3e;background:rgba(229,62,62,.08)}.ayah-actions__btn--memorized.ayah-actions__btn--active{border-color:#2f9e44;color:#2f9e44;background:rgba(47,158,68,.08)}.ayah-actions__btn--last-read.ayah-actions__btn--active{border-color:var(--primary);color:var(--primary-dark);background:var(--primary-soft)}@media (max-width:520px){.ayah-actions__label{display:none}}.dashboard-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:2rem}@media (max-width:900px){.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}}.dashboard-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;padding:1.15rem .85rem;border-radius:16px;border:1px solid var(--border);background:var(--bg-elevated);box-shadow:var(--shadow-sm);transition:all .2s ease;color:inherit;text-decoration:none;text-align:center}@media (max-width:720px){.dashboard-stat{padding:.75rem .4rem;gap:.45rem}}.dashboard-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.dashboard-stat__icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}@media (max-width:720px){.dashboard-stat__icon{width:34px;height:34px;font-size:.85rem}}.dashboard-stat__content{display:flex;flex-direction:column;align-items:center;gap:.15rem;min-width:0;width:100%}.dashboard-stat__value{font-size:1.75rem;font-weight:800;line-height:1;color:var(--text-strong)}@media (max-width:720px){.dashboard-stat__value{font-size:1.35rem}}.dashboard-stat__label{font-size:.875rem;font-weight:600;color:var(--text-muted);line-height:1.25;max-width:100%;text-wrap:balance}.dashboard-stat__label--short{display:none}@media (max-width:720px){.dashboard-stat__label{font-size:.72rem;letter-spacing:-.01em}.dashboard-stat__label--full{display:none}.dashboard-stat__label--short{display:block}}.dashboard-stat--saved .dashboard-stat__icon{background:var(--primary-softer);color:var(--primary)}.dashboard-stat--favorite .dashboard-stat__icon{background:rgba(229,62,62,.1);color:#e53e3e}.dashboard-stat--memorized .dashboard-stat__icon{background:rgba(47,158,68,.1);color:#2f9e44}.dashboard-stat--memorized_broken .dashboard-stat__icon{background:rgba(245,159,0,.12);color:#f59f00}.dashboard-section{margin-bottom:2rem}.dashboard-section__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.dashboard-section__head h2{margin:0;font-size:1.15rem;color:var(--text-strong);display:flex;align-items:center;gap:.5rem}.dashboard-section__head h2 i{color:var(--primary);font-size:.95rem}.dashboard-section__link{font-size:.875rem;font-weight:600;white-space:nowrap}.dashboard-section__list{display:grid;gap:.85rem}.dashboard-section__list--full{gap:1rem}.dashboard-section__empty{margin:0;padding:1rem;border-radius:16px;background:var(--primary-softer);color:var(--text-muted);font-size:.9rem;line-height:1.6}.verse-collection-item{display:block;padding:1.15rem 1.25rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-elevated);box-shadow:var(--shadow-sm);color:inherit;text-decoration:none;transition:all .2s ease}.verse-collection-item:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.verse-collection-item__head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.85rem;flex-wrap:wrap}.verse-collection-item__surah{display:inline-flex;align-items:center;gap:.45rem;font-size:.9rem;font-weight:700;color:var(--text-strong)}.verse-collection-item__surah i{font-size:.8rem}.verse-collection-item__badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:999px;background:var(--primary-softer);color:var(--primary);font-size:.72rem;font-weight:700}.verse-collection-item__arabic{text-align:right;margin:0 0 .65rem;font-size:1.35rem;line-height:1.9}.verse-collection-item__arabic,.verse-collection-item__translate{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.verse-collection-item__translate{margin:0 0 .75rem;font-size:.9rem;color:var(--text);line-height:1.65}.verse-collection-item__cta{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:600;color:var(--primary)}.verse-collection-item--favorite .verse-collection-item__badge,.verse-collection-item--favorite .verse-collection-item__surah i{color:#e53e3e}.verse-collection-item--favorite .verse-collection-item__badge{background:rgba(229,62,62,.1)}.verse-collection-item--memorized .verse-collection-item__badge,.verse-collection-item--memorized .verse-collection-item__surah i{color:#2f9e44}.verse-collection-item--memorized .verse-collection-item__badge{background:rgba(47,158,68,.1)}.ayah-sentinel{height:1px}.auth-page{display:flex;justify-content:center;padding-top:1rem}.auth-card{width:100%;max-width:440px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-md)}.auth-card__hero{background:var(--hero-gradient);padding:2rem 2rem 1.75rem;color:#fff;text-align:center}.auth-card__hero h1{margin:0 0 .35rem;font-size:1.5rem;font-weight:700}.auth-card__hero p{margin:0;opacity:.88;font-size:.9rem}.auth-card__body{padding:1.75rem 2rem 2rem}.auth-card__footer{text-align:center;padding:0 2rem 1.75rem;font-size:.875rem;color:var(--text-muted)}.auth-card__footer a{font-weight:600}.auth-card--preview{position:relative}.auth-soon{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;padding:1rem;border:1px solid var(--border-strong);border-radius:16px;background:var(--primary-softer)}.auth-soon__icon{width:36px;height:36px;border-radius:50%;background:var(--hero-gradient);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.85rem}.auth-soon__title{margin:0 0 .2rem;font-size:.95rem;font-weight:700;color:var(--text-strong)}.auth-soon__text{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.5}.auth-form--disabled{opacity:.45;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.auth-back{display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;font-size:.875rem;font-weight:500}.auth-note{margin:1.25rem 0 0;font-size:.85rem;line-height:1.55;color:var(--text-muted);text-align:center}.field{margin-bottom:1.1rem}.field__label{display:block;margin-bottom:.4rem;font-size:.875rem;font-weight:600;color:var(--text-strong)}.field__input{width:100%;padding:.7rem 1rem;font-family:inherit;font-size:.925rem;color:var(--text-strong);background:var(--bg-input);border:1.5px solid var(--border);border-radius:10px;transition:border-color .2s ease,box-shadow .2s ease}.field__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width:480px){.field-row{grid-template-columns:1fr}}.field-check{display:flex;align-items:flex-start;gap:.55rem;margin-bottom:1.25rem}.field-check input{accent-color:var(--primary);margin-top:.2rem}.field-check label{font-size:.875rem;color:var(--text);cursor:pointer;line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.7rem 1.4rem;font-family:inherit;font-size:.925rem;font-weight:600;border-radius:10px;border:none;cursor:pointer;transition:all .2s ease}.btn--primary{background:var(--hero-gradient);color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--primary-glow);color:#fff}.btn--ghost{background:transparent;color:var(--text-muted);border:1.5px solid var(--border)}.btn--ghost:hover{border-color:var(--primary);color:var(--primary)}.btn--block{width:100%}.btn--google{background:#fff;color:#3c4043;border:1.5px solid var(--border);text-decoration:none}.btn--google:hover{background:var(--primary-softer);border-color:var(--border-strong);color:#3c4043;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn--google i{color:#ea4335}.not-found{text-align:center;padding:4rem 1rem}.not-found__code{font-size:clamp(5rem,15vw,8rem);font-weight:800;line-height:1;background:var(--hero-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.not-found__title{font-size:1.35rem;font-weight:700;color:var(--text-strong);margin:0 0 .5rem}.not-found__desc{color:var(--text-muted);margin:0 0 1.75rem}.site-footer{padding:1.5rem 0;text-align:center;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:auto}@media (max-width:768px){.site-footer{padding-bottom:calc(1.5rem + 62px + env(safe-area-inset-bottom, 0px))}}@media (orientation:landscape) and (max-height:520px){.site-footer{padding-bottom:calc(1.5rem + 62px + env(safe-area-inset-bottom, 0px))}}@font-face{font-family:LPMQ Isep Misbah;src:url(/fonts/LPMQ-IsepMisbah.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}.quran-text{font-family:LPMQ Isep Misbah,Scheherazade New,Amiri,serif;font-size:clamp(1.75rem,4vw,2rem);line-height:2.35;letter-spacing:.04em;word-spacing:.06em;text-rendering:optimizeLegibility;font-feature-settings:"liga" 1,"calt" 1,"mark" 1,"mkmk" 1}.quran-text--lg{font-size:clamp(2rem,5vw,2.75rem);line-height:2.15;letter-spacing:.035em;word-spacing:.05em}.quran-text--tajweed{letter-spacing:.05em;word-spacing:.08em}.quran-text .tajweed{font-weight:inherit;font-family:inherit;color:inherit;border-radius:3px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.tajweed-ikhafa{background-color:rgba(148,0,168,.22)}.tajweed-iqlab{background-color:rgba(38,191,253,.22)}.tajweed-izhar{background-color:rgba(108,117,125,.2)}.tajweed-idgh-ghunnah{background-color:rgba(22,146,0,.2)}.tajweed-idgh-no-ghunnah{background-color:rgba(22,146,0,.15);box-shadow:inset 0 -2px 0 rgba(22,146,0,.55)}.tajweed-idghm-shafawi{background-color:rgba(88,184,0,.22)}.tajweed-ikhfa-shafawi{background-color:rgba(213,0,183,.2)}.tajweed-izhar-shafawi{background-color:rgba(134,142,150,.2)}.tajweed-legend{display:flex;flex-wrap:wrap;gap:.5rem .85rem;margin-top:.85rem;padding-top:.85rem;border-top:1px solid var(--border);font-size:.72rem;color:var(--text-muted)}.tajweed-legend__item{display:inline-flex;align-items:center;gap:.3rem}.tajweed-legend__swatch{font-size:.85rem;line-height:1}.api-docs-hero{background:var(--hero-gradient);border-radius:24px;padding:2.5rem 2rem;margin-bottom:2rem;color:#fff;box-shadow:var(--shadow-lg)}.api-docs-hero__badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;background:hsla(0,0%,100%,.18);font-size:.78rem;font-weight:600;margin-bottom:.85rem}.api-docs-hero__title{margin:0 0 .5rem;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;letter-spacing:-.03em}.api-docs-hero__desc{margin:0 0 1.5rem;opacity:.92;max-width:640px;line-height:1.65}.api-docs-hero__base{display:flex;align-items:center;flex-wrap:wrap;gap:.65rem;padding:.85rem 1rem;border-radius:16px;background:hsla(0,0%,100%,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.api-docs-hero__label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;opacity:.85}.api-docs-hero .api-code{color:#fff;background:rgba(0,0,0,.15)}.api-docs-hero .api-copy{border-color:hsla(0,0%,100%,.25);color:#fff;background:hsla(0,0%,100%,.1)}.api-docs-hero .api-copy:hover{background:hsla(0,0%,100%,.2);color:#fff}.api-docs-section{margin-bottom:2.5rem}.api-docs-section__title{margin:0 0 1.25rem;font-size:1.35rem;font-weight:700;color:var(--text-strong)}.api-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.api-info-card{display:flex;flex-direction:column;gap:.35rem;padding:1.25rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-sm)}.api-info-card i{color:var(--primary);font-size:1.25rem;margin-bottom:.25rem}.api-info-card strong{color:var(--text-strong);font-size:.95rem}.api-info-card span{font-size:.85rem;color:var(--text-muted);line-height:1.5}.api-info-card code{font-size:.8rem}.api-endpoint{background:var(--bg-elevated);border:1px solid var(--border);border-radius:24px;padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)}.api-endpoint__head{display:flex;align-items:center;flex-wrap:wrap;gap:.65rem;margin-bottom:.85rem}.api-endpoint__title{margin:0 0 .35rem;font-size:1.1rem;font-weight:700;color:var(--text-strong)}.api-endpoint__desc{margin:0 0 1rem;color:var(--text-muted);font-size:.9rem;line-height:1.6}.api-endpoint__params{margin-bottom:1rem}.api-endpoint__params h4{margin:0 0 .65rem;font-size:.85rem;font-weight:600;color:var(--text-strong)}.api-endpoint__try{border-top:1px solid var(--border);padding-top:1rem}.api-endpoint__url{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.api-method{display:inline-flex;padding:.25rem .6rem;border-radius:10px;background:rgba(71,195,99,.15);color:#2f9e44;font-size:.75rem;font-weight:800;letter-spacing:.04em}.api-code{display:inline-block;padding:.45rem .75rem;border-radius:10px;background:var(--bg-input);border:1px solid var(--border);font-family:Consolas,Monaco,monospace;font-size:.82rem;color:var(--text-strong);word-break:break-all}.api-code--inline{flex:1;min-width:0}.api-code--grow{flex:1;min-width:180px}.api-copy{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--border);border-radius:10px;background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all .2s ease}.api-copy:hover{border-color:var(--primary);color:var(--primary)}.api-input{width:72px;padding:.5rem .65rem;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:.875rem;background:var(--bg-input);color:var(--text-strong)}.api-input:focus{outline:none;border-color:var(--primary)}.api-table{width:100%;border-collapse:collapse;font-size:.85rem}.api-table td,.api-table th{padding:.55rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.api-table th{font-weight:600;color:var(--text-strong);background:var(--primary-softer)}.api-table td{color:var(--text)}.api-table code{font-size:.8rem;color:var(--primary)}.api-response{margin-top:1rem}.api-response__meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.api-response__status{font-size:.8rem;font-weight:700;padding:.2rem .55rem;border-radius:999px}.api-response__status--ok{background:rgba(71,195,99,.15);color:#2f9e44}.api-response__status--err{background:rgba(229,62,62,.12);color:#e53e3e}.api-response__body{margin:0;padding:1rem;border-radius:16px;background:#1e1e2e;color:#cdd6f4;font-family:Consolas,Monaco,monospace;font-size:.78rem;line-height:1.55;overflow-x:auto;max-height:360px;white-space:pre-wrap;word-break:break-word}.api-response__body--compact,.api-response__body--example{max-height:none}.api-response__body--compact{font-size:.72rem}.api-code-block{position:relative}.api-code-block__copy{position:absolute;top:.65rem;right:.65rem;z-index:1;width:34px;height:34px;background:rgba(24,24,37,.92);border-color:rgba(205,214,244,.18);color:#cdd6f4}.api-code-block__copy:hover{border-color:var(--primary);color:var(--primary);background:rgba(24,24,37,.98)}.api-code-block .api-response__body--example{padding-right:3rem}.api-example-tabs{display:flex;gap:.35rem;margin-bottom:.75rem}.api-tab{padding:.45rem .9rem;border:1px solid var(--border);border-radius:999px;background:var(--bg-elevated);color:var(--text-muted);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.api-tab--active,.api-tab:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-softer)}.api-schema-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.api-schema-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;padding:1rem}.api-schema-card h4{margin:0 0 .75rem;font-size:.95rem;color:var(--text-strong)}.hafalan-page{padding:.5rem 0 2rem}.hafalan-page__back{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:1rem;color:var(--text-muted);font-size:.875rem;text-decoration:none}.hafalan-page__back:hover{color:var(--primary)}.hafalan-page__head{margin-bottom:1.5rem}.hafalan-page__head h1{margin:0 0 .35rem;font-size:1.75rem;color:var(--text-strong)}.hafalan-page__head p{margin:0;color:var(--text-muted);line-height:1.55}.hafalan-page__empty,.hafalan-page__loading{text-align:center;padding:2.5rem 1rem;color:var(--text-muted)}@media (max-width:768px){.hafalan-page{padding:0 0 1rem}.hafalan-page__back{margin-bottom:.6rem;font-size:.8rem}.hafalan-page__head{margin-bottom:.85rem}.hafalan-page__head h1{font-size:1.3rem}.hafalan-page__head p{font-size:.84rem;line-height:1.45}}@media (orientation:landscape) and (max-height:520px){.hafalan-page{padding:0 0 1rem}.hafalan-page__back{margin-bottom:.6rem;font-size:.8rem}.hafalan-page__head{margin-bottom:.85rem}.hafalan-page__head h1{font-size:1.3rem}.hafalan-page__head p{font-size:.84rem;line-height:1.45}}.hafalan-menu{display:grid;gap:1rem;max-width:520px}.hafalan-menu__card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;padding:1.15rem 1.25rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-elevated);color:inherit;text-decoration:none;box-shadow:var(--shadow-sm);transition:all .2s ease}.hafalan-menu__card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.hafalan-menu__icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--primary-softer);color:var(--primary);font-size:1.2rem;flex-shrink:0}.hafalan-menu__icon--review{background:rgba(245,159,0,.12);color:#f59f00}.hafalan-menu__body{min-width:0}.hafalan-menu__title{display:block;font-weight:700;color:var(--text-strong);margin-bottom:.2rem}.hafalan-menu__desc{display:block;font-size:.875rem;color:var(--text-muted);line-height:1.45}.hafalan-menu__arrow{color:var(--text-muted);font-size:.85rem;flex-shrink:0}@media (max-width:768px){.hafalan-menu{gap:.6rem;max-width:none}.hafalan-menu__card{display:flex;align-items:center;gap:.7rem;padding:.72rem .8rem;border-radius:10px}.hafalan-menu__card:hover{transform:none}.hafalan-menu__icon{width:36px;height:36px;font-size:.95rem}.hafalan-menu__title{font-size:.92rem;margin-bottom:.1rem}.hafalan-menu__desc{font-size:.76rem;line-height:1.35}.hafalan-menu__arrow{font-size:.72rem;margin-left:.15rem}}@media (orientation:landscape) and (max-height:520px){.hafalan-menu{gap:.6rem;max-width:none}.hafalan-menu__card{display:flex;align-items:center;gap:.7rem;padding:.72rem .8rem;border-radius:10px}.hafalan-menu__card:hover{transform:none}.hafalan-menu__icon{width:36px;height:36px;font-size:.95rem}.hafalan-menu__title{font-size:.92rem;margin-bottom:.1rem}.hafalan-menu__desc{font-size:.76rem;line-height:1.35}.hafalan-menu__arrow{font-size:.72rem;margin-left:.15rem}}.hafalan-setup{display:grid;gap:1rem;max-width:520px;padding:1.25rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-elevated)}.hafalan-setup__field{display:grid;gap:.35rem}.hafalan-setup__field span{font-size:.875rem;font-weight:600;color:var(--text-strong)}.hafalan-setup__field input,.hafalan-setup__field select{width:100%;padding:.65rem .8rem;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);font:inherit}.hafalan-setup__range{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.hafalan-practice__toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-elevated)}.hafalan-practice__info{display:flex;flex-direction:column;gap:.15rem}.hafalan-practice__info strong{color:var(--text-strong)}.hafalan-practice__info span{font-size:.85rem;color:var(--text-muted)}.hafalan-practice__list{display:grid;gap:.85rem}@media (max-width:768px){.hafalan-practice__list{padding-bottom:3.1rem}}@media (orientation:landscape) and (max-height:520px){.hafalan-practice__list{padding-bottom:3.1rem}}.hafalan-dock{position:sticky;bottom:0;z-index:210;margin-top:1rem;padding:1.35rem 0 .35rem;background:linear-gradient(0deg,var(--bg) 0,var(--bg) 55%,transparent)}@media (max-width:768px){.hafalan-dock{position:fixed;left:0;right:0;bottom:calc(62px + env(safe-area-inset-bottom, 0px));margin:0;padding:.5rem 1rem;background:var(--bg);border-top:1px solid var(--border);box-shadow:0 -4px 24px rgba(15,23,42,.06)}}@media (orientation:landscape) and (max-height:520px){.hafalan-dock{position:fixed;left:0;right:0;bottom:calc(62px + env(safe-area-inset-bottom, 0px));margin:0;padding:.5rem 1rem;background:var(--bg);border-top:1px solid var(--border);box-shadow:0 -4px 24px rgba(15,23,42,.06)}}.hafalan-dock-panel{display:grid;gap:.5rem;padding:0;background:transparent;border:none;border-radius:0;box-shadow:none}.hafalan-dock-panel__info{text-align:center}.hafalan-dock-panel__info-lead{margin:0;font-size:.8rem;line-height:1.5;color:var(--text-muted)}.hafalan-dock-panel__info-lead i{color:var(--primary);margin-right:.35rem}.hafalan-dock-panel__info-hint{margin:.35rem 0 0;font-size:.76rem;line-height:1.45;color:var(--text-muted)}.hafalan-dock-panel__actions{display:flex;flex-direction:column;gap:.5rem}@media (min-width:769px){.hafalan-dock-panel__actions:not(.hafalan-dock-panel__actions--recorded){display:grid;grid-template-columns:1fr 1fr;align-items:stretch}.hafalan-dock-panel__actions:not(.hafalan-dock-panel__actions--recorded) .hafalan-dock-panel__extra-row,.hafalan-dock-panel__actions:not(.hafalan-dock-panel__actions--recorded) .hafalan-dock-panel__record-row{display:contents}}.hafalan-dock-panel__actions--recorded .hafalan-dock-panel__record-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.hafalan-dock-panel__actions--recorded .hafalan-dock-panel__extra-row{display:block;width:100%}.hafalan-dock-panel__actions--recorded .hafalan-dock-panel__extra-row>.btn{width:100%}.hafalan-dock-panel__extra-row,.hafalan-dock-panel__record-row{gap:.5rem}.hafalan-dock-panel__extra-row>.btn--block:only-child{width:100%}.hafalan-dock-panel__btn{min-height:44px;background:var(--bg-elevated);border-color:rgba(47,158,68,.35);color:var(--primary)}.hafalan-dock-panel__btn--recording{border-color:rgba(224,49,49,.35);color:#e03131}.hafalan-dock-panel__btn--playing{border-color:var(--primary);background:var(--primary-soft)}.hafalan-dock-panel__btn--rerecord{background:var(--bg-elevated);border-color:var(--border);color:var(--text-muted)}.hafalan-dock-panel__btn--rerecord:hover{border-color:var(--primary);color:var(--primary)}.hafalan-dock-panel__duration{margin-left:auto;font-variant-numeric:tabular-nums;font-size:.8rem;opacity:.9}.hafalan-dock-panel__error{margin:0;font-size:.76rem;line-height:1.45;text-align:center;color:#e03131}.hafalan-dock-panel__audio{display:none}.hafalan-dock-panel .btn{min-height:44px}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__actions{display:flex;flex-direction:column;gap:.5rem}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__actions .hafalan-dock-panel__record-row{display:grid;grid-template-columns:1fr}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__actions .hafalan-dock-panel__extra-row{display:block;width:100%}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__actions.hafalan-dock-panel__actions--recorded .hafalan-dock-panel__record-row{grid-template-columns:1fr 1fr}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__review-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;width:100%}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__review-actions .btn{min-width:0;padding:.65rem .5rem;font-size:.85rem}@media (max-width:768px){.hafalan-dock-panel--review-revealed .hafalan-dock-panel__review-actions{gap:.45rem}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__review-actions .btn{padding:.62rem .4rem;font-size:.76rem;line-height:1.25;white-space:normal;text-align:center}}@media (orientation:landscape) and (max-height:520px){.hafalan-dock-panel--review-revealed .hafalan-dock-panel__review-actions{gap:.45rem}.hafalan-dock-panel--review-revealed .hafalan-dock-panel__review-actions .btn{padding:.62rem .4rem;font-size:.76rem;line-height:1.25;white-space:normal;text-align:center}}.hafalan-verse-card{padding:1rem 1.1rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-elevated);transition:border-color .25s ease,background .25s ease}.hafalan-verse-card--memorized{border-color:rgba(47,158,68,.35);background:linear-gradient(180deg,var(--bg-elevated),rgba(47,158,68,.05))}.hafalan-verse-card--masked{background:var(--bg-elevated)}.hafalan-verse-card--masked .hafalan-verse-card__cover,.hafalan-verse-card--masked .hafalan-verse-card__cover-fill{background:var(--bg-elevated);border-radius:0;margin-top:0}.hafalan-verse-card--active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow),var(--shadow-md)}.hafalan-verse-card__top{display:flex;align-items:center;gap:.65rem;margin-bottom:.75rem}.hafalan-verse-card__marker{min-width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:var(--primary-softer);color:var(--primary);font-weight:700;font-size:.85rem}.hafalan-verse-card__chapter{margin-left:auto;font-size:.85rem;color:var(--text-muted);font-weight:600;text-align:right}.hafalan-verse-card__play{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--bg-elevated);color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s ease;flex-shrink:0;margin-left:auto}.hafalan-verse-card__play:hover{border-color:var(--primary);background:var(--primary-soft)}.hafalan-verse-card__play--playing{background:var(--hero-gradient);border-color:transparent;color:#fff;box-shadow:0 4px 14px var(--primary-glow)}.hafalan-verse-card__top:has(.hafalan-verse-card__chapter) .hafalan-verse-card__play{margin-left:0}.hafalan-verse-card__panel{position:relative}.hafalan-verse-card__panel--arabic{margin-bottom:.25rem}.hafalan-verse-card__ghost{visibility:hidden;opacity:0;pointer-events:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;margin:0}.hafalan-verse-card__ghost.ayah-card__arabic{margin:0 0 1rem}.hafalan-verse-card__ghost.ayah-card__latin{margin:0 0 .65rem}.hafalan-verse-card__ghost::-moz-selection{background:transparent;color:transparent}.hafalan-verse-card__ghost::selection{background:transparent;color:transparent}.hafalan-verse-card__layer{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:stretch;overflow:hidden}.hafalan-verse-card__layer--meaning{justify-content:flex-start}.hafalan-verse-card__layer .ayah-card__arabic{margin:0;flex-shrink:0}.hafalan-verse-card__placeholder{margin:0;padding:.35rem 0;color:var(--text-muted);font-size:.9rem;font-style:italic;flex-shrink:0}.hafalan-verse-card__cover-fill{flex:1 1 auto;min-height:0}.hafalan-verse-card__cover,.hafalan-verse-card__cover-fill{background:var(--bg-elevated);-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;pointer-events:none}.hafalan-verse-card__cover{position:absolute;inset:0;z-index:2}.hafalan-verse-card__meaning-divider .ayah-card__divider{margin:.85rem 0 1rem}.hafalan-verse-card__meaning-divider--hidden .ayah-card__divider{visibility:hidden}.hafalan-verse-card__meaning .hafalan-verse-card__panel+.hafalan-verse-card__panel{margin-top:.65rem}.hafalan-verse-card__meaning .ayah-card__latin,.hafalan-verse-card__meaning .ayah-card__translate{margin:0}.hafalan-review{display:grid;gap:1rem}@media (max-width:768px){.hafalan-review--docked{padding-bottom:3.1rem}}@media (orientation:landscape) and (max-height:520px){.hafalan-review--docked{padding-bottom:3.1rem}}.hafalan-review__meta{display:flex;flex-wrap:wrap;gap:.65rem 1rem;font-size:.875rem;color:var(--text-muted)}.hafalan-review__meta span:first-child{color:var(--text-strong);font-weight:600}.hafalan-review__actions{display:flex;flex-wrap:wrap;gap:.65rem;width:100%}@media (max-width:768px){.hafalan-review__actions{flex-wrap:nowrap;gap:.5rem}.hafalan-review__actions .btn{flex:1 1 0;min-width:0;padding:.62rem .45rem;font-size:.78rem;line-height:1.25;white-space:normal;text-align:center}.hafalan-review__actions .btn i{flex-shrink:0;font-size:.85em}}@media (orientation:landscape) and (max-height:520px){.hafalan-review__actions{flex-wrap:nowrap;gap:.5rem}.hafalan-review__actions .btn{flex:1 1 0;min-width:0;padding:.62rem .45rem;font-size:.78rem;line-height:1.25;white-space:normal;text-align:center}.hafalan-review__actions .btn i{flex-shrink:0;font-size:.85em}}.hafalan-review__broken{background:rgba(245,159,0,.14);border:1.5px solid rgba(245,159,0,.38);color:#f59f00;box-shadow:0 2px 10px rgba(245,159,0,.12)}.hafalan-review__broken:hover:not(:disabled){background:rgba(245,159,0,.22);border-color:rgba(245,159,0,.55);color:#fbbf24;transform:translateY(-1px);box-shadow:0 4px 14px rgba(245,159,0,.18)}.hafalan-review__broken:disabled{opacity:.55;cursor:not-allowed}.text-muted{color:var(--text-muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.tajweed-toggle[data-v-6892cbfd]{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.tajweed-toggle[data-v-6892cbfd]:hover{border-color:var(--border-strong);color:var(--text)}.tajweed-toggle--active[data-v-6892cbfd]{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.tajweed-toggle__label[data-v-6892cbfd]{line-height:1}
.route-loading[data-v-2fc58500]{padding:3rem 0;text-align:center}.route-loading__text[data-v-2fc58500]{color:var(--text-muted);font-size:.95rem}
.route-error[data-v-61dcc4ad]{padding:3rem 0;text-align:center}.route-error__title[data-v-61dcc4ad]{font-size:1.05rem;font-weight:600;margin-bottom:.5rem}.route-error__desc[data-v-61dcc4ad]{color:var(--text-muted);font-size:.9rem;margin-bottom:1.25rem;max-width:28rem;margin-left:auto;margin-right:auto}
.surah-item--ready[data-v-257c62e4]{border-color:var(--border-strong)}.list-sentinel[data-v-257c62e4]{padding:1.5rem 0;text-align:center}.list-sentinel__text[data-v-257c62e4]{font-size:.875rem;color:var(--text-muted)}.pagination-info[data-v-257c62e4]{text-align:center;font-size:.8rem;color:var(--text-muted);padding:.5rem 0 1rem}
.reading-state[data-v-37d84805]{padding:3rem 0;text-align:center}.reading-state--error .reading-state__title[data-v-37d84805]{font-size:1.05rem;font-weight:600;margin-bottom:.5rem}.reading-state__text[data-v-37d84805]{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.ayah-sentinel[data-v-37d84805]{padding:1rem 0;text-align:center;min-height:1px}.list-sentinel__text[data-v-37d84805]{font-size:.875rem;color:var(--text-muted)}.pagination-info[data-v-37d84805]{text-align:center;font-size:.8rem;color:var(--text-muted);padding:.75rem 0 1rem}
.profile-page__head[data-v-bea11f76]{margin-bottom:1.5rem}.profile-page__head h1[data-v-bea11f76]{margin:0 0 .35rem;font-size:1.75rem;color:var(--text-strong)}.profile-page__head p[data-v-bea11f76]{margin:0;color:var(--text-muted)}.profile-page__loading[data-v-bea11f76]{text-align:center;padding:2rem;color:var(--text-muted)}.profile-card[data-v-bea11f76]{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}.profile-card__identity[data-v-bea11f76]{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.profile-card__avatar[data-v-bea11f76]{width:56px;height:56px;border-radius:50%;overflow:hidden;background:var(--primary-softer);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.profile-card__avatar img[data-v-bea11f76]{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-card__name[data-v-bea11f76]{margin:0 0 .15rem;font-size:1.1rem;font-weight:700;color:var(--text-strong)}.profile-card__email[data-v-bea11f76]{margin:0;font-size:.875rem;color:var(--text-muted)}.profile-card__meta[data-v-bea11f76]{margin-bottom:1.25rem;padding:.85rem 1rem;border-radius:10px;background:var(--primary-softer)}.profile-card__meta-label[data-v-bea11f76]{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.2rem}.profile-card__code[data-v-bea11f76]{font-family:Consolas,Monaco,monospace;font-size:1.15rem;font-weight:700;letter-spacing:.12em;color:var(--primary)}.profile-form__error[data-v-bea11f76]{color:#e53e3e;font-size:.875rem;margin:0 0 1rem}.profile-form__success[data-v-bea11f76]{color:#2f9e44;font-size:.875rem;margin:0 0 1rem}
.dashboard-page__head[data-v-ed293672]{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem}.dashboard-page__head h1[data-v-ed293672]{margin:0 0 .35rem;font-size:1.75rem;color:var(--text-strong)}.dashboard-page__head p[data-v-ed293672]{margin:0;color:var(--text-muted)}.dashboard-page__loading[data-v-ed293672]{text-align:center;padding:3rem 1rem;color:var(--text-muted)}
.dashboard-page__head--list[data-v-0b6992ac]{display:flex;flex-direction:column;align-items:flex-start;gap:.85rem;margin-top:.5rem;margin-bottom:1.5rem}.dashboard-page__intro h1[data-v-0b6992ac]{margin:0 0 .35rem;font-size:1.75rem;color:var(--text-strong)}.dashboard-page__intro p[data-v-0b6992ac]{margin:0;color:var(--text-muted)}.dashboard-list-count[data-v-0b6992ac]{padding:.35rem .75rem;border-radius:999px;background:var(--primary-softer);color:var(--primary);font-size:.8rem;font-weight:700;white-space:nowrap}.dashboard-back[data-v-0b6992ac],.dashboard-list-count[data-v-0b6992ac]{display:inline-flex;align-items:center}.dashboard-back[data-v-0b6992ac]{gap:.4rem;margin-bottom:1rem;font-size:.875rem;font-weight:500;color:var(--text-muted)}.dashboard-back[data-v-0b6992ac]:hover{color:var(--primary)}.dashboard-page__loading[data-v-0b6992ac]{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.dashboard-section__empty--center[data-v-0b6992ac]{text-align:center;padding:2rem 1rem}.dashboard-pagination[data-v-0b6992ac]{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"info info" "prev next";gap:.75rem;margin-top:1.5rem;width:100%}.dashboard-pagination .btn[data-v-0b6992ac]{width:100%;padding:.65rem .85rem;font-size:.85rem}.dashboard-pagination .btn[data-v-0b6992ac]:first-of-type{grid-area:prev}.dashboard-pagination .btn[data-v-0b6992ac]:last-of-type{grid-area:next}.dashboard-pagination__info[data-v-0b6992ac]{grid-area:info;text-align:center;font-size:.875rem;color:var(--text-muted)}@media (min-width:640px){.dashboard-pagination[data-v-0b6992ac]{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:1rem;width:auto}.dashboard-pagination .btn[data-v-0b6992ac]{width:auto;padding:.7rem 1.4rem;font-size:.925rem}.dashboard-pagination__info[data-v-0b6992ac]{order:0;text-align:center}}
