/* ============================================================
   KHATRI MASJID, MUMBAI — Premium Immersive UI
   
   ANTI-REGRESSION POLICY:
   1. Cache-Busting: Any structural change here MUST be accompanied by incrementing the `?v=` version string on the <link> tag in `index.html`.
   2. Layout Rule: Do NOT write layout changes that crash if old HTML is cached. Ensure backward CSS compatibility.
   3. Testing: All redesigns MUST validate against: Fresh mobile load, Cached mobile load, Desktop load, and Orientation change.
   ============================================================ */

/* ────────────────────── DESIGN TOKENS ────────────────────── */
:root {
    /* Foundation palette — deep midnight base */
    --d-950: #050B14;
    --d-900: #070F1A;
    --d-850: #0A1929;
    --d-800: #0D2137;
    --d-750: #102A45;
    --d-700: #163656;
    --d-650: #1A3A5C;
    --d-600: #1B4F7A;
    --d-500: #1565C0;
    --d-400: #1976D2;
    --d-300: #42A5F5;
    --d-200: #90CAF9;
    --d-100: #BBDEFB;
    --d-50:  #E3F2FD;

    /* Luminous accent palette — metallic warmth */
    --a-800: #6B500E;
    --a-700: #8B6914;
    --a-600: #AD8B00;
    --a-500: #C49000;
    --a-400: #D4A836;
    --a-300: #E8C96A;
    --a-200: #F0D68A;
    --a-100: #FDF8E8;

    /* Neutral slate */
    --s-950: #0F172A;
    --s-900: #1E293B;
    --s-800: #334155;
    --s-700: #475569;
    --s-600: #64748B;
    --s-500: #94A3B8;
    --s-400: #B0BEC5;
    --s-300: #CBD5E1;
    --s-200: #E2E8F0;
    --s-100: #F1F5F9;
    --s-50:  #F8FAFC;

    /* Semantic */
    --err: #EF4444;
    --err-deep: #DC2626;
    --ok: #16A34A;

    /* App-level tokens */
    --bg: #F4F7FA;
    --bg-card: #FFFFFF;
    --text-1: #0F172A;
    --text-2: #475569;
    --text-3: #94A3B8;
    --accent: var(--d-500);
    --accent-soft: var(--d-50);
    --warm: var(--a-500);
    --border: rgba(0,0,0,0.05);

    /* Glassmorphism */
    --glass-light: rgba(255,255,255,0.08);
    --glass-border: rgba(255,255,255,0.12);
    --glass-dark: rgba(10,25,41,0.82);

    /* Shadows */
    --sh-xs: 0 1px 2px rgba(15,23,42,0.04);
    --sh-sm: 0 2px 6px rgba(15,23,42,0.06), 0 1px 2px rgba(15,23,42,0.04);
    --sh-md: 0 4px 16px rgba(15,23,42,0.07), 0 2px 4px rgba(15,23,42,0.04);
    --sh-lg: 0 12px 40px rgba(15,23,42,0.1), 0 4px 12px rgba(15,23,42,0.05);
    --sh-xl: 0 20px 60px rgba(15,23,42,0.14), 0 8px 20px rgba(15,23,42,0.06);
    --glow-warm: 0 0 40px rgba(196,144,0,0.12), 0 0 80px rgba(196,144,0,0.06);
    --glow-accent: 0 0 40px rgba(21,101,192,0.12);

    /* Radii */
    --r-xs: 8px;
    --r-sm: 12px;
    --r-md: 16px;
    --r-lg: 20px;
    --r-xl: 24px;
    --r-2xl: 28px;
    --r-full: 999px;

    /* Layout */
    --dock-h: 66px;
    --safe-b: env(safe-area-inset-bottom, 0px);
}

/* ────────────────────── RESET & BASE ────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
    font-family:'Outfit','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    background:var(--bg);
    color:var(--text-1);
    line-height:1.5;
    min-height:100dvh;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}

/* Refined geometric texture — derived from logo's 8-pointed star */
body::before{
    content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%231565C0' fill-opacity='0.018'%3E%3Cpath d='M30 0L60 30L30 60L0 30z M30 8L52 30L30 52L8 30z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

a{text-decoration:none;color:inherit}
button{border:none;background:none;cursor:pointer;font-family:inherit}
img{max-width:100%;display:block}

/* ==================== HERO ==================== */
.hero{
    position:relative;
    height:72vh;
    min-height:420px;
    max-height:600px;
    overflow:hidden;
    z-index:10;
}

/* ── Slider ── */
.hero__slider{position:absolute;inset:0;z-index:0}
.hero__slide{
    position:absolute;inset:0;
    background-size:cover;
    background-position:center 40%;
    opacity:0;
    transition:opacity 1.2s ease-in-out;
    transform:scale(1);
}
.hero__slide.active{
    opacity:1;
    animation:hero-ken-burns 12s ease-in-out forwards;
    will-change:opacity,transform;
}
@keyframes hero-ken-burns{
    0%{transform:scale(1)}
    100%{transform:scale(1.08)}
}

/* ── Overlays ── */
.hero__overlay{
    position:absolute;inset:0;z-index:1;
    background:
        linear-gradient(180deg, rgba(7,15,26,0.45) 0%, rgba(7,15,26,0.15) 35%, rgba(7,15,26,0.55) 70%, rgba(7,15,26,0.92) 100%),
        radial-gradient(ellipse at 50% 110%, rgba(21,101,192,0.12) 0%, transparent 55%);
}
.hero__vignette{
    position:absolute;inset:0;z-index:2;
    background:radial-gradient(ellipse at center, transparent 50%, rgba(5,11,20,0.35) 100%);
}
.hero__pattern{
    position:absolute;inset:0;z-index:3;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.4' stroke-opacity='0.04'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 10L70 40L40 70L10 40z'/%3E%3Cpath d='M40 20L60 40L40 60L20 40z'/%3E%3C/g%3E%3C/svg%3E");
    pointer-events:none;
}
.hero__light{
    position:absolute;top:-20%;left:50%;transform:translateX(-50%);z-index:3;
    width:400px;height:400px;
    background:radial-gradient(circle, rgba(196,144,0,0.08) 0%, transparent 65%);
    pointer-events:none;
}

/* ── Hero content ── */
.hero__content{
    position:relative;z-index:5;
    height:100%;
    display:flex;flex-direction:column;justify-content:space-between;
    padding:16px 18px 22px;
    color:#fff;
}

.hero__top{display:flex;justify-content:space-between;align-items:flex-start}
.hero__brand{display:flex;align-items:center;gap:11px}
.hero__logo{
    width:48px;height:48px;border-radius:50%;object-fit:cover;
    border:2px solid rgba(196,144,0,0.5);
    box-shadow:0 0 16px rgba(196,144,0,0.2);
    flex-shrink:0;
}
.hero__brand-info{display:flex;flex-direction:column}
.hero__name{
    font-size:19px;font-weight:800;letter-spacing:-0.01em;line-height:1.2;
    text-shadow:0 2px 8px rgba(0,0,0,0.3);
}
.hero__location{font-size:11.5px;opacity:.72;font-weight:400;letter-spacing:.02em;margin-top:1px}
.hero__location i{font-size:9px;margin-right:3px}

.hero__controls{display:flex;gap:6px}
.hero__icon-btn{
    width:38px;height:38px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    color:rgba(255,255,255,.85);font-size:15px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.08);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    position:relative;transition:.25s ease;
}
.hero__icon-btn:active{transform:scale(.9);background:rgba(255,255,255,.15)}
.hero__badge{
    position:absolute;top:3px;right:3px;
    width:16px;height:16px;border-radius:50%;
    background:var(--err);font-size:9px;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    border:2px solid rgba(7,15,26,.6);
    animation:badge-pulse 2s infinite;
}
@keyframes badge-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

.hero__bottom{display:flex;flex-direction:column;gap:10px}
.hero__greeting{display:flex;flex-direction:column;gap:2px}
.hero__greeting-text{
    font-size:22px;font-weight:700;letter-spacing:-0.01em;
    text-shadow:0 2px 12px rgba(0,0,0,0.3);
}
.hero__greeting-sub{
    font-size:12px;opacity:.55;font-weight:400;letter-spacing:.03em;
}

.hero__meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.hero__date-chip{
    display:flex;align-items:center;gap:6px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.1);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    padding:5px 12px;border-radius:var(--r-full);
    font-size:11px;font-weight:500;
}
.hero__date-chip i{color:var(--a-300);font-size:10px}
.hero__date-sep{opacity:.35;font-size:8px}
#hijri-date{color:var(--a-300)}
#greg-date{opacity:.8}

.hero__live-pill{
    display:flex;align-items:center;gap:5px;
    background:rgba(239,68,68,.18);
    border:1px solid rgba(239,68,68,.35);
    padding:4px 10px;border-radius:var(--r-full);
    font-size:10px;font-weight:600;color:#FCA5A5;
    text-transform:uppercase;letter-spacing:.06em;
}

.live-dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--err);
    animation:live-blink 1.4s infinite;
    flex-shrink:0;
}
@keyframes live-blink{0%,100%{opacity:1}50%{opacity:.2}}

/* ── Hero dots ── */
.hero__dots{
    position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:6;
    display:flex;gap:6px;
}
.hero__dot{
    width:6px;height:6px;border-radius:50%;
    background:rgba(255,255,255,.3);
    transition:.4s ease;cursor:pointer;
}
.hero__dot.active{width:20px;border-radius:var(--r-full);background:rgba(255,255,255,.85)}

/* ==================== MAIN CONTENT ==================== */
.main{
    position:relative;z-index:20;
    padding:0 16px;
    display:flex;flex-direction:column;gap:28px;
}

/* ==================== FLOATING PRAYER CARD ==================== */
.prayer-card{
    position:relative;
    margin-top:-56px;
    z-index:30;
    border-radius:var(--r-xl);
    overflow:visible;
    animation:card-rise .7s cubic-bezier(.16,1,.3,1) both;
}
@keyframes card-rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

.prayer-card__glow{
    position:absolute;inset:-2px;border-radius:inherit;z-index:0;
    background:linear-gradient(135deg, rgba(196,144,0,0.35), rgba(196,144,0,0.08) 30%, transparent 50%, rgba(21,101,192,0.12) 70%, rgba(21,101,192,0.3));
    filter:blur(1px);
}
.prayer-card__glow::after{
    content:'';position:absolute;inset:2px;border-radius:inherit;
    background:var(--d-850);
}

.prayer-card__inner{
    position:relative;z-index:1;
    background:linear-gradient(160deg, var(--d-850) 0%, var(--d-900) 50%, var(--d-800) 100%);
    border-radius:var(--r-xl);
    border:1px solid rgba(255,255,255,.07);
    padding:22px 20px 18px;
    display:flex;flex-direction:column;gap:14px;
    color:#fff;
    box-shadow:
        0 8px 32px rgba(0,0,0,0.25),
        0 0 60px rgba(21,101,192,0.06),
        inset 0 1px 0 rgba(255,255,255,.05);
    overflow:hidden;
}

/* Subtle inner pattern */
.prayer-card__inner::before{
    content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.35' stroke-opacity='0.03'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 15L65 40L40 65L15 40z'/%3E%3C/g%3E%3C/svg%3E");
}

.prayer-card__header{
    display:flex;justify-content:space-between;align-items:center;
    position:relative;z-index:1;
}
.prayer-card__label{
    font-size:10px;text-transform:uppercase;letter-spacing:.12em;
    opacity:.45;font-weight:500;
}
.prayer-card__clock{
    font-size:14px;font-weight:600;color:var(--a-300);
    font-variant-numeric:tabular-nums;
}

