:root {
  --primary: #0f172a;
  --primary-light: #1e293b;
  --primary-glow: rgba(15,23,42,0.04);
  --accent: #0d9488;
  --accent-light: #5eead4;
  --accent-dark: #0f766e;
  --accent-glow: rgba(13,148,136,0.15);
  --accent-subtle: rgba(13,148,136,0.06);
  --tertiary: #10b981;
  --tertiary-light: #34d399;
  --tertiary-dark: #059669;
  --tertiary-glow: rgba(16,185,129,0.15);
  --tertiary-subtle: rgba(16,185,129,0.06);
  --gold: #f59e0b;
  --gold-light: #fbbf24;
  --bg: #f1f5f9;
  --bg-warm: #e2e8f0;
  --bg-cool: #f8fafc;
  --surface: #ffffff;
  --surface-hover: #f8fafc;
  --surface-glass: rgba(255,255,255,0.7);
  --text: #0f172a;
  --text-secondary: #475569;
  --text-muted: #94a3b8;
  --border: #cbd5e1;
  --border-light: rgba(203,213,225,0.5);
  --success: #059669;
  --success-bg: #ecfdf5;
  --success-glow: rgba(5,150,105,0.12);
  --danger: #dc2626;
  --danger-bg: #fef2f2;
  --white-glass: rgba(255,255,255,0.9);
  --shadow-sm: 0 1px 3px rgba(15,23,42,0.04);
  --shadow: 0 4px 20px rgba(15,23,42,0.06);
  --shadow-lg: 0 12px 48px rgba(15,23,42,0.08);
  --shadow-xl: 0 24px 72px rgba(15,23,42,0.10);
  --shadow-glow: 0 4px 24px var(--accent-glow);
  --shadow-glow-lg: 0 8px 40px var(--accent-glow);
  --radius-sm: 12px;
  --radius: 20px;
  --radius-lg: 28px;
  --radius-xl: 36px;
  --font-body: 'Amiri', 'Noto Naskh Arabic', 'Traditional Arabic', serif;
  --font-heading: 'Tajawal', 'Traditional Arabic', sans-serif;
  --font-ui: 'Tajawal', system-ui, sans-serif;
  --transition: 0.25s cubic-bezier(.4,0,.2,1);
  --transition-smooth: 0.4s cubic-bezier(.4,0,.2,1);
  --transition-bounce: 0.4s cubic-bezier(.34,1.56,.64,1);
  --rdr-bg: #fffbeb;
  --bg-mesh: radial-gradient(ellipse at 20% 50%, rgba(13,148,136,0.05) 0%, transparent 60%),
             radial-gradient(ellipse at 80% 20%, rgba(16,185,129,0.04) 0%, transparent 50%),
             radial-gradient(ellipse at 50% 80%, rgba(13,148,136,0.03) 0%, transparent 50%);
  --radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;
  --transition-fast: 0.15s ease;--transition-smooth: 0.4s cubic-bezier(.4,0,.2,1);
  --font-spacing: -0.2px;--shadow-xs: 0 1px 2px rgba(0,0,0,0.04);
}
[data-theme="dark"] {
  --primary: #e2e8f0;
  --primary-light: #cbd5e1;
  --primary-glow: rgba(226,232,240,0.05);
  --bg: #020617;
  --bg-warm: #0f172a;
  --bg-cool: #020617;
  --surface: #1e293b;
  --surface-hover: #334155;
  --surface-glass: rgba(30,41,59,0.6);
  --text: #f1f5f9;
  --text-secondary: #94a3b8;
  --text-muted: #64748b;
  --border: #334155;
  --border-light: rgba(51,65,85,0.5);
  --white-glass: rgba(30,41,59,0.92);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow: 0 4px 20px rgba(0,0,0,0.4);
  --shadow-lg: 0 12px 48px rgba(0,0,0,0.5);
  --shadow-xl: 0 24px 72px rgba(0,0,0,0.6);
  --accent: #5eead4;
  --accent-light: #99f6e4;
  --accent-dark: #2dd4bf;
  --accent-glow: rgba(94,234,212,0.14);
  --accent-subtle: rgba(94,234,212,0.04);
  --tertiary: #34d399;
  --tertiary-light: #6ee7b7;
  --tertiary-dark: #10b981;
  --tertiary-glow: rgba(52,211,153,0.12);
  --tertiary-subtle: rgba(52,211,153,0.04);
  --gold: #fbbf24;
  --gold-light: #fde68a;
  --success: #34d399;
  --success-bg: rgba(52,211,153,0.1);
  --rdr-bg: #1a1a0f;
  --bg-mesh: radial-gradient(ellipse at 20% 50%, rgba(94,234,212,0.08) 0%, transparent 60%),
             radial-gradient(ellipse at 80% 20%, rgba(52,211,153,0.05) 0%, transparent 50%),
             radial-gradient(ellipse at 50% 80%, rgba(94,234,212,0.03) 0%, transparent 50%);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);background-image:var(--bg-mesh);color:var(--text);direction:rtl;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-height:100dvh;overflow-x:hidden;transition:background var(--transition-smooth),color var(--transition-smooth);letter-spacing:var(--font-spacing)}
.material-symbols-outlined{font-size:22px;vertical-align:middle;line-height:1;transition:all var(--transition)}
::selection{background:var(--accent);color:#fff}
[data-theme="dark"] ::selection, [data-premium-theme="night"] ::selection{background:var(--accent);color:var(--primary)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ─── Horizontal Scroll ─── */
.horiz-scroll{display:flex;gap:14px;overflow-x:auto;padding:4px 0 18px;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
.horiz-scroll::-webkit-scrollbar{display:none}
.horiz-card{flex:0 0 145px;scroll-snap-align:start;cursor:pointer;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border-light);overflow:hidden;transition:all var(--transition-bounce);position:relative;display:flex;flex-direction:column}
.horiz-card::after{content:'';position:absolute;inset:0;border-radius:var(--radius);background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,0.03));pointer-events:none}
.horiz-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.horiz-card:active{transform:translateY(-2px) scale(.98)}
.horiz-card-cover{width:100%;aspect-ratio:3/4;max-height:180px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:38px;position:relative;overflow:hidden}
.horiz-card-cover .cover-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.horiz-card-cover .cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.horiz-card:hover .cover-img{transform:scale(1.06)}
.horiz-card-cover::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.25));pointer-events:none;z-index:1}
.horiz-card-body{padding:12px 14px;position:relative;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.horiz-card-title{font-family:var(--font-heading);font-size:13px;font-weight:600;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;min-height:0}
.horiz-card-sub{color:var(--text-muted);font-size:11px;font-family:var(--font-ui);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:4px}

/* ─── Splash Screen ─── */
.splash{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--bg);background-image:var(--bg-mesh)}
.splash-content{text-align:center;animation:fadeUp .6s ease}
.splash-icon{font-size:72px;margin-bottom:20px;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 8px 24px var(--accent-glow))}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.splash-title{font-family:var(--font-heading);font-size:34px;font-weight:800;color:var(--primary);letter-spacing:-1px;background:linear-gradient(135deg,var(--accent),var(--tertiary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.splash-sub{color:var(--text-muted);font-size:14px;margin-top:6px;font-family:var(--font-ui)}
.splash-loader{display:flex;gap:10px;margin-top:24px;justify-content:center}
.splash-loader div{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));animation:pulse-dot 1.4s infinite}
.splash-loader div:nth-child(2){animation-delay:.2s}
.splash-loader div:nth-child(3){animation-delay:.4s}
@keyframes pulse-dot{0%,80%,100%{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:1}}

/* ─── Top Bar ─── */
.top-bar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface-glass);backdrop-filter:blur(30px) saturate(1.2);-webkit-backdrop-filter:blur(30px) saturate(1.2);border-bottom:1px solid var(--border-light)}
.top-bar-title{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--primary);letter-spacing:-.3px;background:linear-gradient(135deg,var(--accent),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.top-bar-btn{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);font-size:16px;flex-shrink:0}
.top-bar-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);transform:scale(1.05);box-shadow:0 2px 12px var(--accent-glow)}
.top-bar-btn:active{transform:scale(.88)}

/* ─── Bottom Navigation ─── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--surface-glass);backdrop-filter:blur(30px) saturate(1.2);-webkit-backdrop-filter:blur(30px) saturate(1.2);border-top:1px solid var(--border-light);padding:6px 0;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));box-shadow:0 -4px 24px rgba(0,0,0,0.04)}
.bottom-nav-inner{display:flex;justify-content:space-around;max-width:440px;margin:0 auto}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 22px;border-radius:16px;text-decoration:none;color:var(--text-muted);font-size:11px;font-family:var(--font-ui);font-weight:700;transition:all var(--transition);position:relative}
.nav-item i{font-size:24px;transition:all var(--transition)}
.nav-item:hover{color:var(--text-secondary)}
.nav-item.active{color:var(--accent)}
.nav-item.active i{transform:translateY(-2px)}
.nav-item.active::after{content:'';position:absolute;top:-3px;width:24px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--tertiary));box-shadow:0 0 8px var(--accent-glow)}
.nav-item:active{transform:scale(.92)}

/* ─── Page Content ─── */
.page-content{padding:16px 20px 100px;max-width:500px;margin:0 auto}
/* club chat: full-width, no padding */
.page-content.club{padding:0;max-width:none;margin:0}

/* ─── Hero ─── */
.hero{text-align:center;padding:40px 0 28px}
.hero-icon{font-size:60px;margin-bottom:16px;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 8px 24px var(--accent-glow))}
.hero-title{font-family:var(--font-heading);font-size:36px;font-weight:800;color:var(--primary);letter-spacing:-1.5px;background:linear-gradient(135deg,var(--accent),var(--tertiary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{color:var(--text-secondary);font-size:15px;margin-top:10px;font-family:var(--font-ui);line-height:1.7;max-width:340px;margin-left:auto;margin-right:auto}
.home-header{display:flex;align-items:center;gap:14px;padding:16px 0 20px}
.home-header-logo{flex-shrink:0}
.home-header-logo svg{width:48px;height:48px}
.home-header-title{font-family:var(--font-heading);font-size:20px;font-weight:700;color:var(--text);line-height:1.3}
.home-header-sub{font-family:var(--font-ui);font-size:13px;color:var(--text-muted);margin-top:2px}
.home-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}
.home-summary-item{text-align:center;padding:14px 8px;border-radius:var(--radius-sm);background:var(--tertiary-subtle)}
.home-summary-num{display:block;font-family:var(--font-heading);font-size:24px;font-weight:800;color:var(--text);line-height:1}
.home-summary-lbl{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:4px}
.home-empty{text-align:center;padding:40px 20px;background:var(--surface);border-radius:var(--radius);border:1px var(--border-light) dashed}
.home-empty-icon{font-size:52px;margin-bottom:12px;opacity:.35}
.home-empty-title{font-family:var(--font-heading);font-size:17px;font-weight:600;color:var(--text);margin-bottom:4px}
.home-empty-desc{font-family:var(--font-ui);font-size:13px;color:var(--text-muted);margin-bottom:18px}

/* ─── Cards ─── */
.card{background:var(--surface);border-radius:var(--radius);padding:22px;transition:all var(--transition-bounce);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);position:relative}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.5),transparent);border-radius:var(--radius) var(--radius) 0 0;pointer-events:none}
[data-theme="dark"] .card::before{background:linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent)}
.card.clickable{cursor:pointer}
.card.clickable:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.card.clickable:active{transform:translateY(-1px) scale(.99)}
.glass-card{background:var(--surface-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px;transition:all var(--transition)}
.glass-card:hover{box-shadow:var(--shadow-lg)}

/* ─── Text Utilities ─── */
.muted{color:var(--text-muted);font-size:12px;font-family:var(--font-ui)}
.dot{color:var(--text-muted);margin:0 4px;font-size:10px}
.tag{font-family:var(--font-ui);font-size:11px;padding:4px 14px;border-radius:20px;background:var(--tertiary-glow);color:var(--tertiary);font-weight:500;border:1px solid var(--border)}

/* ─── Section Title ─── */
.section-title{font-family:var(--font-heading);font-size:16px;font-weight:700;margin-bottom:14px;color:var(--primary);display:flex;align-items:center;gap:8px;letter-spacing:-.2px}
.section{margin-top:28px}
.section:first-of-type{margin-top:0}

/* ─── Lists ─── */
.khatma-list,.book-list,.wirds-list{display:flex;flex-direction:column;gap:14px}

/* ─── Empty State ─── */
.empty-state{text-align:center;padding:60px 20px}
.empty-icon{font-size:64px;margin-bottom:16px;opacity:.4;filter:grayscale(.3)}
.empty-sub{color:var(--text-muted);font-size:13px;margin-top:8px;font-family:var(--font-ui);line-height:1.6}

/* ─── Buttons ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:var(--radius);font-family:var(--font-heading);font-weight:600;font-size:14px;border:none;cursor:pointer;transition:all var(--transition-bounce);text-decoration:none;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.2) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.btn:hover::after{opacity:1}
.btn:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,0.12)}
.btn:active{transform:scale(.96)}
.btn-gold{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;box-shadow:0 4px 20px var(--accent-glow);font-weight:700}
.btn-gold:hover{box-shadow:var(--shadow-glow-lg);background:linear-gradient(135deg,var(--accent-dark),var(--accent))}
.btn-outline{background:transparent;color:var(--text-secondary);border:2px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);box-shadow:0 4px 16px var(--accent-glow)}
.btn-full{width:100%;justify-content:center}
.btn-danger{width:100%;padding:14px;border-radius:var(--radius);border:2px solid var(--danger);color:var(--danger);background:transparent;font-family:var(--font-ui);font-weight:600;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--transition)}
.btn-danger:hover{background:var(--danger-bg);transform:translateY(-2px);box-shadow:0 4px 16px rgba(220,38,38,0.15)}
.btn-ghost-sm{background:transparent;border:2px solid var(--border);color:var(--text-secondary);padding:8px 18px;border-radius:var(--radius-sm);font-size:13px;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all var(--transition);font-family:var(--font-ui);font-weight:500}
.btn-ghost-sm:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-1px)}
.btn-sm{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-family:var(--font-heading);font-weight:600;font-size:13px;border:none;cursor:pointer;transition:all var(--transition)}
.btn-icon-sm{padding:6px 14px;border-radius:var(--radius-sm);background:transparent;border:2px solid var(--border);color:var(--text-secondary);cursor:pointer;font-family:var(--font-ui);transition:all var(--transition)}
.btn-icon-sm:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn:disabled::after{display:none}

/* ─── Pills / Badges ─── */
.pill{display:inline-block;padding:4px 16px;border-radius:20px;font-family:var(--font-ui);font-weight:500;font-size:11px;border:1px solid transparent;transition:all var(--transition)}
.pill-active{background:var(--accent-subtle);color:var(--accent);border-color:var(--accent-glow)}
.pill-completed{background:var(--primary-glow);color:var(--primary);border-color:var(--border)}
.pill-paused{background:var(--surface-hover);color:var(--text-muted);border-color:var(--border)}

/* ─── Progress ─── */
.kh-card-head,.kh-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.kh-card-title,.kh-title{font-family:var(--font-heading);font-size:15px;font-weight:600;line-height:1.3;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-left:10px}
.kh-card-book,.kh-book{font-size:12px;color:var(--text-muted);font-family:var(--font-ui);margin-bottom:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kh-card-date,.kh-date{margin-top:10px;font-family:var(--font-ui);font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.khatma-card{padding:18px 20px!important}
.progress-label{display:flex;justify-content:space-between;font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-bottom:6px}
.progress-pct{font-weight:700;color:var(--text)}
.progress-bar{height:6px;background:var(--border);border-radius:4px;overflow:hidden;position:relative}
.progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--accent-light));transition:width .8s cubic-bezier(.4,0,.2,1);position:relative}
.progress-fill::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}

/* ─── Search ─── */
.search-box{position:relative;margin-bottom:16px}
.search-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex}
.search-input{width:100%;padding:14px 48px 14px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:14px;color:var(--text);outline:none;transition:all var(--transition)}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow),0 2px 12px rgba(154,138,186,0.08);background:var(--surface)}

/* ─── Chips ─── */
.chips{display:flex;gap:8px;overflow-x:auto;padding:4px 0 16px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{white-space:nowrap;padding:8px 22px;border-radius:24px;font-family:var(--font-ui);font-size:12px;font-weight:500;border:2px solid var(--border);cursor:pointer;transition:all var(--transition-bounce);background:var(--surface);color:var(--text-secondary)}
.chip:hover{border-color:var(--tertiary);color:var(--tertiary);transform:translateY(-1px)}
.chip.active{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;border-color:var(--accent);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}

/* ─── Book Items ─── */
.book-item{display:flex;align-items:center;gap:14px}
.book-cover-small{width:52px;height:74px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;background:linear-gradient(145deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 4px 16px var(--primary-glow);transition:all var(--transition);position:relative;overflow:hidden}
.book-cover-small .cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:10px}
.book-cover-small .cover-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.book-item:hover .book-cover-small{transform:scale(1.08) rotate(-2deg);box-shadow:0 8px 24px rgba(46,44,56,.2)}
.book-item:hover .book-cover-small .cover-img{transform:scale(1.1)}
.book-info{flex:1;min-width:0}
.book-title{font-family:var(--font-heading);font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}
.book-author{color:var(--text-muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-ui);margin-top:3px}
.book-meta{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}
.book-meta span{color:var(--text-muted);font-size:11px;font-family:var(--font-ui)}
.chevron{color:var(--text-muted);display:flex;font-size:18px;transition:all var(--transition)}
.book-item:hover .chevron{color:var(--accent);transform:translateX(-4px)}

/* ─── Book Hero / Detail ─── */
.book-hero{text-align:center;padding:24px 0}
.book-cover-large{width:120px;height:170px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:42px;margin:0 auto 24px;background:linear-gradient(145deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 12px 40px rgba(46,44,56,.2);position:relative;overflow:hidden}
.book-cover-large::after{content:'';position:absolute;bottom:-10px;left:15%;right:15%;height:16px;background:radial-gradient(ellipse at center,rgba(46,44,56,.18) 0%,transparent 70%);border-radius:50%;filter:blur(8px);transition:all .3s}
.book-cover-large .cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius);transition:transform .4s ease}
.book-cover-large .cover-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.book-hero:hover .book-cover-large::after{opacity:.6;transform:scaleY(1.5)}
.book-hero:hover .cover-img{transform:scale(1.04)}
.book-detail-title{font-family:var(--font-heading);font-size:24px;font-weight:700;letter-spacing:-.5px;line-height:1.3}
.book-detail-author{color:var(--text-secondary);font-size:15px;margin-top:8px;font-family:var(--font-ui)}
.book-detail-meta{display:flex;justify-content:center;gap:10px;align-items:center;margin-top:14px;color:var(--text-muted);font-size:13px;flex-wrap:wrap}
.book-desc{font-size:15px;line-height:2.2;color:var(--text-secondary);font-family:var(--font-body)}

/* ─── Stats Grid ─── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:20px 0}
.stat{text-align:center;padding:14px 6px;border-radius:var(--radius-sm);background:var(--surface-hover);transition:all var(--transition);position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,var(--accent-glow) 0%,transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none}
.stat:hover::before{opacity:1}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.stat-val{font-family:var(--font-heading);font-size:24px;font-weight:800;color:var(--primary);position:relative}
.stat-lbl{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:4px;position:relative}

/* ─── Button Group ─── */
.btn-group{display:flex;gap:12px;margin-top:20px}

/* ─── Form ─── */
.form-card{max-width:400px;margin:0 auto}
.form-title{font-family:var(--font-heading);font-size:20px;font-weight:700;margin-bottom:24px;color:var(--primary)}
.form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:6px}
.label{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-secondary)}
.input{width:100%;padding:14px 18px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:14px;color:var(--text);outline:none;transition:all var(--transition)}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow),0 2px 12px rgba(154,138,186,0.06);background:var(--surface)}
.input:hover{border-color:var(--text-muted)}
select.input{font-family:var(--font-ui);cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239c94a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 14px center;padding-left:40px}
textarea.input{resize:vertical;min-height:80px;line-height:1.6}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ─── Book Info Bar ─── */
.book-info-bar{background:var(--tertiary-subtle);border-radius:var(--radius-sm);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;font-size:13px;font-family:var(--font-ui);border:1px solid var(--tertiary-glow)}
.est-days{color:var(--tertiary);font-weight:700}
.error{color:var(--danger);font-family:var(--font-ui);font-size:12px;text-align:center;padding:8px;background:var(--danger-bg);border-radius:8px}

/* ─── Khatma Detail ─── */
.khatma-header{margin-bottom:16px}
.kh-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.kh-title{font-family:var(--font-heading);font-size:18px;font-weight:700;line-height:1.3}
.progress-section{margin-top:14px}
.khatma-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:20px}
.khatma-stats .stat{background:var(--surface);padding:14px 8px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.khatma-stats .stat-val{font-size:22px;font-weight:800;color:var(--primary);line-height:1.2}
.khatma-stats .stat-val small{font-size:13px;color:var(--text-muted);font-weight:600}
.khatma-stats .stat-lbl{font-size:11px;color:var(--text-secondary);margin-top:4px;font-weight:600}
.rdr2-zm-btn{width:34px;height:34px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:var(--font-ui);line-height:1}
.rdr2-zm-btn:hover:not(:disabled){background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}
.rdr2-zm-btn:active:not(:disabled){transform:scale(.95)}
.rdr2-zm-btn:disabled{opacity:.35;cursor:not-allowed}
.rdr2-zm-input{width:48px;text-align:center;font-family:var(--font-heading);font-weight:700;font-size:16px;color:var(--text);background:transparent;border:none;outline:none;-moz-appearance:textfield}
.rdr2-zm-input::-webkit-outer-spin-button,.rdr2-zm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.today-btn{margin-top:0;margin-bottom:16px;position:relative}
.today-btn::after{content:'';position:absolute;inset:-3px;border-radius:calc(var(--radius) + 3px);background:linear-gradient(135deg,var(--accent),transparent 40%,var(--accent-light));z-index:-1;opacity:0;transition:opacity .4s}
.today-btn:hover::after{opacity:.5}

/* ─── Done Banner ─── */
.done-banner{text-align:center;padding:16px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--success-bg),var(--success-bg));color:var(--success);font-family:var(--font-ui);font-weight:600;font-size:14px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--success-glow);position:relative;overflow:hidden}
.done-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);animation:shimmer 3s infinite}

