/* ═══════════════════════════════════════════════════════════════
   NAITAKU V7 — Production CSS
   Consolidated from: variables.css, global.css, components.css, animations.css
   Verified against full source analysis of app/(tabs), components/, hooks/
   Background: #0F0A1A | Surface: #1A1035 | Primary: #8B5CF6
═══════════════════════════════════════════════════════════════ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Lora:ital,wght@0,400;0,600;1,400&display=swap');

/* ══════════════════════════════════════════
   1. DESIGN TOKENS (css/variables.css)
══════════════════════════════════════════ */
:root {
  /* Backgrounds */
  --bg:             #0F0A1A;
  --surface:        #1A1035;
  --surface-2:      #221445;
  --surface-3:      #2A1A55;
  /* Borders */
  --border:         #2D1F4E;
  --border-light:   rgba(255,255,255,0.08);
  /* Text */
  --text:           #FFFFFF;
  --text-secondary: #A0A0A0;
  --text-muted:     rgba(255,255,255,0.45);
  /* Primary */
  --primary:        #8B5CF6;
  --primary-light:  #A78BFA;
  --primary-05:     rgba(139,92,246,0.05);
  --primary-10:     rgba(139,92,246,0.10);
  --primary-12:     rgba(139,92,246,0.12);
  --primary-15:     rgba(139,92,246,0.15);
  --primary-20:     rgba(139,92,246,0.20);
  --primary-30:     rgba(139,92,246,0.30);
  --primary-40:     rgba(139,92,246,0.40);
  /* Semantic colours */
  --green:          #10B981;
  --green-12:       rgba(16,185,129,0.12);
  --green-15:       rgba(16,185,129,0.15);
  --amber:          #F59E0B;
  --amber-12:       rgba(245,158,11,0.12);
  --red:            #EF4444;
  --red-10:         rgba(239,68,68,0.10);
  --orange:         #FF9800;
  --gold:           #FFD700;
  --gold-15:        rgba(255,215,0,0.15);
  /* Rating colours (verified from utils/colors.ts) */
  --score-excellent:#4CAF50;
  --score-great:    #8BC34A;
  --score-good:     #CDDC39;
  --score-avg:      #FFC107;
  --score-below:    #FF9800;
  --score-poor:     #F44336;
  /* Badge colours (verified from components/MediaCard.tsx) */
  --sub-badge:      rgba(16,185,129,0.90);
  --dub-badge:      rgba(139,92,246,0.90);
  /* Layout */
  --tab-bar-h:      68px;
  --header-h:       60px;
  --max-w:          480px;
  --pad:            16px;
  /* Radii */
  --r-xs:  6px;  --r-sm: 8px; --r-md: 12px; --r-lg: 14px;
  --r-xl: 16px;  --r-2xl:20px;--r-full:9999px;
  /* Typography */
  --font:       'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-serif: 'Lora', Georgia, serif;
  /* Shadows */
  --shadow-sm:     0 1px  4px rgba(0,0,0,.30);
  --shadow-md:     0 4px 12px rgba(0,0,0,.40);
  --shadow-lg:     0 8px 24px rgba(0,0,0,.50);
  --shadow-purple: 0 4px 24px rgba(139,92,246,.30);
  /* Easing */
  --ease:       cubic-bezier(.4,0,.2,1);
  --ease-out:   cubic-bezier(0,0,.2,1);
  --ease-in:    cubic-bezier(.4,0,1,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  /* Z-index */
  --z-sticky:  100; --z-overlay:200; --z-modal:300; --z-toast:400;
}

/* Light mode overrides */
html.light-mode {
  --bg:             #FFFFFF;
  --surface:        #F5F5F8;
  --surface-2:      #EEEEEE;
  --surface-3:      #E5E5E5;
  --text:           #1A1A1A;
  --text-secondary: #666666;
  --text-muted:     rgba(0,0,0,.40);
  --border:         #E0E0E0;
  --border-light:   rgba(0,0,0,.08);
}

/* ══════════════════════════════════════════
   2. RESET & BASE (css/global.css)
══════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
html { font-size:16px; scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  min-height:100vh; min-height:100dvh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Desktop decoration */
@media (min-width:500px) {
  body { background:radial-gradient(ellipse at 50% 0%,rgba(139,92,246,.12) 0%,var(--bg) 60%); }
  #app { box-shadow:0 0 80px rgba(0,0,0,.8); }
}

/* App shell */
#app {
  width:100%; max-width:var(--max-w);
  margin:0 auto; min-height:100vh; min-height:100dvh;
  position:relative; background:var(--bg); overflow:hidden;
}

/* Pages */
.page { display:none; flex-direction:column; min-height:100vh; min-height:100dvh; background:var(--bg); }
.page.active { display:flex; }

/* Page content area */
.page-content {
  flex:1; overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch; scrollbar-width:none;
}
.page-content::-webkit-scrollbar { display:none; }

/* Horizontal scroll rows */
.scroll-row {
  display:flex; gap:12px; overflow-x:auto; overflow-y:visible;
  -webkit-overflow-scrolling:touch; scrollbar-width:none;
  padding-bottom:4px; padding-right:16px;
}
.scroll-row::-webkit-scrollbar { display:none; }

/* Section wrapper */
.section { padding:0 var(--pad); margin-bottom:32px; }
.section:last-child { margin-bottom:0; }