.prayer-card__hero{
    text-align:center;padding:4px 0;
    position:relative;z-index:1;
}
.prayer-card__next-label{
    display:block;font-size:10px;text-transform:uppercase;
    letter-spacing:.16em;opacity:.4;margin-bottom:6px;font-weight:500;
}
.prayer-card__name{
    font-size:52px;font-weight:900;letter-spacing:-.03em;line-height:1;
    background:linear-gradient(135deg, #fff 20%, var(--a-400) 80%);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    filter:drop-shadow(0 2px 8px rgba(196,144,0,0.15));
}
.prayer-card__arabic{
    font-family:'Amiri',serif;font-size:22px;
    opacity:.35;margin-top:4px;
    color:var(--a-200);
}

/* Countdown */
.prayer-card__countdown{
    display:flex;align-items:stretch;gap:0;
    background:rgba(255,255,255,.05);
    border-radius:var(--r-md);
    border:1px solid rgba(255,255,255,.06);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    overflow:hidden;
    position:relative;z-index:1;
}
.prayer-card__cd-box{
    flex:1;display:flex;flex-direction:column;align-items:center;
    gap:3px;padding:14px 10px;
}
.prayer-card__cd-label{
    font-size:9px;text-transform:uppercase;letter-spacing:.12em;
    opacity:.45;font-weight:500;
}
.prayer-card__cd-val{
    font-size:26px;font-weight:700;color:var(--a-300);
    font-variant-numeric:tabular-nums;letter-spacing:.03em;
}
.prayer-card__cd-sep{width:1px;background:rgba(255,255,255,.08);margin:10px 0}

/* Progress */
.prayer-card__progress{
    height:3px;background:rgba(255,255,255,.06);
    border-radius:var(--r-full);overflow:hidden;
    position:relative;z-index:1;
}
.prayer-card__progress-fill{
    height:100%;width:50%;position:relative;
    background:linear-gradient(90deg, var(--a-500), var(--a-400));
    border-radius:var(--r-full);
    transition:width 1s ease;
}
.prayer-card__progress-glow{
    position:absolute;right:-2px;top:50%;transform:translateY(-50%);
    width:8px;height:8px;border-radius:50%;
    background:var(--a-400);
    box-shadow:0 0 8px var(--a-400), 0 0 16px rgba(196,144,0,0.3);
}

/* Prayer Timeline */
.prayer-card__timeline{
    display:flex;justify-content:space-between;gap:2px;
    position:relative;z-index:1;
}
.pt-slot{
    flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
    padding:8px 2px;border-radius:var(--r-xs);
    transition:.3s ease;cursor:default;
}
.pt-slot.passed{opacity:.3}
.pt-slot.active{
    background:rgba(196,144,0,.12);
    border:1px solid rgba(196,144,0,.2);
    opacity:1;
}
.pt-slot__dot{
    width:5px;height:5px;border-radius:50%;
    background:rgba(255,255,255,.25);transition:.3s ease;
}
.pt-slot.active .pt-slot__dot{
    background:var(--a-400);
    box-shadow:0 0 6px var(--a-400);
}
.pt-slot.passed .pt-slot__dot{background:rgba(255,255,255,.15)}
.pt-slot__name{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.pt-slot__time{font-size:11px;font-weight:500;font-variant-numeric:tabular-nums;opacity:.7}

/* ==================== SECTION HEADERS ==================== */
.sec-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.sec-title{font-size:18px;font-weight:700;color:var(--text-1);letter-spacing:-.01em}
.sec-chip{
    display:flex;align-items:center;gap:6px;
    font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
    color:var(--text-2);padding-left:2px;
}
.sec-chip i{color:var(--accent);font-size:13px}
.sec-link{
    font-size:12px;font-weight:600;color:var(--accent);
    display:flex;align-items:center;gap:5px;cursor:pointer;
}
.sec-link i{font-size:10px;transition:transform .25s ease}
.sec-link:hover i{transform:translateX(3px)}

/* ==================== ANNOUNCEMENTS ==================== */
.announcements{animation:section-up .6s cubic-bezier(.16,1,.3,1) .08s both}
@keyframes section-up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.announce-track{display:flex;flex-direction:column;gap:8px}
.ann-card{
    display:flex;align-items:center;gap:12px;
    padding:14px 16px;background:var(--bg-card);
    border-radius:var(--r-md);
    box-shadow:var(--sh-sm);
    border:1px solid var(--border);
    cursor:pointer;transition:.25s ease;
}
.ann-card:active{transform:scale(.98);box-shadow:var(--sh-md)}
.ann-card__icon{
    width:38px;height:38px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:14px;flex-shrink:0;
}
.ann-card--urgent .ann-card__icon{background:#FEF2F2;color:var(--err-deep)}
.ann-card--info .ann-card__icon{background:var(--d-50);color:var(--d-500)}
.ann-card--donate .ann-card__icon{background:var(--a-100);color:var(--a-600)}
.ann-card__body{flex:1;min-width:0}
.ann-card__text{
    font-size:13px;font-weight:500;line-height:1.4;color:var(--text-1);
    display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ann-card__date{font-size:11px;color:var(--text-3);margin-top:2px;display:block}
.ann-card__arrow{color:var(--text-3);font-size:10px;flex-shrink:0}

.announce-dots{display:flex;justify-content:center;gap:6px;margin-top:10px}
.a-dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--s-300);transition:.35s ease;cursor:pointer;
}
.a-dot.active{width:18px;border-radius:var(--r-full);background:var(--accent)}

/* ==================== QUICK ACCESS — STRUCTURED LAYOUT ==================== */
.quick-actions{animation:section-up .6s cubic-bezier(.16,1,.3,1) .16s both}

/* ── Featured Hero Cards (Top 4) ── */
.qa-featured{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;margin-bottom:18px;
}

.qa-hero{
    position:relative;overflow:hidden;
    display:flex;flex-direction:column;
    padding:16px;gap:10px;
    background:var(--bg-card);
    border-radius:var(--r-md);
    box-shadow:var(--sh-sm);border:1px solid var(--border);
    transition:.3s cubic-bezier(.16,1,.3,1);
    cursor:pointer;text-decoration:none;
    min-height:100px;
}
.qa-hero:active{transform:scale(.96);box-shadow:var(--sh-md)}

.qa-hero__bg{
    position:absolute;inset:0;z-index:0;pointer-events:none;
    background:radial-gradient(circle at 85% 15%,
        hsla(var(--qh),var(--qs),var(--ql),0.08) 0%, transparent 65%);
}
.qa-hero__body{
    position:relative;z-index:1;
    display:flex;align-items:flex-start;gap:10px;
}
.qa-hero__icon{
    width:42px;height:42px;border-radius:var(--r-sm);flex-shrink:0;
    display:flex;align-items:center;justify-content:center;font-size:17px;
    color:hsla(var(--qh),var(--qs),var(--ql),1);
    background:hsla(var(--qh),var(--qs),var(--ql),0.09);
    transition:.3s ease;
}
.qa-hero__icon--sm{width:36px;height:36px;font-size:15px}
.qa-hero__label{
    display:block;font-size:13px;font-weight:700;color:var(--text-1);line-height:1.2;
}
.qa-hero__sub{
    display:block;font-size:10px;color:var(--text-3);margin-top:2px;line-height:1.3;
}
.qa-hero__arrow{
    position:absolute;bottom:12px;right:12px;z-index:1;
    font-size:11px;color:var(--text-3);
    width:26px;height:26px;border-radius:50%;
    background:var(--s-50);
    display:flex;align-items:center;justify-content:center;
    transition:.25s ease;
}
.qa-hero__live{
    position:absolute;top:10px;right:10px;z-index:1;
    display:flex;align-items:center;gap:4px;
    padding:3px 8px;border-radius:var(--r-full);
    background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.18);
    font-size:9px;font-weight:700;color:var(--err-deep);
    text-transform:uppercase;letter-spacing:.04em;
}

/* Half-width hero cards */
.qa-hero--half{
    min-height:78px;padding:14px;gap:8px;
    flex-direction:row;align-items:center;
}
.qa-hero--half .qa-hero__body{align-items:center}

/* ── Category Sections ── */
.qa-cat{
    margin-bottom:16px;
    padding:14px;
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:var(--r-md);
    box-shadow:var(--sh-sm);
}
.qa-cat--sys{
    background:transparent;
    border:none;box-shadow:none;
    padding:0;margin-bottom:8px;
}

.qa-cat__title{
    display:flex;align-items:center;gap:8px;
    font-size:12px;font-weight:700;color:var(--text-1);
    text-transform:uppercase;letter-spacing:.5px;
    margin:0 0 12px;
}
.qa-cat__dot{
    width:8px;height:8px;border-radius:50%;flex-shrink:0;
    background:var(--cd);
    box-shadow:0 0 6px hsla(var(--cd),0.3);
}

/* Category grid — 4 columns on mobile */
.qa-cat__grid{
    display:grid;gap:6px;
    grid-template-columns:repeat(4,1fr);
}

/* ── Feature Items (icon + label) ── */
.qa-item{
    display:flex;flex-direction:column;align-items:center;
    gap:6px;padding:10px 4px 8px;
    border-radius:10px;text-decoration:none;
    transition:.2s cubic-bezier(.16,1,.3,1);
    cursor:pointer;
}
.qa-item:active{transform:scale(.92);background:var(--s-50)}

.qa-item__icon{
    width:38px;height:38px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    font-size:15px;flex-shrink:0;
    color:hsla(var(--qi-h),var(--qi-s),var(--qi-l),1);
    background:hsla(var(--qi-h),var(--qi-s),var(--qi-l),0.08);
    transition:.25s ease;
}
.qa-item span{
    font-size:10px;font-weight:600;color:var(--text-2);
    text-align:center;line-height:1.25;
    max-width:72px;
    display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;
}

/* Coming Soon Modifier */
.qa-item--coming-soon, .qa-hero--coming-soon {
    opacity: 0.55;
    pointer-events: none;
    position: relative;
}
.qa-item--coming-soon::after, .qa-hero--coming-soon::after {
    content: 'COMING SOON';
    position: absolute;
    top: -2px;
    right: 0px;
    background: var(--s-800);
    color: #fff;
    font-size: 7px;
    font-weight: 800;
    padding: 2px 4px;
    border-radius: 4px;
    letter-spacing: 0.05em;
    z-index: 10;
}


/* ── System Row (Settings/Exit) ── */
.qa-cat__grid--sys{
    display:flex;gap:8px;justify-content:center;
}
.qa-sys{
    display:flex;align-items:center;gap:6px;
    padding:10px 18px;
    border-radius:var(--r-full);
    background:var(--s-50);border:1px solid var(--border);
    font-size:12px;font-weight:600;color:var(--text-2);
    text-decoration:none;cursor:pointer;
    transition:.2s ease;
}
.qa-sys i{font-size:12px;color:var(--text-3)}
.qa-sys:active{transform:scale(.94);background:var(--s-100)}



/* ==================== EXPLORE PANEL (MODAL) ==================== */
.explore-panel{
    position:fixed;inset:0;z-index:500;
    pointer-events:none;
    visibility:hidden;
}
.explore-panel.open{pointer-events:auto;visibility:visible}

.explore-panel__overlay{
    position:absolute;inset:0;
    background:rgba(5,11,20,.6);
    backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
    opacity:0;transition:opacity .35s ease;
}
.explore-panel.open .explore-panel__overlay{opacity:1}

.explore-panel__sheet{
    position:absolute;bottom:0;left:0;right:0;
    max-height:85vh;
    background:var(--bg);
    border-radius:var(--r-2xl) var(--r-2xl) 0 0;
    box-shadow:0 -8px 40px rgba(0,0,0,.2);
    display:flex;flex-direction:column;
    transform:translateY(100%);
    transition:transform .4s cubic-bezier(.16,1,.3,1);
    overflow:hidden;
}
.explore-panel.open .explore-panel__sheet{transform:translateY(0)}

.explore-panel__header{
    padding:12px 20px 14px;
    border-bottom:1px solid var(--border);
    flex-shrink:0;
}
.explore-panel__handle{
    width:36px;height:4px;border-radius:var(--r-full);
    background:var(--s-300);margin:0 auto 12px;
}
.explore-panel__title-row{display:flex;justify-content:space-between;align-items:center}
.explore-panel__title{font-size:18px;font-weight:700;color:var(--text-1)}
.explore-panel__close{
    width:32px;height:32px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:14px;color:var(--text-2);
    background:var(--s-100);border:none;cursor:pointer;
    transition:.2s ease;
}
.explore-panel__close:active{transform:scale(.9);background:var(--s-200)}
.explore-panel__sub{font-size:12px;color:var(--text-3);margin-top:2px}

.explore-panel__body{
    flex:1;overflow-y:auto;padding:16px 20px 32px;
    display:flex;flex-direction:column;gap:22px;
    -webkit-overflow-scrolling:touch;
}

/* ── Explore Section ── */
.ep-section{display:flex;flex-direction:column;gap:10px}
.ep-section__title{
    display:flex;align-items:center;gap:8px;
    font-size:12px;font-weight:700;color:var(--text-2);
    text-transform:uppercase;letter-spacing:.08em;
}
.ep-section__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

.ep-grid{
    display:grid;grid-template-columns:repeat(4, 1fr);gap:10px;
}

.ep-item{
    display:flex;flex-direction:column;align-items:center;gap:7px;
    padding:14px 4px 12px;text-align:center;
    background:var(--bg-card);border-radius:var(--r-md);
    border:1px solid var(--border);box-shadow:var(--sh-xs);
    transition:.25s cubic-bezier(.16,1,.3,1);cursor:pointer;
}
.ep-item:active{transform:scale(.93)}
.ep-item__icon{
    width:38px;height:38px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:15px;
    color:hsla(var(--ei-h),var(--ei-s),var(--ei-l),1);
    background:hsla(var(--ei-h),var(--ei-s),var(--ei-l),0.08);
    transition:.25s ease;
}
.ep-item span{font-size:10.5px;font-weight:600;color:var(--text-1);line-height:1.25}

/* ==================== SPIRITUAL FEED ==================== */
.spiritual-feed{animation:section-up .6s cubic-bezier(.16,1,.3,1) .24s both}
.feed-scroll{
    display:flex;gap:12px;overflow-x:auto;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    padding-bottom:4px;scrollbar-width:none;
}
.feed-scroll::-webkit-scrollbar{display:none}

.feed-card{
    min-width:195px;max-width:220px;flex-shrink:0;scroll-snap-align:start;
    background:var(--bg-card);border-radius:var(--r-md);overflow:hidden;
    box-shadow:var(--sh-sm);border:1px solid var(--border);
    cursor:pointer;transition:.3s cubic-bezier(.16,1,.3,1);
}
.feed-card:active{transform:scale(.97);box-shadow:var(--sh-md)}
.feed-card__accent{height:4px;background:var(--fc,var(--accent))}
.feed-card__body{padding:14px;display:flex;flex-direction:column;gap:6px}
.feed-card__type{
    font-size:10px;font-weight:600;text-transform:uppercase;
    letter-spacing:.08em;color:var(--text-3);
}
.feed-card__ar{
    font-family:'Amiri',serif;font-size:18.5px;
    color:var(--text-1);line-height:1.55;
}
.feed-card__en{font-size:12px;color:var(--text-2);line-height:1.35}
.feed-card__cta{
    display:inline-flex;align-items:center;gap:5px;
    font-size:11px;font-weight:600;color:var(--accent);
    margin-top:4px;padding:5px 11px;
    background:var(--d-50);border-radius:var(--r-full);
    width:fit-content;transition:.2s ease;
}
.feed-card__cta i{font-size:11px}

/* ==================== LIVE SECTION ==================== */
.live-section{animation:section-up .6s cubic-bezier(.16,1,.3,1) .32s both}

.live-badge-sm{
    display:flex;align-items:center;gap:5px;
    background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.18);
    padding:3px 10px;border-radius:var(--r-full);
    font-size:10px;font-weight:700;color:var(--err-deep);
    text-transform:uppercase;letter-spacing:.06em;
}

.live-card{
    background:var(--bg-card);border-radius:var(--r-lg);overflow:hidden;
    box-shadow:var(--sh-lg);border:1px solid var(--border);
}
.live-card__preview{
    position:relative;height:170px;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
}
.live-card__bg{
    position:absolute;inset:0;
    background:linear-gradient(150deg, var(--d-950) 0%, var(--d-900) 40%, var(--d-800) 100%);
}
.live-card__bg::after{
    content:'';position:absolute;inset:0;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.3' stroke-opacity='0.04'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 15L65 40L40 65L15 40z'/%3E%3C/g%3E%3C/svg%3E");
}
.live-card__center{position:relative;display:flex;align-items:center;justify-content:center}
.live-card__logo{
    width:68px;height:68px;border-radius:50%;object-fit:cover;
    border:2px solid rgba(196,144,0,.3);opacity:.75;
    position:relative;z-index:1;
}
.live-card__ring{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:96px;height:96px;border-radius:50%;
    border:2px solid rgba(196,144,0,.2);
    animation:ring-expand 2.4s cubic-bezier(0,0,.2,1) infinite;
}
.live-card__ring--delay{animation-delay:.8s}
@keyframes ring-expand{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}100%{transform:translate(-50%,-50%) scale(1.6);opacity:0}}

.live-card__tag{
    position:absolute;top:12px;left:12px;z-index:2;
    display:flex;align-items:center;gap:5px;
    background:var(--err-deep);color:#fff;
    padding:4px 10px;border-radius:var(--r-full);
    font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
    box-shadow:0 2px 10px rgba(220,38,38,.4);
}
.live-card__tag .live-dot{background:#fff}

.live-card__info{padding:16px;display:flex;flex-direction:column;gap:5px}
.live-card__title{font-size:16px;font-weight:700;color:var(--text-1)}
.live-card__meta{font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:6px}
.live-card__meta i{font-size:11px;color:var(--text-3);width:14px}

.live-card__cta{
    display:flex;align-items:center;justify-content:center;gap:8px;
    margin:0 16px 16px;padding:12px;
    background:linear-gradient(135deg, var(--err-deep), #B91C1C);
    color:#fff;border-radius:var(--r-md);
    font-size:14px;font-weight:600;
    transition:.25s ease;
    box-shadow:0 4px 14px rgba(220,38,38,.25);
}
.live-card__cta:active{transform:scale(.97);box-shadow:0 2px 8px rgba(220,38,38,.4)}
.live-card__cta i{font-size:13px}

/* ==================== EVENTS ==================== */
.events-section{animation:section-up .6s cubic-bezier(.16,1,.3,1) .4s both}
.events-list{display:flex;flex-direction:column;gap:10px}

.ev-card{
    display:flex;gap:14px;padding:14px;
    background:var(--bg-card);border-radius:var(--r-md);
    box-shadow:var(--sh-sm);border:1px solid var(--border);
    cursor:pointer;transition:.25s ease;
}
.ev-card:active{transform:scale(.98);box-shadow:var(--sh-md)}
.ev-card__date{
    width:50px;height:54px;border-radius:var(--r-sm);
    background:linear-gradient(145deg, var(--d-650), var(--d-850));
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    color:#fff;flex-shrink:0;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.ev-card__day{font-size:18px;font-weight:800;line-height:1}
.ev-card__month{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;opacity:.75}

.ev-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.ev-card__body h4{font-size:14px;font-weight:600;color:var(--text-1);line-height:1.3}
.ev-card__body p{
    font-size:12px;color:var(--text-2);line-height:1.35;
    display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.ev-card__time{
    font-size:11px;color:var(--accent);font-weight:500;
    display:flex;align-items:center;gap:5px;margin-top:2px;
}
.ev-card__time i{font-size:10px}

/* ==================== BOTTOM SPACER ==================== */
.bottom-spacer{height:calc(var(--dock-h) + var(--safe-b) + 28px)}

/* ==================== DOCK (BOTTOM NAV) ==================== */
.dock{
    position:fixed;bottom:0;left:0;right:0;z-index:200;
    height:calc(var(--dock-h) + var(--safe-b));
    padding-bottom:var(--safe-b);
    background:rgba(7,15,26,.92);
    backdrop-filter:blur(24px) saturate(180%);
    -webkit-backdrop-filter:blur(24px) saturate(180%);
    border-top:1px solid rgba(255,255,255,.06);
    display:flex;align-items:stretch;
    box-shadow:0 -4px 24px rgba(0,0,0,.15);
}
.dock__item{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;padding:8px 0;
    color:rgba(255,255,255,.4);
    font-size:10px;font-weight:500;
    transition:.25s ease;position:relative;cursor:pointer;
}
.dock__item i{font-size:19px;transition:.25s ease}
.dock__item.active{color:var(--a-400)}
.dock__item.active::before{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:28px;height:3px;border-radius:0 0 var(--r-full) var(--r-full);
    background:linear-gradient(90deg, var(--a-500), var(--a-400));
    box-shadow:0 2px 8px rgba(196,144,0,0.3);
}
.dock__item.active i{transform:scale(1.12)}
.dock__item:active{transform:scale(.9)}

.dock__live-icon{position:relative}
.dock__live-dot{
    position:absolute;top:-2px;right:-4px;
    width:7px;height:7px;border-radius:50%;
    background:var(--err);
    border:1.5px solid rgba(7,15,26,.9);
    animation:live-blink 1.4s infinite;
}

/* ==================== RESPONSIVE ==================== */
@media(min-width:480px){
    .qa-card__sub{display:block}
    .feed-card{min-width:215px;max-width:240px}
    .live-card__preview{height:200px}
    .hero{min-height:460px}
}

@media(min-width:640px){
    .main{max-width:600px;margin:0 auto;padding:0 20px;gap:30px}
    .hero__content{max-width:600px;margin:0 auto;width:100%;padding:20px 20px 26px}
    .dock{
        max-width:600px;left:50%;transform:translateX(-50%);
        border-radius:var(--r-lg) var(--r-lg) 0 0;
        border:1px solid rgba(255,255,255,.08);border-bottom:none;
    }
    .qa-grid{gap:14px}
    .qa-card{padding:18px 10px 16px}
    .qa-card__icon{width:46px;height:46px;font-size:19px}
    .qa-card__label{font-size:12px}
    .qa-card__sub{display:block;font-size:10px}
    .prayer-card__name{font-size:56px}
    .prayer-card__cd-val{font-size:28px}
}

@media(min-width:1024px){
    .main{max-width:720px;padding:0 28px;gap:34px}
    .hero__content{max-width:720px;padding:24px 28px 30px}
    .prayer-card{margin-top:-64px}
    .prayer-card__name{font-size:60px}
    .prayer-card__cd-val{font-size:30px}
    .hero{max-height:700px}
}

/* ==================== ANIMATION & MOTION ==================== */
.announcements,.quick-actions,.spiritual-feed,.live-section,.events-section{
    opacity:0;animation-fill-mode:both;
}

@media(hover:hover){
    .qa-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
    .qa-card:hover .qa-card__icon{transform:scale(1.08)}
    .ann-card:hover{border-color:var(--d-200);box-shadow:var(--sh-md)}
    .ev-card:hover{border-color:var(--d-200);box-shadow:var(--sh-md)}
    .feed-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
    .live-card__cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(220,38,38,.35)}
}

/* ==================== ACCESSIBILITY ==================== */
:focus-visible{outline:2px solid var(--d-300);outline-offset:2px;border-radius:var(--r-xs)}

@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{
        animation-duration:.01ms!important;animation-iteration-count:1!important;
        transition-duration:.01ms!important;scroll-behavior:auto!important;
    }
    .hero__slide{transition-duration:.01ms!important}
    .hero__slide.active{transform:scale(1)!important}
}

::selection{background:var(--d-100);color:var(--d-900)}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s-300);border-radius:var(--r-full)}