/* ─── Wird Items ─── */
.wird-item{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--radius);transition:all var(--transition);border:2px solid transparent;margin-bottom:4px;cursor:pointer;background:var(--surface);box-shadow:var(--shadow-sm)}
.wird-item:hover{background:var(--surface-hover);transform:translateX(-4px);box-shadow:var(--shadow)}
.wird-item.today{background:linear-gradient(135deg,var(--accent-glow),var(--accent-subtle));border-color:var(--accent-glow);box-shadow:0 2px 16px var(--accent-glow)}
.wird-item.done{background:linear-gradient(135deg,var(--success-bg),transparent);border-color:var(--success-glow)}
.wird-num{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:14px;flex-shrink:0}
.wird-item:not(.done):not(.today) .wird-num{border:2px solid var(--border);color:var(--text-muted)}
.wird-item.today .wird-num{border:2px solid var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:var(--accent-subtle)}
.wird-item.done .wird-num{background:linear-gradient(135deg,var(--success),var(--tertiary-dark));color:#fff;border-color:var(--success);box-shadow:0 2px 8px var(--success-glow)}
.wird-info{flex:1;font-size:13px}
.wird-day{font-family:var(--font-ui);color:var(--text-muted);font-weight:500}
.wird-pages{color:var(--text-muted);font-family:var(--font-ui)}
.wird-check{color:var(--accent);font-size:20px;font-weight:700}
.wird-tag{padding:4px 16px;border-radius:20px;font-family:var(--font-ui);font-size:10px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;box-shadow:0 2px 8px var(--accent-glow);letter-spacing:.3px}

/* ─── Reader ─── */
.reader-page{animation:fadeUp .3s ease}
.rdr-root{position:fixed;inset:0;overflow:hidden;background:var(--rdr-bg);user-select:none;font-family:var(--font-ui)}
.rdr-screen{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}
.rdr-screen canvas{flex-shrink:0;border-radius:2px;position:relative;z-index:1}
.rdr-side{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:48px;height:120px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .25s;opacity:0;background:rgba(0,0,0,0.04);color:var(--text-muted)}
.rdr-side-prev{left:0;border-radius:0 12px 12px 0}
.rdr-side-next{right:0;border-radius:12px 0 0 12px}
.rdr-screen:hover .rdr-side{opacity:1}
.rdr-screen:hover .rdr-side:hover{background:rgba(0,0,0,0.08);color:var(--text)}
.rdr-side:disabled{display:none}
.rdr-ui{position:absolute;inset:0;display:flex;flex-direction:column;z-index:10;transition:opacity .2s;pointer-events:none}
.rdr-ui-inner,.rdr-mid,.rdr-bot,.rdr-top{pointer-events:auto}
.rdr-hide{opacity:0!important;pointer-events:none!important}
.rdr-top{flex-shrink:0}
.rdr-progress{height:3px;background:rgba(0,0,0,0.08);overflow:hidden}
.rdr-progress-fill{height:100%;background:var(--accent);transition:width .4s ease}
.rdr-top-inner{display:flex;align-items:center;padding:6px 8px;gap:4px;background:linear-gradient(180deg,rgba(15,23,42,0.95),rgba(15,23,42,0.85));border-bottom:1px solid rgba(255,255,255,0.06)}
.rdr-icn{width:36px;height:36px;border-radius:10px;border:none;background:transparent;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all .12s;flex-shrink:0}
.rdr-icn:hover{background:rgba(255,255,255,0.08)}
.rdr-title{font-size:13px;font-weight:600;color:var(--text);text-align:center;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rdr-mid{flex:1}
.rdr-bot{flex-shrink:0;background:linear-gradient(0deg,rgba(15,23,42,0.98),rgba(15,23,42,0.88));border-top:1px solid rgba(255,255,255,0.06)}
.rdr-bot-inner{display:flex;align-items:center;justify-content:space-between;padding:6px 12px}
/* Light reading theme overrides for nav bars */
.rdr-light .rdr-top-inner{background:linear-gradient(180deg,rgba(255,255,255,0.95),rgba(255,255,255,0.85));border-bottom-color:rgba(0,0,0,0.04)}
.rdr-light .rdr-bot{background:linear-gradient(0deg,rgba(255,255,255,0.98),rgba(255,255,255,0.88));border-top-color:rgba(0,0,0,0.04)}
.rdr-light .rdr-icn:hover{background:rgba(0,0,0,0.05)}
.rdr-page-btn{width:44px;height:44px;border-radius:50%;border:none;background:var(--surface);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.rdr-page-btn:hover{background:var(--surface-hover);color:var(--text)}
.rdr-page-btn:disabled{opacity:.2;cursor:default;box-shadow:none}
.rdr-page-info{font-size:13px;font-weight:600;color:var(--text-muted);font-family:var(--font-ui)}
.rdr-zoom-row{display:flex;align-items:center;justify-content:center;gap:4px;padding:4px 0}
.rdr-icn-sm{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .12s}
.rdr-icn-sm:hover{background:rgba(0,0,0,0.05);color:var(--text)}
.rdr-zoom-lbl{font-size:12px;font-weight:600;color:var(--text-muted);min-width:36px;text-align:center}
.rdr-nav{display:flex;justify-content:space-around;padding:2px 0 4px;border-top:1px solid var(--border-light);margin-top:4px}
.rdr-nav-item{display:flex;flex-direction:column;align-items:center;gap:1px;padding:4px 16px 6px;border-radius:12px;border:none;background:transparent;color:var(--text-muted);font-size:10px;font-family:var(--font-ui);cursor:pointer;transition:all .12s}
.rdr-nav-item:hover{color:var(--accent)}
.rdr-nav-item .material-symbols-outlined{font-size:20px}
.rdr-wird-row{display:flex;justify-content:space-between;padding:8px 14px;margin:4px 10px;background:var(--accent-subtle);border-radius:10px;font-size:12px;font-weight:600;color:var(--accent)}
.rdr-done{width:100%;padding:12px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;font-weight:700;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .12s}
.rdr-done:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}

/* ─── Tablet+ ─── */
@media(min-width:600px){
.rdr-top-inner{padding:10px 16px;gap:10px}
.rdr-icn{width:42px;height:42px;border-radius:12px;font-size:22px}
.rdr-title{font-size:15px}
.rdr-bot-inner{padding:10px 20px}
.rdr-page-btn{width:52px;height:52px}
.rdr-page-info{font-size:15px}
.rdr-zoom-row{padding:6px 0}
.rdr-icn-sm{width:38px;height:38px;font-size:18px}
.rdr-zoom-lbl{font-size:13px}
.rdr-nav{gap:12px;padding:6px 0 8px}
.rdr-nav-item{font-size:11px;padding:6px 24px 8px}
.rdr-nav-item .material-symbols-outlined{font-size:22px}
.rdr-wird-row{padding:10px 18px;font-size:13px}
.rdr-jump-input{font-size:15px;width:46px}
}

/* ─── Mobile Touch Target Minimums ─── */
@media(max-width:599px){
  .rdr-icn{width:44px;height:44px;min-width:44px;min-height:44px}
  .rdr-icn-sm{width:44px;height:44px;min-width:44px;min-height:44px;font-size:18px}
  .rdr-page-btn{width:44px;height:44px;min-width:44px;min-height:44px}
  .rdr-nav-item{padding:8px 14px 8px;min-height:44px;display:flex;align-items:center;justify-content:center}
  .rdr-jump-input{width:48px;padding:8px 4px;font-size:14px}
  .rdr-done{padding:14px;font-size:15px;min-height:48px}
}

/* ─── Rendering Overlay ─── */
.rdr-rendering{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:5;background:var(--rdr-bg);opacity:.85;transition:opacity .2s}
.rdr-rendering .splash-loader div{width:8px;height:8px}

/* ─── Page Jump Input ─── */
.rdr-page-info{display:flex;align-items:center;gap:4px}
.rdr-jump-input{width:38px;padding:4px 2px;border:none;border-bottom:2px solid var(--border);background:transparent;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text);text-align:center;outline:none;transition:border-color .2s;direction:ltr;-moz-appearance:textfield}
.rdr-jump-input::-webkit-outer-spin-button,.rdr-jump-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.rdr-jump-input:focus{border-color:var(--accent)}
.rdr-page-sep{color:var(--text-muted);font-size:13px}
.rdr-page-total{color:var(--text-muted);font-size:13px;font-weight:600}

/* ─── Flip Animation ─── */
.rdr-flip-next{animation:flipNext .35s cubic-bezier(.34,1.56,.64,1)}
.rdr-flip-prev{animation:flipPrev .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes flipNext{from{opacity:.6;transform:perspective(600px) rotateY(-6deg) scale(.98)}to{opacity:1;transform:perspective(600px) rotateY(0) scale(1)}}
@keyframes flipPrev{from{opacity:.6;transform:perspective(600px) rotateY(6deg) scale(.98)}to{opacity:1;transform:perspective(600px) rotateY(0) scale(1)}}

/* ─── Desktop ─── */
@media(min-width:1024px){
.rdr-root{background:var(--rdr-bg)}
.rdr-screen canvas{border-radius:4px;box-shadow:0 8px 60px rgba(0,0,0,0.1),0 2px 12px rgba(0,0,0,0.06);transition:all .3s}
.rdr-screen canvas:hover{box-shadow:0 12px 80px rgba(0,0,0,0.12),0 4px 16px rgba(0,0,0,0.08)}
.rdr-side{width:56px;height:160px;opacity:0}
.rdr-side-prev{border-radius:0 16px 16px 0}
.rdr-side-next{border-radius:16px 0 0 16px}
.rdr-top-inner{padding:14px 28px;gap:14px}
.rdr-icn{width:44px;height:44px;border-radius:12px;font-size:24px}
.rdr-title{font-size:17px;font-weight:700}
.rdr-bot-inner{padding:14px 28px}
.rdr-page-btn{width:56px;height:56px;transition:all .15s}
.rdr-page-btn:hover{transform:scale(1.06);box-shadow:0 4px 16px rgba(0,0,0,0.1)}
.rdr-page-info{font-size:16px}
.rdr-zoom-row{gap:8px}
.rdr-nav{padding:8px 0 10px}
.rdr-nav-item{padding:8px 32px 10px;font-size:12px}
}

/* ─── Dark Mode PDF Inversion ─── */
[data-theme="dark"] .rdr-light .rdr-screen canvas {
  filter: invert(0.88) hue-rotate(180deg) brightness(0.92) contrast(0.95);
}
[data-theme="dark"] .rdr-rendering {
  background: #2a2828 !important;
}

/* ─── Profile ─── */
.profile-header{text-align:center;padding:28px 0}
.avatar{width:84px;height:84px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 18px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 8px 28px rgba(46,44,56,.15);border:3px solid var(--accent)}
.profile-name{font-family:var(--font-heading);font-size:22px;font-weight:700;letter-spacing:-.3px}
.profile-email{color:var(--text-muted);font-size:13px;margin-top:6px;font-family:var(--font-ui)}
.profile-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px;padding:20px}
.profile-stats .stat{background:var(--accent-subtle);padding:18px 14px;border-radius:var(--radius-sm)}
.profile-stats .stat-val{font-size:26px}
.version{text-align:center;color:var(--text-muted);font-size:11px;margin-top:24px;font-family:var(--font-ui)}

/* ─── Skeleton ─── */
.skel{background:linear-gradient(90deg,var(--border-light) 25%,var(--bg-warm) 50%,var(--border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
.skel-list{display:flex;flex-direction:column;gap:12px}

/* ─── Toast ─── */
#toast-container{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:380px;width:calc(100% - 32px)}
.toast{padding:14px 22px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:13px;font-weight:500;box-shadow:0 8px 40px rgba(0,0,0,0.18);opacity:0;transform:translateY(-16px) scale(.95);transition:all .35s cubic-bezier(.34,1.56,.64,1);pointer-events:auto;text-align:center;direction:rtl;border:1px solid rgba(255,255,255,0.1)}
.toast-show{opacity:1;transform:translateY(0) scale(1)}
.toast-info{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#1a1528;font-weight:600}
.toast-success{background:linear-gradient(135deg,var(--success),var(--tertiary));color:#fff}
.toast-error{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}

/* ─── Transitions ─── */
.fade-enter-active,.fade-leave-active{transition:all .25s cubic-bezier(.4,0,.2,1)}
.fade-enter-from{opacity:0;transform:translateY(10px)}
.fade-leave-to{opacity:0;transform:translateY(-10px)}
.page-enter-active,.page-leave-active{transition:all .25s cubic-bezier(.4,0,.2,1)}
.page-enter-from{opacity:0;transform:translateX(30px)}
.page-leave-to{opacity:0;transform:translateX(-30px)}

/* ─── Theme Toggle ─── */
.theme-toggle{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);font-size:20px;flex-shrink:0}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);transform:scale(1.05);box-shadow:0 2px 12px var(--accent-glow)}
.theme-toggle:active{transform:scale(.85) rotate(15deg)}

/* ═══════════════════════════════════
   PREMIUM ENHANCEMENTS
   ═══════════════════════════════════ */

/* ─── Custom Scrollbar ─── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px;border:1px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted);background-clip:content-box}

/* ─── Scale-in Entrance ─── */
.scale-in{animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1) both}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}

/* ─── Slide-up Stagger ─── */
.slide-up{animation:slideUp .5s cubic-bezier(.34,1.56,.64,1) both}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}
.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}.delay-6{animation-delay:.3s}
.delay-7{animation-delay:.35s}.delay-8{animation-delay:.4s}.delay-9{animation-delay:.45s}
.delay-10{animation-delay:.5s}

/* ─── Gold Shimmer ─── */
.skel-gold{background:linear-gradient(90deg,var(--accent-glow) 25%,var(--gold) 50%,var(--accent-glow) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}

/* ─── Pulse Glow ─── */
.pulse-glow{animation:pulseGlow 2s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 10px transparent}}

/* ─── Count Up Animation ─── */
.count-up{animation:countUp .6s cubic-bezier(.34,1.56,.64,1) both}
@keyframes countUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ─── Glass Premium ─── */
.glass-premium{background:var(--surface-glass);backdrop-filter:blur(30px) saturate(1.3);-webkit-backdrop-filter:blur(30px) saturate(1.3);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(46,44,56,0.06),inset 0 1px 0 rgba(255,255,255,0.5)}

/* ─── Card Press ─── */
.card-press{transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s ease}
.card-press:active{transform:scale(.97)}

/* ─── Gold Border Hover ─── */
.hover-gold{border:2px solid transparent;transition:all var(--transition)}
.hover-gold:hover{border-color:var(--accent);box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-3px)}

/* ─── Ripple Button ─── */
.btn-ripple{position:relative;overflow:hidden}
.btn-ripple::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.25) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.btn-ripple:active::after{opacity:1}

/* ─── Gold Dot ─── */
.gold-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;animation:pulse-dot 2s infinite;box-shadow:0 0 6px var(--accent-glow)}



/* ─── Badge Bounce ─── */
.badge-bounce{animation:badgeBounce .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes badgeBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}100%{transform:scale(1)}}

/* ─── Progress Pulse ─── */
.progress-pulse{animation:progressPulse 2s ease-in-out infinite}
@keyframes progressPulse{0%,100%{opacity:1}50%{opacity:.7}}

/* ─── Fade-up Cards ─── */
.fade-up{animation:fadeUp .5s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeOut{from{opacity:1}to{opacity:0}}
.splash-leave{animation:fadeOut .4s ease forwards}

/* ─── Bottom Nav Active Bounce ─── */
.nav-item.active .material-symbols-outlined{animation:navBounce .4s cubic-bezier(.34,1.56,.64,1)}
@keyframes navBounce{0%{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.15)}100%{transform:translateY(-3px) scale(1)}}

/* ─── Reader Canvas Glow ─── */
.reader-card canvas{border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,0.06),0 1px 4px rgba(0,0,0,0.04);transition:all .3s ease}
.reader-card canvas:hover{box-shadow:0 4px 24px rgba(0,0,0,0.1)}

/* ─── Wird Item Entrance ─── */
.wird-item{animation:wirdSlide .4s cubic-bezier(.34,1.56,.64,1) both}
@keyframes wirdSlide{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}

/* ─── Reader Empty State Float ─── */
.reader-page .empty-icon{animation:emptyFloat 4s ease-in-out infinite}
@keyframes emptyFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ─── Section Title Icon Sparkle ─── */
.section-title .material-symbols-outlined{color:var(--tertiary);font-variation-settings:'FILL' 1}

/* ─── Gold Separator ─── */
.gold-sep{height:2px;background:linear-gradient(90deg,transparent,var(--tertiary),transparent);margin:20px 0;border-radius:2px;opacity:.4}

/* ─── Wird Done Celebration ─── */
.wird-item.done{position:relative}
.wird-item.done::after{content:'✓';position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--success);font-weight:700;animation:badgeBounce .4s cubic-bezier(.34,1.56,.64,1);text-shadow:0 2px 8px var(--success-glow)}

/* ─── Chevron Slide ─── */
.chevron{transition:transform .3s cubic-bezier(.34,1.56,.64,1),color .3s}
.card.clickable:hover .chevron{transform:translateX(-6px)}

/* ─── App Shell Background ─── */
.app-shell{min-height:100dvh;background:var(--bg);background-image:var(--bg-mesh)}

/* ─── Enhanced Glass Card ─── */
.glass-card:not(.form-card){position:relative}
.glass-card:not(.form-card)::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);border-radius:var(--radius-lg) var(--radius-lg) 0 0;pointer-events:none}
[data-theme="dark"] .glass-card:not(.form-card)::before{background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)}