/* Bottom safe-area padding */
.bottom-pad { height:calc(var(--tab-bar-h) + 24px); }

/* Typography */
h1 { font-size:28px; font-weight:800; line-height:1.2; letter-spacing:-.5px; }
h2 { font-size:22px; font-weight:800; line-height:1.2; letter-spacing:-.3px; }
h3 { font-size:18px; font-weight:700; line-height:1.3; }
h4 { font-size:16px; font-weight:600; line-height:1.4; }
p  { font-size:15px; line-height:1.6; color:var(--text-secondary); }
a  { color:var(--primary); text-decoration:none; cursor:pointer; }

/* Buttons */
button { cursor:pointer; border:none; background:none; font-family:var(--font); color:inherit; }
button:active { transform:scale(.96); }

.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px; padding:12px 20px; border-radius:var(--r-full);
  font-size:15px; font-weight:600; white-space:nowrap;
  transition:opacity .15s var(--ease),transform .15s var(--ease-spring);
  cursor:pointer; border:none;
}
.btn:active { transform:scale(.96); }
.btn-primary {
  background:linear-gradient(135deg,var(--primary),#6D28D9);
  color:#fff; box-shadow:var(--shadow-purple);
}
.btn-ghost { background:var(--primary-10); color:var(--primary); border:1px solid var(--primary-30); }
.btn-outline { background:transparent; color:var(--text); border:1.5px solid rgba(255,255,255,.25); }

/* Inputs */
input,textarea,select {
  font-family:var(--font); font-size:15px; background:var(--surface);
  color:var(--text); border:1px solid var(--border); border-radius:var(--r-md);
  padding:10px 14px; outline:none; width:100%;
  transition:border-color .2s var(--ease);
}
input:focus,textarea:focus,select:focus { border-color:var(--primary); }
input::placeholder,textarea::placeholder { color:var(--text-secondary); }

/* Images */
img { display:block; max-width:100%; }

/* Spinner */
.spinner-wrap {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:16px; min-height:200px;
  color:var(--text-secondary); font-size:14px;
}
.spinner {
  width:36px; height:36px; border:3px solid var(--border);
  border-top-color:var(--primary); border-radius:50%;
  animation:spin .8s linear infinite;
}

/* Empty state */
.empty-state {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; padding:60px 32px; text-align:center; min-height:300px;
}
.empty-state .icon-wrap {
  width:72px; height:72px; border-radius:50%; background:var(--primary-10);
  display:flex; align-items:center; justify-content:center; font-size:28px; margin-bottom:8px;
}
.empty-state h3 { color:var(--text); font-size:18px; font-weight:700; }
.empty-state p  { font-size:14px; color:var(--text-secondary); max-width:280px; line-height:1.5; }

/* Toast */
#global-toast {
  position:fixed; bottom:calc(var(--tab-bar-h) + 16px);
  left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--surface-2); color:var(--text);
  padding:10px 20px; border-radius:var(--r-full);
  font-size:14px; font-weight:500; white-space:nowrap;
  box-shadow:var(--shadow-lg); z-index:var(--z-toast);
  opacity:0; transition:all .3s var(--ease-spring);
  border:1px solid var(--border); max-width:calc(var(--max-w) - 32px);
}
#global-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
#global-toast.success { border-color:var(--green); }
#global-toast.error   { border-color:var(--red); }

/* Skeleton shimmer */
.skeleton {
  background:linear-gradient(90deg,var(--surface) 25%,var(--surface-2) 50%,var(--surface) 75%);
  background-size:200% 100%; animation:shimmer 1.5s infinite;
}

/* Pills */
.score-pill {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 8px; border-radius:var(--r-xs);
  background:var(--gold-15); font-size:11px; font-weight:700; color:#B8860B;
}
.format-pill {
  display:inline-flex; align-items:center; padding:3px 8px;
  border-radius:var(--r-xs); background:var(--primary-15);
  font-size:10px; font-weight:700; color:var(--primary);
  text-transform:uppercase; letter-spacing:.3px;
}
.genre-tag {
  display:inline-block; padding:4px 10px; border-radius:var(--r-sm);
  background:rgba(255,255,255,.08); color:var(--text-secondary);
  font-size:12px; font-weight:500; white-space:nowrap; cursor:pointer;
  transition:background .15s;
}
.genre-tag:hover { background:var(--primary-15); color:var(--primary); }

/* Divider */
.divider { height:1px; background:var(--border); margin:16px 0; }

/* Progress bar */
.progress-bar { height:3px; background:var(--border); border-radius:var(--r-full); overflow:hidden; }
.progress-bar-fill { height:100%; background:var(--primary); border-radius:var(--r-full); transition:width .3s var(--ease); }

/* Settings card */
.settings-card { background:var(--surface); border-radius:var(--r-xl); overflow:hidden; margin-bottom:16px; }
.settings-row {
  display:flex; align-items:center; padding:14px 16px; gap:12px;
  border-bottom:1px solid var(--border); cursor:pointer; transition:background .15s;
}
.settings-row:last-child { border-bottom:none; }
.settings-row:active { background:var(--primary-05); }
.settings-row-icon { width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0; }
.settings-row-content { flex:1; }
.settings-row-title { font-size:15px;font-weight:600;color:var(--text); }
.settings-row-desc  { font-size:12px;color:var(--text-secondary);margin-top:2px; }
.settings-row-arrow { color:var(--text-secondary);font-size:14px; }