/* ==================== PAGE SYSTEM ==================== */
.page{display:none}
.page.active{display:block;animation:page-enter .35s cubic-bezier(.16,1,.3,1) both}
@keyframes page-enter{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes section-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes card-rise{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ==================== PAGE HEADER (shared) ==================== */
.pg-header{
    position:relative;overflow:hidden;
    padding:48px 20px 28px;
    min-height:160px;
    display:flex;align-items:flex-end;
}
.pg-header__bg{
    position:absolute;inset:0;z-index:0;
    background:linear-gradient(160deg, var(--d-950) 0%, var(--d-850) 50%, var(--d-700) 100%);
}
.pg-header__pattern{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.4' stroke-opacity='0.04'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 10L70 40L40 70L10 40z'/%3E%3Cpath d='M40 20L60 40L40 60L20 40z'/%3E%3C/g%3E%3C/svg%3E");
}
.pg-header__content{
    position:relative;z-index:2;color:#fff;
    display:flex;flex-direction:column;gap:4px;
}
.pg-header__icon{
    width:40px;height:40px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:16px;color:var(--a-300);
    background:rgba(196,144,0,.12);border:1px solid rgba(196,144,0,.18);
    margin-bottom:10px;
}
.pg-header__title{font-size:24px;font-weight:800;letter-spacing:-.02em;line-height:1.2}
.pg-header__sub{font-size:13px;opacity:.55;font-weight:400;margin-top:2px}
.pg-header--live .pg-header__bg{
    background:linear-gradient(160deg, #1a0808 0%, var(--d-950) 40%, #2a0a0a 100%);
}

.pg-body{padding:20px 16px;display:flex;flex-direction:column;gap:20px}

/* ==================== TIMETABLE PAGE — PREMIUM ==================== */

/* ── Immersive Header ── */
.tt-hero{
    position:relative;overflow:hidden;
    padding:48px 20px 24px;
}
.tt-hero__bg{
    position:absolute;inset:0;z-index:0;
    background:linear-gradient(165deg, var(--d-950) 0%, var(--d-850) 35%, var(--d-750) 70%, var(--d-700) 100%);
}
.tt-hero__pattern{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.4' stroke-opacity='0.04'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 10L70 40L40 70L10 40z'/%3E%3Cpath d='M40 20L60 40L40 60L20 40z'/%3E%3C/g%3E%3C/svg%3E");
}
.tt-hero__light{
    position:absolute;top:-30%;left:50%;transform:translateX(-50%);z-index:1;
    width:350px;height:350px;
    background:radial-gradient(circle, rgba(196,144,0,0.07) 0%, transparent 60%);
    pointer-events:none;
}
.tt-hero__content{
    position:relative;z-index:2;color:#fff;
    display:flex;flex-direction:column;gap:14px;
}
.tt-hero__top{display:flex;justify-content:space-between;align-items:flex-start}
.tt-hero__title-row{display:flex;align-items:center;gap:10px}
.tt-hero__title-icon{font-size:18px;color:var(--a-300)}
.tt-hero__title{font-size:22px;font-weight:800;letter-spacing:-.01em}
.tt-hero__loc{
    font-size:11px;opacity:.5;display:flex;align-items:center;gap:4px;
    padding:5px 10px;background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.06);
    border-radius:var(--r-full);
}
.tt-hero__loc i{font-size:9px}

.tt-hero__dates{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.tt-hero__date-pill{
    display:flex;align-items:center;gap:5px;
    font-size:11px;font-weight:500;
}
.tt-hero__date-pill i{color:var(--a-300);font-size:10px}
.tt-hero__date-pill--greg{opacity:.65}
.tt-hero__date-sep{opacity:.25;font-size:8px}


/* ── Main Content Area ── */
.tt-main{
    padding:0 16px;display:flex;flex-direction:column;gap:22px;
}

/* ── Section Titles ── */
.tt-sec-title{
    display:flex;align-items:center;gap:12px;
    padding:0 2px;
}
.tt-sec-title__text{
    font-size:13px;font-weight:700;color:var(--text-2);
    text-transform:uppercase;letter-spacing:.08em;
    white-space:nowrap;
}
.tt-sec-title__line{
    flex:1;height:1px;
    background:linear-gradient(90deg, var(--border) 0%, transparent 100%);
}

/* ══════════ FLOATING NEXT-PRAYER HERO CARD ══════════ */
.tt-next{
    position:relative;margin-top:-36px;z-index:30;
    border-radius:var(--r-xl);overflow:visible;
    animation:card-rise .7s cubic-bezier(.16,1,.3,1) both;
}
.tt-next__glow{
    position:absolute;inset:-2px;border-radius:inherit;z-index:0;
    background:linear-gradient(135deg, rgba(196,144,0,0.4), rgba(196,144,0,0.08) 30%, transparent 50%, rgba(21,101,192,0.12) 70%, rgba(21,101,192,0.35));
    filter:blur(1px);
}
.tt-next__glow::after{
    content:'';position:absolute;inset:2px;border-radius:inherit;
    background:var(--d-850);
}
.tt-next__inner{
    position:relative;z-index:1;
    background:linear-gradient(160deg, var(--d-850) 0%, var(--d-900) 50%, var(--d-800) 100%);
    border-radius:var(--r-xl);
    border:1px solid rgba(255,255,255,.07);
    padding:20px;display:flex;flex-direction:column;gap:16px;
    color:#fff;
    box-shadow:0 8px 32px rgba(0,0,0,.25),0 0 60px rgba(21,101,192,.06),inset 0 1px 0 rgba(255,255,255,.05);
    overflow:hidden;
}
.tt-next__inner-pattern{
    position:absolute;inset:0;z-index:0;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.35' stroke-opacity='0.03'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 15L65 40L40 65L15 40z'/%3E%3C/g%3E%3C/svg%3E");
}

.tt-next__header{
    display:flex;justify-content:space-between;align-items:center;
    position:relative;z-index:1;
}
.tt-next__clock{
    display:flex;align-items:center;gap:6px;
    font-size:13px;font-weight:600;color:var(--a-300);
    font-variant-numeric:tabular-nums;
}
.tt-next__clock i{font-size:11px;opacity:.6}
.tt-next__status{
    display:flex;align-items:center;gap:5px;
    padding:3px 10px;border-radius:var(--r-full);
    background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.2);
    font-size:10px;font-weight:600;color:#FCA5A5;
    text-transform:uppercase;letter-spacing:.05em;
}

.tt-next__body{
    text-align:center;padding:4px 0;position:relative;z-index:1;
}
.tt-next__label{
    display:block;font-size:10px;text-transform:uppercase;
    letter-spacing:.16em;opacity:.4;margin-bottom:6px;font-weight:500;
}
.tt-next__name{
    font-size:48px;font-weight:900;letter-spacing:-.03em;line-height:1;
    background:linear-gradient(135deg, #fff 20%, var(--a-400) 80%);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    filter:drop-shadow(0 2px 8px rgba(196,144,0,0.15));
}
.tt-next__arabic{
    font-family:'Amiri',serif;font-size:20px;
    opacity:.35;margin-top:4px;color:var(--a-200);
}

.tt-next__counters{
    display:flex;align-items:stretch;gap:0;
    background:rgba(255,255,255,.05);
    border-radius:var(--r-md);
    border:1px solid rgba(255,255,255,.06);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    overflow:hidden;position:relative;z-index:1;
}
.tt-next__counter{
    flex:1;display:flex;flex-direction:column;align-items:center;
    gap:3px;padding:14px 10px;
}
.tt-next__counter-label{
    font-size:9px;text-transform:uppercase;letter-spacing:.12em;
    opacity:.45;font-weight:500;
}
.tt-next__counter-val{
    font-size:24px;font-weight:700;color:var(--a-300);
    font-variant-numeric:tabular-nums;letter-spacing:.03em;
}
.tt-next__counter-sep{width:1px;background:rgba(255,255,255,.08);margin:10px 0}

.tt-next__progress{
    height:3px;background:rgba(255,255,255,.06);
    border-radius:var(--r-full);overflow:hidden;
    position:relative;z-index:1;
}
.tt-next__progress-fill{
    height:100%;width:50%;position:relative;
    background:linear-gradient(90deg, var(--a-500), var(--a-400));
    border-radius:var(--r-full);transition:width 1s ease;
}
.tt-next__progress-glow{
    position:absolute;right:-2px;top:50%;transform:translateY(-50%);
    width:8px;height:8px;border-radius:50%;
    background:var(--a-400);
    box-shadow:0 0 8px var(--a-400), 0 0 16px rgba(196,144,0,0.3);
}

/* ══════════ PRAYER CARD STACK ══════════ */
.tt-stack{display:flex;flex-direction:column;gap:10px}

.tt-card{
    display:flex;align-items:center;
    padding:14px 16px;background:var(--bg-card);
    border-radius:var(--r-md);
    box-shadow:var(--sh-sm);border:1px solid var(--border);
    transition:.3s cubic-bezier(.16,1,.3,1);
    position:relative;overflow:hidden;cursor:default;
}
.tt-card__indicator{
    position:absolute;left:0;top:0;bottom:0;width:4px;
    background:transparent;border-radius:var(--r-full) 0 0 var(--r-full);
    transition:.3s ease;
}

/* Visual states */
.tt-card.is-passed{opacity:.45}
.tt-card.is-passed .tt-card__name{color:var(--text-3)}
.tt-card.is-passed .tt-card__icon{opacity:.5}
.tt-card.is-passed .tt-card__time-val{color:var(--text-3)}

.tt-card.is-active{
    border-color:rgba(196,144,0,.25);
    box-shadow:var(--sh-md),0 0 20px rgba(196,144,0,.06);
    background:linear-gradient(135deg, rgba(196,144,0,.02) 0%, var(--bg-card) 100%);
}
.tt-card.is-active .tt-card__indicator{background:var(--a-400)}
.tt-card.is-active .tt-card__name{color:var(--a-800)}
.tt-card.is-active .tt-card__icon{
    box-shadow:0 0 12px hsla(var(--tc-h),var(--tc-s),var(--tc-l),0.2);
}

.tt-card.is-next{
    border-color:rgba(21,101,192,.2);
    box-shadow:var(--sh-md),0 0 20px rgba(21,101,192,.05);
}
.tt-card.is-next .tt-card__indicator{background:var(--d-400)}

.tt-card__left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.tt-card__icon{
    width:44px;height:44px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;
    color:hsla(var(--tc-h),var(--tc-s),var(--tc-l),1);
    background:hsla(var(--tc-h),var(--tc-s),var(--tc-l),0.08);
    transition:.3s ease;
}
.tt-card__info{display:flex;flex-direction:column;gap:1px}
.tt-card__name{font-size:15px;font-weight:700;color:var(--text-1);transition:.3s ease}
.tt-card__ar{font-family:'Amiri',serif;font-size:12.5px;color:var(--text-3)}

.tt-card__right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.tt-card__time-col{
    display:flex;flex-direction:column;align-items:center;gap:1px;
    min-width:52px;text-align:center;
}
.tt-card__time-col--single{min-width:64px}
.tt-card__time-label{
    font-size:9px;text-transform:uppercase;letter-spacing:.08em;
    color:var(--text-3);font-weight:500;
}
.tt-card__time-val{
    font-size:14px;font-weight:700;color:var(--text-1);
    font-variant-numeric:tabular-nums;
    transition:.3s ease;
}
.tt-card__time-val small{font-size:10px;font-weight:500;opacity:.65;margin-left:1px}
.tt-card__time-divider{width:1px;height:26px;background:var(--border)}

/* ══════════ MAKROOH SECTION ══════════ */
.tt-card--makrooh{
    background:linear-gradient(135deg, rgba(220,80,40,.02) 0%, var(--bg-card) 100%);
    border-style:dashed;border-color:rgba(220,80,40,.12);
}
.tt-card--makrooh .tt-card__name{font-size:13.5px;font-weight:600}
.tt-card--makrooh .tt-card__ar{font-family:'Inter','Outfit',sans-serif;font-size:11px;color:var(--text-3);font-style:italic}
.tt-card__icon--makrooh{
    color:hsl(15, 80%, 50%);
    background:hsla(15, 80%, 50%, 0.08);
}
.tt-makrooh__range{
    font-size:12px;font-weight:600;color:var(--text-2);
    white-space:nowrap;font-variant-numeric:tabular-nums;
}
.tt-card--makrooh.is-active{
    border-color:rgba(220,80,40,.25);
    box-shadow:var(--sh-md),0 0 20px rgba(220,80,40,.06);
    background:linear-gradient(135deg, rgba(220,80,40,.04) 0%, var(--bg-card) 100%);
}
.tt-card--makrooh.is-active .tt-card__indicator{background:hsl(15, 80%, 50%)}
.tt-card--makrooh.is-active .tt-card__name{color:hsl(15, 80%, 40%)}
.tt-card--makrooh.is-active .tt-makrooh__range{color:hsl(15, 80%, 40%);font-weight:700}
.tt-card--makrooh.is-passed{opacity:.4}

/* ══════════ JUMMAH SECTION ══════════ */
.tt-jummah{
    position:relative;border-radius:var(--r-xl);overflow:visible;
}
.tt-jummah__glow{
    position:absolute;inset:-2px;border-radius:inherit;z-index:0;
    background:linear-gradient(135deg, rgba(22,163,74,0.35), rgba(22,163,74,0.08) 30%, transparent 50%, rgba(21,101,192,0.08) 70%, rgba(21,101,192,0.25));
    filter:blur(1px);
}
.tt-jummah__glow::after{
    content:'';position:absolute;inset:2px;border-radius:inherit;
    background:linear-gradient(160deg, #0a1f13 0%, var(--d-900) 50%, #0a1520 100%);
}
.tt-jummah__inner{
    position:relative;z-index:1;
    background:linear-gradient(160deg, #0d2418 0%, var(--d-900) 50%, #0d1a24 100%);
    border-radius:var(--r-xl);
    border:1px solid rgba(22,163,74,.12);
    padding:20px;color:#fff;
    display:flex;flex-direction:column;align-items:center;gap:14px;
    box-shadow:0 8px 32px rgba(0,0,0,.2);
}
.tt-jummah__icon-wrap{
    width:52px;height:52px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:rgba(22,163,74,.12);
    border:1px solid rgba(22,163,74,.2);
    font-size:20px;color:#4ade80;
}
.tt-jummah__body{text-align:center}
.tt-jummah__title{font-size:18px;font-weight:800;letter-spacing:-.01em}
.tt-jummah__ar{
    font-family:'Amiri',serif;font-size:16px;
    color:rgba(74,222,128,.4);margin-top:2px;
}

.tt-jummah__times{
    display:flex;align-items:stretch;gap:0;width:100%;
    background:rgba(255,255,255,.04);
    border-radius:var(--r-md);border:1px solid rgba(255,255,255,.06);
    overflow:hidden;
}
.tt-jummah__time-item{
    flex:1;display:flex;flex-direction:column;align-items:center;
    gap:3px;padding:12px 10px;
}
.tt-jummah__time-label{
    font-size:9px;text-transform:uppercase;letter-spacing:.1em;
    opacity:.45;font-weight:500;
}
.tt-jummah__time-val{
    font-size:20px;font-weight:700;color:#4ade80;
    font-variant-numeric:tabular-nums;
}
.tt-jummah__time-sep{width:1px;background:rgba(255,255,255,.08);margin:8px 0}

/* ══════════ SETTINGS & TOGGLES ══════════ */
.tt-settings{
    background:var(--bg-card);border-radius:var(--r-lg);
    box-shadow:var(--sh-sm);border:1px solid var(--border);
    overflow:hidden;
}
.tt-setting{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 16px;
}
.tt-setting:not(:last-child){border-bottom:1px solid var(--border)}
.tt-setting__left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.tt-setting__icon{
    width:38px;height:38px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:14px;color:var(--d-500);background:var(--d-50);
    flex-shrink:0;
}
.tt-setting__info{display:flex;flex-direction:column;gap:1px}
.tt-setting__title{font-size:14px;font-weight:600;color:var(--text-1)}
.tt-setting__sub{font-size:11.5px;color:var(--text-3)}

/* Premium Toggle */
.tt-toggle{position:relative;cursor:pointer}
.tt-toggle input{position:absolute;opacity:0;width:0;height:0}
.tt-toggle__track{
    display:block;width:46px;height:26px;
    background:var(--s-300);border-radius:var(--r-full);
    padding:2px;transition:.3s cubic-bezier(.16,1,.3,1);
}
.tt-toggle input:checked + .tt-toggle__track{
    background:linear-gradient(135deg, var(--d-500), var(--d-400));
    box-shadow:0 0 10px rgba(21,101,192,.2);
}
.tt-toggle__thumb{
    display:block;width:22px;height:22px;
    background:#fff;border-radius:50%;
    box-shadow:0 1px 3px rgba(0,0,0,.15);
    transition:.3s cubic-bezier(.16,1,.3,1);
}
.tt-toggle input:checked + .tt-toggle__track .tt-toggle__thumb{
    transform:translateX(20px);
}

/* ── Note (keeps same design) ── */
.tt-note{
    display:flex;align-items:flex-start;gap:10px;
    padding:14px 16px;background:var(--d-50);
    border-radius:var(--r-md);font-size:12px;color:var(--text-2);line-height:1.5;
}
.tt-note i{color:var(--accent);font-size:13px;margin-top:2px;flex-shrink:0}

/* ==================== LIVE PAGE ==================== */
.lp-player{
    position:relative;min-height:220px;border-radius:var(--r-lg);overflow:hidden;
    display:flex;align-items:center;justify-content:center;
}

/* ── Embed container: hidden by default ── */
.lp-player__embed{
    display:none;
}

/* ── When LIVE: switch to block, embed takes over ── */
.lp-player.is-live{
    display:block;height:auto;min-height:0;
}
.lp-player.is-live .lp-player__embed{
    display:block;position:relative;width:100%;
    padding-bottom:56.25%;height:0;overflow:hidden;background:#000;
}
.lp-player__embed iframe{
    position:absolute;top:0;left:0;width:100%;height:100%;border:0;
}

/* Hide everything else when live */
.lp-player.is-live .lp-player__bg,
.lp-player.is-live .lp-player__center,
.lp-player.is-live .lp-player__tag,
.lp-player.is-live .lp-player__ring{
    display:none !important;
}
.lp-player__bg{
    position:absolute;inset:0;
    background:linear-gradient(150deg, var(--d-950) 0%, var(--d-900) 40%, var(--d-800) 100%);
}
.lp-player__bg::after{
    content:'';position:absolute;inset:0;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.3' stroke-opacity='0.04'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 15L65 40L40 65L15 40z'/%3E%3C/g%3E%3C/svg%3E");
}
.lp-player__center{position:relative;display:flex;align-items:center;justify-content:center}
.lp-player__logo{
    width:72px;height:72px;border-radius:50%;object-fit:cover;
    border:2px solid rgba(196,144,0,.3);opacity:.75;position:relative;z-index:1;
}
.lp-player__ring{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:100px;height:100px;border-radius:50%;
    border:2px solid rgba(196,144,0,.2);animation:ring-expand 2.4s cubic-bezier(0,0,.2,1) infinite;
}
.lp-player__ring--d2{animation-delay:.8s}
.lp-player__tag{
    position:absolute;top:14px;left:14px;z-index:2;
    display:flex;align-items:center;gap:5px;
    background:var(--err-deep);color:#fff;
    padding:5px 12px;border-radius:var(--r-full);
    font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
    box-shadow:0 2px 10px rgba(220,38,38,.4);
}
.lp-player__play{
    position:absolute;z-index:3;
    width:56px;height:56px;border-radius:50%;
    background:rgba(255,255,255,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    border:2px solid rgba(255,255,255,.2);color:#fff;font-size:18px;
    display:flex;align-items:center;justify-content:center;
    transition:.3s ease;cursor:pointer;
}
.lp-player__play:active{transform:scale(.9);background:rgba(255,255,255,.25)}
.lp-player__play i{margin-left:3px}

.lp-info{display:flex;flex-direction:column;gap:6px}
.lp-info__title{font-size:20px;font-weight:700;color:var(--text-1)}
.lp-info__meta{display:flex;gap:16px;font-size:13px;color:var(--text-2)}
.lp-info__meta span{display:flex;align-items:center;gap:6px}
.lp-info__meta i{color:var(--text-3);font-size:12px}

.lp-actions{display:flex;gap:10px}
.lp-action-btn{
    flex:1;display:flex;align-items:center;justify-content:center;gap:7px;
    padding:12px;border-radius:var(--r-md);
    font-size:13px;font-weight:600;cursor:pointer;
    background:var(--bg-card);color:var(--text-1);
    border:1px solid var(--border);box-shadow:var(--sh-sm);
    transition:.25s ease;
}
.lp-action-btn:active{transform:scale(.96)}
.lp-action-btn--primary{
    background:linear-gradient(135deg, var(--err-deep), #B91C1C);
    color:#fff;border:none;box-shadow:0 4px 14px rgba(220,38,38,.25);
}
.lp-action-btn i{font-size:13px}

.lp-upcoming{display:flex;flex-direction:column;gap:12px}
.lp-upcoming__title{font-size:16px;font-weight:700;color:var(--text-1)}
.lp-upcoming__list{display:flex;flex-direction:column;gap:8px}
.lp-upcoming__item{
    display:flex;gap:14px;padding:14px 16px;
    background:var(--bg-card);border-radius:var(--r-md);
    box-shadow:var(--sh-sm);border:1px solid var(--border);
}
.lp-upcoming__time{
    font-size:11px;font-weight:600;color:var(--accent);
    min-width:80px;padding-top:2px;
}
.lp-upcoming__detail{display:flex;flex-direction:column;gap:2px}
.lp-upcoming__detail span{font-size:14px;font-weight:600;color:var(--text-1)}
.lp-upcoming__detail small{font-size:12px;color:var(--text-3)}

/* ==================== QIBLA PAGE ==================== */
.qb-compass-wrap{
    display:flex;align-items:center;justify-content:center;
    padding:24px 0;
}
.qb-compass{
    position:relative;width:240px;height:240px;
    border-radius:50%;
    background:linear-gradient(145deg, var(--d-850), var(--d-950));
    box-shadow:0 8px 40px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.06);
    border:2px solid rgba(255,255,255,.06);
    display:flex;align-items:center;justify-content:center;
}
.qb-compass__ring{
    position:absolute;inset:12px;border-radius:50%;
    border:1px solid rgba(255,255,255,.08);
}
.qb-compass__dir{
    position:absolute;font-size:13px;font-weight:700;color:rgba(255,255,255,.4);
    text-transform:uppercase;letter-spacing:.04em;
}
.qb-compass__dir--n{top:8px;left:50%;transform:translateX(-50%);color:var(--a-400)}
.qb-compass__dir--s{bottom:8px;left:50%;transform:translateX(-50%)}
.qb-compass__dir--e{right:8px;top:50%;transform:translateY(-50%)}
.qb-compass__dir--w{left:8px;top:50%;transform:translateY(-50%)}
.qb-compass__needle{
    position:absolute;inset:20px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
}
.qb-compass__needle-tip{
    position:absolute;top:16px;left:50%;transform:translateX(-50%);
    width:3px;height:50px;
    background:linear-gradient(180deg, var(--a-400) 0%, transparent 100%);
    border-radius:var(--r-full);
    box-shadow:0 0 10px rgba(196,144,0,.4);
}
.qb-compass__kaaba{
    position:absolute;top:2px;left:50%;transform:translateX(-50%);
    font-size:16px;color:var(--a-400);
    filter:drop-shadow(0 0 6px rgba(196,144,0,.4));
}
.qb-compass__center{
    width:48px;height:48px;border-radius:50%;
    background:linear-gradient(135deg, var(--d-800), var(--d-900));
    border:2px solid rgba(196,144,0,.2);
    display:flex;align-items:center;justify-content:center;
    z-index:2;
}
.qb-compass__center span{font-size:11px;font-weight:700;color:var(--a-300);letter-spacing:.02em}

.qb-info-card{
    background:var(--bg-card);border-radius:var(--r-lg);
    box-shadow:var(--sh-md);border:1px solid var(--border);
    padding:4px 0;overflow:hidden;
}
.qb-info-card__row{
    display:flex;align-items:center;gap:14px;
    padding:14px 18px;
}
.qb-info-card__row:not(:last-child){border-bottom:1px solid var(--border)}
.qb-info-card__row i{
    width:36px;height:36px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:14px;flex-shrink:0;
    color:var(--d-500);background:var(--d-50);
}
.qb-info-card__row div{display:flex;flex-direction:column;gap:1px}
.qb-info-card__row strong{font-size:13px;font-weight:600;color:var(--text-1)}
.qb-info-card__row span{font-size:12px;color:var(--text-2)}

.qb-note{
    display:flex;align-items:flex-start;gap:10px;
    padding:14px 16px;background:var(--d-50);
    border-radius:var(--r-md);font-size:12px;color:var(--text-2);line-height:1.5;
}
.qb-note i{color:var(--accent);font-size:13px;margin-top:2px;flex-shrink:0}

/* ==================== MORE PAGE ==================== */
.more-header{
    position:relative;overflow:hidden;
    padding:48px 20px 32px;text-align:center;
}
.more-header__bg{
    position:absolute;inset:0;z-index:0;
    background:linear-gradient(160deg, var(--d-950) 0%, var(--d-850) 40%, var(--d-700) 100%);
}
.more-header__pattern{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.4' stroke-opacity='0.04'%3E%3Cpath d='M40 0L80 40L40 80L0 40z'/%3E%3Cpath d='M40 10L70 40L40 70L10 40z'/%3E%3Cpath d='M40 20L60 40L40 60L20 40z'/%3E%3C/g%3E%3C/svg%3E");
}
.more-header__content{
    position:relative;z-index:2;color:#fff;
    display:flex;flex-direction:column;align-items:center;gap:4px;
}
.more-header__logo{
    width:64px;height:64px;border-radius:50%;object-fit:cover;
    border:2px solid rgba(196,144,0,.4);
    box-shadow:0 0 20px rgba(196,144,0,.15);
    margin-bottom:8px;
}
.more-header__title{font-size:22px;font-weight:800;letter-spacing:-.01em}
.more-header__location{font-size:12px;opacity:.55;display:flex;align-items:center;gap:4px}
.more-header__location i{font-size:10px}
.more-header__tagline{
    font-size:13px;opacity:.4;margin-top:6px;font-weight:400;letter-spacing:.02em;
}

.more-body{padding:20px 16px;display:flex;flex-direction:column;gap:24px}

.more-section{display:flex;flex-direction:column;gap:10px;animation:section-up .5s cubic-bezier(.16,1,.3,1) both}
.more-section:nth-child(1){animation-delay:.05s}
.more-section:nth-child(2){animation-delay:.1s}
.more-section:nth-child(3){animation-delay:.15s}
.more-section:nth-child(4){animation-delay:.2s}
.more-section:nth-child(5){animation-delay:.25s}
.more-section:nth-child(6){animation-delay:.3s}

.more-section__title{
    display:flex;align-items:center;gap:10px;
    font-size:13px;font-weight:700;color:var(--text-2);
    text-transform:uppercase;letter-spacing:.08em;
    padding-left:2px;
}
.more-section__accent{
    width:4px;height:18px;border-radius:var(--r-full);flex-shrink:0;
}

.more-section__card{
    background:var(--bg-card);border-radius:var(--r-lg);
    box-shadow:var(--sh-sm);border:1px solid var(--border);
    overflow:hidden;
}

.more-item{
    display:flex;align-items:center;gap:14px;
    padding:14px 16px;transition:.2s ease;
    cursor:pointer;position:relative;
}
.more-item:not(:last-child)::after{
    content:'';position:absolute;bottom:0;left:62px;right:16px;
    height:1px;background:var(--border);
}
.more-item:active{background:rgba(0,0,0,.02)}

.more-item__icon{
    width:40px;height:40px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:15px;flex-shrink:0;
    color:hsla(var(--mi-h),var(--mi-s),var(--mi-l),1);
    background:hsla(var(--mi-h),var(--mi-s),var(--mi-l),0.08);
    transition:.25s ease;
}

.more-item__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.more-item__title{font-size:14px;font-weight:600;color:var(--text-1);line-height:1.3}
.more-item__sub{font-size:11.5px;color:var(--text-3);line-height:1.3}
.more-item__arrow{font-size:10px;color:var(--text-3);flex-shrink:0;transition:.2s ease}
.more-item__badge{
    font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
    padding:3px 8px;border-radius:var(--r-full);
    background:rgba(239,68,68,.1);color:var(--err-deep);
    flex-shrink:0;
}

.more-footer{
    display:flex;flex-direction:column;align-items:center;gap:4px;
    padding:24px 0 8px;opacity:.35;
}
.more-footer__logo{width:28px;height:28px;border-radius:50%;object-fit:cover;opacity:.5}
.more-footer span{font-size:12px;font-weight:600;color:var(--text-2)}
.more-footer small{font-size:10px;color:var(--text-3)}

/* ==================== DYNAMIC CONTENT SYSTEM ==================== */

/* ── Skeleton Loading ── */
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.8}}
.skeleton-card{background:var(--s-100) !important;border-radius:12px;animation:pulse 1.5s ease-in-out infinite}

/* ── Content Viewer (slide-up panel for islamic content) ── */
.content-viewer{
    position:fixed;inset:0;z-index:600;
    pointer-events:none;visibility:hidden;
}
.content-viewer.open{pointer-events:auto;visibility:visible}
.content-viewer__overlay{
    position:absolute;inset:0;background:rgba(5,11,20,.6);
    backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
    opacity:0;transition:opacity .35s ease;
}
.content-viewer.open .content-viewer__overlay{opacity:1}
.content-viewer__sheet{
    position:absolute;bottom:0;left:0;right:0;max-height:90vh;
    background:var(--bg);border-radius:var(--r-2xl) var(--r-2xl) 0 0;
    box-shadow:0 -8px 40px rgba(0,0,0,.2);
    display:flex;flex-direction:column;
    transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);
    overflow:hidden;
}
.content-viewer.open .content-viewer__sheet{transform:translateY(0)}
.content-viewer__header{
    padding:12px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.content-viewer__body{
    flex:1;overflow-y:auto;padding:16px 16px 32px;
    display:flex;flex-direction:column;gap:12px;
    -webkit-overflow-scrolling:touch;
}

/* ── Content Cards ── */
.content-card{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--r-md);padding:16px;box-shadow:var(--sh-sm);
    display:flex;flex-direction:column;gap:8px;
}
.content-card--name{flex-direction:row;align-items:center;gap:14px}
.content-card__num{
    width:36px;height:36px;border-radius:50%;
    background:linear-gradient(135deg,var(--d-600),var(--d-800));
    color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:13px;font-weight:700;flex-shrink:0;
}
.content-card__body{display:flex;flex-direction:column;gap:3px;min-width:0}
.content-card__title{font-size:14px;font-weight:650;color:var(--text-1)}
.content-card__arabic{
    font-family:'Amiri',serif;font-size:22px;color:var(--d-600);
    line-height:1.8;text-align:right;
}
.content-card__translit{font-size:12px;color:var(--d-400);font-style:italic}
.content-card__translation{font-size:12.5px;color:var(--text-2);line-height:1.5}
.content-card__ref{
    font-size:10px;font-weight:600;color:var(--a-600);
    background:var(--a-100);padding:2px 8px;border-radius:var(--r-full);
    align-self:flex-start;
}
.content-card__header{display:flex;justify-content:space-between;align-items:center;gap:8px}
.content-card__media{
    display:inline-flex;align-items:center;gap:6px;
    font-size:12px;font-weight:600;color:var(--d-500);
    padding:6px 12px;background:var(--d-50);border-radius:var(--r-full);
    align-self:flex-start;
}

/* ── Quiz ── */
.quiz-options{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.quiz-option{
    padding:10px 14px;text-align:left;font-size:13px;font-weight:500;
    background:var(--s-50);border:1px solid var(--border);border-radius:var(--r-sm);
    cursor:pointer;transition:.2s ease;color:var(--text-1);
}
.quiz-option:active{transform:scale(.98)}
.quiz-option:disabled{cursor:default;opacity:.8}
.quiz-correct{background:rgba(22,163,74,.1) !important;border-color:var(--ok) !important;color:var(--ok) !important}
.quiz-wrong{background:rgba(239,68,68,.1) !important;border-color:var(--err) !important;color:var(--err) !important}
.quiz-explanation{
    font-size:12px;color:var(--text-2);margin-top:6px;padding:10px 12px;
    background:var(--d-50);border-radius:var(--r-sm);line-height:1.5;
}

/* ── Event Cards ── */
.event-card{
    display:flex;align-items:flex-start;gap:14px;
    padding:14px;background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--r-md);box-shadow:var(--sh-sm);
}
.event-card__date{
    display:flex;flex-direction:column;align-items:center;
    padding:8px 10px;background:linear-gradient(135deg,var(--d-600),var(--d-800));
    border-radius:var(--r-sm);color:#fff;min-width:48px;flex-shrink:0;
}
.event-card__day{font-size:20px;font-weight:800;line-height:1}
.event-card__month{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.8}
.event-card__body{display:flex;flex-direction:column;gap:3px;min-width:0}
.event-card__title{font-size:14px;font-weight:650;color:var(--text-1)}
.event-card__desc{font-size:12px;color:var(--text-3);line-height:1.4}
.event-card__type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ── Gallery Grid ── */
.gallery-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:4px;border-radius:var(--r-md);overflow:hidden;
}
.gallery-item{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.3s ease}
.gallery-item:active img{transform:scale(1.05)}
.gallery-item__title{
    position:absolute;bottom:0;left:0;right:0;padding:6px 8px;
    font-size:10px;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.6));
}

