/* ============================================================
   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;
    -moz-osx-font-smoothing:grayscale;
}

/* 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.8s cubic-bezier(.4,0,.2,1);
    transform:scale(1.05);
}
.hero__slide.active{opacity:1;transform:scale(1);will-change:opacity,transform;transition:opacity 1.8s cubic-bezier(.4,0,.2,1),transform 8s cubic-bezier(.4,0,.2,1)}

/* ── 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;-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;-webkit-box-orient:vertical;
    overflow:hidden;
}

/* ── 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;-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}

/* ── Day Toggle ── */
.tt-day-toggle{
    position:relative;display:inline-flex;
    background:rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.08);
    border-radius:var(--r-full);padding:3px;
    align-self:flex-start;
}
.tt-day-toggle__btn{
    position:relative;z-index:2;
    padding:6px 20px;border-radius:var(--r-full);
    font-size:12px;font-weight:600;color:rgba(255,255,255,.55);
    background:none;border:none;cursor:pointer;
    transition:.3s ease;
}
.tt-day-toggle__btn.active{color:#fff}
.tt-day-toggle__slider{
    position:absolute;top:3px;left:3px;z-index:1;
    width:calc(50% - 3px);height:calc(100% - 6px);
    background:rgba(255,255,255,.12);
    border-radius:var(--r-full);
    transition:transform .35s cubic-bezier(.16,1,.3,1);
}
.tt-day-toggle[data-active="tomorrow"] .tt-day-toggle__slider{
    transform:translateX(100%);
}

/* ── 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)}

.tt-card--sunrise{
    background:linear-gradient(135deg, rgba(255,183,77,.03) 0%, var(--bg-card) 100%);
    border-style:dashed;border-color:rgba(255,183,77,.15);
}

/* ══════════ 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;height:220px;border-radius:var(--r-lg);overflow:hidden;
    display:flex;align-items:center;justify-content:center;
}
.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;
}

/* ── 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;color:var(--s-300);
    transition:.2s ease;z-index:2;
}
.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;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-top:4px;
}
.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)}
}

/* ==================== 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); }

/* 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__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; }

/* ── 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;
}


/* ==================== QUIZ NAV BUTTONS ==================== */
.quiz-nav {
    display: flex; gap: 12px;
    margin-top: 24px;
}
.quiz-nav__btn {
    flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 12px 16px; border: 2px solid var(--border);
    border-radius: var(--r-sm);
    font-size: 0.95rem; font-weight: 600;
    cursor: pointer; font-family: inherit;
    background: var(--bg-card); color: var(--text-2);
    transition: all 0.15s;
}
.quiz-nav__btn:disabled { opacity: 0.4; cursor: not-allowed; }
.quiz-nav__btn--primary {
    background: linear-gradient(135deg, var(--d-500), var(--d-700));
    color: #fff; border-color: transparent;
}
.quiz-nav__btn:active:not(:disabled) { transform: scale(0.97); }


/* ── Quiz option selected state ── */
.quiz-option--selected {
    border-color: var(--d-500) !important;
    background: rgba(21,101,192,0.06) !important;
}
.quiz-option__letter {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--s-100); color: var(--s-600);
    font-weight: 700; font-size: 0.85rem;
    flex-shrink: 0; margin-right: 10px;
    transition: all 0.2s;
}
.quiz-option--selected .quiz-option__letter {
    background: var(--d-500); color: #fff;
}
.quiz-option__text { flex: 1; text-align: left; }
.quiz-option {
    display: flex !important; align-items: center !important;
}


/* ── Quiz difficulty badge ── */
.quiz-diff {
    display: inline-block;
    font-size: 0.7rem; text-transform: uppercase;
    font-weight: 700; letter-spacing: 0.5px;
    padding: 3px 10px; border-radius: var(--r-full);
    margin-top: 8px;
}
.quiz-diff--easy { background: rgba(22,163,74,0.1); color: var(--ok); }
.quiz-diff--medium { background: rgba(196,144,0,0.1); color: var(--a-600); }
.quiz-diff--hard { background: rgba(239,68,68,0.1); color: var(--err); }


/* ── Quiz user badge ── */
.quiz-start__user {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    font-size: 0.9rem; color: var(--d-500); font-weight: 500;
    margin-bottom: 12px;
}

/* ── Quiz stats row ── */
.quiz-start__stats {
    display: flex; gap: 16px; justify-content: center;
    margin: 20px 0;
}
.quiz-stat {
    display: flex; flex-direction: column; align-items: center;
    padding: 12px 16px;
    background: var(--bg-card); border-radius: var(--r-sm);
    border: 1px solid var(--border); min-width: 70px;
}
.quiz-stat__val {
    font-size: 1.4rem; font-weight: 800; color: var(--text-1);
}
.quiz-stat__label {
    font-size: 0.7rem; color: var(--s-500);
    text-transform: uppercase; font-weight: 600;
    letter-spacing: 0.5px; margin-top: 2px;
}

/* ── Quiz history rows ── */
.quiz-start__recent {
    margin: 16px 0; text-align: left;
}
.quiz-start__recent h4 {
    font-size: 0.8rem; text-transform: uppercase;
    color: var(--s-500); margin-bottom: 8px;
    font-weight: 700; letter-spacing: 0.5px;
}
.quiz-history-row {
    display: flex; align-items: center; gap: 12px;
    padding: 8px 12px; border-radius: var(--r-sm);
    background: var(--bg-card); border: 1px solid var(--border);
    margin-bottom: 6px; font-size: 0.9rem;
}
.quiz-history-pct {
    font-weight: 700; color: var(--ok);
    margin-left: auto;
}
.quiz-history-date {
    font-size: 0.8rem; color: var(--s-400);
}


/* ── Quiz review explanation ── */
.quiz-review-item__exp {
    font-size: 0.82rem; color: var(--d-500);
    margin-top: 4px; font-style: italic;
}
.quiz-review-item__exp i { margin-right: 4px; }


/* ==================== 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 Banner — */
.notify-banner {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--surface);
    z-index: 1000;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    border-top: 1px solid var(--border);
    box-shadow: 0 -10px 40px rgba(0,0,0,0.4);
}

.notify-banner.show {
    transform: translateY(0);
}

.notify-banner__icon {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: rgba(30, 144, 255, 0.1);
    color: #1e90ff;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}

.notify-banner__body {
    flex-grow: 1;
}

.notify-banner__body h4 {
    color: var(--text);
    margin: 0 0 4px 0;
    font-size: 15px;
}

.notify-banner__body p {
    color: var(--text-2);
    margin: 0;
    font-size: 13px;
    line-height: 1.4;
}

.notify-banner__actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.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;
}