/* Switch toggle */
.switch-wrap { display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border); }
.switch-wrap:last-child { border-bottom:none; }
.switch-info { flex:1; }
.switch-info .switch-title { font-size:15px;font-weight:600;color:var(--text); }
.switch-info .switch-desc  { font-size:12px;color:var(--text-secondary);margin-top:2px; }
.switch { position:relative;width:44px;height:24px;flex-shrink:0;margin-left:16px; }
.switch input { display:none; }
.switch-slider { position:absolute;inset:0;background:var(--border);border-radius:var(--r-full);cursor:pointer;transition:background .2s; }
.switch-slider::after { content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s var(--ease-spring); }
.switch input:checked + .switch-slider { background:var(--primary); }
.switch input:checked + .switch-slider::after { transform:translateX(20px); }

/* Info card */
.info-card { background:var(--surface);border-radius:var(--r-xl);padding:14px 16px;display:flex;align-items:center;gap:12px;margin-bottom:16px;border:1px solid var(--border); }

/* Truncation */
.truncate-1 { display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden; }
.truncate-2 { display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.truncate-3 { display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden; }

/* Sub-header used on inner pages */
.sub-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:52px 16px 14px; gap:12px;
}
.sub-header-center { flex:1; }
.sub-header-center h2 { font-size:20px;font-weight:700;color:var(--text); }
.sub-header-center p  { font-size:13px;color:var(--text-secondary);margin-top:1px; }

/* Back button */
.back-btn {
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);cursor:pointer;border:1px solid var(--border-light);
  flex-shrink:0;transition:transform .15s var(--ease-spring);font-size:18px;color:#fff;
}
.back-btn:active { transform:scale(.92); }

/* Gradient text */
.gradient-text {
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* ══════════════════════════════════════════
   3. COMPONENTS (css/components.css)
══════════════════════════════════════════ */

/* ── App Header ── */
.app-header {
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--max-w);height:var(--header-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;background:rgba(15,10,26,.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-light);z-index:var(--z-sticky);
}
html.light-mode .app-header { background:rgba(255,255,255,.95); }
.header-spacer { height:var(--header-h); }
.header-logo { display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none; }
.header-logo-text { font-size:20px;font-weight:800;color:var(--primary);letter-spacing:-.5px; }
.header-actions { display:flex;align-items:center;gap:10px; }
.header-action-btn {
  width:40px;height:40px;border-radius:var(--r-md);
  background:var(--primary-15);border:1px solid var(--primary-20);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:transform .15s var(--ease-spring),background .15s;
  color:var(--primary);font-size:16px;flex-shrink:0;
}
.header-action-btn:active { transform:scale(.92); }
.header-avatar { width:32px;height:32px;border-radius:10px;border:2px solid var(--primary);object-fit:cover; }

/* ── Tab Bar (matches _layout.tsx exactly) ── */
.tab-bar {
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--max-w);height:var(--tab-bar-h);
  display:flex;align-items:center;
  background:rgba(18,18,18,.98);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-light);
  z-index:var(--z-sticky);padding:0 8px 8px;
}
html.light-mode .tab-bar { background:rgba(255,255,255,.98); }
.tab-item {
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:4px;cursor:pointer;padding:8px 4px;
  position:relative;transition:transform .2s var(--ease-spring);
  border:none;background:none;height:100%;
}
.tab-item:active { transform:scale(.92); }
.tab-icon  { font-size:22px;transition:color .2s var(--ease);line-height:1; }
.tab-label { font-size:11px;font-weight:500;transition:color .2s var(--ease);line-height:1; }
.tab-item .tab-icon,.tab-item .tab-label { color:rgba(255,255,255,.55); }
html.light-mode .tab-item .tab-icon,html.light-mode .tab-item .tab-label { color:rgba(0,0,0,.55); }
.tab-item.active .tab-icon,.tab-item.active .tab-label { color:var(--primary); }
.tab-indicator {
  position:absolute;bottom:0;width:16px;height:2px;
  background:var(--primary);border-radius:var(--r-full);opacity:0;
  transition:opacity .2s var(--ease);
}
.tab-item.active .tab-indicator { opacity:1; }