/* ==================== QIBLA ENHANCEMENTS ==================== */

/* ── Status indicator ── */
.qb-status{
    display:flex;align-items:center;gap:10px;
    padding:10px 16px;margin-bottom:16px;
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--r-md);box-shadow:var(--sh-sm);
}
.qb-status__icon{
    width:32px;height:32px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:14px;color:var(--qbs-color, var(--d-500));
    background:hsla(210,80%,42%,.08);flex-shrink:0;
}
.qb-status__text{font-size:12px;font-weight:500;color:var(--text-2)}

/* ── Compass live transitions ── */
.qb-compass__ring{transition:transform .15s linear}
.qb-compass__needle{transition:transform .3s cubic-bezier(.16,1,.3,1)}

/* ── Calibrate button ── */
.qb-calibrate-btn{
    display:flex;align-items:center;justify-content:center;gap:8px;
    width:100%;padding:12px 18px;margin-top:12px;
    background:linear-gradient(135deg,var(--d-600),var(--d-800));
    border:none;border-radius:var(--r-md);
    color:#fff;font-size:13px;font-weight:600;
    cursor:pointer;transition:.3s cubic-bezier(.16,1,.3,1);
    box-shadow:var(--sh-md);
}
.qb-calibrate-btn:active{transform:scale(.97)}
.qb-calibrate-btn i{font-size:14px}

/* ==================== 99 NAMES OF ALLAH ==================== */

/* ==================== 99 NAMES OF ALLAH — PREMIUM MODULE ==================== */