/* ─── Card Gradient Border ─── */
.card-border-gold{position:relative;background-clip:padding-box;border:1px solid transparent}
.card-border-gold::before{content:'';position:absolute;inset:0;border-radius:var(--radius);padding:1px;background:linear-gradient(135deg,var(--accent),var(--accent-light),var(--accent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* ─── shimmer keyframes used throughout ─── */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ─── Premium Gradient Text ─── */
.text-gold{background:linear-gradient(135deg,var(--accent),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* ─── Floating Action Button ─── */
.fab{position:fixed;bottom:80px;left:20px;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px var(--accent-glow);transition:all var(--transition-bounce);z-index:40}
.fab:hover{transform:translateY(-4px);box-shadow:0 8px 32px var(--accent-glow)}
.fab:active{transform:scale(.92)}
.fab .material-symbols-outlined{font-size:28px}

/* ─── Attendtion / Notice ─── */
.notice{padding:14px 18px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:13px;display:flex;align-items:center;gap:10px;margin-bottom:12px}
.notice-info{background:var(--tertiary-subtle);color:var(--tertiary);border:1px solid var(--tertiary-glow)}
.notice-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(45,125,70,.12)}
.notice-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(220,38,38,.12)}

/* ─── Modal Overlay ─── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease;backdrop-filter:blur(4px)}
.modal-box{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);max-width:400px;width:100%;padding:24px;box-shadow:var(--shadow-xl);animation:slideUp .25s cubic-bezier(.34,1.56,.64,1)}
.modal-title{font-family:var(--font-heading);font-size:18px;font-weight:700;margin-bottom:12px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ─── Page Turn Loading ─── */
.page-turn{animation:pageTurn .6s ease}
@keyframes pageTurn{0%{opacity:0;transform:perspective(800px) rotateY(-8deg)}100%{opacity:1;transform:perspective(800px) rotateY(0)}}

/* ─── Skeleton Card ─── */
.skel-card{background:var(--surface);border-radius:var(--radius);padding:20px;border:1px solid var(--border-light)}

/* ═══════════════════════════════════════════
   PDF READER — Premium Edition v3
   ═══════════════════════════════════════════ */
/* ─── Root & Themes ─── */
.rdr-root{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden;font-family:system-ui,-apple-system,sans-serif;user-select:none;-webkit-user-select:none;color:#fff;background:#111827}
.rdr-root *{box-sizing:border-box;tap-highlight-color:transparent;-webkit-tap-highlight-color:transparent}

/* ─── Error / Loading ─── */
.rdr-err{position:fixed;inset:0;background:#111827;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;z-index:100}
.rdr-btn-back{display:inline-flex;align-items:center;gap:8px;padding:14px 36px;border-radius:50px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(255,255,255,.55);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.rdr-btn-back:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.2);color:#fff}
.rdr-spinner{display:flex;gap:7px}.rdr-spinner span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.25);animation:rdrBounce 1.4s infinite}.rdr-spinner span:nth-child(2){animation-delay:.18s}.rdr-spinner span:nth-child(3){animation-delay:.36s}@keyframes rdrBounce{0%,80%,100%{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:.8}}
.rdr-load-bar{width:180px;height:2px;background:rgba(255,255,255,.06);border-radius:1px;overflow:hidden;margin-top:16px}.rdr-load-fill{height:100%;background:var(--accent);border-radius:1px;transition:width .4s ease}

/* ─── Book progress ─── */
.rdr-book-progress{position:absolute;top:0;left:0;right:0;height:2px;background:transparent;z-index:20}.rdr-book-progress-fill{height:100%;background:var(--accent);transition:width .5s ease}

/* ─── Header ─── */
.rdr-hdr{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;gap:6px;padding:6px 8px;padding-top:max(6px,env(safe-area-inset-top));transition:opacity .4s ease,transform .4s ease}
.rdr-hdr.off{opacity:0;pointer-events:none;transform:translateY(-20px)}
.rdr-btn{width:38px;height:38px;border-radius:50%;border:none;background:rgba(255,255,255,.06);color:rgba(255,255,255,.45);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.rdr-btn:hover{color:#fff;background:rgba(255,255,255,.12)}.rdr-btn:active{transform:scale(.9)}.rdr-btn.on{color:var(--accent);background:var(--accent-subtle)}.rdr-light .rdr-btn{color:rgba(0,0,0,.45);background:rgba(0,0,0,.04)}.rdr-light .rdr-btn:hover{color:#000;background:rgba(0,0,0,.08)}.rdr-light .rdr-btn.on{color:var(--accent);background:var(--accent-subtle)}
.rdr-hdr-center{flex:1;min-width:0;text-align:center;padding:0 4px}.rdr-book-name{display:block;font-size:12px;font-weight:600;color:rgba(255,255,255,.5);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.1px}.rdr-light .rdr-book-name{color:rgba(0,0,0,.5)}.rdr-page-num{font-size:9px;color:rgba(255,255,255,.2);margin-top:1px;display:block;font-weight:500}.rdr-light .rdr-page-num{color:rgba(0,0,0,.25)}.rdr-hdr-actions{display:flex;gap:2px}

/* ─── Settings Sheet ─── */
.rdr-settings{position:absolute;bottom:0;left:0;right:0;z-index:15;background:rgba(15,23,42,.98);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-radius:24px 24px 0 0;padding:8px 20px 32px;padding-bottom:max(32px,calc(24px + env(safe-area-inset-bottom)));transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);box-shadow:0 -8px 40px rgba(0,0,0,.3)}
.rdr-light .rdr-settings{background:rgba(255,255,255,.97);box-shadow:0 -8px 40px rgba(0,0,0,.1)}.rdr-settings.open{transform:translateY(0)}.rdr-settings-handle{width:32px;height:4px;background:rgba(255,255,255,.15);border-radius:2px;margin:8px auto 16px}.rdr-light .rdr-settings-handle{background:rgba(0,0,0,.12)}.rdr-settings-title{font-size:17px;font-weight:800;margin-bottom:20px;color:rgba(255,255,255,.85)}.rdr-light .rdr-settings-title{color:rgba(0,0,0,.8)}
.rdr-settings-section{margin-bottom:20px}.rdr-settings-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:rgba(255,255,255,.5);margin-bottom:12px}.rdr-light .rdr-settings-label{color:rgba(0,0,0,.5)}.rdr-settings-label i{font-size:16px}
.rdr-prem-lock{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;color:var(--gold);margin-right:auto;background:rgba(245,158,11,.1);padding:3px 8px;border-radius:8px}.rdr-reset-btn{padding:8px 20px;border-radius:20px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(255,255,255,.45);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.rdr-reset-btn:hover{border-color:rgba(255,255,255,.25);color:#fff}
/* Theme grid */
.rdr-theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.rdr-theme-opt{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;border-radius:14px;border:1px solid rgba(255,255,255,.06);background:transparent;color:rgba(255,255,255,.35);font-size:10px;font-weight:600;cursor:pointer;transition:all .2s}.rdr-light .rdr-theme-opt{color:rgba(0,0,0,.35);border-color:rgba(0,0,0,.06)}.rdr-theme-opt:hover{border-color:rgba(255,255,255,.15);color:rgba(255,255,255,.6)}.rdr-theme-opt.active{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.rdr-theme-dot{width:26px;height:26px;border-radius:8px;border:2px solid rgba(255,255,255,.1);transition:all .2s;box-shadow:inset 0 1px 3px rgba(0,0,0,.2)}.rdr-theme-opt.active .rdr-theme-dot{border-color:var(--accent);box-shadow:inset 0 1px 3px rgba(0,0,0,.2),0 0 0 3px var(--accent-glow)}
/* Settings — desktop side panel */
@media(min-width:768px){
  .rdr-settings{position:absolute;top:0;bottom:0;right:0;left:auto;width:300px;z-index:15;background:rgba(15,23,42,.97);backdrop-filter:blur(30px);border-radius:20px 0 0 20px;padding:24px 20px 32px;transform:translateX(100%);transition:transform .35s cubic-bezier(.22,1,.36,1);box-shadow:-8px 0 40px rgba(0,0,0,.3)}
  .rdr-light .rdr-settings{background:rgba(255,255,255,.97);box-shadow:-8px 0 40px rgba(0,0,0,.08)}
  .rdr-settings.open{transform:translateX(0)}
  .rdr-settings-handle{display:none}
}

/* Font size slider */
.rdr-font-slider{display:flex;align-items:center;gap:12px;padding:8px 0}.rdr-font-step{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.08);background:transparent;color:rgba(255,255,255,.4);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.rdr-font-step:hover{border-color:rgba(255,255,255,.2);color:#fff}.rdr-font-step:active{transform:scale(.92)}.rdr-light .rdr-font-step{color:rgba(0,0,0,.4);border-color:rgba(0,0,0,.08)}.rdr-light .rdr-font-step:hover{color:#000;border-color:rgba(0,0,0,.2)}
.rdr-font-ticks{flex:1;display:flex;justify-content:space-around;align-items:center;padding:0 4px}.rdr-font-tick{font-family:serif;font-weight:700;color:rgba(255,255,255,.12);transition:all .3s}.rdr-font-tick.active{color:rgba(255,255,255,.7)}.rdr-light .rdr-font-tick{color:rgba(0,0,0,.12)}.rdr-light .rdr-font-tick.active{color:rgba(0,0,0,.7)}.rdr-font-tick.mid{font-size:18px}.rdr-font-tick.lg{font-size:22px}

/* ─── Page Area ─── */
.rdr-page{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;background:#0d1117}
.rdr-page canvas{border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.1),0 2px 30px rgba(0,0,0,.5);transition:opacity .3s ease,width .12s ease,height .12s ease,box-shadow .5s ease}
.rdr-page canvas.fading{opacity:.25}

/* ─── Tap Zones (always active) + Arrows (desktop only) ─── */
.rdr-zone{position:absolute;top:0;bottom:0;width:25%;z-index:2;display:flex;align-items:center;cursor:pointer}
.rdr-zone-next{left:0;justify-content:flex-start;padding-left:4px}
.rdr-zone-prev{right:0;justify-content:flex-end;padding-right:4px}
.rdr-arrow-icon{display:none}
.rdr-zone:hover .rdr-arrow-icon,.rdr-zone:active .rdr-arrow-icon{display:flex}
/* Selection */
.rdr-sel{position:absolute;border:2px solid rgba(239,68,68,.6);background:rgba(239,68,68,.06);border-radius:2px;pointer-events:none;z-index:3}
.rdr-sel-acts{position:absolute;transform:translate(-50%,0);display:flex;gap:6px;z-index:4;white-space:nowrap}.rdr-sel-btn{padding:9px 18px;border-radius:20px;border:none;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .15s;box-shadow:0 2px 12px rgba(0,0,0,.15)}.rdr-sel-btn.save{background:var(--accent);color:#fff}.rdr-sel-btn.share{background:#fff;color:#333}.rdr-sel-btn.cancel{background:rgba(255,255,255,.85);color:#1a1a1a}.rdr-sel-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:13px;color:rgba(255,255,255,.4);background:rgba(0,0,0,.5);padding:10px 22px;border-radius:20px;pointer-events:none;animation:fadeUp .3s ease;z-index:3}
/* Text layer for selection */
.rdr-txt-layer{position:absolute;z-index:2;pointer-events:none}
.rdr-txt-layer span{color:rgba(255,255,255,0.15)!important}
.rdr-txt-layer span::selection{background:rgba(239,68,68,.35);color:rgba(255,255,255,0.3)}
.rdr-txt-layer span::-moz-selection{background:rgba(239,68,68,.35);color:rgba(255,255,255,0.3)}

/* ─── Footer ─── */
.rdr-ftr{position:absolute;bottom:0;left:0;right:0;z-index:10;padding:6px 10px;padding-bottom:max(6px,env(safe-area-inset-bottom));transition:opacity .4s ease,transform .4s ease}.rdr-ftr.off{opacity:0;pointer-events:none;transform:translateY(20px)}
/* Wird card */
.rdr-wird{margin:0 0 8px;padding:10px 16px;background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.03);border-radius:16px;backdrop-filter:blur(8px)}.rdr-light .rdr-wird{background:rgba(0,0,0,.015);border-color:rgba(0,0,0,.04)}.rdr-wird-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:10px;font-weight:500;color:rgba(255,255,255,.3)}.rdr-wird-header span:first-child{display:flex;align-items:center;gap:4px;color:var(--accent-light)}.rdr-light .rdr-wird-header{color:rgba(0,0,0,.3)}.rdr-light .rdr-wird-header span:first-child{color:var(--accent-dark)}.rdr-wird-bar{height:3px;background:rgba(255,255,255,.04);border-radius:2px;overflow:hidden;margin-bottom:3px}.rdr-light .rdr-wird-bar{background:rgba(0,0,0,.05)}.rdr-wird-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .5s ease}.rdr-wird-footer{font-size:9px;color:rgba(255,255,255,.15);font-weight:500}.rdr-light .rdr-wird-footer{color:rgba(0,0,0,.2)}
/* Footer controls */
.rdr-ftr-row{display:flex;align-items:center;justify-content:center;gap:8px}
.rdr-ftr-page{display:flex;align-items:center;gap:3px}.rdr-ftr-page input{width:40px;padding:5px 0;border:none;background:transparent;color:rgba(255,255,255,.6);font-size:14px;font-weight:600;text-align:center;outline:none;direction:ltr;-moz-appearance:textfield}.rdr-ftr-page input::-webkit-inner-spin-button,.rdr-ftr-page input::-webkit-outer-spin-button{-webkit-appearance:none}.rdr-light .rdr-ftr-page input{color:rgba(0,0,0,.55)}.rdr-ftr-sep{font-size:12px;color:rgba(255,255,255,.1)}.rdr-light .rdr-ftr-sep{color:rgba(0,0,0,.15)}.rdr-ftr-max{font-size:12px;color:rgba(255,255,255,.18);font-weight:500}.rdr-light .rdr-ftr-max{color:rgba(0,0,0,.25)}
/* Done button */
.rdr-done{display:flex;align-items:center;justify-content:center;gap:6px;width:calc(100% - 2px);margin:8px 0 0;padding:14px;border:none;border-radius:16px;background:var(--accent);color:#fff;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 16px var(--accent-glow)}.rdr-done:hover{filter:brightness(1.08);box-shadow:0 4px 24px var(--accent-glow)}.rdr-done:active{transform:scale(.98)}

/* Render overlay + keyboard hint */
.rdr-overlay{position:absolute;inset:0;z-index:8;display:flex;align-items:center;justify-content:center;pointer-events:none}
.rdr-kbd-hint{position:absolute;bottom:60px;left:50%;transform:translateX(-50%);z-index:6;display:none;gap:16px;padding:6px 14px;background:rgba(0,0,0,.45);border-radius:8px;font-size:9px;color:rgba(255,255,255,.2);white-space:nowrap;pointer-events:none}

/* ─── Responsive ─── */
@media(min-width:768px){
  .rdr-hdr{padding:10px 20px}.rdr-btn{width:42px;height:42px}.rdr-book-name{font-size:13px}.rdr-kbd-hint{display:flex;bottom:80px}
  .rdr-page canvas{box-shadow:0 0 0 1px rgba(0,0,0,.1),0 3px 40px rgba(0,0,0,.6)}.rdr-light .rdr-page canvas{box-shadow:0 0 0 1px rgba(0,0,0,.05),0 5px 30px rgba(0,0,0,.12)}.rdr-root[data-theme="sepia"] .rdr-page canvas{box-shadow:0 0 0 1px rgba(0,0,0,.12),0 3px 36px rgba(0,0,0,.45)}
  /* Side arrows visible on tablets+ */
  .rdr-zone{width:18%}.rdr-zone-next{padding-left:16px}.rdr-zone-prev{padding-right:16px}
  .rdr-arrow-icon{display:flex;font-size:32px;width:52px;height:52px;color:rgba(255,255,255,.35);background:rgba(0,0,0,.35);border-radius:50%;align-items:center;justify-content:center;transition:all .2s ease}.rdr-zone:hover .rdr-arrow-icon{color:#fff;background:rgba(0,0,0,.55);transform:scale(1.08)}.rdr-zone:active .rdr-arrow-icon{transform:scale(.95)}.rdr-light .rdr-arrow-icon{color:rgba(0,0,0,.35);background:rgba(255,255,255,.55)}.rdr-light .rdr-zone:hover .rdr-arrow-icon{color:#000;background:rgba(255,255,255,.85)}
  .rdr-ftr{padding:8px 24px}.rdr-wird{margin:0 0 10px;padding:12px 20px}
}
@media(min-width:1024px){
  .rdr-page canvas{box-shadow:0 0 0 1px rgba(0,0,0,.12),0 4px 50px rgba(0,0,0,.7)}.rdr-light .rdr-page canvas{box-shadow:0 0 0 1px rgba(0,0,0,.04),0 6px 36px rgba(0,0,0,.14)}.rdr-root[data-theme="sepia"] .rdr-page canvas{box-shadow:0 0 0 1px rgba(0,0,0,.1),0 4px 44px rgba(0,0,0,.5)}
  .rdr-zone{width:16%}.rdr-arrow-icon{font-size:38px;width:60px;height:60px}.rdr-zone:hover .rdr-arrow-icon{background:rgba(0,0,0,.6)}
  .rdr-ftr{max-width:800px;left:50%;transform:translateX(-50%)}.rdr-ftr.off{transform:translateX(-50%) translateY(20px)}
}
@media(min-width:1024px){
  .rdr-page canvas{box-shadow:0 6px 80px rgba(0,0,0,.8)}
  .rdr-root[data-theme="light"] .rdr-page canvas{box-shadow:0 4px 50px rgba(0,0,0,.2)}
}

/* ─── Tablet (600-1023) ─── */
@media(min-width:600px) and (max-width:1023px){
  .rdr2-top{padding:8px 16px;gap:10px}
  .rdr2-btn{width:44px;height:44px}
  .rdr2-title{font-size:15px}
  .rdr2-controls{padding:10px 20px}
  .rdr2-screen canvas{border-radius:4px}
}

/* ─── Desktop (1024+) ─── */
@media(min-width:1024px){
  .rdr2-top{padding:10px 24px;gap:14px}
  .rdr2-btn{width:48px;height:48px;font-size:20px}
  .rdr2-title{font-size:17px}
  .rdr2-arrow{width:56px;height:100px;border-radius:14px}
  .rdr2-arrow-l{left:12px}.rdr2-arrow-r{right:12px}
  .rdr2-controls{padding:12px 28px}
  .rdr2-pg-btn{width:48px;height:48px}
  .rdr2-pg-btn:hover{transform:scale(1.05)}
  .rdr2-jump{font-size:15px;width:50px}
  .rdr2-screen canvas{border-radius:6px;box-shadow:0 8px 60px rgba(0,0,0,0.4)}
  .rdr2-wird{padding:10px 20px;font-size:13px}
   .rdr2-done-btn{width:calc(100% - 24px);margin:8px 12px 12px;padding:14px;font-size:15px}
}

/* ═══════════════════════════════════════════
   PREMIUM SYSTEM — premium-*, rank-*, lb-*, cert-*, theme-*, feature-*
   ═══════════════════════════════════════════ */



/* ─── Premium Gate Modal ─── */
.premium-gate-box{text-align:center}
.premium-gate-icon{font-size:48px;margin-bottom:12px;color:var(--accent)}
.premium-gate-title{font-family:var(--font-heading);font-size:18px;font-weight:700;margin-bottom:8px;color:var(--text)}
.premium-gate-desc{font-family:var(--font-ui);font-size:13px;color:var(--text-muted);margin-bottom:16px}

/* ─── Rank System ─── */
.rank-card{padding:14px 16px;margin-bottom:12px}
.rank-badge{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 10px;box-shadow:0 4px 16px rgba(0,0,0,0.1)}
.rank-badge-sm{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rank-title{font-family:var(--font-heading);font-size:16px;font-weight:700;color:var(--text)}
.rank-sub{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);margin-top:4px}
.rank-progress{height:6px;background:var(--border);border-radius:3px;margin:10px auto 4px;max-width:200px;overflow:hidden}
.rank-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .5s ease}
.rank-next{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}

/* ─── Feature List ─── */
.feature-card{display:flex;align-items:center;gap:12px;padding:14px 16px;margin-bottom:8px;transition:all var(--transition)}
.feature-card.locked{opacity:.6}
.feature-card.locked:hover{opacity:.85}
.feature-icon{font-size:24px;flex-shrink:0;width:40px;text-align:center}
.feature-info{flex:1}
.feature-name{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.feature-desc{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.feature-lock{color:var(--text-muted);font-size:18px}
.feature-check{color:var(--success);font-size:18px;font-weight:700}

/* ─── Leaderboard ─── */
.lb-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border-radius:var(--radius-sm);margin-bottom:4px;border:1px solid var(--border-light);transition:all var(--transition)}
.lb-rank{font-family:var(--font-heading);font-weight:800;font-size:16px;min-width:28px;text-align:center}
.lb-name{flex:1;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text)}
.lb-score{font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);font-weight:600}

/* ─── Certificate ─── */
.cert-card{display:flex;align-items:center;gap:12px;padding:12px 14px;margin-bottom:6px}
.cert-card-icon{font-size:28px;flex-shrink:0}
.cert-card-info{flex:1}
.cert-card-title{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.cert-card-date{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.cert-frame{background:linear-gradient(135deg,#faf5ee,#f0e8d8);border:3px double #c8922b;border-radius:12px;padding:24px;text-align:center}
.cert-stars{font-size:20px;margin-bottom:12px}
.cert-title{font-family:var(--font-heading);font-size:22px;font-weight:800;color:#3d2800;margin-bottom:12px}
.cert-text{font-family:var(--font-body);font-size:15px;color:#5c4b2e;margin-bottom:4px;line-height:2}
.cert-name{font-family:var(--font-heading);font-size:20px;font-weight:700;color:#2e1a00;margin:8px 0}
.cert-book{font-family:var(--font-heading);font-size:18px;font-weight:700;color:#5c3a1e;margin:8px 0}
.cert-code{font-family:var(--font-ui);font-size:11px;color:#8a7a5e;margin-top:12px}
.cert-date{font-family:var(--font-ui);font-size:12px;color:#8a7a5e;margin-top:4px}

/* ─── Theme Selector ─── */
.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.theme-option{padding:14px;border-radius:var(--radius);border:2px solid transparent;cursor:pointer;transition:all .2s;text-align:center}
.theme-option:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}
.theme-option.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.theme-swatch{width:32px;height:32px;border-radius:50%;margin:0 auto 8px}
.theme-name{font-family:var(--font-heading);font-size:13px;font-weight:700}
.theme-desc{font-size:10px;opacity:.7;margin-top:2px}

/* ─── Theme-based navbar color ─── */
[data-premium-theme="night"] .bottom-nav{background:rgba(22,27,34,0.95)!important;border-color:rgba(48,54,61,0.5)!important}
[data-premium-theme="oasis"] .bottom-nav{background:rgba(240,246,238,0.95)!important;border-color:rgba(200,215,200,0.5)!important}
[data-premium-theme="desert"] .bottom-nav{background:rgba(248,240,230,0.95)!important;border-color:rgba(220,200,170,0.5)!important}
[data-premium-theme="sepia"] .bottom-nav{background:rgba(240,232,210,0.95)!important;border-color:rgba(200,180,150,0.5)!important}

/* ─── Social Share Frame ─── */
.share-frame{width:100%;max-width:400px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.share-frame-header{background:linear-gradient(135deg,var(--accent),var(--accent-light));padding:16px;text-align:center;color:#fff;font-family:var(--font-heading);font-weight:700;font-size:16px}
.share-frame-body{background:var(--surface);padding:20px;text-align:center}
.share-frame-book{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}
.share-frame-pages{font-family:var(--font-ui);font-size:13px;color:var(--text-muted)}
.share-frame-footer{background:var(--surface-hover);padding:12px;text-align:center;font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}

/* ─── Animations ─── */
@keyframes rankUp{0%{transform:scale(1)}50%{transform:scale(1.15)}100%{transform:scale(1)}}
.rank-up{animation:rankUp .5s ease}

/* ─── Feature Grid ─── */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:8px}
.feature-tile{position:relative;padding:16px 14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border-light);text-decoration:none;color:var(--text);transition:all var(--transition);overflow:hidden}
.feature-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(154,138,186,0.03));opacity:0;transition:opacity .3s}
.feature-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.feature-tile:hover::after{opacity:1}
.feature-tile.locked{opacity:.55;filter:grayscale(.3)}
.feature-tile.locked:hover{opacity:.75;filter:grayscale(0);border-color:var(--border)}
.feature-tile-icon{font-size:28px;margin-bottom:8px}
.feature-tile-name{font-family:var(--font-heading);font-size:13px;font-weight:600;margin-bottom:4px;color:var(--text)}
.feature-tile-desc{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);line-height:1.5}
.feature-lock-icon{position:absolute;top:8px;left:8px;font-size:14px;opacity:.7}

/* ─── Leaderboard Tabs ─── */
.lb-tabs{display:flex;gap:6px;margin-bottom:10px}
.lb-tab{padding:6px 16px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-family:var(--font-ui);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition)}
.lb-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.lb-tab:hover:not(.active){border-color:var(--accent);color:var(--accent)}
.lb-list{display:flex;flex-direction:column;gap:4px}
.lb-item{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:all var(--transition)}
.lb-item:hover{transform:translateX(-4px);border-color:var(--accent)}
.lb-pos{font-family:var(--font-heading);font-weight:800;font-size:15px;min-width:26px;text-align:center;color:var(--text-muted)}
.lb-pos.pos1{color:#c8922b;font-size:18px}
.lb-pos.pos2{color:#aaa;font-size:16px}
.lb-pos.pos3{color:#b87a4a;font-size:15px}
.lb-user{flex:1;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-val{font-family:var(--font-ui);font-size:12px;color:var(--accent);font-weight:600;white-space:nowrap}

/* ─── Certificate Chips ─── */
.cert-list-inline{display:flex;flex-wrap:wrap;gap:6px}
.cert-chip{padding:8px 14px;border-radius:20px;background:var(--accent-subtle);border:1px solid var(--accent-glow);font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:6px}
.cert-chip:hover{background:var(--accent-glow);transform:translateY(-2px)}
.cert-chip-date{font-size:10px;color:var(--text-muted);font-weight:400}

/* ─── Certificate Premium View ─── */
.cert-frame-prem{background:linear-gradient(135deg,#faf5ee,#f0e8d8,#faf5ee);border:3px double #c8922b;border-radius:16px;padding:28px;text-align:center;position:relative}
.cert-frame-prem::before{content:'';position:absolute;inset:6px;border:1px solid rgba(200,146,43,0.3);border-radius:10px;pointer-events:none}
.cert-stars-prem{font-size:24px;margin-bottom:10px}
.cert-title-prem{font-family:var(--font-heading);font-size:24px;font-weight:800;color:#3d2800;margin-bottom:14px}
.cert-text-prem{font-family:var(--font-body);font-size:16px;color:#5c4b2e;margin-bottom:4px;line-height:2.2}
.cert-name-prem{font-family:var(--font-heading);font-size:22px;font-weight:700;color:#2e1a00;margin:8px 0}
.cert-book-prem{font-family:var(--font-heading);font-size:20px;font-weight:700;color:#5c3a1e;margin:8px 0}
.cert-code-prem{font-family:var(--font-ui);font-size:11px;color:#8a7a5e;margin-top:14px}
.cert-date-prem{font-family:var(--font-ui);font-size:12px;color:#8a7a5e;margin-top:4px}

/* ═══════════════════════════════════════════
   FAVORITES PAGE — quote cards
   ═══════════════════════════════════════════ */
.quote-card{padding:18px 20px;margin-bottom:10px}
.quote-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.quote-card-cover{width:40px;height:52px;border-radius:8px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:14px;font-weight:700}
.quote-card-cover img{width:100%;height:100%;object-fit:cover}
.quote-book-title{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.quote-book-author{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.quote-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin-bottom:12px}
.quote-text{font-family:var(--font-body);font-size:16px;line-height:2.2;color:var(--text-secondary);padding:0 4px;position:relative}
.quote-mark{color:var(--accent);opacity:.5;font-size:20px;margin:0 4px}
.quote-meta{display:flex;align-items:center;gap:6px;margin-top:10px;flex-wrap:wrap}
.quote-date{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-right:auto}

/* ═══════════════════════════════════════════
   SUMMARY PAGE — hero, audio player
   ═══════════════════════════════════════════ */
.summary-hero{text-align:center;padding:28px 20px;margin-bottom:14px;background:linear-gradient(135deg,rgba(122,174,142,0.08),rgba(122,174,142,0.03));border-color:var(--tertiary-glow)}
.summary-date{font-family:var(--font-ui);font-size:14px;color:var(--text-secondary);margin-bottom:10px}
.summary-big-num{font-family:var(--font-heading);font-size:64px;font-weight:800;color:var(--tertiary);line-height:1;text-shadow:0 4px 16px var(--tertiary-glow)}
.summary-big-label{font-family:var(--font-ui);font-size:14px;color:var(--text-muted);margin-top:4px}
.summary-row{display:flex;justify-content:center;gap:24px;margin:16px 0}
.summary-stat{text-align:center}
.sval{display:block;font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text)}
.slbl{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.summary-text{font-family:var(--font-body);font-size:15px;line-height:2.2;color:var(--text-secondary);padding:10px 0;border-top:1px solid var(--border-light)}

/* ─── Audio Player ─── */
.audio-card{padding:16px 20px;margin-bottom:14px}
.audio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.audio-title{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text)}
.audio-voice-label{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.audio-controls{display:flex;gap:8px}
.audio-btn{padding:10px 20px;border-radius:var(--radius-sm);border:none;font-family:var(--font-heading);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);flex:1}
.play-btn{background:linear-gradient(135deg,var(--tertiary),var(--tertiary-light));color:#fff;box-shadow:0 4px 16px var(--tertiary-glow)}
.play-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--tertiary-glow)}
.play-btn.playing{background:linear-gradient(135deg,var(--accent),var(--accent-light))}
.voice-btn{background:var(--surface-hover);color:var(--text-secondary);border:1px solid var(--border)}
.voice-btn:hover{border-color:var(--accent);color:var(--accent)}
.audio-error{font-family:var(--font-ui);font-size:11px;color:var(--danger);margin-top:8px;text-align:center}

/* ─── Today Detail Row ─── */
.today-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light)}
.today-detail-row:last-child{border-bottom:none}
.td-book{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text)}
.td-pages{font-family:var(--font-ui);font-size:12px;color:var(--text-secondary)}
.td-page-num{color:var(--text-muted);font-size:11px}

/* ─── Khatma Summary Card ─── */
.khatma-summary-card{padding:14px 16px;margin-bottom:8px}
.ks-header{display:flex;justify-content:space-between;align-items:center}
.ks-title{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.ks-pct{font-family:var(--font-ui);font-size:12px;font-weight:700;color:var(--accent)}
.ks-text{font-family:var(--font-body);font-size:13px;color:var(--text-secondary);line-height:1.8;margin-top:6px}

/* ═══════════════════════════════════════════
   CLUBS PAGE
   ═══════════════════════════════════════════ */
.club-card{padding:16px 20px;margin-bottom:8px}
.club-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.club-icon{font-size:28px;flex-shrink:0}
.club-name{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text)}
.club-book{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);margin-top:2px}
.club-meta{display:flex;gap:14px;margin-bottom:10px;flex-wrap:wrap;font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.club-actions{display:flex;justify-content:flex-end}

/* ─── Club Member Row ─── */
.club-member-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--surface-hover);margin-bottom:4px}
.cm-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:14px;font-weight:700;flex-shrink:0}
.cm-name{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text)}
.cm-pages{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:1px}
.cm-rank{font-size:16px}

/* ═══════════════════════════════════════════
   ANIMATIONS & UTILITY
   ═══════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideLeft{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes popIn{0%{opacity:0;transform:scale(.8)}70%{transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}

.fade-enter-active{animation:slideLeft .25s ease}
.fade-leave-active{animation:fadeUp .2s ease reverse}

.celebration-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.7);animation:fadeIn .3s ease;backdrop-filter:blur(4px)}
.celebration-box{text-align:center;padding:32px;animation:popIn .5s cubic-bezier(.34,1.56,.64,1)}
.celebration-emoji{font-size:64px;animation:float 1s ease-in-out infinite}
.celebration-title{font-family:var(--font-heading);font-size:24px;font-weight:800;color:#fff;margin:16px 0 8px}
.celebration-sub{font-family:var(--font-ui);font-size:14px;color:rgba(255,255,255,.7);margin-bottom:20px}

/* ─── Premium Theme Overrides ─── */
/* Each theme is a completely different visual identity */

/* 🌿 oasis — spacious nature sanctuary */
:root[data-premium-theme="oasis"]{--bg:#f2f6f0;--bg-warm:#e8efe5;--surface:#ffffff;--surface-hover:#f4f8f2;--text:#2c382e;--text-secondary:#5a6e5c;--text-muted:#8a9e8a;--border:#d0dcc8;--border-light:rgba(208,220,200,0.5);--accent:#6a9a6e;--accent-light:#8aba8e;--accent-dark:#4a7a4e;--accent-glow:rgba(106,154,110,0.12);--accent-subtle:rgba(106,154,110,0.05);--tertiary:#5a8a6e;--tertiary-light:#7ab88a;--tertiary-dark:#3a5a4e;--tertiary-glow:rgba(90,138,110,0.12);--tertiary-subtle:rgba(90,138,110,0.05);--gold:#c8922b;--gold-light:#e0b04a;--success:#22c55e;--success-bg:rgba(34,197,94,0.08);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.08);--success-glow:rgba(34,197,94,0.15);--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow:0 4px 16px rgba(0,0,0,0.06);--shadow-lg:0 12px 40px rgba(0,0,0,0.08);--shadow-xl:0 24px 64px rgba(0,0,0,0.1);--radius-sm:10px;--radius:16px;--radius-lg:22px;--radius-xl:30px;--transition-fast:0.2s ease;--transition-smooth:0.5s cubic-bezier(.4,0,.2,1);--font-spacing:-0.3px;--shadow-xs:0 1px 3px rgba(0,0,0,0.04);--bg-mesh:radial-gradient(ellipse at 30% 60%,rgba(106,154,110,0.06) 0%,transparent 60%),radial-gradient(ellipse at 70% 20%,rgba(90,138,110,0.04) 0%,transparent 50%)}
/* oasis card style */
[data-premium-theme="oasis"] .card{background:rgba(255,255,255,0.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
[data-premium-theme="oasis"] .btn{border-radius:50px}
[data-premium-theme="oasis"] .home-read-card{border-left:4px solid var(--tertiary-light)}
[data-premium-theme="oasis"] body{font-weight:350}

/* 🏜️ desert — warm golden hour */
:root[data-premium-theme="desert"]{--bg:#faf5ee;--bg-warm:#f2e8d8;--surface:#ffffff;--surface-hover:#faf6f0;--text:#3d3028;--text-secondary:#6b5a4a;--text-muted:#a09080;--border:#e0d4c0;--border-light:rgba(224,212,192,0.5);--accent:#c8922b;--accent-light:#e0b04a;--accent-dark:#995000;--accent-glow:rgba(200,146,43,0.12);--accent-subtle:rgba(200,146,43,0.05);--tertiary:#b87a4a;--tertiary-light:#d4945a;--tertiary-dark:#905a30;--tertiary-glow:rgba(184,122,74,0.12);--tertiary-subtle:rgba(184,122,74,0.05);--gold:#d4a028;--gold-light:#e8c050;--success:#22c55e;--success-bg:rgba(34,197,94,0.08);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.08);--success-glow:rgba(34,197,94,0.15);--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow:0 4px 20px rgba(0,0,0,0.07);--shadow-lg:0 12px 48px rgba(0,0,0,0.1);--shadow-xl:0 24px 72px rgba(0,0,0,0.12);--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--transition-fast:0.12s ease;--transition-smooth:0.55s cubic-bezier(.4,0,.2,1);--font-spacing:0px;--shadow-xs:0 1px 1px rgba(0,0,0,0.03);--bg-mesh:radial-gradient(ellipse at 80% 20%,rgba(200,146,43,0.08) 0%,transparent 50%),radial-gradient(ellipse at 20% 60%,rgba(184,122,74,0.05) 0%,transparent 50%)}
[data-premium-theme="desert"] .card{border-right:3px solid var(--accent);border-top:1px solid var(--border)}
[data-premium-theme="desert"] .btn{border-radius:6px}
[data-premium-theme="desert"] .home-read-card{box-shadow:3px 3px 0 var(--border-light)}

/* 📜 sepia — traditional arabic manuscript */
:root[data-premium-theme="sepia"]{--bg:#f4ecd8;--bg-warm:#ece0c8;--surface:#fefaf2;--surface-hover:#faf4e8;--text:#5c4b2e;--text-secondary:#7a6a4a;--text-muted:#a89878;--border:#d8ccb0;--border-light:rgba(216,204,176,0.5);--accent:#8b6b3d;--accent-light:#a8845a;--accent-dark:#6b4b2d;--accent-glow:rgba(139,107,61,0.12);--accent-subtle:rgba(139,107,61,0.05);--tertiary:#6b5030;--tertiary-light:#8a6a4a;--tertiary-dark:#4b3020;--tertiary-glow:rgba(107,80,48,0.12);--tertiary-subtle:rgba(107,80,48,0.05);--gold:#b8960c;--gold-light:#d4b030;--success:#22c55e;--success-bg:rgba(34,197,94,0.08);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.08);--success-glow:rgba(34,197,94,0.15);--shadow-sm:2px 2px 0 rgba(0,0,0,0.04);--shadow:2px 3px 0 rgba(0,0,0,0.05);--shadow-lg:3px 5px 0 rgba(0,0,0,0.06);--shadow-xl:5px 8px 0 rgba(0,0,0,0.07);--radius-sm:4px;--radius:6px;--radius-lg:8px;--radius-xl:12px;--transition-fast:0.1s ease;--transition-smooth:0.3s ease;--font-spacing:0.5px;--shadow-xs:1px 1px 0 rgba(0,0,0,0.03);--bg-mesh:repeating-linear-gradient(0deg,transparent,transparent 23px,rgba(139,107,61,0.03) 23px,rgba(139,107,61,0.03) 24px),repeating-linear-gradient(90deg,transparent,transparent 23px,rgba(139,107,61,0.02) 23px,rgba(139,107,61,0.02) 24px)}
/* sepia — paper texture overlay */
[data-premium-theme="sepia"] body::before{content:'';position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse at 30% 50%,rgba(139,107,61,0.04) 0%,transparent 70%);pointer-events:none}
[data-premium-theme="sepia"] .card{box-shadow:2px 3px 0 var(--border-light);border-radius:4px}
[data-premium-theme="sepia"] body{font-family:var(--font-body);line-height:1.9;letter-spacing:0.3px}
[data-premium-theme="sepia"] .btn{border-radius:4px;box-shadow:2px 2px 0 var(--border)}
[data-premium-theme="sepia"] .section-title{font-family:var(--font-heading);font-weight:800}

/* 🌙 night — starry sky */
[data-premium-theme="night"] body{background:#0d1117!important;background-image:radial-gradient(1px 1px at 10% 15%,rgba(255,255,255,0.4),transparent),radial-gradient(1px 1px at 25% 35%,rgba(255,255,255,0.3),transparent),radial-gradient(1px 1px at 40% 10%,rgba(255,255,255,0.5),transparent),radial-gradient(1px 1px at 55% 45%,rgba(255,255,255,0.2),transparent),radial-gradient(1px 1px at 70% 20%,rgba(255,255,255,0.4),transparent),radial-gradient(1px 1px at 85% 40%,rgba(255,255,255,0.3),transparent),radial-gradient(1px 1px at 15% 60%,rgba(255,255,255,0.3),transparent),radial-gradient(1px 1px at 60% 70%,rgba(255,255,255,0.4),transparent),radial-gradient(1px 1px at 90% 80%,rgba(255,255,255,0.25),transparent),radial-gradient(1px 1px at 35% 85%,rgba(255,255,255,0.3),transparent),radial-gradient(2px 2px at 50% 25%,rgba(88,166,255,0.15),transparent),radial-gradient(2px 2px at 80% 60%,rgba(88,166,255,0.1),transparent)!important}
:root[data-premium-theme="night"]{--bg:#0d1117;--bg-warm:#161b22;--surface:#161b22;--surface-hover:#21262d;--text:#c9d1d9;--text-secondary:#8b949e;--text-muted:#6e7681;--border:#30363d;--border-light:rgba(48,54,61,0.5);--accent:#58a6ff;--accent-light:#79c0ff;--accent-dark:#388bfd;--accent-glow:rgba(88,166,255,0.15);--accent-subtle:rgba(88,166,255,0.05);--tertiary:#3fb950;--tertiary-light:#56d364;--tertiary-dark:#2ea043;--tertiary-glow:rgba(63,185,80,0.15);--tertiary-subtle:rgba(63,185,80,0.05);--gold:#d2991d;--gold-light:#e3b341;--success:#3fb950;--success-bg:rgba(63,185,80,0.08);--danger:#f85149;--danger-bg:rgba(248,81,73,0.08);--success-glow:rgba(63,185,80,0.15);--shadow-sm:0 1px 3px rgba(0,0,0,0.4);--shadow:0 4px 24px rgba(0,0,0,0.5);--shadow-lg:0 12px 48px rgba(0,0,0,0.6);--shadow-xl:0 24px 72px rgba(0,0,0,0.7);--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--transition-fast:0.15s ease;--transition-smooth:0.4s cubic-bezier(.4,0,.2,1);--font-spacing:-0.2px;--shadow-xs:0 1px 2px rgba(0,0,0,0.3);--bg-mesh:none}
[data-premium-theme="night"] .card{background:rgba(22,27,34,0.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border)}
[data-premium-theme="night"] .btn-gold{box-shadow:0 0 28px var(--accent-glow)}
[data-premium-theme="night"] .home-identity{background:linear-gradient(135deg,rgba(88,166,255,0.1),rgba(88,166,255,0.02));border-color:rgba(88,166,255,0.15)}
[data-premium-theme="night"] ::selection{background:var(--accent);color:var(--bg)}
[data-premium-theme="night"] .section-title{text-shadow:0 0 20px var(--accent-glow)}

/* 🌊 ocean — deep sea */
:root[data-premium-theme="ocean"]{--bg:#e8f4f8;--bg-warm:#dceaf0;--surface:#ffffff;--surface-hover:#f0f7fa;--text:#1a3a4a;--text-secondary:#3a5a6a;--text-muted:#7a9aaa;--border:#c0d8e8;--border-light:rgba(192,216,232,0.5);--accent:#0ea5e9;--accent-light:#38bdf8;--accent-dark:#0284c7;--accent-glow:rgba(14,165,233,0.12);--accent-subtle:rgba(14,165,233,0.05);--tertiary:#0891b2;--tertiary-light:#22d3ee;--tertiary-dark:#0e7490;--tertiary-glow:rgba(8,145,178,0.12);--tertiary-subtle:rgba(8,145,178,0.05);--gold:#d97706;--gold-light:#fbbf24;--success:#22c55e;--success-bg:rgba(34,197,94,0.08);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.08);--success-glow:rgba(34,197,94,0.15);--shadow-sm:0 1px 3px rgba(0,0,0,0.04);--shadow:0 4px 20px rgba(0,0,0,0.06);--shadow-lg:0 12px 48px rgba(0,0,0,0.1);--shadow-xl:0 24px 72px rgba(0,0,0,0.12);--radius-sm:8px;--radius:14px;--radius-lg:20px;--radius-xl:28px;--transition-fast:0.18s ease;--transition-smooth:0.45s cubic-bezier(.4,0,.2,1);--font-spacing:-0.1px;--shadow-xs:0 1px 2px rgba(0,0,0,0.03);--bg-mesh:radial-gradient(ellipse at 30% 60%,rgba(14,165,233,0.06) 0%,transparent 60%),radial-gradient(ellipse at 70% 30%,rgba(8,145,178,0.04) 0%,transparent 50%)}
[data-premium-theme="ocean"] .card{border-left:3px solid var(--accent);border-radius:var(--radius)}
[data-premium-theme="ocean"] .btn{transition:all 0.25s cubic-bezier(0.68,-0.55,0.27,1.55)}
[data-premium-theme="ocean"] .btn:active{transform:scale(0.94)}
[data-premium-theme="ocean"] body{font-weight:350;letter-spacing:-0.1px}
[data-premium-theme="ocean"] .home-read-card:hover{box-shadow:0 0 0 3px var(--accent-subtle),0 8px 32px var(--accent-glow)}

/* 🌅 maghrib — sunset city */
:root[data-premium-theme="maghrib"]{--bg:#fef7f0;--bg-warm:#fceee0;--surface:#ffffff;--surface-hover:#fef9f4;--text:#4a2020;--text-secondary:#6a3a3a;--text-muted:#a08080;--border:#e8d0c0;--border-light:rgba(232,208,192,0.5);--accent:#e85d3a;--accent-light:#f08060;--accent-dark:#c04028;--accent-glow:rgba(232,93,58,0.12);--accent-subtle:rgba(232,93,58,0.05);--tertiary:#d4a030;--tertiary-light:#e8c050;--tertiary-dark:#b08020;--tertiary-glow:rgba(212,160,48,0.12);--tertiary-subtle:rgba(212,160,48,0.05);--gold:#d4a030;--gold-light:#e8c050;--success:#22c55e;--success-bg:rgba(34,197,94,0.08);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.08);--success-glow:rgba(34,197,94,0.15);--shadow-sm:0 1px 3px rgba(0,0,0,0.05);--shadow:0 4px 20px rgba(0,0,0,0.08);--shadow-lg:0 12px 48px rgba(0,0,0,0.12);--shadow-xl:0 24px 72px rgba(0,0,0,0.14);--radius-sm:8px;--radius:12px;--radius-lg:18px;--radius-xl:26px;--transition-fast:0.14s ease;--transition-smooth:0.4s cubic-bezier(.4,0,.2,1);--font-spacing:0px;--shadow-xs:0 1px 1px rgba(0,0,0,0.03);--bg-mesh:radial-gradient(ellipse at 80% 20%,rgba(232,93,58,0.06) 0%,transparent 60%),radial-gradient(ellipse at 20% 50%,rgba(212,160,48,0.05) 0%,transparent 50%)}
[data-premium-theme="maghrib"] .card{border:2px solid var(--border);box-shadow:0 4px 0 var(--border-light)}
[data-premium-theme="maghrib"] .btn{background:linear-gradient(135deg,var(--accent),var(--tertiary));border:0;color:#fff}
[data-premium-theme="maghrib"] .home-read-card{border:2px solid var(--border);border-right:4px solid var(--accent)}
[data-premium-theme="maghrib"] .section-title{font-family:var(--font-heading);text-shadow:1px 1px 0 var(--border-light)}

/* ─── Premium-Exclusive Visual Flourishes ─── */
[data-premium-theme] body{transition:background var(--transition-smooth),color var(--transition-smooth)}
[data-premium-theme] .card{transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}
[data-premium-theme] .card:hover{box-shadow:0 8px 32px rgba(0,0,0,0.1),0 0 0 1px var(--border-light),0 0 0 4px var(--accent-subtle)}
[data-premium-theme] .btn-gold{box-shadow:0 4px 16px var(--accent-glow)}
[data-premium-theme] .hdr-avatar-ring.premium{box-shadow:0 0 0 2px var(--accent-glow),0 0 24px var(--accent-glow)}

/* ─── V3 PREMIUM TABS + HOME + TOAST + CONFETTI ─── */



/* ─── Feature Grid v3 ─── */
.feat-grid-v3{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:8px}
.feat-tile-v3{position:relative;padding:16px 12px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border-light);text-align:center;transition:all var(--transition);cursor:pointer}
.feat-tile-v3:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.feat-tile-v3.locked{opacity:.5;filter:grayscale(.3)}
.feat-tile-v3.locked:hover{opacity:.75;filter:grayscale(0)}
.feat-icon-v3{font-size:28px;margin-bottom:6px}
.feat-name-v3{font-family:var(--font-heading);font-size:12px;font-weight:600;color:var(--text)}
.feat-desc-v3{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:2px}
.feat-lock-v3{position:absolute;top:6px;left:6px;font-size:12px;opacity:.8}
.v3-section{font-family:var(--font-heading);font-size:16px;font-weight:700;margin:16px 0 10px;color:var(--text);letter-spacing:-.2px}

/* ─── Rank Card v3 ─── */
.rank-card-v3{text-align:center;padding:18px;margin-bottom:16px;cursor:pointer}
.rank-badge-v3{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 8px;box-shadow:0 4px 16px rgba(0,0,0,0.1);animation:rankBadgeFloat 2.5s ease-in-out infinite}
.rank-info-v3{margin-bottom:10px}
.rank-title-v3{font-family:var(--font-heading);font-size:17px;font-weight:700;color:var(--text)}
.rank-sub-v3{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);margin-top:2px}
.rank-progress-v3{height:5px;background:var(--border);border-radius:3px;margin:0 auto 6px;max-width:200px;overflow:hidden}
.rank-progress-fill-v3{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .6s ease}
.rank-next-v3{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}



/* ─── Fav Card v3 ─── */
.fav-card-v3{padding:14px 16px;margin-bottom:8px}
.fav-quote-v3{font-family:var(--font-body);font-size:15px;line-height:2.2;color:var(--text-secondary);margin-bottom:10px}
.fav-meta-v3{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ─── Summary v3 ─── */
.sum-hero-v3{text-align:center;padding:24px 20px;margin-bottom:14px;background:linear-gradient(135deg,rgba(122,174,142,0.08),rgba(122,174,142,0.03));border-color:var(--tertiary-glow)}
.sum-date-v3{font-family:var(--font-ui);font-size:13px;color:var(--text-secondary);margin-bottom:8px}
.sum-big-v3{font-family:var(--font-heading);font-size:56px;font-weight:800;color:var(--tertiary);line-height:1;text-shadow:0 4px 16px var(--tertiary-glow)}
.sum-lbl-v3{font-family:var(--font-ui);font-size:13px;color:var(--text-muted);margin-top:2px}
.sum-row-v3{display:flex;justify-content:center;gap:20px;margin:12px 0}
.sum-stat-v3{text-align:center}
.ssv{display:block;font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--text)}
.ssl{font-family:var(--font-ui);font-size:10px;color:var(--text-muted)}
.sum-text-v3{font-family:var(--font-body);font-size:14px;line-height:2.1;color:var(--text-secondary);padding:10px 0;border-top:1px solid var(--border-light)}
.sum-audio-v3{display:flex;gap:6px;margin-top:10px}
.audio-btn-v3{flex:1;padding:10px;border-radius:var(--radius-sm);border:none;font-family:var(--font-heading);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,var(--tertiary),var(--tertiary-light));color:#fff}
.audio-btn-v3:hover{transform:translateY(-2px)}
.audio-btn-v3.playing{background:linear-gradient(135deg,var(--accent),var(--accent-light))}
.audio-voice-btn-v3{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-hover);font-family:var(--font-ui);font-size:11px;cursor:pointer;transition:all var(--transition);color:var(--text-secondary)}
.audio-voice-btn-v3:hover{border-color:var(--accent)}

/* ─── Club v3 ─── */
.club-card-v3{padding:14px 16px;margin-bottom:8px}
.club-head-v3{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.club-icon-v3{font-size:24px}
.club-name-v3{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text)}
.club-book-v3{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.club-meta-v3{display:flex;gap:12px;flex-wrap:wrap;font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.club-members-v3{max-height:300px;overflow-y:auto}
.cm-row-v3{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--surface-hover);margin-bottom:4px}
.cm-av-v3{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:14px;font-weight:700;flex-shrink:0}
.cm-nm-v3{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text)}
.cm-pg-v3{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:1px}
.cm-badge-v3{font-size:16px}

/* ─── LB v3 ─── */
.lb-tabs-v3{display:flex;gap:6px;margin-bottom:10px}
.lb-tabs-v3 button{padding:6px 16px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-family:var(--font-ui);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition)}
.lb-tabs-v3 button.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.lb-row-v3{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border-light);margin-bottom:4px;transition:all var(--transition)}
.lb-row-v3:hover{transform:translateX(-4px);border-color:var(--accent)}
.lb-pos-v3{font-family:var(--font-heading);font-weight:800;font-size:15px;min-width:24px;text-align:center;color:var(--text-muted)}
.lb-pos-v3.p1{color:#c8922b;font-size:18px}
.lb-pos-v3.p2{color:#aaa;font-size:16px}
.lb-pos-v3.p3{color:#b87a4a}
.lb-nm-v3{flex:1;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-sc-v3{font-family:var(--font-ui);font-size:12px;color:var(--accent);font-weight:600;white-space:nowrap}

/* ─── Cert Grid v3 ─── */
.cert-grid-v3{display:flex;flex-direction:column;gap:6px}
.cert-card-v3{display:flex;align-items:center;gap:10px;padding:12px 14px}
.cert-card-icon-v3{font-size:24px}
.cert-card-info-v3{flex:1}
.cert-card-ttl-v3{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.cert-card-dt-v3{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}

/* ─── Home Streak + Teaser ─── */
.home-top-cards{display:flex;gap:10px;margin-bottom:16px}
.streak-card{flex:1;text-align:center;padding:14px 10px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(255,152,0,0.08),rgba(255,87,34,0.04));border:1px solid rgba(255,152,0,0.15)}
.streak-fire{font-size:28px;animation:float 1.5s ease-in-out infinite}
.streak-num{font-family:var(--font-heading);font-size:28px;font-weight:800;color:#ff6d00;line-height:1}
.streak-label{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:2px}

.rank-mini{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:16px;cursor:pointer}
.rank-mini-badge{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.rank-mini-title{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text)}
.rank-mini-sub{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}

/* ─── Toast v2 ─── */
#toast-container{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}
.toast{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:28px;font-family:var(--font-ui);font-size:13px;font-weight:600;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px rgba(0,0,0,0.15);opacity:0;transform:translateY(-16px);transition:all .3s ease;pointer-events:auto}
.toast-show{opacity:1;transform:translateY(0)}
.toast-success{background:var(--success);color:#fff}
.toast-error{background:var(--danger);color:#fff}
.toast-info{background:var(--text);color:var(--bg)}
.toast-icon{font-size:16px}
.toast-msg{line-height:1.4}
[data-theme="dark"] .toast-info{background:rgba(221,216,224,0.88);color:#16141c}

/* ─── Celebration / Confetti ─── */
@keyframes confettiFall{0%{transform:translateY(0) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}

/* ─── Missing styles v3 ─── */
.ks-card-v3{padding:14px 16px;margin-bottom:8px}
.ks-head-v3{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.ks-title-v3{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.ks-pct-v3{font-family:var(--font-ui);font-size:13px;font-weight:700;color:var(--accent)}
.ks-txt-v3{font-family:var(--font-body);font-size:13px;color:var(--text-secondary);line-height:1.8;margin-top:4px}
.rank-full-v3{padding:24px 20px}
.tag.clickable{cursor:pointer;transition:all var(--transition)}
.tag.clickable:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ═══════════════════════════════════════════
   V4 — RESTRUCTURED PAGES
   ═══════════════════════════════════════════ */

/* ─── Nav item favorite ─── */
.nav-item .material-symbols-outlined{transition:all var(--transition)}

/* ─── Quote Card v4 ─── */
.quote-card-v4{padding:16px 18px;margin-bottom:10px}
.q4-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.q4-cover{width:40px;height:52px;border-radius:8px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:14px;font-weight:700}
.q4-cover img{width:100%;height:100%;object-fit:cover}
.q4-fallback{font-size:18px;font-weight:700}
.q4-book{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text)}
.q4-author{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.q4-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin-bottom:10px}
.q4-quote{font-family:var(--font-body);font-size:16px;line-height:2.2;color:var(--text-secondary);padding:0 4px}
/* Favorites book grid */
.fav-books-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
@media(min-width:600px){.fav-books-grid{grid-template-columns:repeat(3,1fr)}}
.fav-book-card{background:var(--surface);border:1px solid var(--border-light);border-radius:14px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .15s}
.fav-book-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.fav-book-cover{width:56px;height:74px;border-radius:10px;overflow:hidden;margin:0 auto 10px;background:linear-gradient(135deg,var(--primary),var(--primary-light))}
.fav-book-cover img{width:100%;height:100%;object-fit:cover}
.fav-book-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:700}
.fav-book-name{font-family:var(--font-heading);font-size:13px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.fav-book-count{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:3px}
.q4-meta{display:flex;align-items:center;gap:6px;margin-top:8px;flex-wrap:wrap}
.q4-date{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-right:auto}

/* ─── Club v4 ─── */
.club-tabs{display:flex;gap:0;margin-bottom:14px;background:var(--surface);border-radius:var(--radius);padding:4px;border:1px solid var(--border-light)}
.club-tabs button{flex:1;padding:8px;border:none;border-radius:14px;background:transparent;color:var(--text-secondary);font-family:var(--font-heading);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}
.club-tabs button.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}
.club-card-v4{padding:16px 18px;margin-bottom:8px}
.c4-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.c4-icon{font-size:26px;flex-shrink:0}
.c4-name{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text)}
.c4-book{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.c4-meta{display:flex;gap:12px;flex-wrap:wrap;font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}

/* ═══════════════════════════════════════════
   CHAT APP — Full standalone chat interface
   ═══════════════════════════════════════════ */
.club-chat-app{display:flex;flex-direction:column;height:100vh;height:100dvh;background:#eae3d6;overflow:hidden;position:relative;max-width:100vw}
/* center on large screens like a phone */
@media(min-width:768px){.club-chat-app{max-width:560px;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border);box-shadow:0 0 40px rgba(0,0,0,0.08)}}
/* on wide screens, keep wallpaper from stretching too far */
@media(min-width:900px){.club-chat-app{max-width:600px}}
/* HEADER */
.chat-header{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--surface);border-bottom:1px solid var(--border);min-height:56px;z-index:10;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.chat-header-back{width:36px;height:36px;border:none;background:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);font-size:20px;transition:all .15s;flex-shrink:0}
.chat-header-back:hover{background:var(--surface-hover)}
.chat-header-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:16px;font-weight:700;color:#fff;flex-shrink:0;cursor:pointer}
.chat-header-av.official{background:linear-gradient(135deg,#c8922b,#f0d060);color:#3d2800}
.chat-header-info{flex:1;min-width:0;cursor:pointer}
.chat-header-name{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}
.chat-header-sub{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:4px}
.chat-header-sub .online-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;flex-shrink:0}
.chat-header-sub .typing{color:var(--tertiary);font-style:italic;animation:pulse 1.5s infinite}
.chat-header-actions{display:flex;gap:2px}
.chat-header-btn{width:36px;height:36px;border:none;background:none;border-radius:50%;cursor:pointer;color:var(--text-secondary);font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.chat-header-btn:hover{background:var(--surface-hover);color:var(--accent)}
/* WALLPAPER */
.chat-wallpaper{flex:1;overflow-y:auto;padding:8px 6px;display:flex;flex-direction:column;gap:0;background-color:#eae3d6;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Crect fill='%23eae3d6' width='240' height='240'/%3E%3Ccircle cx='120' cy='40' r='100' fill='none' stroke='%23e0d8c8' stroke-width='.5'/%3E%3Ccircle cx='40' cy='200' r='70' fill='none' stroke='%23e0d8c8' stroke-width='.5'/%3E%3Ccircle cx='200' cy='160' r='50' fill='none' stroke='%23e0d8c8' stroke-width='.5'/%3E%3Ccircle cx='120' cy='240' r='90' fill='none' stroke='%23d8cfbc' stroke-width='.3'/%3E%3Cpath d='M60 80 Q80 60 90 80' fill='none' stroke='%23ddd4c4' stroke-width='.6'/%3E%3C/svg%3E");position:relative;scroll-behavior:smooth}
/* DATE */
.chat-date-div{display:flex;align-items:center;justify-content:center;margin:10px 0 6px}
.chat-date-div span{background:rgba(255,255,255,0.9);color:#54656f;font-size:10.5px;font-weight:600;padding:5px 12px;border-radius:7px;font-family:var(--font-ui);box-shadow:0 1px 1px rgba(0,0,0,0.06);letter-spacing:.2px}
/* MESSAGE ROW */
.chat-msg{display:flex;gap:5px;margin-bottom:1px;max-width:92%;position:relative;animation:msgSlide .25s ease both}
.chat-msg.out{flex-direction:row-reverse;align-self:flex-end}
.chat-msg.in{align-self:flex-start}
.chat-msg.first{margin-top:7px}
.chat-msg-av{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:10px;font-weight:700;color:#fff;margin-top:5px;cursor:pointer}
.chat-msg-av.admin{background:linear-gradient(135deg,#c8922b,#f0d060)!important;color:#3d2800}
.chat-msg-av-placeholder{width:26px;flex-shrink:0}
.chat-msg-body{display:flex;flex-direction:column;min-width:0}
.chat-msg-name{font-size:10px;font-weight:700;color:var(--accent);margin-bottom:1px;padding:0 6px;font-family:var(--font-ui)}
.chat-msg-name.admin-name{color:#c8922b}
/* BUBBLES */
.chat-bubble{padding:6px 9px;font-size:13.5px;line-height:1.45;word-break:break-word;font-family:var(--font-ui);position:relative;max-width:100%;display:inline-block}
.chat-msg.in .chat-bubble{background:#fff;color:var(--text);border-radius:0 8px 8px 8px;box-shadow:0 1px 2px rgba(0,0,0,0.05)}
.chat-msg.out .chat-bubble{background:#d9fdd3;color:#1b3a1b;border-radius:8px 0 8px 8px;box-shadow:0 1px 2px rgba(0,0,0,0.05)}
.chat-msg.out .chat-bubble a{color:#1a6e1a}
.chat-msg.first.in .chat-bubble::before{content:'';position:absolute;top:0;right:-6px;width:12px;height:12px;background:radial-gradient(circle at 100% 0,transparent 12px,#fff 0);clip-path:polygon(0 0,100% 0,100% 100%)}
.chat-msg.first.out .chat-bubble::before{content:'';position:absolute;top:0;left:-6px;width:12px;height:12px;background:radial-gradient(circle at 0 0,transparent 12px,#d9fdd3 0);clip-path:polygon(0 0,100% 0,0 100%)}
.chat-msg:not(.first) .chat-bubble{border-radius:4px 8px 8px 8px}
.chat-msg:not(.first).out .chat-bubble{border-radius:8px 4px 8px 8px}
.chat-bubble img,.chat-bubble video{max-width:260px;max-height:220px;border-radius:4px;display:block;margin:2px 0;cursor:pointer}
.chat-bubble audio{max-width:220px;height:30px;margin:2px 0}
/* bubble footer */
.chat-bubble-foot{display:flex;align-items:center;gap:3px;justify-content:flex-end;margin-top:3px}
.chat-msg-time{font-size:10px;opacity:.45;white-space:nowrap;font-family:var(--font-ui)}
.chat-msg-check{font-size:10px;opacity:.45;color:#53bdeb}
/* DOUBLE‑TAP HEART */
.chat-msg-reaction{position:absolute;top:-14px;right:10px;font-size:16px;pointer-events:none;animation:reactionPop .7s ease forwards;z-index:5}
@keyframes reactionPop{0%{opacity:0;transform:scale(.5) translateY(6px)}30%{opacity:1;transform:scale(1.4) translateY(-10px)}100%{opacity:0;transform:scale(1) translateY(-22px)}}
@keyframes msgSlide{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
/* SYSTEM MSG */
.chat-sys{text-align:center;padding:3px 0;font-size:11px;color:var(--text-muted);font-family:var(--font-ui);opacity:.7;margin:2px 0}
/* CONTEXT MENU */
.chat-ctx{position:fixed;z-index:300;background:var(--surface);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,0.18);padding:6px;min-width:130px;animation:ctxIn .15s ease;font-family:var(--font-ui)}
.chat-ctx button{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;border:none;background:none;border-radius:10px;font-size:13px;cursor:pointer;color:var(--text);transition:background .1s;font-family:var(--font-ui);text-align:right}
.chat-ctx button:hover{background:var(--surface-hover)}
.chat-ctx button.danger{color:var(--danger)}
.chat-ctx button.danger:hover{background:rgba(239,68,68,0.1)}
/* edit banner above input */
.chat-edit-banner{display:flex;align-items:center;gap:8px;padding:6px 12px;margin:4px 0 0;background:var(--accent-subtle);border-radius:10px;font-size:11px;color:var(--accent);font-family:var(--font-ui);font-weight:600;animation:fabIn .15s ease}
.chat-edit-banner span{flex:1}
.chat-edit-banner button{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:14px;padding:2px 4px;border-radius:4px}
.chat-edit-banner button:hover{background:var(--surface-hover);color:var(--text)}
@keyframes ctxIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
/* IMAGE PREVIEW */
.chat-img-preview{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,0.92);display:flex;align-items:center;justify-content:center;cursor:pointer;animation:fadeIn .2s ease}
.chat-img-preview img{max-width:94vw;max-height:92vh;border-radius:6px;object-fit:contain}
/* FAB */
.chat-fab{position:absolute;bottom:12px;right:14px;z-index:15;width:38px;height:38px;border-radius:50%;background:var(--surface);border:1px solid var(--border-light);box-shadow:0 2px 12px rgba(0,0,0,0.1);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--text-secondary);animation:fabIn .2s ease;transition:all .15s}
.chat-fab:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.chat-fab .badge{position:absolute;top:-4px;right:-4px;background:var(--tertiary);color:#fff;font-size:9px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-weight:700}
@keyframes fabIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
/* INPUT */
.chat-input-bar{display:flex;align-items:flex-end;gap:6px;padding:6px 8px;background:var(--surface);border-top:1px solid var(--border);z-index:10;position:relative}
.chat-input-btn{width:38px;height:38px;border:none;background:none;border-radius:50%;cursor:pointer;color:var(--text-muted);font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.chat-input-btn:hover{color:var(--accent);background:var(--surface-hover)}
/* emoji palette */
.chat-emoji-palette{position:absolute;bottom:58px;right:8px;z-index:25;background:var(--surface);border-radius:14px;padding:8px;box-shadow:0 4px 24px rgba(0,0,0,0.15);display:grid;grid-template-columns:repeat(8,1fr);gap:4px;max-width:min(280px,calc(100vw - 20px));animation:fabIn .15s ease}
.chat-emoji-btn{width:30px;height:30px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .1s}
.chat-emoji-btn:hover{background:var(--surface-hover)}
.chat-textarea{flex:1;padding:10px 14px;border-radius:22px;border:1px solid var(--border);background:var(--bg-warm);font-size:13.5px;font-family:var(--font-ui);color:var(--text);outline:none;resize:none;line-height:1.4;max-height:100px;min-height:40px;transition:border-color .15s}
.chat-textarea:focus{border-color:var(--accent)}
.chat-send-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--border);color:#fff;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.chat-send-btn.ready{background:var(--accent);transform:scale(1.04)}
.chat-send-btn.ready:hover{transform:scale(1.1)}
.chat-send-btn:disabled{cursor:default}
/* VOICE OVERLAY */
.chat-recording{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:50;background:var(--surface);border-radius:20px;padding:14px 24px;box-shadow:0 4px 24px rgba(0,0,0,0.15);display:flex;align-items:center;gap:12px;animation:fabIn .2s ease;font-family:var(--font-ui)}
.chat-recording .rec-dot{width:12px;height:12px;border-radius:50%;background:var(--danger);animation:pulse 1s infinite}
.chat-recording .rec-time{font-size:14px;font-weight:600;color:var(--text);min-width:36px}
.chat-recording .rec-hint{font-size:11px;color:var(--text-muted)}
/* TYPING DOTS */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.chat-typing-dots{display:flex;align-items:center;gap:3px;padding:6px 10px}
.chat-typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.2s infinite}
.chat-typing-dots span:nth-child(2){animation-delay:.2s}
.chat-typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);opacity:.3}30%{transform:translateY(-5px);opacity:1}}
/* EMPTY */
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:6px;font-family:var(--font-ui);text-align:center;padding:20px}
.chat-empty-icon{opacity:.35;margin-bottom:2px}
.chat-empty-icon svg{width:80px;height:80px}
.chat-empty-title{font-weight:700;font-size:14px;color:var(--text)}
.chat-empty-sub{font-size:12px;color:var(--text-muted);max-width:240px}
/* LOAD MORE */
.chat-load-more{text-align:center;padding:6px}
.chat-load-more button{background:var(--surface);border:1px solid var(--border-light);border-radius:16px;padding:6px 18px;font-size:11px;color:var(--accent);cursor:pointer;font-family:var(--font-ui);font-weight:600;transition:all .15s}
.chat-load-more button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
/* VOTE CARD */
.chat-vote{background:var(--surface);border-radius:12px;margin:6px 2px;padding:14px;border:1.5px solid var(--accent-glow,#d4c5a0);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.chat-vote-hd{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.chat-vote-title{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text)}
.chat-vote-date{font-family:var(--font-ui);font-size:10px;color:var(--text-muted)}
.chat-vote-opt{display:flex;align-items:center;gap:10px;padding:9px 10px;margin-bottom:5px;border-radius:10px;background:var(--bg-warm);cursor:pointer;border:2px solid transparent;transition:all .15s}
.chat-vote-opt:hover:not(.done){border-color:var(--accent);transform:translateX(-3px)}
.chat-vote-opt.done{opacity:.7;cursor:default}
.chat-vote-bar{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.chat-vote-bar-label{font-size:10px;color:var(--text-secondary);min-width:50px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-ui)}
.chat-vote-bar-track{flex:1;height:8px;background:var(--bg-warm);border-radius:4px;overflow:hidden}
.chat-vote-bar-fill{height:100%;background:var(--accent);border-radius:4px;min-width:3px;transition:width .6s ease}
.chat-vote-bar-num{font-size:10px;font-weight:700;color:var(--accent);min-width:20px;text-align:right;font-family:var(--font-ui)}
/* MEMBERS SHEET */
.chat-members-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.35);display:flex;align-items:flex-end;justify-content:center}
.chat-members-sheet{width:100%;max-width:500px;max-height:65vh;background:var(--surface);border-radius:20px 20px 0 0;overflow-y:auto;padding:14px 14px 24px;animation:slideUp .25s ease}
.chat-members-handle{width:34px;height:5px;border-radius:3px;background:var(--border);margin:0 auto 12px}
.chat-members-row{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:var(--surface-hover);margin-bottom:4px}
.chat-members-row .av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:15px;font-weight:700;color:#fff;flex-shrink:0}
.chat-members-row .info{flex:1;min-width:0}
.chat-members-row .nm{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text)}
.chat-members-row .pg{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.chat-members-row .badge{font-size:16px}
/* JOIN GATE */
.chat-join{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;gap:12px;flex:1;background:#eae3d6}
.chat-join-icon{font-size:56px}
.chat-join-title{font-family:var(--font-heading);font-size:17px;font-weight:700;color:var(--text)}
.chat-join-sub{font-family:var(--font-body);font-size:13px;color:var(--text-muted);line-height:1.7;max-width:280px}
.chat-join-btn{padding:12px 36px;border-radius:24px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;font-family:var(--font-heading);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}
.chat-join-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}
/* SPOILER */
.chat-spoiler{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;gap:12px;flex:1;background:#eae3d6}
.chat-spoiler-icon{font-size:52px}
.chat-spoiler-title{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--text)}
.chat-spoiler-text{font-family:var(--font-body);font-size:13px;color:var(--text-secondary);line-height:1.8;max-width:320px}
.chat-spoiler-btn{padding:12px 28px;border-radius:24px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;font-family:var(--font-heading);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}
.chat-spoiler-btn:hover{transform:translateY(-2px)}
/* BANNERS */
.chat-banner{padding:6px 10px;text-align:center;font-size:11px;font-family:var(--font-ui);font-weight:600}
.chat-banner.warn{background:#f59e0b;color:#fff}
.chat-banner.danger{background:#ef4444;color:#fff}
.chat-banner.info{background:linear-gradient(135deg,var(--accent-subtle),transparent);color:var(--text-secondary);border-bottom:1px solid var(--border-light)}
.chat-banner.paused{background:var(--surface-hover);color:var(--text-secondary);font-weight:400}
/* pinned message */
.chat-pinned-card{display:flex;align-items:center;gap:8px;padding:8px 12px;margin:4px 2px 6px;background:var(--accent-subtle);border-radius:10px;border:1px solid var(--accent-glow);animation:msgSlide .2s ease;flex-shrink:0}
.chat-pinned-close{background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-muted);padding:2px 4px;border-radius:4px;flex-shrink:0}
.chat-pinned-close:hover{background:var(--surface-hover);color:var(--danger)}
.chat-readonly{text-align:center;padding:8px;font-size:11px;color:var(--text-muted);font-family:var(--font-ui);background:var(--surface);border-top:1px solid var(--border-light)}
/* DARK MODE */
[data-theme="dark"] .club-chat-app{background:#0b141a}
[data-theme="dark"] .chat-wallpaper{background-color:#0b141a;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Crect fill='%230b141a' width='240' height='240'/%3E%3Ccircle cx='120' cy='40' r='100' fill='none' stroke='%23101b24' stroke-width='.5'/%3E%3C/svg%3E")}
[data-theme="dark"] .chat-header{background:#111b21;border-color:rgba(255,255,255,0.06)}
[data-theme="dark"] .chat-input-bar{background:#111b21;border-color:rgba(255,255,255,0.06)}
[data-theme="dark"] .chat-textarea{background:#1f2c33;border-color:rgba(255,255,255,0.08);color:#d1d7db}
[data-theme="dark"] .chat-msg.in .chat-bubble{background:#1f2c33;color:#d1d7db}
[data-theme="dark"] .chat-msg.out .chat-bubble{background:#005c4b;color:#d1f4e0}
[data-theme="dark"] .chat-msg.first.in .chat-bubble::before{background:radial-gradient(circle at 100% 0,transparent 12px,#1f2c33 0)}
[data-theme="dark"] .chat-msg.first.out .chat-bubble::before{background:radial-gradient(circle at 0 0,transparent 12px,#005c4b 0)}
[data-theme="dark"] .chat-date-div span{background:rgba(255,255,255,0.1);color:#8696a0}
[data-theme="dark"] .chat-vote{background:#111b21;border-color:rgba(255,255,255,0.08)}
[data-theme="dark"] .chat-vote-opt{background:#1f2c33}
[data-theme="dark"] .chat-readonly{background:#111b21}
[data-theme="dark"] .chat-ctx{background:#1f2c33}
[data-theme="dark"] .chat-ctx button{color:#d1d7db}
[data-theme="dark"] .chat-ctx button:hover{background:rgba(255,255,255,0.06)}
[data-theme="dark"] .chat-fab{background:#1f2c33}
[data-theme="dark"] .chat-join,[data-theme="dark"] .chat-spoiler{background:#0b141a}
.club-vote-card{background:var(--surface);border-radius:16px;padding:18px;border:1px solid var(--border-light);margin-bottom:14px}
.club-vote-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:20px;font-family:var(--font-ui)}
.club-vote-title{font-family:var(--font-heading);font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.club-vote-dates{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-bottom:12px}
.club-vote-voted{font-size:12px;color:var(--tertiary);font-weight:600;margin-bottom:10px;font-family:var(--font-ui)}
.club-vote-books{display:flex;flex-direction:column;gap:8px}
.club-vote-book{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;background:var(--bg-warm);cursor:pointer;transition:all .15s;border:2px solid transparent}
.club-vote-book:hover{border-color:var(--accent);transform:translateX(-4px)}
.club-vote-book.voted{cursor:default;opacity:.7}
.club-vote-book.selected{border-color:var(--accent);background:rgba(var(--accent-rgb,0,0,0),.05)}
.cvb-cover{width:36px;height:48px;border-radius:6px;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-light))}
.cvb-cover img{width:100%;height:100%;object-fit:cover}
.cvb-info{flex:1;min-width:0}
.cvb-title{font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cvb-author{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:1px}
.cvb-count{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--accent);min-width:50px;text-align:center}
/* Vote bar results */
.cv-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.cv-bar-label{font-size:10px;color:var(--text-secondary);min-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-ui)}
.cv-bar-wrap{flex:1;height:12px;background:var(--bg-warm);border-radius:6px;overflow:hidden}
.cv-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:6px;min-width:4px;transition:width .6s ease}
.cv-bar-count{font-size:10px;color:var(--accent);font-weight:700;min-width:24px;text-align:right;font-family:var(--font-ui)}

/* ─── Spoiler Warning ─── */
.spoiler-card{background:var(--surface);border-radius:16px;padding:28px 20px;text-align:center;border:2px solid var(--warning,#f59e0b);max-width:420px;margin:0 auto}
.spoiler-icon{font-size:48px;margin-bottom:10px}
.spoiler-title{font-family:var(--font-heading);font-size:18px;font-weight:800;color:var(--text);margin-bottom:10px}
.spoiler-text{font-family:var(--font-body);font-size:13px;line-height:2;color:var(--text-secondary);margin-bottom:18px}

/* ─── Club Official Card ─── */
.club-card-official{padding:18px;margin-bottom:12px;background:linear-gradient(135deg,rgba(200,146,43,0.08),rgba(200,146,43,0.02));border:1.5px solid rgba(200,146,43,0.25);border-radius:16px}
.club-card-official:hover{border-color:rgba(200,146,43,0.5)}
.cco-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.cco-badge{background:linear-gradient(135deg,#c8922b,#f0d060);color:#3d2800;font-weight:700;padding:3px 12px;border-radius:20px;font-size:11px;font-family:var(--font-ui)}
.cco-name{font-family:var(--font-heading);font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.cco-book{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);margin-bottom:8px}
.cco-meta{display:flex;gap:14px;font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}

/* ─── Create Club Modal v2 ─── */
.create-club-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.create-close{width:34px;height:34px;border:none;background:var(--surface-hover);border-radius:50%;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:15px}
.create-close:hover{background:var(--danger);color:#fff;transform:rotate(90deg)}
.create-type-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.create-type-card{padding:18px 14px 16px;border-radius:16px;border:2px solid var(--border);background:var(--surface);cursor:pointer;text-align:center;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.create-type-card::after{content:'';position:absolute;top:-20px;right:-20px;width:60px;height:60px;border-radius:50%;background:var(--accent);opacity:0;transform:scale(0);transition:all .3s ease}
.create-type-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.08)}
.create-type-card:hover::after{opacity:.04;transform:scale(3)}
.create-type-card.active{border-color:var(--accent);background:var(--accent-subtle);box-shadow:0 0 0 4px var(--accent-glow);transform:translateY(-2px)}
.create-type-card.active::after{opacity:.06;transform:scale(3)}
.ctc-icon{display:flex;align-items:center;justify-content:center;margin-bottom:6px;color:var(--text-secondary);transition:color .2s}
.create-type-card.active .ctc-icon{color:var(--accent)}
.ctc-icon svg{width:26px;height:26px}
.ctc-label{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px;transition:color .2s}
.create-type-card.active .ctc-label{color:var(--accent)}
.ctc-desc{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);line-height:1.5}
.create-input{width:100%;padding:12px 14px;border-radius:14px;border:1.5px solid var(--border);background:var(--bg-warm);font-size:14px;font-family:var(--font-ui);color:var(--text);outline:none;transition:all .2s;box-sizing:border-box}
.create-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--surface)}
.create-input::placeholder{color:var(--text-muted);opacity:.6}
.create-book-drop{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:14px;max-height:220px;overflow-y:auto;box-shadow:0 12px 40px rgba(0,0,0,0.12);animation:fabIn .15s ease}
.create-book-opt{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border-light)}
.create-book-opt:last-child{border-bottom:none}
.create-book-opt:hover,.create-book-opt.selected{background:var(--accent-subtle)}
.cbo-cover{width:34px;height:44px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.create-selected-book{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--accent-subtle);border-radius:12px;margin-bottom:12px;font-size:14px;color:var(--text);font-family:var(--font-ui);border:1px solid var(--accent-glow);animation:msgSlide .2s ease}
.create-vis-toggle{display:flex;gap:6px;margin:4px 0 14px}
.create-vis-toggle button{flex:1;padding:10px 10px;border-radius:12px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;font-size:12px;font-family:var(--font-ui);font-weight:600;color:var(--text-secondary);transition:all .2s}
.create-vis-toggle button.active{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.create-schedule{display:flex;gap:12px;margin-bottom:14px}
.cs-item{flex:1;text-align:center}
.cs-stepper{display:flex;align-items:center;justify-content:center;background:var(--bg-warm);border-radius:14px;overflow:hidden;border:1.5px solid var(--border);transition:border-color .2s}
.cs-stepper:focus-within{border-color:var(--accent)}
.cs-stepper button{width:40px;height:40px;border:none;background:transparent;cursor:pointer;font-size:20px;color:var(--text-secondary);font-weight:600;transition:all .15s;font-family:var(--font-ui);display:flex;align-items:center;justify-content:center}
.cs-stepper button:hover{background:var(--accent);color:#fff}
.cs-stepper span{min-width:48px;text-align:center;font-size:16px;font-weight:700;color:var(--text);font-family:var(--font-ui)}

/* ─── Stats rows (club portal) ─── */
.stat-book-row{display:flex;align-items:center;gap:10px;padding:10px 6px;border-bottom:1px solid var(--border-light);transition:background .15s}
.stat-book-row:hover{background:var(--surface-hover)}
.stat-book-row:last-child{border-bottom:none}
.stat-rank{font-family:var(--font-heading);font-weight:700;font-size:13px;color:var(--text-muted);min-width:22px;text-align:center;flex-shrink:0}
.stat-bk-cover{width:36px;height:48px;border-radius:6px;overflow:hidden;flex-shrink:0}
.stat-bk-cover img{width:100%;height:100%;object-fit:cover}
.stat-bk-info{flex:1;min-width:0}
.stat-bk-title{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-bk-author{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.stat-bk-stars{display:flex;align-items:center;gap:2px;flex-shrink:0;direction:ltr}
.stat-bk-stars .star-fill{color:#f5b342;font-size:13px}
.stat-bk-stars .star-empty{color:var(--border);font-size:13px}
.stat-bk-rating{font-family:var(--font-heading);font-weight:700;font-size:12px;color:var(--text);margin-left:4px}
.stat-bk-count{font-family:var(--font-ui);font-size:10px;color:var(--text-muted)}
.stat-reader-row{display:flex;align-items:center;gap:8px;padding:9px 6px;border-bottom:1px solid var(--border-light);font-family:var(--font-ui);font-size:12px}
.stat-reader-row:last-child{border-bottom:none}
.stat-reader-row.highlight{background:rgba(200,146,43,0.1);border-radius:8px;margin:2px -6px;padding:9px 12px;border-bottom-color:transparent}
.stat-ri{font-size:16px;flex-shrink:0;width:20px;text-align:center}
.stat-rt{font-size:11px;color:var(--text-muted);flex-shrink:0;width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-rn{flex:1;min-width:0;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.stat-rp{font-size:11px;color:var(--text-secondary);flex-shrink:0;direction:ltr;text-align:left}
.stat-me{font-size:14px;flex-shrink:0;margin-right:4px}

/* ─── Profile v4 ─── */
.premium-tag-v4{background:linear-gradient(135deg,#c8922b,#f0d060);color:#3d2800;font-weight:700;padding:4px 12px;border-radius:20px;font-size:12px}
.profile-stats-v4{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;padding:16px}
.stat-v4{text-align:center}
.sv4-num{display:block;font-family:var(--font-heading);font-size:22px;font-weight:800;color:var(--text)}
.sv4-lbl{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:2px}
.sub-card-v4{cursor:pointer;padding:16px 18px;margin-bottom:14px;transition:all var(--transition)}
.sub-card-v4:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-lg)}
.sub-card-top{display:flex;align-items:center;gap:12px}
.sub-card-icon{font-size:28px}
.sub-card-title{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text)}
.sub-card-desc{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.cert-scroll{display:flex;flex-wrap:wrap;gap:6px}
.cert-chip-v4{padding:6px 14px;border-radius:18px;background:var(--accent-subtle);border:1px solid var(--accent-glow);font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--text);cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;gap:6px}
.cert-chip-v4:hover{background:var(--accent-glow);transform:translateY(-2px)}
.cert-chip-dt{font-size:9px;color:var(--text-muted);font-weight:400}
.cert-card-v3.clickable{cursor:pointer}

/* ─── Upgrade Page (Premium) ─── */
.upgrade-hero{position:relative;text-align:center;padding:32px 20px 24px;margin-bottom:20px;border-radius:var(--radius-lg);background:linear-gradient(145deg,rgba(200,146,43,0.1),rgba(154,138,186,0.08),rgba(200,146,43,0.06));border:1px solid rgba(200,146,43,0.2);overflow:hidden}
.upgrade-glow{position:absolute;inset:-50%;background:radial-gradient(circle at 50% 30%,rgba(200,146,43,0.15) 0%,transparent 60%),radial-gradient(circle at 80% 70%,rgba(154,138,186,0.1) 0%,transparent 50%);pointer-events:none}
.upgrade-badge{font-size:56px;margin-bottom:8px;position:relative;animation:float 3s ease-in-out infinite}
.upgrade-title{font-family:var(--font-heading);font-size:24px;font-weight:800;position:relative;background:linear-gradient(135deg,#c8922b,#e0b04a,#c8922b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:6px}
.upgrade-sub{font-family:var(--font-ui);font-size:14px;color:var(--text-secondary);position:relative;line-height:1.6}
.upgrade-actions{margin-top:16px;position:relative}
.upgrade-btn{padding:16px!important;font-size:16px!important}
.upgrade-price{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:8px}
.upgrade-section{font-family:var(--font-heading);font-size:17px;font-weight:700;margin:20px 0 12px;color:var(--text)}
.upgrade-features{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.upgrade-feat{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:all var(--transition)}
.upgrade-feat:hover{transform:translateX(-4px);border-color:var(--accent);box-shadow:var(--shadow)}
.upgrade-feat-icon{font-size:24px;width:36px;text-align:center;flex-shrink:0}
.upgrade-feat-text{flex:1;min-width:0}
.upgrade-feat-name{font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--text)}
.upgrade-feat-desc{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px}
.upgrade-feat-lock{color:var(--text-muted);font-size:14px}
.upgrade-feat-check{color:var(--success);font-size:16px;font-weight:700}
.upgrade-trust{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}
.trust-item{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border-light);font-family:var(--font-ui);font-size:12px;color:var(--text-secondary)}
.trust-icon{font-size:18px}

/* ─── Summary Home Card ─── */
.summary-home-card{padding:16px 18px;margin-bottom:16px;background:linear-gradient(135deg,rgba(122,174,142,0.06),rgba(122,174,142,0.02));border-color:var(--tertiary-glow)}
.sh-top{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.sh-icon{font-size:22px}
.sh-title{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text);flex:1}
.sh-date{font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.sh-row{display:flex;justify-content:space-around;gap:8px}
.sh-stat{text-align:center}
.sh-num{display:block;font-family:var(--font-heading);font-size:24px;font-weight:800;color:var(--tertiary)}
.sh-lbl{font-family:var(--font-ui);font-size:10px;color:var(--text-muted)}
.sh-play-btn{background:linear-gradient(135deg,var(--tertiary),var(--tertiary-light));color:#fff;border:none;font-weight:600;transition:all var(--transition)}
.sh-play-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--tertiary-glow)}
.sh-play-btn.playing{background:linear-gradient(135deg,var(--accent),var(--accent-light))}

/* ─── Rank Progress Detail ─── */
.rank-detail-row{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:6px;font-family:var(--font-ui);font-size:11px;color:var(--text-muted)}
.rank-detail-row .next-icon{font-size:16px}

/* ═══════════════════════════════════════════
   PDF SELECTION + CAPTURE
   ═══════════════════════════════════════════ */
.sel-overlay{position:absolute;inset:0;z-index:4;cursor:crosshair;background:rgba(0,0,0,0.08)}
.sel-box{position:absolute;border:2px dashed #ff6b6b;background:rgba(255,100,100,0.08);border-radius:4px;pointer-events:none}
.sel-actions{position:absolute;transform:translate(-50%,0);display:flex;gap:6px;z-index:5;white-space:nowrap}
.sel-btn{padding:8px 16px;border-radius:10px;border:none;font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}
.sel-btn.save{background:#ff6b6b;color:#fff;box-shadow:0 4px 16px rgba(255,100,100,0.3)}
.sel-btn.save:hover{transform:scale(1.05)}
.sel-btn.cancel{background:rgba(255,255,255,0.9);color:#333;border:1px solid rgba(0,0,0,0.1)}
.sel-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-ui);font-size:15px;color:rgba(255,255,255,0.8);background:rgba(0,0,0,0.5);padding:10px 20px;border-radius:12px;pointer-events:none;animation:fadeUp .3s ease}
.q4-capture{margin:0 0 10px;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 4px 20px rgba(0,0,0,0.08)}
.q4-capture img{width:100%;display:block}

/* ─── Selection v2 (inside rdr2-screen) ─── */
.sel-rect{position:absolute;border:2px dashed #ff6b6b;background:rgba(255,100,100,0.06);border-radius:3px;pointer-events:none;z-index:3}
.sel-acts{position:absolute;transform:translate(-50%,0);display:flex;gap:6px;z-index:5;white-space:nowrap}
.sel-act{padding:8px 16px;border-radius:10px;border:none;font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}
.sel-act.save{background:#ff6b6b;color:#fff;box-shadow:0 4px 16px rgba(255,100,100,0.3)}
.sel-act.save:hover{transform:scale(1.05)}
.sel-act.cancel{background:rgba(255,255,255,0.9);color:#333;border:1px solid rgba(0,0,0,0.1)}
.sel-hint-v2{position:absolute;bottom:60px;left:50%;transform:translateX(-50%);font-family:var(--font-ui);font-size:13px;color:#fff;background:rgba(0,0,0,0.55);padding:8px 16px;border-radius:10px;pointer-events:none;animation:fadeUp .3s ease;z-index:5;white-space:nowrap}

/* ═══════════════════════════════════════════
   HOME PAGE — Reference Design Style
   ═══════════════════════════════════════════ */
/* ─── Identity + Rank ─── */
.home-identity{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding:0 2px}
.home-logo-row{display:flex;align-items:center;gap:10px}
.home-logo-icon{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(13,148,136,0.2);flex-shrink:0}
.home-brand-title{font-family:var(--font-heading);font-size:20px;font-weight:800;color:var(--text);line-height:1.1}
.home-brand-sub{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);font-weight:500}
.home-rank-badge{background:var(--surface);padding:8px 14px;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);display:flex;flex-direction:column;align-items:flex-end;gap:2px;min-width:90px}
.home-rank-title{font-family:var(--font-heading);font-size:11px;font-weight:800;color:var(--accent);display:flex;align-items:center;gap:4px}
.home-rank-points{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);font-weight:600}
/* ─── Rank Progress ─── */
.home-rank-progress{background:linear-gradient(135deg,var(--surface-hover),var(--surface));border-radius:14px;padding:14px 16px;margin-bottom:14px;border:1px solid var(--border-light)}
.home-rank-progress-header{display:flex;justify-content:space-between;font-family:var(--font-ui);font-size:11px;font-weight:700;margin-bottom:8px}
.home-rank-progress-header span:first-child{color:var(--text-secondary);display:flex;align-items:center;gap:4px}
.home-rank-next{color:var(--accent)}
.home-rank-bar{width:100%;background:var(--bg-warm);height:8px;border-radius:4px;overflow:hidden;position:relative}
.home-rank-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:4px;transition:width .6s ease}
.home-rank-labels{display:flex;justify-content:space-between;font-family:var(--font-ui);font-size:9px;color:var(--text-muted);font-weight:600;margin-top:6px}
/* ─── Premium Card ─── */
@keyframes premiumBGGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes premiumSweep{0%{left:-150%}100%{left:150%}}
.home-premium-card{position:relative;background:linear-gradient(135deg,#1e1b4b 0%,#311066 40%,#1e1b4b 100%);background-size:200% 200%;animation:premiumBGGradient 8s ease infinite;border-radius:20px;padding:18px;margin-bottom:16px;cursor:pointer;overflow:hidden;box-shadow:0 10px 25px -5px rgba(46,8,84,0.3)}
.home-premium-card::after{content:'';position:absolute;top:-50%;left:-60%;width:30%;height:200%;background:linear-gradient(to right,rgba(255,255,255,0) 0%,rgba(255,255,255,0.08) 30%,rgba(255,255,255,0.2) 50%,rgba(255,255,255,0.08) 70%,rgba(255,255,255,0) 100%);transform:rotate(25deg);animation:premiumSweep 4s infinite;pointer-events:none}
.home-premium-card::before{content:'';position:absolute;left:-24px;top:-24px;width:120px;height:120px;background:rgba(99,102,241,0.08);border-radius:50%;filter:blur(40px)}
.home-premium-content{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center}
.home-premium-left{max-width:65%}
.home-premium-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(251,191,36,0.18);color:#fde68a;font-family:var(--font-ui);font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;margin-bottom:8px}
.home-premium-title{font-family:var(--font-heading);font-size:15px;font-weight:800;color:#fff;line-height:1.3;margin-bottom:4px}
.home-premium-desc{font-family:var(--font-ui);font-size:10px;color:rgba(199,210,254,0.8);line-height:1.5;font-weight:300}
.home-premium-action{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.home-premium-btn{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#f59e0b,#eab308);color:#1e1b4b;padding:10px 18px;border-radius:14px;font-family:var(--font-heading);font-size:12px;font-weight:800;border:none;cursor:pointer;box-shadow:0 4px 16px rgba(245,158,11,0.3);transition:all .2s;pointer-events:none}
.home-premium-price{font-family:var(--font-ui);font-size:9px;color:#fde68a;font-weight:500;margin-top:4px}
/* ─── Section Title ─── */
.section-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.section-title-row .section-title{margin-bottom:0}
.section-badge{font-family:var(--font-ui);font-size:11px;background:var(--accent-subtle);color:var(--accent);padding:3px 12px;border-radius:20px;font-weight:700}
.section-more{font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--accent);background:none;border:none;cursor:pointer}
/* ─── Empty State ─── */
.home-empty-state{background:var(--surface);border-radius:20px;padding:32px 20px;text-align:center;border:2px dashed var(--border);transition:all .3s}
.home-empty-icon-circle{width:60px;height:60px;border-radius:50%;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.home-empty-state .home-empty-title{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}
.home-empty-state .home-empty-desc{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);line-height:1.6;max-width:280px;margin:0 auto 16px}
/* ─── Read Cards ─── */
.home-reads-list{display:flex;flex-direction:column;gap:12px}
.home-read-card{display:flex;gap:12px;background:var(--surface);border-radius:16px;padding:12px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .2s;position:relative}
.home-read-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.home-read-cover{width:60px;height:85px;border-radius:10px;overflow:hidden;background:var(--bg-warm);flex-shrink:0;position:relative;box-shadow:0 2px 8px rgba(0,0,0,0.06)}
.home-read-cover-img{width:100%;height:100%;object-fit:cover}
.home-read-cover-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:26px;font-weight:800;color:#fff}
.home-read-badge{position:absolute;top:4px;right:4px;padding:1px 6px;border-radius:6px;font-family:var(--font-ui);font-size:8px;font-weight:800;color:#fff;backdrop-filter:blur(6px)}
.home-read-badge.badge-active{background:rgba(13,148,136,0.9)}
.home-read-badge.badge-completed{background:rgba(16,185,129,0.9)}
.home-read-badge.badge-paused{background:rgba(100,116,139,0.85)}
.home-read-info{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0;padding:2px 0}
.home-read-title{font-family:var(--font-heading);font-size:14px;font-weight:800;color:var(--text);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.home-read-sub{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.home-read-progress-label{display:flex;justify-content:space-between;font-family:var(--font-ui);font-size:10px;color:var(--text-muted);font-weight:600;margin:6px 0 4px}
.home-read-progress-bar{width:100%;background:var(--bg-warm);height:5px;border-radius:3px;overflow:hidden}
.home-read-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .4s}
.home-read-btn{width:100%;padding:10px;border-radius:10px;border:none;font-family:var(--font-heading);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .2s;background:var(--accent-subtle);color:var(--accent);margin-top:8px}
.home-read-btn:hover{background:var(--accent);color:#fff;box-shadow:0 4px 16px var(--accent-glow)}
.home-read-btn:active{transform:scale(.97)}
/* ─── Discover Scroll ─── */
.home-discover-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.home-discover-scroll::-webkit-scrollbar{display:none}
.home-discover-scroll{-ms-overflow-style:none;scrollbar-width:none}
.home-discover-card{flex:0 0 100px;scroll-snap-align:start;cursor:pointer;transition:transform .2s}
.home-discover-card:hover{transform:translateY(-4px)}
.home-discover-cover{width:100px;height:140px;border-radius:14px;overflow:hidden;background:var(--bg-warm);box-shadow:0 2px 12px rgba(0,0,0,0.06);position:relative;border:1px solid var(--border-light)}
.home-discover-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.home-discover-card:hover .home-discover-img{transform:scale(1.04)}
.home-discover-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:32px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-light))}
.home-discover-name{font-family:var(--font-heading);font-size:11px;font-weight:700;color:var(--text);margin-top:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}
.home-discover-author{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}

[data-theme="dark"] .home-premium-card{box-shadow:0 10px 25px -5px rgba(46,8,84,0.5)}
[data-theme="dark"] .home-premium-btn{color:#0f0a1e}
[data-theme="dark"] .home-read-btn:hover{background:var(--accent);color:#020617}
[data-theme="dark"] .home-discover-cover{background:var(--surface-hover)}

/* ═══════════════════════════════════════════
   HOME HEADER (Reference Design)
   ═══════════════════════════════════════════ */
.top-bar.home{padding:12px 16px;background:var(--surface-glass);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px)}
.hdr-avatar-btn{position:relative;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0}
.hdr-avatar-ring{width:42px;height:42px;border-radius:50%;padding:2px;box-shadow:0 4px 16px rgba(0,0,0,.1);transition:transform .2s;position:relative;border:2px solid var(--border-light)}
.hdr-avatar-btn:hover .hdr-avatar-ring{transform:scale(1.08);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.hdr-avatar-fb{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:800;font-size:18px;color:#fff;border:2px solid var(--surface,#fff)}
.hdr-online-dot{position:absolute;top:-2px;right:-2px;width:10px;height:10px;border-radius:50%;background:#22c55e;border:2px solid var(--surface,#fff);box-shadow:0 0 0 2px rgba(34,197,94,.3)}
.hdr-premium-ribbon{position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:7px;font-weight:700;padding:1px 7px;border-radius:7px;z-index:3;font-family:var(--font-heading);letter-spacing:.5px;box-shadow:0 1px 3px rgba(245,158,11,.4);white-space:nowrap;border:1.5px solid var(--surface,#fff)}
.hdr-back-btn{width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);flex-shrink:0}
.hdr-back-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:scale(1.05)}
.hdr-back-btn:active{transform:scale(.92)}
.hdr-greet{text-align:center;flex:1;padding:0 8px;overflow:hidden}
.hdr-greet-sub{font-family:var(--font-ui);font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0}
.hdr-greet-main{font-family:var(--font-heading);font-size:14px;font-weight:800;color:var(--text);margin:2px 0 0;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap}

[data-theme="dark"] .hdr-avatar-ring{box-shadow:0 4px 16px rgba(0,0,0,.3)}
[data-theme="dark"] .top-bar.home{background:rgba(2,6,23,0.85)}

/* ═══════════════════════════════════════════
   LIBRARY PAGE
   ═══════════════════════════════════════════ */
/* Tabs */
.lib-tabs{display:flex;gap:6px;margin-bottom:14px;overflow-x:auto;padding-bottom:2px}
.lib-tabs::-webkit-scrollbar{display:none}
.lib-tab{display:flex;align-items:center;gap:5px;padding:8px 16px;border-radius:12px;font-family:var(--font-ui);font-size:12px;font-weight:700;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}
.lib-tab i{font-size:16px}
.lib-tab:hover{border-color:var(--accent);color:var(--accent)}
.lib-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 14px var(--accent-glow)}
/* Header */
.lib-header{margin-bottom:14px}
.lib-title{font-family:var(--font-heading);font-size:20px;font-weight:800;color:var(--text);margin-bottom:2px}
.lib-sub{font-family:var(--font-ui);font-size:12px;color:var(--text-muted)}
/* Search */
.lib-search-wrap{position:relative;margin-bottom:14px}
.lib-search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--text-muted);pointer-events:none}
.lib-search-input{width:100%;padding:12px 38px 12px 16px;border-radius:14px;border:1px solid var(--border);background:var(--surface);font-family:var(--font-ui);font-size:12px;font-weight:500;color:var(--text);outline:none;transition:all .2s}
.lib-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}
.lib-search-input::placeholder{color:var(--text-muted)}
/* Chips */
.lib-chips-scroll{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:10px}
.lib-chips-scroll::-webkit-scrollbar{display:none}
.lib-chip{padding:8px 16px;border-radius:12px;font-family:var(--font-ui);font-size:11px;font-weight:700;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s}
.lib-chip:hover{background:var(--accent-subtle);border-color:var(--accent)}
.lib-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
/* Grid */
.lib-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(min-width:600px){.lib-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.lib-grid{grid-template-columns:repeat(4,1fr);gap:16px}}

.lib-card{background:var(--surface);border-radius:16px;padding:14px;border:1px solid var(--border-light);display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:all .2s;position:relative}
.lib-card:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-2px)}

.lib-cover{width:100%;aspect-ratio:3/4;border-radius:14px;overflow:hidden;background:var(--bg-warm);position:relative;margin-bottom:10px}
.lib-cover-img{width:100%;height:100%;object-fit:cover}
.lib-cover-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:34px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-light))}
.lib-cover-badge{position:absolute;top:8px;right:8px;padding:3px 10px;border-radius:8px;font-family:var(--font-ui);font-size:10px;font-weight:800;color:#fff;background:var(--accent);backdrop-filter:blur(4px)}

.lib-card-title{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;line-height:1.4;margin-top:2px}

.lib-card-btn{width:100%;margin-top:12px;padding:11px 0;border-radius:10px;border:none;font-family:var(--font-heading);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .2s;background:var(--accent-subtle);color:var(--accent)}
.lib-card-btn:hover{background:var(--accent);color:#fff}
.lib-card-btn:active{transform:scale(.97)}
.lib-card-btn:hover{background:var(--accent);color:#fff}
.lib-card-btn:active{transform:scale(.97)}
/* Empty */
.lib-empty{text-align:center;padding:32px 16px}
.lib-empty-icon{margin-bottom:12px}
.lib-empty-text{font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}
.lib-empty-sub{font-family:var(--font-ui);font-size:12px;color:var(--text-muted)}

[data-theme="dark"] .lib-card-btn:hover{color:#020617}
[data-theme="dark"] .lib-tab.active{color:#fff}
[data-theme="dark"] .lib-chip.active{color:#fff}
[data-theme="dark"] .lib-search-input:focus{box-shadow:0 0 0 3px var(--accent-subtle)}

/* ═══════════════════════════════════════════
   PROFILE PAGE
   ═══════════════════════════════════════════ */
.prf-glass-header{position:relative;text-align:center;padding:28px 20px 20px;margin-bottom:16px;border-radius:20px;background:rgba(255,255,255,.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 24px rgba(0,0,0,.04);overflow:hidden}
.prf-glass-header-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(13,148,136,.06),transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(245,158,11,.04),transparent 50%);pointer-events:none}
[data-theme="dark"] .prf-glass-header{background:rgba(30,41,59,.8);border-color:rgba(255,255,255,.06);box-shadow:0 4px 24px rgba(0,0,0,.15)}
[data-theme="dark"] .prf-glass-header-bg{background:radial-gradient(ellipse at 50% 0%,rgba(94,234,212,.06),transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(245,158,11,.04),transparent 50%)}
/* Premium upsell */
.prf-premium-upsell{position:relative;margin:0 0 16px;padding:18px 20px;border-radius:16px;background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(245,158,11,.02));border:1px solid rgba(245,158,11,.15);cursor:pointer;overflow:hidden;transition:all .2s}
.prf-premium-upsell:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(245,158,11,.15);border-color:rgba(245,158,11,.3)}
.prf-upsell-glow{position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.2),transparent 70%);pointer-events:none}
.prf-upsell-content{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.prf-upsell-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.prf-upsell-text{flex:1}
.prf-upsell-text strong{display:block;font-size:14px;font-weight:700;color:#92400e}
.prf-upsell-text span{display:block;font-size:11px;color:#a16207;margin-top:2px}
[data-theme="dark"] .prf-upsell-text strong{color:#fbbf24}
[data-theme="dark"] .prf-upsell-text span{color:#fcd34d}
[data-theme="dark"] .prf-premium-upsell{background:linear-gradient(135deg,rgba(245,158,11,.12),rgba(245,158,11,.03));border-color:rgba(245,158,11,.2)}
.prf-avatar-wrap{position:relative;width:100px;height:100px;margin:0 auto 16px;border-radius:50%}
.prf-avatar-ring-glow{display:none}
.prf-avatar{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:800;font-size:40px;color:#fff;position:relative;z-index:1;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.2)}
.prf-premium-ribbon,.hdr-premium-ribbon,.prf-premium-crown,.hdr-premium-crown{display:none}
.prf-premium-crown-icon{display:none}
/* Premium — clean golden ring + badge */
.prf-avatar-wrap.premium::before{content:'';position:absolute;inset:-8px;border-radius:50%;border:4px solid #fec111;box-sizing:border-box;background:transparent;z-index:0}
.prf-premium-badge{position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);background:#f39c26;color:#fff;font-size:10px;font-weight:900;padding:4px 18px;border-radius:20px;z-index:3;font-family:var(--font-heading);letter-spacing:1px;box-shadow:0 4px 10px rgba(0,0,0,.06);white-space:nowrap}
.hdr-avatar-ring.premium::before{content:'';position:absolute;inset:-2px;border-radius:50%;border:2.5px solid #fec111;box-sizing:border-box;background:transparent;z-index:0}
.hdr-premium-badge{position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);background:#f39c26;color:#fff;font-size:6px;font-weight:800;padding:1px 6px;border-radius:8px;z-index:4;font-family:var(--font-heading);white-space:nowrap}
.prf-name{font-family:var(--font-heading);font-size:18px;font-weight:800;color:var(--text);margin-bottom:4px}
.prf-rank-line{font-family:var(--font-ui);font-size:12px;font-weight:700;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:6px}
.prf-dot{color:var(--border)}
/* Stats */
.prf-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}
.prf-stat{background:var(--surface);border-radius:14px;padding:14px 8px;text-align:center;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}
.prf-stat-num{display:block;font-family:var(--font-heading);font-size:20px;font-weight:800;color:var(--accent);line-height:1;margin-bottom:4px}
.prf-stat-lbl{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);font-weight:700}
/* Premium Stats */
.prf-prem-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.prf-pstat{text-align:center;background:var(--bg-warm);border-radius:12px;padding:10px 6px}
.prf-pstat-num{display:block;font-family:var(--font-heading);font-size:15px;font-weight:700;color:var(--accent);line-height:1;margin-bottom:3px}
.prf-pstat-lbl{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);font-weight:600}
.prf-pstat-row{display:flex;justify-content:center;gap:14px;font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);font-weight:600;margin-top:4px}
.prf-chart{margin-top:4px}
.prf-chart-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.prf-chart-label{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);min-width:44px;text-align:left;font-weight:600}
.prf-chart-bar-wrap{flex:1;height:16px;background:var(--bg-warm);border-radius:8px;overflow:hidden}
.prf-chart-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:8px;min-width:4px;transition:width .8s ease}
.prf-chart-val{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);min-width:36px;text-align:right;font-weight:600;white-space:nowrap}
/* Card */
.prf-card{background:var(--surface);border-radius:16px;padding:16px;margin-bottom:12px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}
.prf-section-title{font-family:var(--font-heading);font-size:14px;font-weight:800;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}
/* Achievements — compact inline */
.prf-rank-inline{display:flex;align-items:center;gap:8px}
.prf-rank-cur{font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--accent);white-space:nowrap}
.prf-rank-bar-inline{flex:1;height:5px;background:var(--bg-warm);border-radius:3px;overflow:hidden}
.prf-rank-fill-inline{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .5s}
.prf-rank-next{font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--text-muted);white-space:nowrap}
.prf-rank-need{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);font-weight:600;text-align:center;margin-top:6px}
/* Progress */
.prf-progress-bar{width:100%;background:var(--bg-warm);height:6px;border-radius:3px;overflow:hidden;margin-bottom:4px}
.prf-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .5s}
.prf-rank-need{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);font-weight:600;text-align:center}
/* Settings */
.prf-setting-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light)}
.prf-setting-label{font-family:var(--font-ui);font-size:12px;font-weight:700;color:var(--text);display:block}
.prf-setting-sub{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:2px;display:block}
.prf-time-input{background:var(--bg-warm);border:1px solid var(--border);padding:6px 10px;border-radius:10px;font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--text);outline:none}
/* Toggle Switch */
.prf-toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}
.prf-toggle input{display:none}
.prf-toggle-slider{position:absolute;inset:0;background:var(--bg-warm);border-radius:12px;transition:all .3s}
.prf-toggle-slider::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.15);transition:all .3s}
.prf-toggle input:checked+.prf-toggle-slider{background:var(--accent)}
.prf-toggle input:checked+.prf-toggle-slider::after{transform:translateX(20px)}
/* Subscription */
.prf-sub-card{cursor:pointer;transition:all .2s}
.prf-sub-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.prf-sub-inner{display:flex;align-items:center;gap:12px}
.prf-sub-icon{font-size:24px;flex-shrink:0}
.prf-sub-title{font-family:var(--font-ui);font-size:13px;font-weight:700;color:var(--text)}
.prf-sub-desc{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:2px}
/* Ranks page */
.ranks-cur-card{background:var(--surface);border-radius:16px;padding:16px;margin-bottom:12px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px}
.ranks-cur-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.ranks-cur-title{font-family:var(--font-heading);font-size:15px;font-weight:800;color:var(--text)}
.ranks-cur-sub{font-family:var(--font-ui);font-size:11px;color:var(--text-muted);font-weight:600;margin-top:2px}
.ranks-cur-bar{height:6px;background:var(--bg-warm);border-radius:3px;overflow:hidden;margin-top:8px}
.ranks-cur-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .5s}
.ranks-cur-need{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);font-weight:600;margin-top:4px}
.ranks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 4px}
.ranks-grid-item{background:var(--surface);border:2px solid var(--border-light);border-radius:14px;padding:14px 8px;text-align:center;transition:all .2s;position:relative;overflow:hidden}
.ranks-grid-item.completed{border-color:transparent;opacity:.85}
.ranks-grid-item.current{box-shadow:0 0 0 2px var(--gold, #c8922b),0 4px 16px rgba(200,146,43,.2)}
.rgi-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin:0 auto 6px}
.rgi-level{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);font-weight:600;margin-bottom:2px}
.rgi-title{font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--text);line-height:1.3}
.rgi-badge{font-family:var(--font-ui);font-size:9px;font-weight:700;color:var(--gold, #c8922b);margin-top:4px;background:rgba(200,146,43,.12);display:inline-block;padding:2px 8px;border-radius:6px}
.rgi-req{font-family:var(--font-ui);font-size:9px;color:var(--text-muted);font-weight:600;margin-top:4px;line-height:1.3}
.rgi-check{font-family:var(--font-ui);font-size:12px;color:var(--tertiary,#3fb950);font-weight:700;margin-top:4px}
/* Cert list */
.prf-cert-list{display:flex;flex-direction:column;gap:6px}
.prf-cert-chip{padding:10px 14px;background:var(--bg-warm);border-radius:10px;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s}
.prf-cert-chip:hover{background:var(--accent-subtle);color:var(--accent)}
.prf-cert-chip span{font-size:10px;color:var(--text-muted)}
/* Empty */
.prf-empty{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);text-align:center;padding:10px 0}
/* Link button */
.prf-link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-family:var(--font-ui);font-size:11px;font-weight:700}
/* Buttons */
.prf-btn-outline{width:100%;padding:13px;border-radius:14px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-family:var(--font-heading);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;margin-bottom:6px}
.prf-btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}
.prf-btn-danger{width:100%;padding:13px;border-radius:14px;border:1px solid var(--danger);background:transparent;color:var(--danger);font-family:var(--font-heading);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s}
.prf-btn-danger:hover{background:var(--danger);color:#fff}
.prf-version{text-align:center;font-family:var(--font-ui);font-size:11px;color:var(--text-muted);margin-top:10px;opacity:.5}
/* Notifications */
.prf-notif{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:11px}
.prf-notif.unread{background:var(--accent-subtle);margin:0 -12px;padding-left:12px;padding-right:12px;border-radius:8px}
.prf-notif-type{font-size:16px;flex-shrink:0}
.prf-notif-title{font-family:var(--font-heading);font-size:12px;font-weight:700;color:var(--text)}
.prf-notif-msg{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prf-notif-date{font-size:10px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}
.prf-notif-del{background:none;border:none;cursor:pointer;font-size:13px;padding:2px;flex-shrink:0}

[data-theme="dark"] .prf-avatar{box-shadow:0 8px 32px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.15)}
/* Avatar picker */
.av-picker{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:12px}
.av-opt{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.08);border:2px solid var(--border-light)}
.av-opt:hover{transform:scale(1.12);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.av-opt.active{box-shadow:0 0 0 3px var(--surface),0 0 0 5px var(--accent);transform:scale(1.08)}
[data-theme="dark"] .prf-toggle-slider::after{background:var(--surface)}

/* ─── Profile Form ─── */
.prf-field{margin-bottom:12px}
.prf-label{display:flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:12px;font-weight:700;color:var(--text-secondary);margin-bottom:6px}
.prf-label i{font-size:14px;color:var(--accent)}
.prf-input{width:100%;padding:11px 14px;border-radius:12px;border:1px solid var(--border);background:var(--bg-warm);font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--text);outline:none;transition:all .2s}
.prf-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle);background:var(--surface)}
.prf-input::placeholder{color:var(--text-muted)}
.prf-btn-cancel{padding:10px 20px;border-radius:14px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-family:var(--font-heading);font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;flex-shrink:0}
.prf-btn-cancel:hover{background:var(--bg-warm);color:var(--text-secondary)}
.prf-msg{font-size:12px;text-align:center;color:var(--success);margin-top:8px;font-weight:600}

/* ═══════════════════════════════════════════
   PREMIUM PAGE — Enhanced
   ═══════════════════════════════════════════ */
@keyframes premGlowPulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
@keyframes premFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes premSweep{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}
@keyframes premRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
/* Hero */
.prem-hero{position:relative;background:linear-gradient(135deg,#1e1b4b 0%,#311066 35%,#1e1b4b 70%,#1a1040 100%);border-radius:28px;padding:44px 24px 32px;margin-bottom:18px;overflow:hidden;box-shadow:0 20px 60px rgba(46,8,84,0.35)}
.prem-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(168,85,247,0.12),transparent 60%),radial-gradient(ellipse at 80% 70%,rgba(245,158,11,0.08),transparent 50%);animation:premGlowPulse 4s ease-in-out infinite}
.prem-hero-circles{position:absolute;inset:0;pointer-events:none}
.prem-hero-c1{position:absolute;top:-60px;right:-40px;width:160px;height:160px;border-radius:50%;border:2px solid rgba(168,85,247,0.12);animation:premRotate 20s linear infinite}
.prem-hero-c2{position:absolute;bottom:-30px;left:-50px;width:120px;height:120px;border-radius:50%;border:2px solid rgba(245,158,11,0.1);animation:premRotate 15s linear infinite reverse}
.prem-hero-c3{position:absolute;top:30%;left:60%;width:80px;height:80px;border-radius:50%;background:rgba(168,85,247,0.04);animation:premFloat 5s ease-in-out infinite}
.prem-hero-content{position:relative;z-index:1;text-align:center}
.prem-crown-wrap{position:relative;display:inline-block;margin-bottom:16px}
.prem-crown-ring{position:absolute;inset:-6px;border-radius:50%;border:2px dashed rgba(245,158,11,0.25);animation:premRotate 12s linear infinite}
.prem-crown-icon{width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg,#f59e0b,#fbbf24);display:flex;align-items:center;justify-content:center;font-size:30px;color:#fff;box-shadow:0 8px 30px rgba(245,158,11,0.35),0 0 0 8px rgba(245,158,11,0.08);animation:premFloat 3s ease-in-out infinite}
.prem-hero-title{font-family:var(--font-heading);font-size:24px;font-weight:900;color:#fff;margin-bottom:8px;text-shadow:0 2px 12px rgba(0,0,0,.2)}
.prem-hero-sub{font-family:var(--font-ui);font-size:13px;color:rgba(199,210,254,.75);line-height:1.7;max-width:280px;margin:0 auto}
/* Status card */
.prem-status-card{text-align:center;padding:28px 20px;background:var(--surface);border-radius:18px;border:1px solid var(--border);margin-bottom:14px}
.prem-status-card.active{border-color:var(--accent);background:linear-gradient(135deg,var(--accent-subtle),var(--surface))}
.prem-status-icon{font-size:48px;margin-bottom:10px}
.prem-status-title{font-family:var(--font-heading);font-size:16px;font-weight:800;color:var(--text)}
.prem-status-title.active{color:var(--accent)}
.prem-status-sub{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);margin-top:4px}
/* Urgency */
.prem-urgency{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(251,191,36,.05));border:1px solid rgba(245,158,11,.2);border-radius:14px;margin-bottom:14px;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-secondary)}
.prem-urgency i{color:var(--gold)}
.prem-urgency strong{color:var(--gold)}
/* Plans */
.prem-plans{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.prem-plan{background:var(--surface);border-radius:18px;padding:22px 14px 18px;text-align:center;border:2px solid var(--border);cursor:pointer;transition:all .3s;position:relative}
.prem-plan:hover{border-color:var(--accent);box-shadow:0 8px 24px rgba(13,148,136,.08)}
.prem-plan.selected{border-color:var(--accent);background:linear-gradient(135deg,var(--accent-subtle),var(--surface));box-shadow:0 0 0 5px var(--accent-glow),0 8px 30px rgba(13,148,136,.12);transform:translateY(-2px)}
.prem-plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold),#eab308);color:#1e1b4b;font-family:var(--font-ui);font-size:10px;font-weight:800;padding:4px 16px;border-radius:20px;white-space:nowrap;display:flex;align-items:center;gap:4px;box-shadow:0 4px 12px rgba(245,158,11,.3)}
.prem-plan-icon{font-size:28px;margin-bottom:6px}
.prem-plan-name{font-family:var(--font-heading);font-size:13px;font-weight:800;color:var(--text);margin-bottom:8px}
.prem-plan-price{font-family:var(--font-heading);font-size:26px;font-weight:900;color:var(--accent);line-height:1}
.prem-plan-price span{font-size:11px;font-weight:600;color:var(--text-muted)}
.prem-old-price{text-decoration:line-through;color:var(--text-muted);font-size:14px!important;font-weight:500!important;margin-left:4px;opacity:.5}
.prem-plan-save-badge{display:inline-block;background:rgba(5,150,105,.1);color:#059669;font-family:var(--font-ui);font-size:10px;font-weight:700;padding:3px 12px;border-radius:10px;margin-top:8px}
.prem-plan-benefits{display:flex;flex-direction:column;gap:2px;margin-top:10px;font-family:var(--font-ui);font-size:10px;font-weight:600;color:var(--text-muted)}
.prem-plan-benefits span{display:flex;align-items:center;gap:3px;justify-content:center}
/* CTA */
.prem-cta{width:100%;padding:18px;border-radius:18px;border:none;font-family:var(--font-heading);font-size:16px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s;background:linear-gradient(135deg,var(--accent),#059669);color:#fff;box-shadow:0 8px 32px rgba(13,148,136,.4);position:relative;overflow:hidden;margin-bottom:10px}
.prem-cta:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(13,148,136,.5)}
.prem-cta:active{transform:scale(.98)}
.prem-cta:disabled{opacity:.6;cursor:not-allowed;transform:none}
.prem-cta-shine{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transform:translateX(-100%);animation:premSweep 2.5s ease-in-out infinite}
.prem-guarantee-row{display:flex;justify-content:center;gap:20px;font-family:var(--font-ui);font-size:10px;font-weight:600;color:var(--text-muted);margin-bottom:6px;flex-wrap:wrap}
.prem-guarantee-row span{display:flex;align-items:center;gap:4px}
.prem-guarantee-row i{font-size:12px;color:var(--accent)}
/* Section title */
.prem-section-title{font-family:var(--font-heading);font-size:17px;font-weight:800;color:var(--text);margin:22px 0 14px;display:flex;align-items:center;gap:8px}
/* Features grid */
.prem-features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}
.prem-feat-card{background:var(--surface);border-radius:14px;padding:16px 12px;border:1px solid var(--border-light);transition:all .2s}
.prem-feat-card:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-1px)}
.prem-feat-card-icon{font-size:26px;margin-bottom:8px}
.prem-feat-card-text strong{display:block;font-family:var(--font-heading);font-size:12px;font-weight:700;color:var(--text);margin-bottom:3px}
.prem-feat-card-text span{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);line-height:1.4;display:block}
/* Trust grid */
.prem-trust-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.prem-trust-card{background:var(--surface);border-radius:14px;padding:16px 14px;border:1px solid var(--border-light);text-align:center;transition:all .2s}
.prem-trust-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.prem-trust-card-icon{width:40px;height:40px;border-radius:12px;background:var(--accent-subtle);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:18px;color:var(--accent)}
.prem-trust-card strong{display:block;font-family:var(--font-heading);font-size:12px;font-weight:700;color:var(--text);margin-bottom:4px}
.prem-trust-card span{font-family:var(--font-ui);font-size:10px;color:var(--text-muted);line-height:1.4;display:block}
/* FAQ */
.prem-faq{margin-bottom:12px}
.prem-faq-item{background:var(--surface);border-radius:14px;border:1px solid var(--border-light);padding:0;margin-bottom:8px;overflow:hidden;cursor:pointer;transition:all .2s}
.prem-faq-item:hover{border-color:var(--accent)}
.prem-faq-q{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;font-family:var(--font-heading);font-size:13px;font-weight:700;color:var(--text)}
.prem-faq-q i{font-size:18px;color:var(--accent);flex-shrink:0;transition:transform .2s}
.prem-faq-a{padding:0 16px 16px;font-family:var(--font-ui);font-size:12px;color:var(--text-secondary);line-height:1.7}
.prem-footer-note{text-align:center;font-family:var(--font-ui);font-size:11px;color:var(--text-muted);padding:12px 0 32px}
/* Buttons */
.prem-btn-outline{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:14px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-family:var(--font-heading);font-weight:600;font-size:13px;cursor:pointer;transition:all .2s}
.prem-btn-danger{color:var(--danger);border-color:var(--danger)}
.prem-btn-danger:hover{background:var(--danger);color:#fff}

.prem-row{display:flex;align-items:center;gap:14px;padding:14px 20px;cursor:pointer;transition:background .15s;border-top:1px solid var(--border-light)}
.prem-row:last-child{padding-bottom:18px}
.prem-row:hover{background:var(--surface-hover)}
.prem-row:active{opacity:.8}
.prem-row-icon{width:44px;height:44px;border-radius:12px;background:var(--accent-subtle);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.prem-row-text{flex:1;min-width:0}
.prem-row-title{font-family:var(--font-heading);font-size:14px;font-weight:700;color:var(--text)}
.prem-row-sub{font-family:var(--font-ui);font-size:12px;color:var(--text-muted);margin-top:1px}
.prem-row-arrow{font-size:14px;color:var(--text-muted);flex-shrink:0}

[data-theme="dark"] .prem-hero{box-shadow:0 24px 70px rgba(46,8,84,0.5)}

.summary-reader-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,0.6);display:flex;align-items:stretch;justify-content:center;animation:fadeIn .2s ease}
.summary-reader{width:100%;max-width:680px;background:var(--bg-warm,#faf5ee);display:flex;flex-direction:column;margin:0;box-shadow:-4px 0 24px rgba(0,0,0,0.15);animation:slideInLeft .3s ease}
.summary-reader-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(200,146,43,0.2);flex-shrink:0}
.summary-reader-title{font-family:var(--font-heading);font-size:16px;font-weight:700;color:#5c4b2e}
.summary-reader-close{width:36px;height:36px;border-radius:50%;border:1px solid rgba(0,0,0,0.1);background:transparent;font-size:16px;cursor:pointer;color:#8a7a5e;display:flex;align-items:center;justify-content:center;transition:all .15s}
.summary-reader-close:hover{background:rgba(0,0,0,0.05);color:#5c4b2e}
.summary-reader-body{flex:1;overflow-y:auto;padding:32px 28px;font-family:var(--font-body,serif);font-size:17px;line-height:2.2;color:#4a3f2f;white-space:pre-wrap;text-align:justify}
@media(min-width:600px){.summary-reader-body{padding:40px 48px;font-size:18px}}
[data-theme="dark"] .summary-reader{background:#1a1814}
[data-theme="dark"] .summary-reader-title{color:#d4c5a0}
[data-theme="dark"] .summary-reader-body{color:#c4b998}
[data-theme="dark"] .summary-reader-close{color:#8a7a5e;border-color:rgba(255,255,255,0.1)}

/* ═══════════ Audio Player ═══════════ */
.ap{position:fixed;inset:0;z-index:500;display:flex;flex-direction:column;font-family:var(--font-ui);background:var(--bg-warm,#faf5ee);color:var(--text)}
.ap.dark{background:#0f172a;color:#f1f5f9}

/* State screens */
.ap-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px}
.ap-state-icon{font-size:56px;opacity:.25}
.ap-state-text{font-size:15px;color:var(--text-muted)}
.ap-state-err{color:#ef4444;font-size:16px;text-align:center;max-width:300px}
.ap-loader{display:flex;gap:10px}
.ap-loader span{width:12px;height:12px;border-radius:50%;background:var(--gold,#c8922b);animation:ap-bounce 1.2s infinite ease-in-out}
.ap-loader span:nth-child(2){animation-delay:.15s}
.ap-loader span:nth-child(3){animation-delay:.3s}
@keyframes ap-bounce{0%,80%,100%{transform:scale(.3);opacity:.3}40%{transform:scale(1);opacity:1}}

/* Main player */
.ap-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 28px;position:relative;overflow:hidden}

/* Ambient background orbs */
.ap-ambient{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.ap-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.12;animation:ap-float 12s ease-in-out infinite}
.ap-orb-1{width:300px;height:300px;background:var(--gold,#c8922b);top:-80px;left:-80px;animation-delay:0s}
.ap-orb-2{width:250px;height:250px;background:var(--accent,#5eead4);bottom:-60px;right:-60px;animation-delay:-4s}
.ap-orb-3{width:200px;height:200px;background:var(--tertiary,#b87a4a);top:40%;left:50%;animation-delay:-8s}
@keyframes ap-float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.1)}66%{transform:translate(-20px,10px) scale(.9)}}

/* Header */
.ap-hdr{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:14px 20px}
.ap-hdr-label{font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--text-muted)}
.ap-back{display:flex;align-items:center;gap:4px;padding:8px 14px;border-radius:12px;border:1px solid var(--border,rgba(0,0,0,.08));background:var(--surface,rgba(255,255,255,.8));color:var(--text-secondary);font-family:var(--font-ui);font-size:13px;cursor:pointer;transition:all .2s;backdrop-filter:blur(10px)}
.ap.dark .ap-back{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.08);color:rgba(255,255,255,.7)}
.ap-back:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.06)}
.ap.dark .ap-back:hover{background:rgba(255,255,255,.1);color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.2)}
.ap-theme-btn{width:36px;height:36px;border-radius:12px;border:1px solid var(--border,rgba(0,0,0,.08));background:var(--surface,rgba(255,255,255,.8));color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;backdrop-filter:blur(10px)}
.ap.dark .ap-theme-btn{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.08);color:rgba(255,255,255,.7)}
.ap-theme-btn:hover{transform:translateY(-1px)}
.ap.dark .ap-theme-btn:hover{background:rgba(255,255,255,.1);color:#fbbf24}

/* Cover art */
.ap-art{margin-bottom:22px;z-index:1}
.ap-art-inner{width:180px;height:240px;border-radius:24px;overflow:hidden;position:relative;box-shadow:0 24px 60px rgba(0,0,0,.15);transition:all .5s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--primary,#0f172a),var(--primary-light,#1e293b))}
.ap.dark .ap-art-inner{box-shadow:0 24px 60px rgba(0,0,0,.4)}
.ap-art-inner.playing{transform:scale(1.03);box-shadow:0 32px 80px rgba(0,0,0,.2)}
.ap-art-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ap-art-fallback{font-size:64px;color:rgba(255,255,255,.35);font-family:var(--font-heading);z-index:0}
.ap-art-ring{position:absolute;inset:-2px;border-radius:26px;border:2px solid var(--gold);opacity:.15;pointer-events:none;transition:opacity .5s}
.ap-art-inner.playing .ap-art-ring{opacity:.35;animation:ap-ring-pulse 2s ease-in-out infinite}
@keyframes ap-ring-pulse{0%,100%{opacity:.15}50%{opacity:.4}}

/* Info */
.ap-info{text-align:center;max-width:320px;z-index:1;margin-bottom:18px}
.ap-title{font-family:var(--font-heading);font-size:20px;font-weight:700;line-height:1.4;margin:0 0 4px;color:var(--text)}
.ap-author{font-size:13px;color:var(--text-muted);margin:0;font-family:var(--font-ui)}

/* Visualizer */
.ap-viz{display:flex;align-items:flex-end;gap:3px;height:40px;margin-bottom:14px;z-index:1}
.ap-viz-bar{width:4px;border-radius:2px;background:var(--gold,#c8922b);opacity:.25;transition:all .3s;min-height:2px}
.ap-viz-bar.active{animation:ap-viz-bounce .6s ease-in-out infinite alternate}
.ap.dark .ap-viz-bar{background:var(--gold-light,#fbbf24)}
@keyframes ap-viz-bounce{0%{opacity:.2;transform:scaleY(.3)}100%{opacity:.7;transform:scaleY(1.2)}}

/* Progress */
.ap-progress-wrap{width:100%;max-width:420px;z-index:1;margin-bottom:20px}
.ap-progress-track{width:100%;height:8px;border-radius:4px;background:var(--border,rgba(0,0,0,.06));cursor:pointer;position:relative;overflow:visible}
.ap.dark .ap-progress-track{background:rgba(255,255,255,.08)}
.ap-progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--gold,#c8922b),var(--gold-light,#e0b04a));transition:width .15s linear;position:relative}
.ap-progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.2);transition:left .15s linear;border:2px solid var(--gold);opacity:0}
.ap-progress-track:hover .ap-progress-thumb{opacity:1}
.ap-times{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-top:6px;font-variant-numeric:tabular-nums}

/* Controls */
.ap-ctrls{display:flex;align-items:center;gap:20px;z-index:1}
.ap-ctrl{display:flex;align-items:center;justify-content:center;border-radius:14px;border:1px solid var(--border,rgba(0,0,0,.06));background:var(--surface,#fff);color:var(--text-secondary);cursor:pointer;transition:all .2s}
.ap.dark .ap-ctrl{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.06);color:rgba(255,255,255,.6)}
.ap-ctrl:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.06)}
.ap.dark .ap-ctrl:hover{background:rgba(255,255,255,.08);color:#fff}
.ap-ctrl-sm{width:40px;height:40px;border-radius:12px}
.ap-ctrl-md{width:48px;height:48px;border-radius:14px;font-size:18px}
.ap-speed{font-size:12px;font-weight:700}

/* Play button with SVG ring */
.ap-play{width:72px;height:72px;border-radius:50%;border:none;background:var(--gold,#c8922b);color:#0f172a;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 30px rgba(200,146,43,.3);font-size:28px}
.ap-play:hover{transform:scale(1.06);box-shadow:0 14px 40px rgba(200,146,43,.45)}
.ap-play:active{transform:scale(.94)}
.ap-play.on{background:var(--text,#0f172a);color:var(--gold,#c8922b);box-shadow:0 8px 30px var(--accent-glow)}
.ap.dark .ap-play.on{color:var(--gold-light,#fbbf24)}
.ap-play-ring{position:absolute;inset:-8px;width:calc(100% + 16px);height:calc(100% + 16px);transform:rotate(-90deg);transition:all .3s}
.ap-play-ring circle{transition:stroke-dashoffset .3s ease}

/* Responsive */
@media(max-width:480px){
  .ap-main{padding:16px 20px}
  .ap-art-inner{width:140px;height:190px;border-radius:18px}
  .ap-title{font-size:17px}
  .ap-ctrls{gap:14px}
  .ap-play{width:64px;height:64px}
  .ap-ctrl-md{width:42px;height:42px}
  .ap-viz{gap:2px;height:30px}
  .ap-viz-bar{width:3px}
}

/* ─── Premium Scrollbars ─── */
[data-premium-theme] ::-webkit-scrollbar{width:8px;height:8px}
[data-premium-theme] ::-webkit-scrollbar-track{background:var(--bg-warm);border-radius:4px}
[data-premium-theme] ::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
[data-premium-theme] ::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* ─── Premium Loading Skeletons ─── */
[data-premium-theme] .skel{background:linear-gradient(90deg,var(--bg-warm) 25%,var(--surface) 50%,var(--bg-warm) 75%);background-size:200% 100%;animation:skelShine 1.5s ease-in-out infinite}
[data-premium-theme="night"] .skel{background:linear-gradient(90deg,var(--bg-warm) 25%,var(--surface-hover) 50%,var(--bg-warm) 75%);background-size:200% 100%}
[data-premium-theme] .skel-card{background:transparent}

/* ─── Keyframe Animations ─── */
@keyframes skelShine{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* Star twinkle for night theme */
@keyframes starTwinkle{0%,100%{opacity:0.2}50%{opacity:1}}
@keyframes starTwinkle2{0%,100%{opacity:0.4}30%{opacity:1}70%{opacity:0.3}}
/* Floating for oasis theme */
@keyframes leafFloat{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-6px) rotate(2deg)}}
/* Wave for ocean theme */
@keyframes waveShift{0%{background-position:0 0}100%{background-position:40px 0}}
/* Sand shimmer for desert */
@keyframes sandShimmer{0%,100%{opacity:0.4}50%{opacity:0.7}}

/* ─── oasis — floating leaves ambient ─── */
[data-premium-theme="oasis"] section:nth-child(odd)::after{content:'';position:absolute;width:20px;height:20px;background:var(--accent-subtle);border-radius:50% 0 50% 0;top:10px;left:30px;animation:leafFloat 4s ease-in-out infinite;opacity:0.3;pointer-events:none}
[data-premium-theme="oasis"] section:nth-child(even)::after{content:'';position:absolute;width:16px;height:16px;background:var(--tertiary-subtle);border-radius:0 50% 0 50%;bottom:10px;right:40px;animation:leafFloat 5s ease-in-out 1s infinite;opacity:0.25;pointer-events:none}

/* ─── ocean — wave ambient at bottom of page ─── */
[data-premium-theme="ocean"] body::after{content:'';position:fixed;bottom:0;left:0;right:0;height:6px;background:repeating-linear-gradient(90deg,var(--accent-light) 0,var(--accent-light) 8px,transparent 8px,transparent 16px);animation:waveShift 3s linear infinite;opacity:0.15;pointer-events:none;z-index:-1}

/* ─── desert — sand shimmer on cards ─── */
[data-premium-theme="desert"] .card::before{background:linear-gradient(135deg,transparent 40%,var(--gold-light) 41%,var(--gold-light) 42%,transparent 43%);animation:sandShimmer 4s ease-in-out infinite;opacity:0.05}

/* ─── night — twinkling stars (ambient) ─── */
[data-premium-theme="night"] body{position:relative}
[data-premium-theme="night"] section:nth-child(3n)::before{content:'';position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;top:15%;left:15%;animation:starTwinkle 3s ease-in-out infinite;pointer-events:none}
[data-premium-theme="night"] section:nth-child(3n+1)::before{content:'';position:absolute;width:1px;height:1px;border-radius:50%;background:#fff;top:25%;right:20%;animation:starTwinkle2 4s ease-in-out 1s infinite;pointer-events:none}

/* ═══════════════════════════════════════════
   🌙 RAMADAN — Exclusive Seasonal Theme
   ═══════════════════════════════════════════ */
:root[data-premium-theme="ramadan"]{--bg:#0a0e1a;--bg-warm:#111827;--surface:#1a1f35;--surface-hover:#222840;--text:#e8d5b0;--text-secondary:#b8a080;--text-muted:#6a5a40;--border:#2a2840;--border-light:rgba(42,40,64,0.5);--accent:#d4a030;--accent-light:#f0d060;--accent-dark:#a07020;--accent-glow:rgba(212,160,48,0.2);--accent-subtle:rgba(212,160,48,0.06);--tertiary:#7c3aed;--tertiary-light:#a78bfa;--tertiary-dark:#5b21b6;--tertiary-glow:rgba(124,58,237,0.15);--tertiary-subtle:rgba(124,58,237,0.05);--gold:#d4a030;--gold-light:#f0d060;--success:#22c55e;--success-bg:rgba(34,197,94,0.08);--danger:#ef4444;--danger-bg:rgba(239,68,68,0.08);--success-glow:rgba(34,197,94,0.15);--shadow-sm:0 1px 3px rgba(0,0,0,0.5);--shadow:0 4px 24px rgba(0,0,0,0.6);--shadow-lg:0 12px 48px rgba(0,0,0,0.7);--shadow-xl:0 24px 72px rgba(0,0,0,0.8);--radius-sm:8px;--radius:12px;--radius-lg:18px;--radius-xl:28px;--transition-fast:0.15s ease;--transition-smooth:0.45s cubic-bezier(.4,0,.2,1);--font-spacing:0px;--shadow-xs:0 1px 2px rgba(0,0,0,0.4);--bg-mesh:radial-gradient(circle at 30% 20%,rgba(212,160,48,0.08) 0%,transparent 50%),radial-gradient(circle at 80% 60%,rgba(124,58,237,0.06) 0%,transparent 40%)}
[data-premium-theme="ramadan"] body{background:#0a0e1a!important;background-image:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,0.3),transparent),radial-gradient(2px 2px at 50% 10%,rgba(212,160,48,0.4),transparent),radial-gradient(1px 1px at 70% 50%,rgba(255,255,255,0.25),transparent),radial-gradient(1px 1px at 90% 20%,rgba(255,255,255,0.2),transparent),radial-gradient(1px 1px at 30% 70%,rgba(255,255,255,0.15),transparent),radial-gradient(2px 2px at 60% 40%,rgba(212,160,48,0.3),transparent),radial-gradient(1px 1px at 15% 60%,rgba(255,255,255,0.2),transparent),radial-gradient(1px 1px at 45% 80%,rgba(255,255,255,0.18),transparent),radial-gradient(1px 1px at 80% 75%,rgba(255,255,255,0.22),transparent)!important}
[data-premium-theme="ramadan"] .card{background:rgba(26,31,53,0.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);box-shadow:0 4px 24px rgba(212,160,48,0.08)}
[data-premium-theme="ramadan"] .card:hover{box-shadow:0 8px 40px rgba(212,160,48,0.15),0 0 0 1px var(--border-light),0 0 0 4px var(--accent-subtle)}
[data-premium-theme="ramadan"] .btn{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#0a0e1a;font-weight:700;border:0}
[data-premium-theme="ramadan"] .btn-gold{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#0a0e1a;box-shadow:0 0 32px var(--accent-glow)}
[data-premium-theme="ramadan"] .section-title{color:var(--accent-light);text-shadow:0 0 16px var(--accent-glow)}
[data-premium-theme="ramadan"] .home-identity{background:linear-gradient(135deg,rgba(212,160,48,0.12),rgba(124,58,237,0.05));border-color:rgba(212,160,48,0.2)}
[data-premium-theme="ramadan"] ::selection{background:var(--accent);color:var(--bg)}
[data-premium-theme="ramadan"] .hdr-avatar-ring.premium{box-shadow:0 0 0 2px var(--accent-glow),0 0 32px var(--accent-glow)}
/* Ramadan lantern glow on nav */
[data-premium-theme="ramadan"] .nav-item.active{text-shadow:0 0 12px var(--accent-glow)}

/* ─── Gift Page ─── */
.gift-plan-card {
  flex:1; padding:12px 8px; border-radius:10px; border:2px solid var(--border);
  text-align:center; cursor:pointer; transition:all .2s;
  background:var(--surface);
}
.gift-plan-card.active {
  border-color:var(--gold); background:var(--gold-subtle); box-shadow:0 0 0 3px rgba(245,158,11,.15);
}
.gift-plan-name { font-size:14px; font-weight:700; color:var(--text); margin-bottom:2px }
.gift-plan-price { font-size:16px; font-weight:800; color:var(--gold); margin-bottom:1px }
.gift-plan-desc { font-size:11px; color:var(--text-muted) }
.gift-code-info { border-radius:8px; text-align:center }

/* ─── Tab buttons (Clubs/Stats) ─── */
.tab-btn.active { background:var(--accent)!important; color:#fff!important; box-shadow:0 2px 8px rgba(13,148,136,.25) }
.stab-btn.active { background:var(--accent-subtle)!important; color:var(--accent)!important; }

/* ─── Stats cards ─── */
.stats-card { transition:all .15s }
.stats-card:hover { background:var(--surface-hover); transform:translateX(-2px) }