/* ── Media Card (matches MediaCard.tsx exactly) ── */
.media-card {
  width:150px;border-radius:var(--r-lg);overflow:hidden;
  background:var(--surface);flex-shrink:0;cursor:pointer;
  transition:transform .2s var(--ease-spring);
}
.media-card:active { transform:scale(.96); }
@media(hover:hover) { .media-card:hover { transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.4); } }
.media-card-cover { position:relative;width:100%;height:213px; }
.media-card-cover img { width:100%;height:100%;object-fit:cover;display:block; }
.cover-placeholder { width:100%;height:100%;background:linear-gradient(135deg,var(--surface-2),var(--surface-3));display:flex;align-items:center;justify-content:center;font-size:32px;opacity:.5; }
/* SUB/DUB badges — top-right, verified from MediaCard.tsx */
.media-card-badges { position:absolute;top:7px;right:7px;display:flex;flex-direction:column;gap:3px;z-index:2; }
.media-badge-sub { padding:2px 5px;border-radius:5px;background:var(--sub-badge);color:#fff;font-size:9px;font-weight:800;letter-spacing:.3px; }
.media-badge-dub { padding:2px 5px;border-radius:5px;background:var(--dub-badge);color:#fff;font-size:9px;font-weight:800;letter-spacing:.3px; }
/* Episode/Chapter count — bottom-left */
.media-card-count { position:absolute;bottom:7px;left:7px;padding:2px 6px;border-radius:5px;background:rgba(0,0,0,.72);color:#fff;font-size:9px;font-weight:700;z-index:2; }
.media-card-info { padding:10px;display:flex;flex-direction:column;gap:5px; }
.media-card-title { font-size:13px;font-weight:600;color:var(--text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.media-card-meta { display:flex;flex-wrap:wrap;gap:5px; }

/* Airing & date badges */
.airing-badge { display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:6px;background:var(--green-12);color:var(--green);font-size:10px;font-weight:600; }
.date-badge   { display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:6px;background:var(--amber-12);color:var(--amber);font-size:10px;font-weight:600; }

/* ── Section Header (matches SectionHeader in MediaCard.tsx) ── */
.section-header { display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px; }
.section-header-left { flex:1; }
.section-title    { font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px;line-height:1.2; }
.section-subtitle { font-size:13px;color:var(--text-muted);margin-top:2px; }
.view-all-btn {
  display:flex;align-items:center;gap:4px;padding:6px 10px;
  background:var(--primary-15);border:1px solid var(--primary-30);
  border-radius:var(--r-md);color:var(--primary);font-size:12px;
  font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;margin-left:12px;
  transition:background .15s;
}
.view-all-btn:hover { background:var(--primary-20); }
.view-all-btn:active { transform:scale(.95); }

/* ── Hero Carousel (matches @anime.tsx / @manga.tsx hero exactly) ── */
.hero-wrapper { position:relative;width:100%;overflow:hidden; }
.hero-track   { display:flex;transition:transform .5s var(--ease-out); }
.hero-slide   { width:100%;flex-shrink:0;position:relative;overflow:hidden; }
.hero-img     { width:100%;height:100%;object-fit:cover;display:block; }
.hero-gradient {
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 20%,rgba(0,0,0,.4) 50%,rgba(0,0,0,.8) 70%,rgba(0,0,0,.95) 100%);
}
.hero-content { position:absolute;bottom:0;left:0;right:0;padding:20px;padding-bottom:50px;display:flex;flex-direction:column;gap:14px; }
.hero-meta {
  display:inline-flex;align-items:center;gap:14px;padding:10px 14px;
  background:rgba(0,0,0,.45);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-radius:14px;border:1px solid rgba(255,255,255,.1);align-self:flex-start;
}
.hero-stat { display:flex;align-items:center;gap:5px;font-size:13px;color:#fff;font-weight:600; }
.hero-title {
  font-size:28px;font-weight:800;color:#fff;letter-spacing:-.5px;line-height:1.2;
  text-shadow:0 2px 8px rgba(0,0,0,.75);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.hero-desc {
  font-size:14px;color:rgba(255,255,255,.85);line-height:1.5;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.hero-cta {
  display:inline-flex;align-items:center;gap:10px;padding:13px 24px;
  border-radius:var(--r-md);background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.25);color:#fff;
  font-size:15px;font-weight:700;cursor:pointer;align-self:flex-start;
  transition:background .15s;
}
.hero-cta:active { transform:scale(.96); }
.hero-dots { position:absolute;bottom:28px;left:0;right:0;display:flex;justify-content:center;gap:8px;z-index:3; }
.hero-dot { width:8px;height:8px;border-radius:var(--r-full);background:rgba(255,255,255,.35);transition:all .3s var(--ease-out);cursor:pointer; }
.hero-dot.active { width:20px;background:var(--primary); }
/* Progress bar at bottom of hero */
.hero-progress-bar { position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.1);z-index:3; }
.hero-progress-fill { height:100%;background:var(--primary);opacity:.8;width:0%;transition:width .1s linear; }

/* ── Search Modal ── */
.search-modal {
  position:fixed;inset:0;z-index:var(--z-modal);
  display:none;flex-direction:column;
  background:rgba(15,10,26,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  max-width:var(--max-w);left:50%;transform:translateX(-50%);
}
.search-modal.open { display:flex; }
.search-modal-header { display:flex;align-items:center;gap:10px;padding:52px 16px 12px; }
.search-input-wrap {
  flex:1;display:flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-md);padding:0 12px;
}
.search-input-wrap:focus-within { border-color:var(--primary); }
.search-input-wrap input { flex:1;background:none;border:none;padding:10px 0;font-size:15px;color:var(--text); }
.search-icon  { color:var(--text-secondary);font-size:16px; }
.search-clear-btn { color:var(--text-secondary);cursor:pointer;font-size:18px;padding:4px; }
.search-close-btn { color:var(--text-secondary);cursor:pointer;font-size:22px;padding:4px;flex-shrink:0; }
.search-filters { display:flex;gap:8px;padding:0 16px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none; }
.search-filters::-webkit-scrollbar { display:none; }
.search-filter-btn {
  padding:5px 14px;border-radius:var(--r-full);font-size:13px;font-weight:600;
  background:var(--surface);color:var(--text-secondary);border:1px solid var(--border);
  white-space:nowrap;cursor:pointer;transition:all .15s;flex-shrink:0;
}
.search-filter-btn.active { background:var(--primary);color:#fff;border-color:var(--primary); }
.search-results { flex:1;overflow-y:auto;padding:0 16px;scrollbar-width:none; }
.search-results::-webkit-scrollbar { display:none; }
.search-section-title { font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 8px; }
.search-result-item {
  display:flex;align-items:center;gap:12px;padding:12px;
  border-radius:var(--r-lg);background:var(--surface);margin-bottom:10px;cursor:pointer;
}
.search-result-item:active { background:var(--surface-2); }
.search-result-img { width:48px;height:48px;border-radius:var(--r-md);object-fit:cover;background:var(--surface-2);flex-shrink:0; }
.search-result-img.circle { border-radius:50%; }
.search-result-info { flex:1;overflow:hidden; }
.search-result-name { font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.search-result-meta { font-size:12px;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }

/* ── Settings Bottom Sheet ── */
.settings-modal-backdrop {
  position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:var(--z-overlay);
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease);
  max-width:var(--max-w);left:50%;transform:translateX(-50%);
}
.settings-modal-backdrop.open { opacity:1;pointer-events:all; }
.settings-sheet {
  position:fixed;bottom:0;left:50%;transform:translateX(-50%) translateY(100%);
  width:100%;max-width:var(--max-w);background:var(--surface);
  border-radius:24px 24px 0 0;z-index:var(--z-modal);
  transition:transform .4s var(--ease-spring);max-height:78vh;
  display:flex;flex-direction:column;overflow:hidden;border-top:1px solid var(--border);
}
.settings-sheet.open { transform:translateX(-50%) translateY(0); }
.settings-sheet-handle { width:36px;height:4px;background:var(--border);border-radius:var(--r-full);margin:12px auto 4px;flex-shrink:0; }
.settings-sheet-content { overflow-y:auto;flex:1;scrollbar-width:none;padding-bottom:32px; }
.settings-sheet-content::-webkit-scrollbar { display:none; }
.settings-user-info { display:flex;align-items:flex-end;gap:12px;padding:16px;position:relative;z-index:2; }
.settings-user-avatar { width:64px;height:64px;border-radius:16px;border:3px solid var(--primary);object-fit:cover;flex-shrink:0;background:var(--surface-2); }
.settings-user-name { font-size:20px;font-weight:800;color:var(--text); }
.settings-user-badge { display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--primary-15);border-radius:var(--r-full);color:var(--primary);font-size:11px;font-weight:700;margin-top:4px; }
.settings-quick-row { display:flex;gap:10px;padding:12px 16px;overflow-x:auto;scrollbar-width:none; }
.settings-quick-row::-webkit-scrollbar { display:none; }
.settings-quick-btn {
  display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;
  border-radius:var(--r-xl);background:var(--surface-2);border:1px solid var(--border);
  cursor:pointer;white-space:nowrap;flex-shrink:0;transition:border-color .15s,background .15s;min-width:80px;
}
.settings-quick-btn.active { border-color:var(--primary);background:var(--primary-10); }
.settings-quick-icon  { font-size:20px; }
.settings-quick-label { font-size:11px;font-weight:600;color:var(--text-secondary); }
.settings-quick-btn.active .settings-quick-label { color:var(--primary); }
.settings-nav-link {
  display:flex;align-items:center;gap:14px;padding:14px 16px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;
}
.settings-nav-link:last-child { border-bottom:none; }
.settings-nav-link:active { background:var(--primary-05); }
.settings-nav-icon { width:38px;height:38px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0; }
.settings-nav-text { flex:1; }
.settings-nav-text strong { display:block;font-size:15px;font-weight:600;color:var(--text); }
.settings-nav-text span  { font-size:12px;color:var(--text-secondary); }
.settings-nav-arrow { color:var(--text-secondary);font-size:14px; }

/* ── Detail page header (anime/manga detail) ── */
.detail-banner { width:100%;height:280px;position:relative;overflow:hidden; }
.detail-banner-img { width:100%;height:100%;object-fit:cover;display:block; }
.detail-banner-gradient {
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.3) 0%,transparent 40%,rgba(15,10,26,.7) 70%,var(--bg) 100%);
}
.detail-banner-back { position:absolute;top:52px;left:16px;z-index:10; }
.detail-banner-actions { position:absolute;top:52px;right:16px;z-index:10;display:flex;gap:10px; }
.detail-header-content { display:flex;gap:16px;padding:0 16px;margin-top:-70px;position:relative;z-index:2; }
.detail-cover { width:110px;height:160px;border-radius:var(--r-xl);object-fit:cover;flex-shrink:0;border:2px solid var(--border);background:var(--surface-2);box-shadow:var(--shadow-lg); }
.detail-title-area { flex:1;padding-top:70px;min-width:0; }
.detail-title { font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.3px;line-height:1.2;margin-bottom:6px; }
.detail-native-title { font-size:13px;color:var(--text-secondary);margin-bottom:10px; }
.detail-badges { display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px; }
.detail-badge { padding:3px 10px;border-radius:var(--r-xs);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px; }
.detail-score { display:flex;align-items:center;gap:6px;font-size:16px;font-weight:700;color:var(--gold); }
.detail-action-row { display:flex;gap:10px;padding:16px 16px 0;flex-wrap:wrap; }
.detail-tabs { display:flex;padding:16px 16px 0;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none; }
.detail-tabs::-webkit-scrollbar { display:none; }
.detail-tab-btn { padding:10px 16px;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .2s;flex-shrink:0;border-radius:0;background:none; }
.detail-tab-btn.active { color:var(--primary);border-bottom-color:var(--primary); }

/* ── Top 50 Rank card ── */
.rank-card { display:flex;align-items:center;padding:12px;background:rgba(255,255,255,.04);border-radius:var(--r-xl);margin-bottom:12px;cursor:pointer;transition:background .15s; }
.rank-card:active { background:var(--primary-05); }
.rank-number { width:44px;text-align:center;font-weight:800;flex-shrink:0;color:var(--text-muted);font-size:18px;letter-spacing:-.5px; }
.rank-number.top3 { color:var(--primary);font-size:22px; }
.rank-cover { width:60px;height:86px;border-radius:var(--r-md);object-fit:cover;background:var(--surface-2);flex-shrink:0; }
.rank-info { flex:1;padding-left:14px;display:flex;flex-direction:column;gap:6px; }
.rank-title { font-size:14px;font-weight:600;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.rank-title.top3 { font-size:15px;font-weight:800; }
.rank-meta { display:flex;flex-wrap:wrap;gap:6px; }
.rank-badge { display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:var(--r-xs);font-size:11px;font-weight:700; }
.rank-badge.score  { background:var(--gold-15);color:#B8860B; }
.rank-badge.format { background:var(--primary-15);color:var(--primary); }
.rank-badge.eps    { background:rgba(76,175,80,.12);color:#4CAF50; }
.rank-badge.season { background:rgba(156,39,176,.12);color:#9C27B0; }

/* ── Continue Watching card ── */
.continue-card { display:flex;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);margin-bottom:10px;cursor:pointer; }
.continue-card:active { background:var(--surface-2); }
.continue-cover-wrap { width:110px;height:80px;position:relative;flex-shrink:0; }
.continue-cover-wrap img { width:100%;height:100%;object-fit:cover;display:block; }
.continue-cover-progress { position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.15); }
.continue-cover-progress-fill { height:100%;background:var(--primary); }
.continue-cover-play { position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);font-size:28px;color:rgba(255,255,255,.9); }
.continue-info { flex:1;padding:10px;display:flex;flex-direction:column;gap:2px; }
.continue-title { font-size:14px;font-weight:600;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3; }
.continue-ep { font-size:12px;color:var(--text-secondary);margin-top:2px; }
.continue-time-row { display:flex;justify-content:space-between;margin-top:4px; }
.continue-time { font-size:11px;color:var(--text-secondary); }
.continue-pct-row { display:flex;align-items:center;gap:6px;margin-top:6px; }
.continue-pct-bar { flex:1;height:3px;background:var(--border);border-radius:var(--r-full);overflow:hidden; }
.continue-pct-fill { height:100%;background:var(--primary);border-radius:var(--r-full); }
.continue-pct-text { font-size:11px;color:var(--text-secondary);min-width:30px; }
.continue-remove-btn { padding:8px;color:rgba(255,255,255,.3);display:flex;align-items:flex-start;cursor:pointer;font-size:18px; }

/* ── My List card ── */
.list-card { display:flex;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);margin-bottom:10px;cursor:pointer; }
.list-card-cover { width:80px;height:110px;object-fit:cover;flex-shrink:0;background:var(--surface-2); }
.list-card-info { flex:1;padding:10px;display:flex;flex-direction:column;gap:3px; }
.list-card-title  { font-size:14px;font-weight:600;color:var(--text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.list-card-format { font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase; }
.list-card-meta   { font-size:12px;color:var(--text-secondary); }
.list-card-note   { font-size:12px;color:var(--text-secondary);font-style:italic;margin-top:4px; }
.list-card-actions { display:flex;flex-direction:column;gap:8px;padding:8px;justify-content:center; }
.list-action-btn { font-size:18px;color:rgba(255,255,255,.3);cursor:pointer;padding:4px; }

/* ── Schedule cards ── */
.schedule-section-header { display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--primary-15);position:sticky;top:0;z-index:10; }
.schedule-dot { width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0; }
.schedule-day-title { font-size:16px;font-weight:700;color:var(--text); }
.schedule-day-sub   { font-size:12px;color:var(--text-secondary);margin-top:1px; }
.schedule-card { display:flex;align-items:center;overflow:hidden;margin:4px 16px;border-radius:var(--r-md);background:var(--surface);cursor:pointer; }
.schedule-cover { width:52px;height:72px;object-fit:cover;flex-shrink:0;background:var(--surface-2); }
.schedule-info { flex:1;padding:8px 10px;display:flex;flex-direction:column;gap:2px;overflow:hidden; }
.schedule-title { font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.schedule-ep    { font-size:12px;font-weight:700;color:var(--primary); }
.schedule-meta  { font-size:11px;color:var(--text-secondary); }
.schedule-time-col { padding:8px 12px;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:5px;flex-shrink:0; }
.schedule-air-time { font-size:14px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums; }
.schedule-status-badge { padding:3px 8px;border-radius:var(--r-sm);font-size:11px;font-weight:700;white-space:nowrap; }

/* ── Download card ── */
.download-card { display:flex;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);margin-bottom:10px; }
.download-cover { width:80px;height:110px;object-fit:cover;flex-shrink:0;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--primary); }
.download-info { flex:1;padding:10px;display:flex;flex-direction:column;gap:3px; }
.download-type-badge { font-size:10px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px; }
.download-title    { font-size:14px;font-weight:600;color:var(--text); }
.download-subtitle { font-size:12px;color:var(--text-secondary); }
.download-size     { font-size:11px;color:var(--text-muted); }
.download-status-badge { display:inline-flex;padding:3px 8px;border-radius:var(--r-xs);font-size:11px;font-weight:700;margin-top:4px;align-self:flex-start; }
.download-actions { display:flex;flex-direction:column;justify-content:center;gap:8px;padding:8px; }
.download-action-btn { font-size:24px;cursor:pointer; }

/* ── Recommendation card ── */
.rec-card { display:flex;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);margin-bottom:10px;cursor:pointer; }
.rec-card:active { background:var(--surface-2); }
.rec-cover { width:90px;height:130px;object-fit:cover;flex-shrink:0;background:var(--surface-2); }
.rec-info { flex:1;padding:12px;display:flex;flex-direction:column;gap:6px; }
.rec-title  { font-size:15px;font-weight:700;color:var(--text); }
.rec-reason { display:flex;align-items:center;gap:5px;color:var(--primary);font-size:13px;font-weight:500; }
.rec-genres { display:flex;flex-wrap:wrap;gap:5px; }
.rec-score  { font-size:13px;color:var(--text-secondary); }

/* ── Backup buttons ── */
.backup-action-btn { display:flex;align-items:center;gap:14px;padding:16px;border-radius:var(--r-xl);margin-bottom:12px;cursor:pointer;transition:opacity .15s,transform .15s;border:none;width:100%;text-align:left; }
.backup-action-btn:active { transform:scale(.98);opacity:.85; }
.backup-btn-content { flex:1; }
.backup-btn-title { font-size:15px;font-weight:700;color:#fff; }
.backup-btn-sub   { font-size:12px;color:rgba(255,255,255,.75);margin-top:2px; }
.interval-grid    { display:flex;gap:8px;flex-wrap:wrap;margin-top:10px; }
.interval-btn { padding:8px 16px;border-radius:var(--r-full);font-size:13px;font-weight:600;background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:all .15s; }
.interval-btn.active { background:var(--primary);color:#fff;border-color:var(--primary); }

/* ── Character / Staff header ── */
.char-header { position:relative;width:100%;overflow:hidden; }
.char-banner { width:100%;height:220px;object-fit:cover;filter:blur(12px) brightness(.4) saturate(1.5);transform:scale(1.05);display:block; }
.char-img-wrap { position:absolute;bottom:-60px;left:50%;transform:translateX(-50%); }
.char-img { width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--primary);box-shadow:0 8px 24px rgba(0,0,0,.6); }
.char-info-area { padding:80px 16px 24px;text-align:center; }
.char-name   { font-size:26px;font-weight:800;color:var(--text); }
.char-native { font-size:15px;color:var(--text-secondary);margin-top:4px; }
.char-stats-row { display:flex;justify-content:center;gap:20px;margin:16px 0;flex-wrap:wrap; }
.char-stat { display:flex;flex-direction:column;align-items:center;gap:2px; }
.char-stat-value { font-size:15px;font-weight:700;color:var(--primary); }
.char-stat-label { font-size:11px;color:var(--text-secondary); }

/* ── Profile page ── */
.profile-banner { width:100%;height:160px;position:relative;overflow:hidden; }
.profile-banner img { width:100%;height:100%;object-fit:cover; }
.profile-banner-gradient { position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(transparent,var(--bg)); }
.profile-user-row { display:flex;align-items:flex-end;gap:12px;padding:0 16px;margin-top:-44px;position:relative;z-index:2;margin-bottom:16px; }
.profile-avatar { width:80px;height:80px;border-radius:20px;object-fit:cover;border:3px solid var(--primary);background:var(--surface-2); }
.profile-user-name { font-size:24px;font-weight:800;color:var(--text);margin-bottom:4px; }
.profile-stats { display:flex;gap:0;padding:0 16px;margin-bottom:24px; }
.profile-stat { flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background:var(--surface);border-right:1px solid var(--border); }
.profile-stat:last-child  { border-right:none;border-radius:0 var(--r-md) var(--r-md) 0; }
.profile-stat:first-child { border-radius:var(--r-md) 0 0 var(--r-md); }
.profile-stat-value { font-size:20px;font-weight:800;color:var(--text); }
.profile-stat-label { font-size:11px;color:var(--text-secondary);text-align:center; }

/* ── Welcome section (home, logged-in) ── */
.welcome-section-card {
  margin:0 0 24px;padding:24px 16px 20px;
  background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(109,40,217,.08));
  border-bottom:1px solid var(--border);position:relative;overflow:hidden;
}
.welcome-section-card::before { content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 0%,rgba(139,92,246,.2) 0%,transparent 60%); }
.welcome-greeting { font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.5px;margin-bottom:6px;position:relative; }
.welcome-message  { font-size:15px;color:var(--text-secondary);line-height:1.5;position:relative;margin-bottom:16px; }
.welcome-stats-row { display:flex;gap:12px;position:relative; }
.welcome-stat-chip { flex:1;background:var(--primary-10);border:1px solid var(--primary-20);border-radius:var(--r-md);padding:10px 12px;display:flex;flex-direction:column;gap:2px; }
.welcome-stat-chip-value { font-size:20px;font-weight:800;color:var(--text); }
.welcome-stat-chip-label { font-size:11px;color:var(--text-secondary); }

/* ── Quick access grid (guest home) ── */
.quick-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px;margin-bottom:24px; }
.quick-tile { background:var(--surface);border-radius:var(--r-xl);padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:transform .15s var(--ease-spring);border:1px solid var(--border); }
.quick-tile:active { transform:scale(.96); }
.quick-tile-icon-wrap { width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:22px; }
.quick-tile-label { font-size:11px;font-weight:600;color:var(--text);text-align:center;line-height:1.3;white-space:pre-line; }