/* ── Full-screen viewer (slide-up panel) ── */
.na-viewer{
    position:fixed;inset:0;z-index:9999;
    pointer-events:none;opacity:0;transition:opacity .3s ease;
}
.na-viewer.open{pointer-events:auto;opacity:1}
.na-viewer__overlay{
    position:absolute;inset:0;
    background:rgba(0,0,0,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.na-viewer__sheet{
    position:absolute;bottom:0;left:0;right:0;
    max-height:95vh;background:var(--bg-main);
    border-radius:20px 20px 0 0;
    display:flex;flex-direction:column;
    transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);
    box-shadow:0 -8px 40px rgba(0,0,0,.15);
}
.na-viewer.open .na-viewer__sheet{transform:translateY(0)}
.na-viewer__header{
    padding:12px 18px 0;flex-shrink:0;
    background:var(--bg-card);border-radius:20px 20px 0 0;
    border-bottom:1px solid var(--border);
}
.na-viewer__title-row{
    display:flex;align-items:flex-start;justify-content:space-between;
    margin-top:8px;
}
.na-viewer__title{font-size:20px;font-weight:800;color:var(--text-1);margin:0}
.na-viewer__subtitle{
    font-family:'Amiri',serif;font-size:16px;color:var(--d-500);
    margin:2px 0 12px;direction:rtl;
}
.na-viewer__close{
    width:32px;height:32px;border-radius:50%;border:none;
    background:var(--s-100);color:var(--text-2);cursor:pointer;
    display:flex;align-items:center;justify-content:center;font-size:14px;
    flex-shrink:0;
}
.na-viewer__body{
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding:14px 14px 100px;flex:1;
}

/* ── Search bar ── */
.na-search{
    position:relative;display:flex;align-items:center;margin-bottom:10px;
}
.na-search__icon{
    position:absolute;left:14px;font-size:13px;color:var(--text-3);
    pointer-events:none;z-index:1;
}
.na-search__input{
    width:100%;padding:11px 38px 11px 38px;
    font-size:13px;font-weight:500;color:var(--text-1);
    background:var(--s-50);border:1px solid var(--border);
    border-radius:var(--r-full);outline:none;
    font-family:inherit;transition:.2s ease;
}
.na-search__input:focus{
    border-color:var(--d-300);
    box-shadow:0 0 0 3px rgba(21,101,192,.08);
    background:#fff;
}
.na-search__input::placeholder{color:var(--text-3);font-weight:400}
.na-search__clear{
    position:absolute;right:10px;
    width:28px;height:28px;border:none;border-radius:50%;
    background:transparent;color:var(--text-3);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;font-size:14px;
}

/* ── Filter bar (All / Favorites) ── */
.na-filter-bar{
    display:flex;gap:8px;padding-bottom:12px;
}
.na-filter-btn{
    padding:6px 14px;border-radius:var(--r-full);
    font-size:12px;font-weight:600;border:1px solid var(--border);
    background:var(--bg-card);color:var(--text-2);cursor:pointer;
    display:flex;align-items:center;gap:5px;
    transition:.2s ease;font-family:inherit;
}
.na-filter-btn.is-active{
    background:var(--d-600);color:#fff;border-color:var(--d-600);
}
.na-filter-btn .fa-heart{font-size:10px;color:var(--a-500)}
.na-filter-btn.is-active .fa-heart{color:rgba(255,255,255,.8)}
.na-filter-count{
    font-size:10px;font-weight:700;opacity:.7;
}

/* ── Global Audio Player (99 Names full-track recitation) ── */
.na-player{
    margin:10px 0;padding:14px 16px;
    background:linear-gradient(135deg,#0f1f38 0%,#162d50 100%);
    border-radius:14px;
    display:flex;flex-direction:column;gap:10px;
    box-shadow:0 4px 20px rgba(0,0,0,.15);
    transition:box-shadow .3s ease;
}
.na-player.is-playing{
    box-shadow:0 4px 24px rgba(21,101,192,.25);
}
.na-player.is-ended{
    background:linear-gradient(135deg,#0d2818 0%,#1a4028 100%);
}
.na-player__info{
    display:flex;align-items:center;gap:12px;
}
.na-player__icon{
    font-size:22px;color:rgba(255,255,255,.7);
    width:40px;height:40px;border-radius:10px;
    background:rgba(255,255,255,.08);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.na-player.is-playing .na-player__icon{
    animation:na-pulse 2s ease-in-out infinite;
}
@keyframes na-pulse{
    0%,100%{opacity:.7;transform:scale(1)}
    50%{opacity:1;transform:scale(1.05)}
}
.na-player__title{
    font-size:13px;font-weight:700;color:#fff;
    line-height:1.3;
}
.na-player__sub{
    font-size:11px;color:rgba(255,255,255,.55);
    line-height:1.3;margin-top:1px;
}
.na-player__controls{
    display:flex;align-items:center;gap:8px;
    margin-left:auto;flex-shrink:0;
}
.na-player__btn{
    width:38px;height:38px;border-radius:50%;border:none;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;font-size:14px;
    transition:transform .15s ease, background .2s ease;
    font-family:inherit;
}
.na-player__btn:active{transform:scale(.9)}
.na-player__btn:disabled{opacity:.3;cursor:default}
.na-player__btn--play{
    background:rgba(255,255,255,.15);color:#fff;
}
.na-player__btn--play:hover{background:rgba(255,255,255,.22)}
.na-player.is-playing .na-player__btn--play{
    background:rgba(255,255,255,.2);
}
.na-player__btn--stop{
    background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);
}
.na-player__btn--stop:hover:not(:disabled){background:rgba(255,255,255,.14)}

.na-player__progress-wrap{
    display:flex;flex-direction:column;gap:4px;
}
.na-player__bar{
    width:100%;height:4px;border-radius:2px;
    background:rgba(255,255,255,.12);
    cursor:pointer;position:relative;
    overflow:hidden;
}
.na-player__bar-fill{
    height:100%;border-radius:2px;
    background:linear-gradient(90deg,#42a5f5,#66bb6a);
    transition:width .25s linear;
}
.na-player.is-ended .na-player__bar-fill{
    background:linear-gradient(90deg,#66bb6a,#81c784);
}
.na-player__times{
    display:flex;justify-content:space-between;
    font-size:10px;font-weight:600;
    color:rgba(255,255,255,.4);
    font-variant-numeric:tabular-nums;
}

/* ── Names Grid ── */
.na-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}

/* ── Name Card ── */
.na-card{
    position:relative;
    display:flex;flex-direction:column;align-items:center;
    gap:5px;padding:20px 12px 16px;text-align:center;
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:14px;
    box-shadow:0 1px 4px rgba(0,0,0,.04);
    cursor:pointer;
    transition:transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s ease;
    overflow:hidden;
}
.na-card::before{
    content:'';position:absolute;inset:0;
    background:radial-gradient(ellipse at 50% 0%, rgba(21,101,192,.04) 0%, transparent 65%);
    pointer-events:none;
}
.na-card:active{transform:scale(.97)}

/* Number badge */
.na-card__num{
    position:absolute;top:8px;left:8px;
    width:22px;height:22px;border-radius:50%;
    background:var(--d-50);color:var(--d-600);
    font-size:9px;font-weight:800;
    display:flex;align-items:center;justify-content:center;
}

/* Favorite button */
.na-card__fav{
    position:absolute;top:6px;right:6px;
    width:28px;height:28px;border:none;border-radius:50%;
    background:transparent;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    font-size:13px;transition:.2s ease;z-index:2;
    color:var(--s-300);
}
.na-card__fav.is-fav{color:#e53935}
.na-card__fav:active{transform:scale(1.3)}

/* Arabic text */
.na-card__arabic{
    font-family:'Amiri',serif;font-size:30px;color:var(--d-700);
    line-height:1.6;margin-top:2px;
    /* Ensure Arabic doesn't break layout */
    word-break:keep-all;white-space:nowrap;
}

/* English name */
.na-card__english{
    font-size:13px;font-weight:700;color:var(--text-1);line-height:1.2;
}

/* Transliteration */
.na-card__translit{
    font-size:10px;color:var(--d-400);font-style:italic;
}

/* Meaning */
.na-card__meaning{
    font-size:11px;color:var(--text-2);line-height:1.3;
    margin-top:2px;
}

/* ── Empty state ── */
.na-empty{
    display:flex;flex-direction:column;align-items:center;
    justify-content:center;gap:10px;
    padding:60px 20px;color:var(--text-3);
}
.na-empty i{font-size:32px;opacity:.3}
.na-empty p{font-size:13px;font-weight:500}

/* ── Skeleton loading ── */
.na-card--skeleton{
    min-height:140px;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:10px;padding:20px;
}
.na-skel{border-radius:6px;background:var(--s-100);animation:skel-pulse 1.2s ease infinite}
.na-skel--circle{width:44px;height:44px;border-radius:50%}
.na-skel--lg{width:70%;height:14px}
.na-skel--md{width:50%;height:10px}
.na-skel--sm{width:60%;height:8px}
@keyframes skel-pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ── Detail Modal ── */
.na-modal{
    position:fixed;inset:0;z-index:10001;
    pointer-events:none;opacity:0;transition:opacity .3s ease;
}
.na-modal.open{pointer-events:auto;opacity:1}
.na-modal__overlay{
    position:absolute;inset:0;
    background:rgba(0,0,0,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.na-modal__sheet{
    position:absolute;bottom:0;left:0;right:0;
    background:var(--bg-card);
    border-radius:24px 24px 0 0;
    padding:16px 24px 40px;
    transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);
    box-shadow:0 -10px 50px rgba(0,0,0,.2);
    text-align:center;
}
.na-modal.open .na-modal__sheet{transform:translateY(0)}
.na-modal__handle{
    width:36px;height:4px;border-radius:2px;
    background:var(--s-200);margin:0 auto 16px;
}
.na-modal__close{
    position:absolute;top:16px;right:16px;
    width:32px;height:32px;border-radius:50%;border:none;
    background:var(--s-100);color:var(--text-2);cursor:pointer;
    display:flex;align-items:center;justify-content:center;font-size:13px;
}
.na-modal__num{
    display:inline-flex;align-items:center;justify-content:center;
    width:36px;height:36px;border-radius:50%;
    background:var(--d-50);color:var(--d-600);
    font-size:13px;font-weight:800;margin-bottom:12px;
}
.na-modal__arabic{
    font-family:'Amiri',serif;font-size:48px;color:var(--d-700);
    line-height:1.6;margin-bottom:8px;
}
.na-modal__english{
    font-size:22px;font-weight:800;color:var(--text-1);margin-bottom:2px;
}
.na-modal__translit{
    font-size:14px;color:var(--d-400);font-style:italic;margin-bottom:16px;
}
.na-modal__divider{
    width:40px;height:3px;border-radius:2px;
    background:linear-gradient(90deg,var(--d-300),var(--d-500));
    margin:0 auto 16px;
}
.na-modal__label{
    font-size:10px;font-weight:700;text-transform:uppercase;
    letter-spacing:1px;color:var(--text-3);margin-bottom:4px;
}
.na-modal__meaning{
    font-size:16px;font-weight:600;color:var(--text-1);
    line-height:1.5;margin-bottom:16px;
}
.na-modal__desc{
    font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:16px;
}
.na-modal__fav-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:12px 28px;border-radius:var(--r-full);
    border:1px solid var(--border);background:var(--bg-card);
    color:var(--text-2);font-size:13px;font-weight:600;
    cursor:pointer;font-family:inherit;transition:.2s ease;
    margin:0 4px 8px;
}
.na-modal__fav-btn.is-fav{color:#e53935;border-color:#ffcdd2;background:#ffebee}
.na-modal__fav-btn:active{transform:scale(.96)}

/* (play button removed — audio is now global only) */
.na-modal__fav-btn .fa-heart{color:var(--s-300);transition:.2s}
.na-modal__fav-btn.is-fav{
    background:linear-gradient(135deg,#ffebee,#fce4ec);
    border-color:#e5737320;color:#c62828;
}
.na-modal__fav-btn.is-fav .fa-heart{color:#e53935}

/* ── Responsive: single column on very small screens ── */
@media(max-width:359px){
    .na-grid{grid-template-columns:1fr}
    .na-card__arabic{font-size:26px}
}
@media(min-width:480px){
    .na-grid{grid-template-columns:repeat(3,1fr)}
    .na-modal__sheet{max-width:420px;left:50%;transform:translateX(-50%) translateY(100%)}
    .na-modal.open .na-modal__sheet{transform:translateX(-50%) translateY(0)}
}
@media(min-width:768px){
    .na-grid{grid-template-columns:repeat(4,1fr)}
    .qa-cat__grid--3{grid-template-columns:repeat(3,1fr)}
    .qa-cat__grid--4{grid-template-columns:repeat(4,1fr)}
}

/* ==================== RESPONSIVE (new pages) ==================== */
@media(min-width:480px){
    .qb-compass{width:280px;height:280px}
    .lp-player{height:260px}
}
@media(min-width:640px){
    .pg-body,.more-body{max-width:600px;margin:0 auto;width:100%;padding:20px}
    .pg-header__content,.more-header__content{max-width:600px;margin:0 auto;width:100%}
    .tt-main{max-width:600px;margin:0 auto;width:100%;padding:0 20px}
    .tt-hero__content{max-width:600px;margin:0 auto;width:100%}
    .tt-card__icon{width:48px;height:48px;font-size:19px}
    .tt-next__name{font-size:52px}
    .tt-next__counter-val{font-size:26px}
    .more-item__icon{width:44px;height:44px;font-size:17px}
    .qb-compass{width:300px;height:300px}
}
@media(min-width:1024px){
    .pg-body,.more-body{max-width:720px;padding:24px 28px}
    .pg-header__content,.more-header__content{max-width:720px}
}

/* ==================== HOVER (new pages) ==================== */
@media(hover:hover){
    .tt-card:not(.is-passed):hover{border-color:var(--d-200);box-shadow:var(--sh-md);transform:translateX(3px)}
    .more-item:hover{background:rgba(0,0,0,.015)}
    .more-item:hover .more-item__icon{transform:scale(1.06)}
    .more-item:hover .more-item__arrow{transform:translateX(3px);color:var(--accent)}
    .lp-action-btn:hover{box-shadow:var(--sh-md)}
    .lp-action-btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(220,38,38,.35)}
    .lp-player__play:hover{background:rgba(255,255,255,.22);transform:scale(1.08)}
    .qa-hero:hover{border-color:var(--d-200);box-shadow:var(--sh-md)}
    .qa-hero:hover .qa-hero__arrow{transform:translateX(3px);color:var(--accent)}
    .qa-item:hover{background:var(--s-50)}
    .qa-item:hover .qa-item__icon{transform:scale(1.08)}
    .qa-sys:hover{background:var(--s-100);border-color:var(--d-200)}
    .ep-item:hover{border-color:var(--d-200);box-shadow:var(--sh-sm)}
    .ep-item:hover .ep-item__icon{transform:scale(1.08)}
}

/* ==================== HERO — INSTANT RENDER + PROGRESSIVE LOAD ==================== */
.hero__slide{
    /* Rich gradient shows INSTANTLY, before any image loads */
    background-color:#0a1628;
    background-image:linear-gradient(135deg, #0a1628 0%, #0f2140 40%, #132a4a 70%, #0a1628 100%);
    background-size:cover;background-position:center;
    /* Image fades in over the gradient once loaded */
    transition:opacity .6s ease;
}
.hero__slide--loaded{
    /* Smooth reveal when image is ready */
    animation:heroFadeIn .8s ease forwards;
}
@keyframes heroFadeIn{
    from{opacity:.7}
    to{opacity:1}
}

/* ==================== LOADING SKELETON (first-load safety) ==================== */
.app-loading .prayer-card__name,
.app-loading .prayer-card__cd-val{
    color:transparent;
    background:var(--s-100);
    border-radius:4px;
    animation:skel-pulse 1.2s ease infinite;
}

/* ==================== ANNOUNCEMENTS ==================== */
.announcements {
    margin: 24px 0;
}
.announce-track {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding: 0 20px 16px 20px;
    margin: 0 -20px; /* Bleed out of padding to screen edge */
    scrollbar-width: none; /* Hide scrollbar Firefox */
    -webkit-overflow-scrolling: touch;
}
.announce-track::-webkit-scrollbar {
    display: none; /* Hide scrollbar Chrome/Safari */
}
.ann-card {
    flex: 0 0 auto; /* Stop Safari flex-basis bug */
    width: calc(100vw - 60px); 
    max-width: 320px;
    min-height: 80px;
    height: auto;
    scroll-snap-align: center;
    background: var(--bg-card);
    border-radius: var(--r-md);
    padding: 16px;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    box-shadow: var(--sh-sm);
    border: 1px solid var(--border);
    position: relative;
    overflow: hidden;
}
.ann-card--urgent {
    border-left: 4px solid var(--err);
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.15);
}
.ann-card--info {
    border-left: 4px solid var(--accent);
}
.ann-card--donate {
    border-left: 4px solid var(--ok);
}
.ann-card__icon {
    font-size: 24px;
    color: var(--s-400);
}
.ann-card--urgent .ann-card__icon { color: var(--err); }
.ann-card--info .ann-card__icon { color: var(--accent); }
.ann-card--donate .ann-card__icon { color: var(--ok); }

.ann-card__body {
    flex: 1;
}
.ann-card__text {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-1);
    margin-bottom: 4px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-clamp: 2;
}
.ann-card__date {
    font-size: 0.8rem;
    color: var(--s-500);
    font-weight: 400;
}
.ann-card__arrow {
    color: var(--s-300);
    font-size: 14px;
}
.announce-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: -8px;
}
.a-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--s-300);
    transition: all 0.3s ease;
}
.a-dot.active {
    width: 16px;
    border-radius: 4px;
    background: var(--accent);
}

/* ==================== UPCOMING EVENTS ==================== */
.events-section {
    margin: 32px 20px;
}
.events-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
}
.ev-card {
    display: flex;
    gap: 16px;
    background: var(--bg-card);
    border-radius: var(--r-md);
    padding: 16px;
    box-shadow: var(--sh-xs);
    border: 1px solid var(--border);
}
.ev-card__date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 64px;
    background: var(--bg);
    border-radius: var(--r-sm);
    color: var(--d-700);
    text-align: center;
}
.ev-card__day {
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1;
}
.ev-card__month {
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.5px;
    margin-top: 2px;
}
.ev-card__body {
    flex: 1;
}
.ev-card__body h4 {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text-1);
    margin-bottom: 4px;
}
.ev-card__body p {
    font-size: 0.9rem;
    color: var(--text-2);
    margin-bottom: 8px;
    line-height: 1.4;
}
.ev-card__time {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    color: var(--accent);
    font-weight: 500;
    background: var(--accent-soft);
    padding: 4px 8px;
    border-radius: 4px;
}

/* ==================== CONTENT VIEWER (Slide-up Panel) ==================== */
.content-viewer {
    position: fixed; inset: 0; z-index: 9000;
    pointer-events: none; opacity: 0;
    transition: opacity .25s ease;
}
.content-viewer.open { opacity: 1; pointer-events: auto; }

.content-viewer__overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(4px);
}
.content-viewer__sheet {
    position: absolute; bottom: 0; left: 0; right: 0;
    height: 94vh;
    background: var(--bg);
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    display: flex; flex-direction: column;
    transform: translateY(100%);
    transition: transform .35s cubic-bezier(.32,.72,.0,1);
    overflow: hidden;
}
.content-viewer.open .content-viewer__sheet {
    transform: translateY(0);
}
.content-viewer__header {
    padding: 12px 20px 0;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.content-viewer__body {
    flex: 1; overflow-y: auto;
    padding: 16px 20px;
    -webkit-overflow-scrolling: touch;
}

/* ── Search bar in content viewer ── */
.cv-search {
    display: flex; align-items: center; gap: 8px;
    background: var(--bg);
    border-radius: var(--r-sm);
    padding: 10px 14px;
    margin: 12px 0;
}
.cv-search__icon { color: var(--s-400); font-size: 14px; flex-shrink: 0; }
.cv-search__input {
    flex: 1; border: none; background: none;
    font-size: 15px; color: var(--text-1);
    font-family: inherit; outline: none;
}
.cv-search__input::placeholder { color: var(--s-400); }
.cv-search__clear {
    border: none; background: none; cursor: pointer;
    color: var(--s-400); font-size: 16px;
    display: flex; align-items: center; padding: 0;
}
.explore-panel__back {
    border: none; background: none; cursor: pointer;
    font-size: 18px; color: var(--text-1); padding: 8px;
    display: flex; align-items: center;
}

/* ==================== CONTENT CARDS ==================== */
.cv-list { display: flex; flex-direction: column; gap: 12px; }

.cv-card {
    background: var(--bg-card);
    border-radius: var(--r-md);
    padding: 16px;
    box-shadow: var(--sh-xs);
    border: 1px solid var(--border);
    display: flex; align-items: flex-start; gap: 14px;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.cv-card:active { transform: scale(0.98); }

.cv-card--dua {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
}
.cv-card--dua .cv-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 12px;
    width: 100%;
}

/* Card number (for Names, Burdah chapters) */
.cv-card__num, .cv-card__chapter {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--d-600), var(--d-800));
    color: #fff; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; flex-shrink: 0;
}

.cv-card__main { flex: 1; min-width: 0; }

.cv-card__arabic {
    font-family: 'Amiri', serif;
    font-size: 1.35rem; line-height: 2;
    color: var(--d-600);
    margin-bottom: 4px;
}
.cv-card__arabic--lg {
    font-size: 1.6rem;
    line-height: 2.2;
    padding: 12px 0;
    text-align: center;
    background: var(--bg);
    border-radius: var(--r-sm);
    margin: 8px 0;
}
.cv-card__title {
    font-size: 1rem; font-weight: 600;
    color: var(--text-1); margin-bottom: 2px;
}
.cv-card__translit {
    font-size: 0.85rem; font-style: italic;
    color: var(--a-600); margin-bottom: 2px;
}
.cv-card__meaning {
    font-size: 0.9rem; color: var(--text-2);
    line-height: 1.4;
}
.cv-card__ref {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 0.78rem; color: var(--d-500);
    margin-top: 6px; font-weight: 500;
}
.cv-card__badge {
    display: inline-block;
    font-size: 0.7rem; text-transform: uppercase;
    font-weight: 600; letter-spacing: 0.5px;
    padding: 2px 8px; border-radius: 4px;
    background: var(--accent-soft); color: var(--accent);
    margin-top: 6px;
}
.cv-card__badge--video { background: rgba(239,68,68,0.1); color: var(--err); }
.cv-card__badge--audio { background: rgba(196,144,0,0.1); color: var(--a-600); }
.cv-card__badge--tts { background: rgba(139,92,246,0.1); color: #8b5cf6; }
.cv-card__arrow { color: var(--s-300); font-size: 14px; align-self: center; }

/* ── Favorite Button ── */
.cv-fav-btn {
    border: none; background: none; cursor: pointer;
    font-size: 18px; color: var(--s-300);
    padding: 4px; transition: color 0.2s, transform 0.2s;
    flex-shrink: 0;
}
.cv-fav-btn.is-fav { color: var(--err); }
.cv-fav-btn:active { transform: scale(1.3); }

/* ── Copy Button (Duas) ── */
.cv-copy-btn {
    border: none; background: none; cursor: pointer;
    font-size: 16px; color: var(--s-400);
    padding: 4px;
}

/* ── Card Header (Duas-style with actions) ── */
.cv-card__header {
    display: flex; justify-content: space-between;
    align-items: flex-start; margin-bottom: 4px;
}
.cv-card__actions { display: flex; gap: 8px; flex-shrink: 0; }

.cv-play-btn {
    border: none; background: none; cursor: pointer;
    width: 32px; height: 32px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: rgba(196,144,0,0.1); color: var(--a-600);
    font-size: 14px; transition: transform 0.2s, background 0.2s;
    flex-shrink: 0;
}
.cv-play-btn:active { transform: scale(0.9); background: rgba(196,144,0,0.2); }

.cv-play-btn--tts {
    background: rgba(139,92,246,0.1); color: #8b5cf6;
}
.cv-play-btn--tts:active { background: rgba(139,92,246,0.2); }

/* ── Media icon (Salam/Naat) ── */
.cv-card__media-icon {
    width: 44px; height: 44px;
    border-radius: var(--r-sm);
    background: linear-gradient(135deg, var(--a-500), var(--a-700));
    color: #fff; font-size: 18px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

/* ── Term badge (Islamic Terms) ── */
.cv-card__term-badge {
    width: 44px; height: 44px;
    border-radius: var(--r-sm);
    background: var(--bg);
    font-family: 'Amiri', serif;
    color: var(--d-600); font-size: 18px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; font-weight: 700;
}

/* ── Advice icon (Social Behaviour) ── */
.cv-card__advice-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(196,144,0,0.12);
    color: var(--a-600); font-size: 16px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

/* ── Learning type icon ── */
.cv-card__learn-type {
    width: 40px; height: 40px;
    border-radius: var(--r-sm);
    background: rgba(22,163,74,0.1);
    color: var(--ok); font-size: 18px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

/* ── Parent card ── */
.cv-card--parent { border-left: 3px solid hsl(152,68%,35%); }
.cv-card__parent-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(22,163,74,0.1);
    color: hsl(152,68%,35%); font-size: 16px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

/* ── Kids card (colorful) ── */
.cv-card--kids {
    border-left: 4px solid var(--kids-color, #45B7D1);
    background: linear-gradient(135deg, var(--bg-card) 80%, color-mix(in srgb, var(--kids-color, #45B7D1) 8%, transparent));
}
.cv-card__kids-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--kids-color, #45B7D1);
    color: #fff; font-size: 16px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

/* ── Quiz list card ── */
.cv-card__quiz-num {
    width: 36px; height: 36px;
    border-radius: var(--r-sm);
    background: linear-gradient(135deg, hsl(152,68%,35%), hsl(152,50%,28%));
    color: #fff; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; flex-shrink: 0;
}

/* ── Empty State ── */
.cv-empty {
    text-align: center; padding: 48px 24px;
    color: var(--text-3);
}
.cv-empty i { font-size: 40px; margin-bottom: 12px; display: block; color: var(--s-300); }
.cv-empty p { font-size: 14px; }


/* ==================== CONTENT DETAIL OVERLAY ==================== */
.cv-detail {
    position: fixed; inset: 0; z-index: 9500;
    pointer-events: none; opacity: 0;
    transition: opacity .25s ease;
}
.cv-detail.open { opacity: 1; pointer-events: auto; }

.cv-detail__overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(6px);
}
.cv-detail__sheet {
    position: absolute; bottom: 0; left: 0; right: 0;
    height: 96vh;
    background: var(--bg);
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    display: flex; flex-direction: column;
    transform: translateY(100%);
    transition: transform .35s cubic-bezier(.32,.72,.0,1);
    overflow: hidden;
}
.cv-detail.open .cv-detail__sheet {
    transform: translateY(0);
}
.cv-detail__sheet--kids {
    background: linear-gradient(180deg, #FFF8E1 0%, var(--bg) 30%);
}

.cv-detail__header {
    padding: 12px 20px 0;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.cv-detail__title-row {
    display: flex; align-items: center; gap: 12px;
    padding-bottom: 12px;
}
.cv-detail__back {
    border: none; background: none; cursor: pointer;
    font-size: 18px; color: var(--text-1); padding: 8px;
}
.cv-detail__cat {
    flex: 1; font-size: 1rem; font-weight: 600;
    color: var(--text-1);
}
.cv-detail__header-actions { display: flex; gap: 8px; }
.cv-detail__share-btn, .cv-detail__fav-btn {
    border: none; background: none; cursor: pointer;
    width: 36px; height: 36px;
    border-radius: 50%; display: flex;
    align-items: center; justify-content: center;
    font-size: 16px; color: var(--s-500);
    background: var(--bg);
}
.cv-detail__fav-btn.is-fav { color: var(--err); }

.cv-detail__body {
    flex: 1; overflow-y: auto;
    padding: 24px 20px;
    -webkit-overflow-scrolling: touch;
}
.cv-detail__arabic {
    font-family: 'Amiri', serif;
    font-size: 2rem; line-height: 2.2;
    color: var(--d-600);
    text-align: center;
    padding: 20px; margin-bottom: 16px;
    background: var(--bg-card);
    border-radius: var(--r-md);
    border: 1px solid var(--border);
}
.cv-detail__title {
    font-size: 1.4rem; font-weight: 700;
    color: var(--text-1); margin-bottom: 8px;
}
.cv-detail__translit {
    font-size: 1rem; font-style: italic;
    color: var(--a-600); margin-bottom: 16px;
}
.cv-detail__section {
    margin-top: 16px;
}
.cv-detail__label {
    font-size: 0.78rem; text-transform: uppercase;
    font-weight: 700; letter-spacing: 1px;
    color: var(--s-500); margin-bottom: 8px;
}
.cv-detail__text {
    font-size: 1rem; line-height: 1.7;
    color: var(--text-2);
    white-space: pre-line;
}
.cv-detail__ref {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.85rem; color: var(--d-500);
    background: var(--accent-soft);
    padding: 6px 12px; border-radius: var(--r-sm);
    margin-top: 16px;
}
.cv-detail__media {
    margin-top: 20px;
}
.cv-detail__audio {
    width: 100%; border-radius: var(--r-sm);
}
.cv-detail__media--video iframe {
    width: 100%; aspect-ratio: 16/9;
    border-radius: var(--r-sm);
}
.cv-detail__copy-btn {
    display: flex; align-items: center; gap: 8px;
    margin-top: 16px; padding: 12px 20px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    font-size: 0.9rem; color: var(--text-2);
    cursor: pointer; width: 100%;
    justify-content: center;
    transition: background 0.2s;
}
.cv-detail__copy-btn:active { background: var(--bg); }


/* ==================== QUIZ PLAYER ==================== */
.quiz-player { padding: 8px 0; }

.quiz-progress {
    height: 6px; background: var(--s-100);
    border-radius: 3px; margin-bottom: 8px;
    overflow: hidden;
}
.quiz-progress__bar {
    height: 100%;
    background: linear-gradient(90deg, var(--d-500), var(--d-300));
    border-radius: 3px;
    transition: width 0.5s ease;
}
.quiz-progress__text {
    font-size: 0.8rem; color: var(--s-500);
    text-align: center; margin-bottom: 20px;
    font-weight: 500;
}

.quiz-question {
    text-align: center; margin-bottom: 24px;
}
.quiz-question__text {
    font-size: 1.2rem; font-weight: 600;
    color: var(--text-1); line-height: 1.5;
}
.quiz-question__arabic {
    font-family: 'Amiri', serif;
    font-size: 1.5rem; color: var(--d-600);
    margin-top: 12px; line-height: 1.8;
}

.quiz-options { display: flex; flex-direction: column; gap: 10px; }

.quiz-option {
    width: 100%; text-align: left;
    padding: 14px 16px;
    background: var(--bg-card);
    border: 2px solid var(--border);
    border-radius: var(--r-sm);
    font-size: 1rem; color: var(--text-1);
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: inherit;
}
.quiz-option:hover { border-color: var(--d-300); }
.quiz-option:active { transform: scale(0.98); }
.quiz-option--disabled { pointer-events: none; }
.quiz-option--correct {
    border-color: var(--ok) !important;
    background: rgba(22,163,74,0.08) !important;
    color: var(--ok) !important;
}
.quiz-option--wrong {
    border-color: var(--err) !important;
    background: rgba(239,68,68,0.08) !important;
    color: var(--err) !important;
}

.quiz-explanation {
    margin-top: 12px; padding: 12px 16px;
    background: rgba(21,101,192,0.06);
    border-left: 3px solid var(--d-500);
    border-radius: 0 var(--r-sm) var(--r-sm) 0;
    font-size: 0.9rem; color: var(--text-2);
    animation: fadeIn 0.3s ease;
}
.quiz-explanation i { color: var(--d-500); margin-right: 6px; }

/* ── Quiz Start Screen ── */
.quiz-start {
    text-align: center; padding: 40px 20px;
}
.quiz-start__icon {
    width: 80px; height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, hsl(152,68%,35%), hsl(152,50%,28%));
    color: #fff; font-size: 32px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
}
.quiz-start__title { font-size: 1.5rem; font-weight: 700; color: var(--text-1); margin-bottom: 8px; }
.quiz-start__desc { font-size: 0.95rem; color: var(--text-2); line-height: 1.5; max-width: 320px; margin: 0 auto 24px; }
.quiz-start__btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 14px 32px;
    background: linear-gradient(135deg, hsl(152,68%,35%), hsl(152,50%,28%));
    color: #fff; border: none; border-radius: var(--r-full);
    font-size: 1.05rem; font-weight: 600;
    cursor: pointer; font-family: inherit;
    box-shadow: 0 4px 16px rgba(22,163,74,0.25);
    transition: transform 0.15s, box-shadow 0.15s;
}
.quiz-start__btn:active { transform: scale(0.96); }
.quiz-start__history {
    margin-top: 20px; padding: 12px 16px;
    background: var(--bg-card);
    border-radius: var(--r-sm);
    border: 1px solid var(--border);
    display: inline-block;
}
.quiz-start__history h4 { font-size: 0.8rem; color: var(--s-500); text-transform: uppercase; margin-bottom: 6px; }
.quiz-start__last { display: flex; gap: 16px; justify-content: center; }
.quiz-start__last-score { font-size: 1.3rem; font-weight: 700; color: var(--text-1); }
.quiz-start__last-pct { font-size: 1.3rem; font-weight: 700; color: var(--ok); }

/* ── Quiz Results ── */
.quiz-results { text-align: center; padding: 24px 0; }
.quiz-results__emoji { font-size: 56px; margin-bottom: 12px; }
.quiz-results__score { font-size: 2.5rem; font-weight: 800; color: var(--text-1); }
.quiz-results__pct { font-size: 1.2rem; font-weight: 600; color: var(--ok); margin-bottom: 8px; }
.quiz-results__msg { font-size: 1rem; color: var(--text-2); margin-bottom: 24px; }
.quiz-results__actions { display: flex; gap: 12px; justify-content: center; margin-bottom: 32px; }
.quiz-results__btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 24px; border: none; border-radius: var(--r-full);
    font-size: 0.95rem; font-weight: 600;
    cursor: pointer; font-family: inherit;
}
.quiz-results__btn--retry {
    background: linear-gradient(135deg, var(--d-500), var(--d-700));
    color: #fff;
}
.quiz-results__btn--close {
    background: var(--s-100); color: var(--text-2);
}

/* ── Quiz Review ── */
.quiz-results__review { text-align: left; }
.quiz-results__review h4 { font-size: 0.85rem; text-transform: uppercase; color: var(--s-500); margin-bottom: 12px; font-weight: 700; letter-spacing: 0.5px; }
.quiz-review-item {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 12px; border-radius: var(--r-sm);
    margin-bottom: 8px;
}
.quiz-review-item--correct { background: rgba(22,163,74,0.06); }
.quiz-review-item--wrong { background: rgba(239,68,68,0.06); }
.quiz-review-item__icon { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.quiz-review-item--correct .quiz-review-item__icon { color: var(--ok); }
.quiz-review-item--wrong .quiz-review-item__icon { color: var(--err); }
.quiz-review-item__q { font-size: 0.95rem; font-weight: 500; color: var(--text-1); margin-bottom: 4px; }
.quiz-review-item__a { font-size: 0.85rem; color: var(--text-2); }
.quiz-review-item__c { font-size: 0.85rem; color: var(--ok); font-weight: 500; margin-top: 2px; }


/* ==================== EXIT DIALOG ==================== */
.exit-dialog {
    position: fixed; inset: 0; z-index: 10000;
    display: flex; align-items: center; justify-content: center;
    pointer-events: none; opacity: 0;
    transition: opacity .2s ease;
}
.exit-dialog.open { opacity: 1; pointer-events: auto; }

.exit-dialog__overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(6px);
}
.exit-dialog__card {
    position: relative; z-index: 1;
    background: var(--bg-card);
    border-radius: var(--r-xl);
    padding: 32px 28px;
    text-align: center;
    max-width: 320px; width: 90%;
    box-shadow: var(--sh-xl);
    transform: scale(0.9);
    transition: transform .3s cubic-bezier(.32,.72,.0,1);
}
.exit-dialog.open .exit-dialog__card { transform: scale(1); }

.exit-dialog__icon {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--d-600), var(--d-800));
    color: #fff; font-size: 28px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
}
.exit-dialog__title {
    font-size: 1.2rem; font-weight: 700;
    color: var(--text-1); margin-bottom: 8px;
}
.exit-dialog__msg {
    font-size: 0.9rem; color: var(--text-2);
    margin-bottom: 24px; line-height: 1.5;
}
.exit-dialog__actions { display: flex; gap: 12px; }
.exit-dialog__btn {
    flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 12px 16px; border: none; border-radius: var(--r-sm);
    font-size: 0.95rem; font-weight: 600;
    cursor: pointer; font-family: inherit;
    transition: transform 0.15s;
}
.exit-dialog__btn:active { transform: scale(0.96); }
.exit-dialog__btn--cancel {
    background: var(--s-100); color: var(--text-2);
}
.exit-dialog__btn--confirm {
    background: linear-gradient(135deg, var(--err), var(--err-deep));
    color: #fff;
}

/* ── Exit fallback message ── */
.exit-msg {
    position: fixed; inset: 0; z-index: 10001;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0,0,0,0.4);
    opacity: 0; pointer-events: none;
    transition: opacity .2s;
}
.exit-msg.open { opacity: 1; pointer-events: auto; }
.exit-msg__card {
    background: var(--bg-card);
    border-radius: var(--r-xl);
    padding: 24px; text-align: center;
    max-width: 300px; width: 85%;
    box-shadow: var(--sh-lg);
}
.exit-msg__card i { font-size: 28px; color: var(--d-500); margin-bottom: 12px; display: block; }
.exit-msg__card p { font-size: 0.9rem; color: var(--text-2); margin-bottom: 16px; line-height: 1.5; }
.exit-msg__card button {
    padding: 10px 24px; border: none;
    border-radius: var(--r-sm);
    background: var(--d-500); color: #fff;
    font-weight: 600; cursor: pointer; font-family: inherit;
}


/* ==================== ANIMATIONS ==================== */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.5} }
@keyframes shake { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-6px)} 40%,80%{transform:translateX(6px)} }
.quiz-shake { animation: shake 0.5s ease; }