/* ── Welcome screen (login page) ── */
.welcome-page { position:relative;width:100%;min-height:100vh;overflow:hidden; }
.welcome-bg { position:absolute;inset:0;z-index:0; }
.welcome-bg img { width:100%;height:100%;object-fit:cover; }
.welcome-bg-gradient { position:absolute;inset:0;background:linear-gradient(to bottom,rgba(15,10,26,.4) 0%,rgba(15,10,26,.2) 30%,rgba(15,10,26,.7) 60%,rgba(15,10,26,.97) 100%); }
.welcome-logo-area { position:absolute;top:35%;left:0;right:0;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:16px;z-index:2;padding:0 24px; }
.welcome-app-name { font-size:36px;font-weight:900;color:#fff;letter-spacing:-1px;text-shadow:0 2px 8px rgba(0,0,0,.5); }
.welcome-tagline  { font-size:16px;color:rgba(255,255,255,.8);text-align:center;line-height:1.5;text-shadow:0 1px 4px rgba(0,0,0,.5); }
.welcome-anime-preview { position:absolute;bottom:200px;left:24px;right:24px;z-index:2;background:rgba(26,16,53,.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:24px;overflow:hidden; }
.welcome-anime-preview-content { padding:14px 16px; }
.welcome-anime-title { font-size:17px;font-weight:700;color:#fff;letter-spacing:.2px;margin-bottom:6px; }
.welcome-genres { display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px; }
.welcome-genre-tag { padding:3px 10px;border-radius:10px;background:rgba(255,255,255,.12);color:#fff;font-size:12px;font-weight:600; }
.welcome-studio-row { display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.85);font-size:13px;font-weight:500; }
.welcome-buttons { position:absolute;bottom:0;left:0;right:0;z-index:2;padding:16px 24px 40px;display:flex;flex-direction:column;gap:12px; }
.welcome-login-btn { width:100%;height:54px;border-radius:28px;border:none;background:linear-gradient(135deg,#8B5CF6,#6D28D9);color:#fff;font-size:17px;font-weight:700;cursor:pointer;box-shadow:0 8px 24px rgba(139,92,246,.4);display:flex;align-items:center;justify-content:center;gap:10px; }
.welcome-login-btn:active { transform:scale(.97); }
.welcome-guest-btn { width:100%;height:50px;border-radius:28px;border:1.5px solid rgba(255,255,255,.4);background:rgba(255,255,255,.07);color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px; }
.welcome-guest-btn:active { transform:scale(.97); }

/* ── Onboarding ── */
.onboarding-page { display:none;flex-direction:column;min-height:100vh;background:var(--bg); }
.onboarding-page.active { display:flex; }
.onboarding-dot { width:8px;height:8px;border-radius:var(--r-full);background:var(--border);transition:all .3s var(--ease-out);display:inline-block; }
.onboarding-dot.active { width:24px;background:var(--primary); }

/* ── Creator (manga by author) ── */
.creator-avatar { width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--surface-2);flex-shrink:0; }

/* ── Birthday card ── */
.birthday-card { width:90px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer; }
.birthday-avatar { width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--border);background:var(--surface-2);transition:border-color .15s; }
.birthday-card:hover .birthday-avatar { border-color:var(--primary); }
.birthday-name { font-size:12px;font-weight:500;color:var(--text);text-align:center;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }

/* ── Sign out ── */
.sign-out-btn { display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;margin:16px;border-radius:var(--r-xl);background:rgba(239,68,68,.1);color:var(--red);font-size:15px;font-weight:600;cursor:pointer;border:1px solid rgba(239,68,68,.25);width:calc(100% - 32px); }

/* ── View All grid ── */
.viewall-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0 16px; }
.viewall-grid .media-card { width:100%; }

/* ══════════════════════════════════════════
   4. ANIMATIONS (css/animations.css)
══════════════════════════════════════════ */
@keyframes spin     { to { transform:rotate(360deg); } }
@keyframes shimmer  { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
@keyframes scaleIn  { from{opacity:0;transform:scale(.9)} to{opacity:1;transform:scale(1)} }
@keyframes bounceIn { 0%{transform:scale(.8);opacity:0} 60%{transform:scale(1.05);opacity:1} 80%{transform:scale(.97)} 100%{transform:scale(1)} }
@keyframes pulse    { 0%,100%{opacity:1} 50%{opacity:.5} }
@keyframes heroProgress { from{width:0%} to{width:100%} }

.page-enter { animation:fadeInUp .3s var(--ease-out) forwards; }

/* Lazy image fade-in */
img.lazy { opacity:0;transition:opacity .3s var(--ease); }
img.lazy.loaded { opacity:1; }

/* Loading dots */
.loading-dots { display:inline-flex;gap:4px;align-items:center; }
.loading-dot  { width:6px;height:6px;border-radius:50%;background:var(--primary);animation:pulse 1.2s ease-in-out infinite; }
.loading-dot:nth-child(2) { animation-delay:.2s; }
.loading-dot:nth-child(3) { animation-delay:.4s; }

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