/* ==================== AUTH MODAL ==================== */
.auth-modal {
    position: fixed; inset: 0; z-index: 11000;
    display: flex; align-items: center; justify-content: center;
    pointer-events: none; opacity: 0;
    transition: opacity .25s ease;
}
.auth-modal.open { opacity: 1; pointer-events: auto; }

.auth-modal__overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(8px);
}
.auth-modal__card {
    position: relative; z-index: 1;
    background: var(--bg-card);
    border-radius: var(--r-xl);
    padding: 32px 28px;
    max-width: 380px; width: 92%;
    box-shadow: var(--sh-xl);
    transform: scale(0.92) translateY(20px);
    transition: transform .35s cubic-bezier(.32,.72,.0,1);
}
.auth-modal.open .auth-modal__card { transform: scale(1) translateY(0); }

.auth-modal__close {
    position: absolute; top: 12px; right: 12px;
    border: none; background: var(--s-100);
    width: 32px; height: 32px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; color: var(--s-500); cursor: pointer;
}
.auth-modal__icon {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--d-500), var(--d-700));
    color: #fff; font-size: 24px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 12px;
}
.auth-modal__title {
    text-align: center; font-size: 1.3rem;
    font-weight: 700; color: var(--text-1); margin-bottom: 4px;
}
.auth-modal__msg {
    text-align: center; font-size: 0.85rem;
    color: var(--text-2); margin-bottom: 16px;
}
.auth-modal__error {
    background: rgba(239,68,68,0.08);
    border: 1px solid var(--err);
    border-radius: var(--r-sm);
    padding: 10px 14px;
    font-size: 0.85rem; color: var(--err);
    margin-bottom: 12px; text-align: center;
}

.auth-field { margin-bottom: 14px; }
.auth-field label {
    display: block; font-size: 0.8rem; font-weight: 600;
    color: var(--text-2); margin-bottom: 4px; text-transform: uppercase;
    letter-spacing: 0.5px;
}
.auth-field input {
    width: 100%; padding: 12px 14px;
    border: 2px solid var(--border);
    border-radius: var(--r-sm);
    font-size: 1rem; color: var(--text-1);
    font-family: inherit; background: var(--bg);
    transition: border-color 0.2s;
    box-sizing: border-box;
}
.auth-field input:focus { border-color: var(--d-500); outline: none; }

.auth-btn {
    width: 100%; padding: 14px;
    background: linear-gradient(135deg, var(--d-500), var(--d-700));
    color: #fff; border: none; border-radius: var(--r-sm);
    font-size: 1rem; font-weight: 600;
    cursor: pointer; font-family: inherit;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    margin-top: 4px;
    transition: transform 0.15s;
}
.auth-btn:active { transform: scale(0.97); }

.auth-toggle {
    text-align: center; margin-top: 16px;
    font-size: 0.85rem; color: var(--text-2);
}
.auth-toggle a {
    color: var(--d-500); font-weight: 600;
    text-decoration: none;
}


/* ==================== OTP AUTH & SCREENS ==================== */
.auth-step { animation: authFadeIn 0.3s ease; display: none; }
.auth-step.active { display: block; }
@keyframes authFadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

.otp-inputs { display: flex; gap: 8px; justify-content: center; margin-bottom: 24px; direction: ltr; }
.otp-input {
    width: 46px; height: 56px;
    text-align: center; font-size: 1.5rem; font-weight: 700;
    border: 2px solid var(--border);
    border-radius: var(--r-sm);
    background: var(--bg); color: var(--text-1);
    transition: all 0.2s ease;
    padding: 0;
}
.otp-input:focus { border-color: var(--d-500); outline: none; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(21,101,192,0.15); }
.otp-input.error { border-color: var(--err); background: rgba(239,68,68,0.05); }
.otp-input.success { border-color: var(--ok); background: rgba(34,197,94,0.05); }

.otp-timer { text-align: center; font-size: 0.85rem; color: var(--text-3); margin-top: -8px; margin-bottom: 20px; }
.otp-resend { color: var(--d-500); font-weight: 600; cursor: pointer; border: none; background: none; padding: 0; font-family: inherit; font-size: inherit; }
.otp-resend:disabled { color: var(--text-3); cursor: not-allowed; text-decoration: none; }
.otp-resend:not(:disabled):hover { text-decoration: underline; }

.auth-success { text-align: center; padding: 24px 0; }
.auth-success__icon {
    width: 64px; height: 64px; border-radius: 50%;
    background: linear-gradient(135deg, #22C55E, #16A34A);
    color: #fff; font-size: 28px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
    animation: successPop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.auth-success__title { font-size: 1.3rem; font-weight: 700; color: var(--text-1); margin-bottom: 8px; }
.auth-success__msg { font-size: 0.9rem; color: var(--text-2); }
@keyframes successPop { 0% { transform: scale(0); } 100% { transform: scale(1); } }

.auth-forgot-link { display: block; text-align: center; font-size: 0.85rem; color: var(--d-500); margin-top: 16px; font-weight: 600; text-decoration: none; cursor: pointer; }


/* ==================== QUIZ ENGINE V3 ==================== */
.qe-loading{text-align:center;padding:48px 20px;color:var(--text-2)}
.qe-loading i{font-size:28px;display:block;margin-bottom:12px;color:var(--d-500)}
.qe-loading p{margin-top:8px;font-size:.9rem}
.qe-empty{text-align:center;padding:48px 20px;color:var(--text-3)}
.qe-empty i{font-size:40px;display:block;margin-bottom:12px;opacity:.4}
.qe-empty p{font-size:.9rem;margin-bottom:12px}
.qe-retry-btn{padding:10px 24px;border:none;border-radius:var(--r-sm);background:var(--d-500);color:#fff;font-weight:600;cursor:pointer;font-family:inherit}

.qe-home{padding:4px 0}
.qe-hero{text-align:center;padding:24px 16px 16px}
.qe-hero__icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#8B5CF6,#6D28D9);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.qe-hero__title{font-size:1.3rem;font-weight:800;color:var(--text-1);margin:0 0 4px}
.qe-hero__sub{font-size:.9rem;color:var(--text-2);margin:0 0 8px}
.qe-hero__user{font-size:.85rem;color:var(--d-500);font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;margin:0}

.qe-stats{display:flex;gap:12px;justify-content:center;margin:16px 0;padding:0 16px}
.qe-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 8px;background:var(--bg-card);border-radius:var(--r-sm);border:1px solid var(--border)}
.qe-stat__val{font-size:1.3rem;font-weight:800;color:var(--text-1)}
.qe-stat__lbl{font-size:.65rem;color:var(--s-500);text-transform:uppercase;font-weight:600;letter-spacing:.5px;margin-top:2px}

.qe-section-title{font-size:1rem;font-weight:700;color:var(--text-1);margin:0 16px 12px;padding-top:8px}
.qe-section-sub{font-size:.85rem;color:var(--text-2);margin:-6px 16px 16px}
.qe-back{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:transparent;color:var(--d-500);font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit;margin:4px 0 8px 8px}

.qe-cat-grid{display:flex;flex-direction:column;gap:8px;padding:0 16px}
.qe-cat-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .2s;text-align:left;width:100%;font-family:inherit;color:inherit}
.qe-cat-card:active{transform:scale(.98)}
.qe-cat-card__icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.qe-cat-card__body{flex:1;min-width:0}
.qe-cat-card__name{font-size:.95rem;font-weight:700;color:var(--text-1)}
.qe-cat-card__desc{font-size:.8rem;color:var(--text-3);margin-top:2px}
.qe-cat-card__count{font-size:.75rem;font-weight:600;color:var(--d-500);background:rgba(21,101,192,.08);padding:3px 8px;border-radius:12px;white-space:nowrap}
.qe-cat-card__arrow{color:var(--text-3);font-size:12px;flex-shrink:0}

.qe-topic-chips{display:flex;flex-wrap:wrap;gap:10px;padding:0 16px}
.qe-topic-chip{display:flex;align-items:center;gap:8px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;color:var(--text-1);transition:all .2s;flex:1;min-width:140px}
.qe-topic-chip:active{transform:scale(.97);border-color:var(--d-500)}
.qe-topic-chip i{font-size:16px;color:var(--d-500)}
.qe-topic-chip__count{margin-left:auto;font-size:.75rem;font-weight:600;color:var(--text-3);background:var(--bg);padding:2px 8px;border-radius:10px}

.qe-history-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 32px);margin:20px 16px;padding:14px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-card);color:var(--text-2);font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit;transition:.2s}
.qe-history-btn:active{transform:scale(.98)}

.qe-player{padding:0 16px 16px}
.qe-progress{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:8px}
.qe-progress__bar{height:100%;background:linear-gradient(90deg,#8B5CF6,#6D28D9);border-radius:3px;transition:width .3s ease}
.qe-progress__info{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-3);margin-bottom:16px;font-weight:500}

.qe-q-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;margin-bottom:16px}
.qe-q-card__img{width:100%;max-height:240px;object-fit:contain;border-radius:var(--r-sm);margin-bottom:12px}
.qe-q-card__text{font-size:1rem;font-weight:600;color:var(--text-1);line-height:1.5;margin:0}

.qe-opts{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.qe-opt{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--r-md);cursor:pointer;font-family:inherit;text-align:left;transition:all .15s;width:100%;color:inherit}
.qe-opt:active{transform:scale(.98)}
.qe-opt--selected{border-color:var(--d-500);background:rgba(21,101,192,.06)}
.qe-opt__letter{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--s-100);color:var(--s-600);font-weight:700;font-size:.85rem;flex-shrink:0;transition:.2s}
.qe-opt--selected .qe-opt__letter{background:var(--d-500);color:#fff}
.qe-opt__body{flex:1;display:flex;align-items:center;gap:8px;min-width:0}
.qe-opt__img{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}
.qe-opt__text{font-size:.9rem;font-weight:500;color:var(--text-1)}

.qe-nav{display:flex;gap:12px}
.qe-nav__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 16px;border:2px solid var(--border);border-radius:var(--r-sm);font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;background:var(--bg-card);color:var(--text-2);transition:.15s}
.qe-nav__btn:disabled{opacity:.4;cursor:not-allowed}
.qe-nav__btn--primary{background:linear-gradient(135deg,var(--d-500),var(--d-700));color:#fff;border-color:transparent}
.qe-nav__btn:active:not(:disabled){transform:scale(.97)}

.qe-shake{animation:qe-shake .5s ease}
@keyframes qe-shake{0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-6px)} 40%,80%{transform:translateX(6px)}}

/* ── Quiz Status Bar ── */
.qe-status-bar{display:flex;gap:8px;margin:0 0 12px;padding:0}
.qe-status-item{display:flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;padding:5px 10px;border-radius:20px;background:var(--bg-card);border:1px solid var(--border)}
.qe-status-item--answered{color:#16A34A}
.qe-status-item--answered i{color:#22C55E}
.qe-status-item--skipped{color:#D97706}
.qe-status-item--skipped i{color:#F59E0B}
.qe-status-item--pending{color:var(--text-3)}
.qe-status-item--pending i{color:var(--s-300);font-size:.55rem}

/* ── Step Dots (tappable question indicators) ── */
.qe-step-dots{display:flex;gap:6px;overflow-x:auto;padding:0 0 12px;margin-bottom:8px;scrollbar-width:none;-ms-overflow-style:none}
.qe-step-dots::-webkit-scrollbar{display:none}
.qe-step-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--border);background:var(--bg-card);font-size:.7rem;font-weight:700;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;font-family:inherit;padding:0}
.qe-step-dot:active{transform:scale(.9)}
.qe-step-dot--answered{background:#D1FAE5;border-color:#22C55E;color:#16A34A}
.qe-step-dot--skipped{background:#FEF3C7;border-color:#F59E0B;color:#D97706}
.qe-step-dot--pending{background:var(--bg-card);border-color:var(--border);color:var(--text-3)}
.qe-step-dot--active{box-shadow:0 0 0 3px rgba(21,101,192,.3);border-color:var(--d-500);transform:scale(1.1)}
.qe-step-dot--active.qe-step-dot--answered{box-shadow:0 0 0 3px rgba(34,197,94,.25)}
.qe-step-dot--active.qe-step-dot--skipped{box-shadow:0 0 0 3px rgba(245,158,11,.25)}

/* ── Skip Button ── */
.qe-nav__btn--skip{background:rgba(245,158,11,.08);color:#D97706;border-color:#F59E0B}
.qe-nav__btn--skip:active:not(:disabled){transform:scale(.97);background:rgba(245,158,11,.15)}

/* ── Submit Gate Warning ── */
.qe-submit-gate{font-size:.8rem;color:#D97706;text-align:center;margin:8px 0 0;padding:8px 12px;background:rgba(245,158,11,.06);border-radius:var(--r-sm);border:1px solid rgba(245,158,11,.15)}
.qe-submit-gate i{margin-right:4px}

/* ── Skipped Review Item ── */
.qe-review-item--skipped{border-left:3px solid #F59E0B}
.qe-review-item--skipped .qe-review-item__icon{color:#F59E0B}
.qe-review-item__skip-lbl{font-size:.82rem;color:#D97706;font-weight:600;margin:4px 0 8px}
.qe-review-item__skip-lbl i{margin-right:4px}

.qe-results{padding:0 16px 16px}
.qe-results__header{text-align:center;padding:24px 0}
.qe-results__emoji{font-size:48px;margin-bottom:8px}
.qe-results__score{font-size:2rem;font-weight:800;color:var(--text-1);margin:0 0 4px}
.qe-results__pct{font-size:1.2rem;font-weight:700;color:var(--d-500)}
.qe-results__msg{font-size:.95rem;color:var(--text-2);margin:8px 0 4px}
.qe-results__cat{font-size:.8rem;color:var(--text-3)}
.qe-results__actions{display:flex;gap:12px;margin:20px 0}
.qe-results__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px;border:none;border-radius:var(--r-sm);font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s}
.qe-results__btn:active{transform:scale(.97)}
.qe-results__btn--retry{background:linear-gradient(135deg,#8B5CF6,#6D28D9);color:#fff}
.qe-results__btn--home{background:var(--s-100);color:var(--text-2)}

.qe-review{margin-top:16px}
.qe-review__title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin-bottom:12px}
.qe-review-item{display:flex;gap:10px;padding:14px;border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:8px}
.qe-review-item--correct{border-left:3px solid #22C55E}
.qe-review-item--wrong{border-left:3px solid #EF4444}
.qe-review-item__icon{font-size:18px;flex-shrink:0;padding-top:2px}
.qe-review-item--correct .qe-review-item__icon{color:#22C55E}
.qe-review-item--wrong .qe-review-item__icon{color:#EF4444}
.qe-review-item__body{flex:1;min-width:0}
.qe-review-item__q{font-size:.9rem;font-weight:600;color:var(--text-1);margin:0 0 8px;line-height:1.4}
.qe-review-item__img{max-width:100%;max-height:120px;border-radius:6px;margin-bottom:8px}
.qe-review-item__exp{font-size:.82rem;color:var(--d-500);margin-top:8px;font-style:italic}
.qe-review-item__exp i{margin-right:4px;color:#F59E0B}

.qe-review-opts{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.qe-review-opt{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:.8rem;background:var(--s-50,#f5f5f5);color:var(--text-2);border:1px solid transparent}
.qe-review-opt--correct{background:#D1FAE5;color:#059669;border-color:#059669}
.qe-review-opt--wrong{background:#FEE2E2;color:#DC2626;border-color:#DC2626}
.qe-review-opt__lbl{font-weight:700;min-width:14px}

.qe-history{padding:0 0 16px}
.qe-hist-list{padding:0 16px}
.qe-hist-card{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:8px}
.qe-hist-card__score{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:#fff;flex-shrink:0}
.qe-hist-card__score--high{background:linear-gradient(135deg,#22C55E,#16A34A)}
.qe-hist-card__score--mid{background:linear-gradient(135deg,#F59E0B,#D97706)}
.qe-hist-card__score--low{background:linear-gradient(135deg,#EF4444,#DC2626)}
.qe-hist-card__body{flex:1;min-width:0}
.qe-hist-card__title{font-weight:600;font-size:.9rem;color:var(--text-1)}
.qe-hist-card__detail{font-size:.8rem;color:var(--text-3);margin-top:2px}

.qe-player,.qe-results{user-select:none;-webkit-user-select:none}
@media(max-width:480px){.qe-review-opts{grid-template-columns:1fr}}




/* ==================== SHARE BUTTON ==================== */
.cv-share-btn {
    border: none; background: none;
    color: var(--s-400); cursor: pointer;
    font-size: 14px; padding: 6px;
    border-radius: 50%;
    transition: all 0.2s;
    display: flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
}
.cv-share-btn:hover,
.cv-share-btn:active { color: var(--d-500); background: var(--s-100); }

/* Card actions container — vertical stack on right side */
.cv-card__actions {
    display: flex; flex-direction: column; gap: 2px;
    flex-shrink: 0; align-items: center;
    margin-left: 4px;
}

/* ================================================================
   NOTIFICATIONS MODULE
   Banner and Settings UI
   ================================================================ */

/* — Permission Popup Modal — */
.notify-popup-overlay {
    position: fixed; inset: 0; z-index: 9999;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    padding: 24px;
    opacity: 0; transition: opacity 0.35s ease;
}
.notify-popup-overlay.show { opacity: 1; }
.notify-popup-overlay.show .notify-popup {
    transform: scale(1); opacity: 1;
}

.notify-popup {
    position: relative;
    background: var(--bg-card, #fff);
    border-radius: 20px;
    padding: 32px 24px 24px;
    max-width: 340px; width: 100%;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    transform: scale(0.9); opacity: 0;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.notify-popup__close {
    position: absolute; top: 12px; right: 12px;
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--bg, #f5f5f5);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    color: var(--text-3, #999); font-size: 12px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: 0.2s;
}
.notify-popup__close:hover { background: var(--border, #eee); }

.notify-popup__icon {
    width: 64px; height: 64px; border-radius: 50%;
    background: linear-gradient(135deg, rgba(30,144,255,0.1), rgba(30,144,255,0.05));
    color: #1e90ff; font-size: 24px;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
}

.notify-popup h4 {
    margin: 0 0 8px; font-size: 18px; font-weight: 700;
    color: var(--text-1, #1a1a1a);
}

.notify-popup p {
    margin: 0 0 20px; font-size: 14px; line-height: 1.5;
    color: var(--text-2, #666);
}

.notify-popup__actions {
    display: flex; flex-direction: column; gap: 8px;
}

.notify-popup__btn {
    width: 100%; padding: 12px 20px; border-radius: 12px;
    font-size: 14px; font-weight: 600; cursor: pointer;
    border: none; transition: 0.2s;
}
.notify-popup__btn--enable {
    background: linear-gradient(135deg, #1e90ff, #1565c0);
    color: #fff; box-shadow: 0 4px 14px rgba(30,144,255,0.3);
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.notify-popup__btn--enable:active { transform: scale(0.97); }
.notify-popup__btn--later {
    background: transparent; color: var(--text-3, #999);
}

.notify-btn {
    background: #1e90ff;
    color: white;
    border: none;
    border-radius: 8px;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}

.notify-btn--ghost {
    background: transparent;
    color: var(--text-2);
    padding: 10px;
}

.notify-unsupported {
    background: rgba(255, 69, 58, 0.1);
    color: #ff453a;
    padding: 16px;
    border-radius: 12px;
    display: flex;
    gap: 12px;
    font-size: 14px;
    line-height: 1.5;
    margin: 16px 0;
}

/* — Settings Panel — */
.ns-list {
    background: var(--surface);
    border-radius: 16px;
    border: 1px solid var(--border);
    overflow: hidden;
    margin: 16px 0;
}

.ns-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    border-bottom: 1px solid var(--border);
}
.ns-item:last-child {
    border-bottom: none;
}

.ns-item__icon {
    width: 40px; height: 40px;
    border-radius: 12px;
    background: hsla(var(--ns-h), 80%, 50%, 0.15);
    color: hsl(var(--ns-h), 80%, 65%);
    display: flex; align-items: center; justify-content: center;
    font-size: 18px;
}

.ns-item__info {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.ns-item__name {
    font-weight: 600;
    color: var(--text);
    font-size: 16px;
}

.ns-item__status {
    font-size: 13px;
    color: var(--text-2);
}

.ns-help {
    padding: 16px;
    color: var(--text-2);
    font-size: 13px;
    line-height: 1.5;
    display: flex;
    gap: 12px;
    border-radius: 12px;
    background: var(--surface);
    margin-bottom: 24px;
}

/* ══════════════════════════════════════════════════════════════════
   GLOBAL AUDIO PLAYER — Sticky Mini-Player + Content Play Buttons
   ══════════════════════════════════════════════════════════════════ */

/* ── Play button on content cards ── */
.cv-play-btn{
    width:32px;height:32px;border-radius:50%;border:none;
    background:linear-gradient(135deg, var(--d-400), var(--d-600));
    color:#fff;font-size:13px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .2s ease;flex-shrink:0;
    position:relative;
}
.cv-play-btn:hover{transform:scale(1.1);box-shadow:0 2px 8px rgba(21,101,192,.25)}
.cv-play-btn:active{transform:scale(0.95)}
.cv-play-btn.is-playing{background:linear-gradient(135deg, var(--a-400), var(--a-600))}
.cv-play-btn.is-loading{pointer-events:none;opacity:.7}
.cv-play-btn .fa-spinner{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Sticky Mini-Player Bar ── */
.audio-player{
    position:fixed;bottom:calc(var(--dock-h, 72px) + env(safe-area-inset-bottom, 0px));
    left:0;right:0;z-index:9500;
    background:linear-gradient(135deg, var(--d-800) 0%, var(--d-950) 100%);
    border-top:1px solid rgba(255,255,255,.08);
    padding:0;
    transform:translateY(100%);opacity:0;
    transition:transform .35s cubic-bezier(.16,1,.3,1), opacity .25s ease;
    pointer-events:none;
    box-shadow:0 -4px 20px rgba(0,0,0,.3);
}
.audio-player.is-visible{
    transform:translateY(0);opacity:1;pointer-events:auto;
}

.audio-player__progress{
    height:3px;background:rgba(255,255,255,.1);cursor:pointer;position:relative;
}
.audio-player__progress-fill{
    height:100%;background:linear-gradient(90deg, var(--a-400), var(--a-600));
    width:0%;transition:width .15s linear;border-radius:0 2px 2px 0;
}
.audio-player__progress-dot{
    position:absolute;right:0;top:50%;transform:translateY(-50%);
    width:10px;height:10px;border-radius:50%;background:var(--a-400);
    box-shadow:0 0 6px rgba(196,144,0,.4);opacity:0;transition:opacity .2s;
}
.audio-player__progress:hover .audio-player__progress-dot{opacity:1}

.audio-player__body{
    display:flex;align-items:center;gap:12px;padding:10px 16px;
}
.audio-player__play{
    width:36px;height:36px;border-radius:50%;border:none;
    background:linear-gradient(135deg, var(--a-400), var(--a-600));
    color:var(--d-950);font-size:14px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .2s ease;flex-shrink:0;
}
.audio-player__play:hover{transform:scale(1.08)}
.audio-player__play:active{transform:scale(0.95)}

.audio-player__info{flex:1;min-width:0}
.audio-player__title{
    font-size:13px;font-weight:600;color:#fff;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    line-height:1.3;
}
.audio-player__sub{
    font-size:11px;color:rgba(255,255,255,.5);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.audio-player__time{
    font-size:11px;color:rgba(255,255,255,.5);
    font-variant-numeric:tabular-nums;flex-shrink:0;min-width:32px;text-align:right;
}

.audio-player__close{
    width:28px;height:28px;border-radius:50%;border:none;
    background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);
    font-size:12px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .2s ease;flex-shrink:0;
}
.audio-player__close:hover{background:rgba(255,255,255,.15);color:#fff}

/* ── TTS indicator ── */
.audio-player__tts-badge{
    font-size:9px;font-weight:600;text-transform:uppercase;
    letter-spacing:.06em;color:var(--a-400);
    background:rgba(196,144,0,.12);
    padding:2px 6px;border-radius:4px;margin-left:4px;
}

/* ══════════════════════════════════════════════════════════════════
   SYSTEM MODALS (Settings & Notifications)
   ══════════════════════════════════════════════════════════════════ */
.sys-modal {
    position: fixed; inset: 0; z-index: 9999;
    display: flex; flex-direction: column; justify-content: flex-end;
    pointer-events: none;
}
.sys-modal.is-open { pointer-events: auto; }

.sys-modal__overlay {
    position: absolute; inset: 0;
    background: rgba(5, 11, 20, 0.7);
    backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
    opacity: 0; transition: opacity 0.3s ease;
}
.sys-modal.is-open .sys-modal__overlay { opacity: 1; }

.sys-modal__sheet {
    position: relative; z-index: 1;
    background: var(--d-900);
    border-radius: 24px 24px 0 0;
    border-top: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 -10px 40px rgba(0,0,0,0.5);
    padding: 0 0 calc(env(safe-area-inset-bottom, 20px) + 20px) 0;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    max-height: 85vh; display: flex; flex-direction: column;
}
.sys-modal.is-open .sys-modal__sheet { transform: translateY(0); }

.sys-modal__header {
    padding: 20px 24px 16px;
    display: flex; align-items: center; justify-content: space-between;
    position: relative;
}
.sys-modal__handle {
    position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
    width: 36px; height: 4px; border-radius: 2px;
    background: rgba(255,255,255,0.2);
}
.sys-modal__title {
    font-size: 18px; font-weight: 700; color: #fff; margin: 0;
}
.sys-modal__close {
    width: 32px; height: 32px; border-radius: 50%; border: none;
    background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.7);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: all 0.2s;
}
.sys-modal__close:hover { background: rgba(255,255,255,0.15); color: #fff; }

.sys-modal__body {
    padding: 0 24px 20px; overflow-y: auto; flex: 1;
}

.sys-section { margin-bottom: 24px; }
.sys-section__title {
    font-size: 13px; font-weight: 600; color: var(--a-400);
    text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 12px;
}
.sys-list {
    background: rgba(255,255,255,0.03); border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.05); overflow: hidden;
}
.sys-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 16px; border-bottom: 1px solid rgba(255,255,255,0.05);
}
.sys-item:last-child { border-bottom: none; }
.sys-item__info { display: flex; flex-direction: column; }
.sys-item__name { font-size: 15px; font-weight: 500; color: #fff; }
.sys-item__desc { font-size: 13px; color: rgba(255,255,255,0.5); margin-top: 2px; }

.sys-select {
    background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
    color: #fff; border-radius: 8px; padding: 6px 10px; font-size: 14px; outline: none;
    cursor: pointer;
}
.sys-select option { background: var(--d-800); color: #fff; }

/* Notification Feed Items */
.notif-card {
    background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.05);
    border-radius: 12px; padding: 16px; margin-bottom: 12px;
    display: flex; gap: 14px; position: relative; overflow: hidden;
    transition: opacity 0.3s, transform 0.3s;
}
.notif-card.is-read { opacity: 0.5; }
.notif-card.is-dismissing { opacity: 0; transform: translateX(20px); }
.notif-card__icon {
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(212,168,54,0.15); color: var(--a-400);
    display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0;
}
.notif-card__content { flex: 1; }
.notif-card__title { font-size: 15px; font-weight: 600; color: #fff; margin-bottom: 4px; }
.notif-card__text { font-size: 13px; color: rgba(255,255,255,0.7); line-height: 1.4; }
.notif-card__time { font-size: 11px; color: rgba(255,255,255,0.4); margin-top: 6px; display: block; }
.notif-card__unread-dot {
    position: absolute; top: 16px; right: 16px;
    width: 8px; height: 8px; border-radius: 50%; background: var(--a-400);
}

.sys-modal__footer { padding: 16px 24px; border-top: 1px solid rgba(255,255,255,0.05); }
.sys-btn {
    background: linear-gradient(135deg, var(--a-400), var(--a-600)); border: none;
    color: var(--d-950); font-size: 15px; font-weight: 600; border-radius: 12px;
    padding: 14px; cursor: pointer; transition: transform 0.2s; text-align: center; display: block;
}
.sys-btn:active { transform: scale(0.98); }
.sys-btn--ghost { background: rgba(255,255,255,0.06); color: #fff; }
.sys-btn--ghost:hover { background: rgba(255,255,255,0.1); }

/* ================================================================
   CALENDAR MODULE
   ================================================================ */
.cal-controls {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; padding: 0 16px;
}
.cal-btn {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--bg-card); border: 1px solid var(--border);
    color: var(--text-1); font-size: 16px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: 0.2s;
}
.cal-btn:active { transform: scale(0.9); }
.cal-month-title { text-align: center; display: flex; flex-direction: column; align-items: center; }
.cal-month-title h2 { font-size: 18px; font-weight: 700; color: var(--text-1); margin: 0; }
.cal-month-title span { font-size: 12px; color: var(--text-3); font-weight: 500; text-transform: uppercase; letter-spacing: 0.5px; }

.cal-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--r-lg); box-shadow: var(--sh-md);
    overflow: hidden; margin: 0 16px 24px;
}
.cal-weekdays {
    display: grid; grid-template-columns: repeat(7, 1fr);
    background: rgba(255,255,255,0.02); border-bottom: 1px solid var(--border);
    padding: 12px 0; text-align: center; font-size: 11px;
    font-weight: 600; text-transform: uppercase; color: var(--text-3);
    letter-spacing: 0.5px;
}
.cal-grid {
    display: grid; grid-template-columns: repeat(7, 1fr);
}
.cal-cell {
    aspect-ratio: 1; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    position: relative; cursor: pointer; transition: 0.2s;
}
.cal-cell:nth-child(7n) { border-right: none; }
.cal-cell:active { background: rgba(255,255,255,0.05); }
.cal-cell--muted .cal-hijri { color: var(--text-3); opacity: 0.5; }
.cal-cell--muted .cal-greg { opacity: 0.3; }
.cal-cell--today { background: rgba(59, 130, 246, 0.08); }
.cal-cell--today .cal-hijri { color: #3B82F6; font-weight: 800; }
.cal-cell--friday { background: rgba(34, 197, 94, 0.05); }
.cal-cell--has-event::after {
    content: ''; position: absolute; inset: 0;
    border: 2px solid transparent; border-radius: 8px; transition: 0.2s;
}
.cal-hijri { font-size: 18px; font-weight: 600; color: var(--text-1); line-height: 1; margin-bottom: 4px; }
.cal-greg { font-size: 10px; color: var(--text-3); }

.cal-dots {
    display: flex; gap: 3px; position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%);
}
.cal-dot { width: 4px; height: 4px; border-radius: 50%; }
.cal-dot--islamic { background: #22C55E; box-shadow: 0 0 6px rgba(34, 197, 94, 0.6); }
.cal-dot--masjid { background: #EAB308; box-shadow: 0 0 6px rgba(234, 179, 8, 0.6); }
.cal-dot--personal { background: #3B82F6; box-shadow: 0 0 6px rgba(59, 130, 246, 0.6); }

.cal-legend {
    display: flex; justify-content: center; gap: 16px; margin: 0 16px 16px;
    background: var(--bg-card); padding: 12px; border-radius: var(--r-md);
    border: 1px solid var(--border);
    position: relative; z-index: 10;
}
.cal-legend-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-2); font-weight: 500; }

.fab-btn {
    position: fixed; bottom: 85px; right: 20px;
    width: 56px; height: 56px; border-radius: 50%;
    background: linear-gradient(135deg, #3B82F6, #2563EB); color: #fff;
    border: none; font-size: 20px; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.4); cursor: pointer; z-index: 9000;
    transition: transform 0.2s, box-shadow 0.2s;
}
.fab-btn:active { transform: scale(0.9); }

.cal-event-card {
    background: var(--bg); border: 1px solid var(--border); border-left: 4px solid var(--accent);
    border-radius: var(--r-md); padding: 14px 16px; margin-bottom: 12px;
}
.cal-event-card__title { font-size: 15px; font-weight: 700; color: var(--text-1); margin-bottom: 4px; }
.cal-event-card__desc { font-size: 13px; color: var(--text-2); line-height: 1.4; }

/* ── Calendar Modal Inputs ── */
.cal-input {
    width: 100%;
    padding: 12px 14px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    color: var(--text-1);
    font-size: 15px;
    transition: all 0.2s ease;
    outline: none;
    font-family: inherit;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.02);
}
.cal-input:hover {
    border-color: rgba(21, 101, 192, 0.4);
}
.cal-input:focus {
    border-color: var(--d-400);
    box-shadow: 0 0 0 3px rgba(21, 101, 192, 0.15), inset 0 1px 2px rgba(0,0,0,0.02);
    background: var(--bg-card);
}
.cal-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 8px;
}

/* ================================================================
   CALENDAR — MONTH EVENT LIST (User Panel)
   ================================================================ */
.cal-month-section {
    margin: 0 16px calc(var(--dock-h, 72px) + 24px);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    overflow: hidden;
}
.cal-month-section__header {
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    background: rgba(255,255,255,0.02);
}
.cal-month-section__title {
    margin: 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--text-1);
    display: flex;
    align-items: center;
    gap: 8px;
}
.cal-month-section__title i {
    color: var(--a-400);
    font-size: 14px;
}
.cal-month-section__body {
    padding: 12px 16px;
}

/* Event Item Card */
.cml-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    margin-bottom: 10px;
    transition: all 0.2s ease;
    position: relative;
}
.cml-item:last-child {
    margin-bottom: 0;
}
.cml-item:active {
    transform: scale(0.99);
}
.cml-item__color {
    width: 4px;
    border-radius: 4px;
    min-height: 40px;
    flex-shrink: 0;
    align-self: stretch;
}
.cml-item__body {
    flex: 1;
    min-width: 0;
}
.cml-item__title {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-1);
    margin: 0 0 4px;
    line-height: 1.3;
}
.cml-item__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    margin-bottom: 4px;
}
.cml-item__date {
    font-size: 12px;
    color: var(--text-3);
    display: flex;
    align-items: center;
    gap: 4px;
}
.cml-item__date i {
    font-size: 10px;
}
.cml-item__desc {
    font-size: 12px;
    color: var(--text-2);
    line-height: 1.4;
    margin-top: 4px;
}
.cml-item__thumb {
    width: 44px;
    height: 44px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--border);
}

/* Type Badges */
.cml-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    line-height: 1.6;
}
.cml-badge--islamic {
    background: rgba(34, 197, 94, 0.12);
    color: #22C55E;
}
.cml-badge--masjid {
    background: rgba(234, 179, 8, 0.12);
    color: #EAB308;
}
.cml-badge--personal {
    background: rgba(59, 130, 246, 0.12);
    color: #3B82F6;
}
.cml-badge--repeat {
    background: rgba(255,255,255,0.05);
    color: var(--text-3);
    border: 1px solid var(--border);
}

/* Actions (Edit/Delete) — only for user-owned events */
.cml-item__actions {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex-shrink: 0;
    margin-left: 4px;
}
.cml-action-btn {
    width: 30px;
    height: 30px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-3);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    transition: all 0.2s;
}
.cml-action-btn:active {
    transform: scale(0.92);
}
.cml-action-btn--edit:hover {
    background: rgba(59, 130, 246, 0.15);
    color: #3B82F6;
    border-color: rgba(59, 130, 246, 0.3);
}
.cml-action-btn--del:hover {
    background: rgba(239, 68, 68, 0.15);
    color: #EF4444;
    border-color: rgba(239, 68, 68, 0.3);
}

/* Empty State */
.cal-month-empty {
    text-align: center;
    padding: 32px 16px;
    color: var(--text-3);
}
.cal-month-empty i {
    font-size: 36px;
    margin-bottom: 12px;
    opacity: 0.3;
    display: block;
}
.cal-month-empty p {
    font-size: 14px;
    margin: 0;
    color: var(--text-3);
}

