/* ═══════════════════════════════════════════════════════════════════════════
   Film Database Theme — Main CSS
   Light mode primary, dark mode via [data-theme="dark"]
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── CSS Variables: Light Mode ─────────────────────────────────────────── */
:root {
    --fdb-accent:        #1A56FF;
    --fdb-accent-dark:   #1240cc;
    --fdb-accent-light:  #e8f0ff;

    /* Light mode colours */
    --fdb-bg:            #ffffff;
    --fdb-bg-2:          #f5f6f8;
    --fdb-bg-3:          #eef0f4;
    --fdb-text:          #111827;
    --fdb-text-2:        #4b5563;
    --fdb-text-3:        #9ca3af;
    --fdb-border:        #e5e7eb;
    --fdb-border-2:      #d1d5db;
    --fdb-card-bg:       #ffffff;
    --fdb-card-shadow:   0 2px 12px rgba(0,0,0,.07);
    --fdb-card-hover-shadow: 0 8px 32px rgba(0,0,0,.12);
    --fdb-overlay-light: rgba(0,0,0,.35);
    --fdb-overlay-heavy: rgba(0,0,0,.65);

    /* Footer */
    --fdb-footer-bg:     #0f1626;
    --fdb-footer-text:   #cbd5e1;
    --fdb-footer-border: rgba(255,255,255,.08);

    /* Status colours */
    --fdb-status-available:     #059669;
    --fdb-status-available-bg:  #ecfdf5;
    --fdb-status-licensed:      #d97706;
    --fdb-status-licensed-bg:   #fffbeb;
    --fdb-status-not-available: #dc2626;
    --fdb-status-not-bg:        #fef2f2;

    /* Spacing & radii */
    --fdb-radius:        10px;
    --fdb-radius-sm:     6px;
    --fdb-radius-lg:     16px;
    --fdb-radius-pill:   999px;
    --fdb-container:     1280px;
    --fdb-header-h:      70px;
    --fdb-transition:    .2s ease;
}

/* ── Dark Mode ─────────────────────────────────────────────────────────── */
[data-theme="dark"] {
    --fdb-bg:            #0d1117;
    --fdb-bg-2:          #161b22;
    --fdb-bg-3:          #1c2230;
    --fdb-text:          #f0f6ff;
    --fdb-text-2:        #8b98b8;
    --fdb-text-3:        #4a5568;
    --fdb-border:        #1e2d40;
    --fdb-border-2:      #2d3a52;
    --fdb-card-bg:       #161b22;
    --fdb-card-shadow:   0 2px 12px rgba(0,0,0,.3);
    --fdb-card-hover-shadow: 0 8px 32px rgba(0,0,0,.5);
    --fdb-overlay-light: rgba(0,0,0,.5);
    --fdb-overlay-heavy: rgba(0,0,0,.78);
}

/* ── Reset & Base ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif; background: var(--fdb-bg); color: var(--fdb-text); line-height: 1.6; transition: background var(--fdb-transition), color var(--fdb-transition); -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--fdb-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h1,h2,h3,h4,h5,h6 { line-height: 1.2; font-weight: 700; }

/* ── Container ─────────────────────────────────────────────────────────── */
.fdb-container { max-width: var(--fdb-container); margin: 0 auto; padding: 0 24px; }

/* ══════════════════════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: var(--fdb-bg); border-bottom: 1px solid var(--fdb-border); height: var(--fdb-header-h); transition: background var(--fdb-transition), box-shadow var(--fdb-transition); }
.fdb-header.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,.08); }
.fdb-header-inner { display: flex; align-items: center; gap: 24px; height: 100%; max-width: var(--fdb-container); margin: 0 auto; padding: 0 24px; }
.fdb-header-brand { flex-shrink: 0; }
.fdb-site-name { font-size: 1.15rem; font-weight: 800; color: var(--fdb-text); letter-spacing: -.02em; font-family: 'Courier New', monospace; }
.fdb-custom-logo-link img { max-height: 44px; width: auto; }

/* Nav */
.fdb-nav { flex: 1; }
.fdb-nav-menu { display: flex; list-style: none; gap: 4px; }
.fdb-nav-menu a { display: block; padding: 6px 14px; font-size: .875rem; font-weight: 500; color: var(--fdb-text-2); border-radius: var(--fdb-radius-sm); transition: all var(--fdb-transition); }
.fdb-nav-menu a:hover, .fdb-nav-menu .current-menu-item > a { color: var(--fdb-accent); background: var(--fdb-accent-light); text-decoration: none; }
[data-theme="dark"] .fdb-nav-menu a:hover,
[data-theme="dark"] .fdb-nav-menu .current-menu-item > a { background: rgba(26,86,255,.15); }

/* Header Controls */
.fdb-header-controls { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.fdb-search-toggle, .fdb-dark-toggle { background: none; border: none; cursor: pointer; padding: 8px; border-radius: var(--fdb-radius-sm); color: var(--fdb-text-2); display: flex; align-items: center; transition: color var(--fdb-transition), background var(--fdb-transition); }
.fdb-search-toggle:hover, .fdb-dark-toggle:hover { color: var(--fdb-accent); background: var(--fdb-bg-2); }
.fdb-icon-sun, .fdb-icon-moon { display: flex; }
[data-theme="light"] .fdb-icon-sun  { display: none; }
[data-theme="dark"]  .fdb-icon-moon { display: none; }
[data-theme="dark"]  .fdb-icon-sun  { display: flex; }
[data-theme="light"] .fdb-icon-moon { display: flex; }

/* Mobile toggle */
.fdb-mobile-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; }
.fdb-mobile-toggle span { display: block; width: 22px; height: 2px; background: var(--fdb-text); border-radius: 2px; transition: all .3s; }

/* Search overlay */
.fdb-search-overlay { position: fixed; top: 0; left: 0; right: 0; z-index: 2000; background: var(--fdb-bg); padding: 0 24px; height: var(--fdb-header-h); display: flex; align-items: center; gap: 16px; border-bottom: 2px solid var(--fdb-accent); transform: translateY(-100%); transition: transform .3s ease; }
.fdb-search-overlay.open { transform: translateY(0); }
.fdb-search-form { flex: 1; display: flex; align-items: center; gap: 12px; max-width: var(--fdb-container); margin: 0 auto; }
.fdb-search-form input[type=search] { flex: 1; background: transparent; border: none; font-size: 1.25rem; color: var(--fdb-text); outline: none; }
.fdb-search-form button { background: none; border: none; cursor: pointer; color: var(--fdb-text-2); }
.fdb-search-close { background: none; border: none; cursor: pointer; font-size: 1.5rem; color: var(--fdb-text-2); padding: 8px; }

/* Page offset for fixed header */
main, .fdb-hero { padding-top: var(--fdb-header-h); }
.fdb-hero { padding-top: 0; } /* Hero handles its own offset */

/* ══════════════════════════════════════════════════════════════════════════
   HERO SECTION — Banner + Poster Overlap
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-hero { margin-top: var(--fdb-header-h); position: relative; }
.fdb-hero-banner { position: relative; min-height: 90vh; background: var(--fdb-bg-3) var(--banner-url) center/cover no-repeat; display: flex; align-items: flex-end; }
.fdb-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,.85) 40%, rgba(0,0,0,.3) 100%), linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 50%); }
.fdb-hero-inner { position: relative; z-index: 1; width: 100%; max-width: var(--fdb-container); margin: 0 auto; padding: 0 24px 0 24px; display: flex; align-items: flex-end; gap: 40px; }

/* Poster — top half in banner, bottom half bleeds below */
.fdb-hero-poster-wrap { flex-shrink: 0; position: relative; margin-bottom: -80px; z-index: 10; }
.fdb-hero-poster { width: 220px; }
.fdb-hero-poster img { width: 100%; border-radius: var(--fdb-radius-lg); box-shadow: 0 20px 60px rgba(0,0,0,.5); }

/* Title content to the right of poster */
.fdb-hero-content { flex: 1; padding-bottom: 40px; color: #fff; }
.fdb-hero-year { font-size: .875rem; font-weight: 600; opacity: .8; letter-spacing: .1em; text-transform: uppercase; display: block; margin-bottom: 8px; }
.fdb-hero-title { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 800; line-height: 1.1; margin-bottom: 12px; text-shadow: 0 2px 16px rgba(0,0,0,.5); }
.fdb-hero-tagline { font-size: 1rem; opacity: .85; margin-bottom: 16px; max-width: 600px; }
.fdb-hero-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.fdb-hero-genre { color: #fff; opacity: .85; font-size: .875rem; }
.fdb-hero-genre:hover { opacity: 1; text-decoration: none; }
.fdb-sep { opacity: .5; }
.fdb-meta-dot { font-size: .875rem; opacity: .8; }
.fdb-meta-badge { display: inline-flex; align-items: center; padding: 3px 10px; border: 1px solid rgba(255,255,255,.6); border-radius: var(--fdb-radius-sm); font-size: .75rem; font-weight: 600; color: #fff; }
.fdb-hero-status { margin-top: 12px; }

/* Back bar — below hero, above content */
.fdb-back-bar { background: var(--fdb-bg); border-bottom: 1px solid var(--fdb-border); position: relative; z-index: 5; }
.fdb-back-bar .fdb-container { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; padding-top: 100px; padding-bottom: 16px; }
.fdb-back-link { display: flex; align-items: center; gap: 6px; font-size: .875rem; color: var(--fdb-text-2); font-weight: 500; }
.fdb-back-link:hover { color: var(--fdb-accent); text-decoration: none; }
.fdb-title-taxonomy-bar { display: flex; flex-wrap: wrap; gap: 8px; }

/* ══════════════════════════════════════════════════════════════════════════
   PILLS / TAGS / BADGES
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-pill { display: inline-flex; align-items: center; padding: 4px 12px; background: var(--fdb-bg-2); color: var(--fdb-text-2); border-radius: var(--fdb-radius-pill); font-size: .75rem; font-weight: 600; border: 1px solid var(--fdb-border); }
.fdb-pill-genre   { background: var(--fdb-accent-light); color: var(--fdb-accent); border-color: transparent; }
.fdb-tag, .fdb-genre-tag { display: inline-flex; align-items: center; padding: 3px 10px; background: var(--fdb-accent-light); color: var(--fdb-accent); border-radius: var(--fdb-radius-pill); font-size: .75rem; font-weight: 600; }
[data-theme="dark"] .fdb-tag,
[data-theme="dark"] .fdb-genre-tag { background: rgba(26,86,255,.2); }
.fdb-runtime-tag { background: var(--fdb-bg-3); color: var(--fdb-text-2); }

/* Status badges */
.fdb-status-badge { display: inline-flex; align-items: center; padding: 4px 12px; border-radius: var(--fdb-radius-pill); font-size: .75rem; font-weight: 600; }
.fdb-status-available-for-licensing,
.fdb-status-available   { background: var(--fdb-status-available-bg); color: var(--fdb-status-available); }
.fdb-status-licensed     { background: var(--fdb-status-licensed-bg);  color: var(--fdb-status-licensed); }
.fdb-status-not-available{ background: var(--fdb-status-not-bg);       color: var(--fdb-status-not-available); }
[data-theme="dark"] .fdb-status-badge { filter: brightness(.9); }

/* ══════════════════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 22px; border-radius: var(--fdb-radius-sm); font-size: .875rem; font-weight: 600; cursor: pointer; border: none; text-decoration: none; transition: all var(--fdb-transition); white-space: nowrap; }
.fdb-btn:hover { text-decoration: none; }
.fdb-btn-primary   { background: var(--fdb-accent); color: #fff; }
.fdb-btn-primary:hover { background: var(--fdb-accent-dark); }
.fdb-btn-accent    { background: var(--fdb-accent); color: #fff; }
.fdb-btn-accent:hover { background: var(--fdb-accent-dark); }
.fdb-btn-secondary { background: #ff6b35; color: #fff; }
.fdb-btn-secondary:hover { background: #e55a25; }
.fdb-btn-outline   { background: transparent; color: var(--fdb-text); border: 1.5px solid var(--fdb-border-2); }
.fdb-btn-outline:hover { border-color: var(--fdb-accent); color: var(--fdb-accent); }
.fdb-btn-ghost     { background: transparent; color: var(--fdb-text-2); }
.fdb-btn-ghost:hover { color: var(--fdb-accent); }
.fdb-btn-wide      { width: 100%; justify-content: center; }
.fdb-btn-sm        { padding: 6px 14px; font-size: .8rem; }
.fdb-btn-play      { background: rgba(255,255,255,.2); color: #fff; border: 1.5px solid rgba(255,255,255,.6); backdrop-filter: blur(4px); }
.fdb-btn-play:hover { background: var(--fdb-accent); border-color: var(--fdb-accent); }

/* ══════════════════════════════════════════════════════════════════════════
   MODULES WRAPPER
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-content-area { background: var(--fdb-bg); padding: 48px 0 80px; }
.fdb-modules-wrap { display: flex; flex-direction: column; gap: 0; }
.fdb-module { padding: 48px 0; border-bottom: 1px solid var(--fdb-border); }
.fdb-module:last-child { border-bottom: none; }
.fdb-module-title { font-size: 1.5rem; font-weight: 700; margin-bottom: 24px; color: var(--fdb-text); }
.fdb-module-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }

/* ── Trailer ───────────────────────────────────────────────────────────── */
.fdb-trailer-player-wrap { max-width: 760px; }
.fdb-trailer-thumb-btn { position: relative; width: 100%; aspect-ratio: 16/9; background: var(--fdb-bg-3); border: none; border-radius: var(--fdb-radius-lg); overflow: hidden; cursor: pointer; display: block; }
.fdb-trailer-thumb { width: 100%; height: 100%; object-fit: cover; }
.fdb-play-circle { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.35); transition: background var(--fdb-transition); }
.fdb-trailer-thumb-btn:hover .fdb-play-circle { background: rgba(26,86,255,.6); }

/* ── Videos row ────────────────────────────────────────────────────────── */
.fdb-videos-row { display: flex; gap: 16px; overflow-x: auto; padding-bottom: 8px; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; }
.fdb-video-card { flex: 0 0 220px; scroll-snap-align: start; }
.fdb-video-thumb { position: relative; width: 100%; aspect-ratio: 16/9; background: var(--fdb-bg-3); border-radius: var(--fdb-radius); overflow: hidden; cursor: pointer; border: none; }
.fdb-video-thumb img { width: 100%; height: 100%; object-fit: cover; }
.fdb-video-thumb-placeholder { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--fdb-text-3); }
.fdb-video-play-icon { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.3); color: #fff; transition: background var(--fdb-transition); }
.fdb-video-thumb:hover .fdb-video-play-icon { background: rgba(26,86,255,.55); }
.fdb-video-label { font-size: .8rem; color: var(--fdb-text-2); margin-top: 8px; text-align: center; }

/* ── Synopsis ──────────────────────────────────────────────────────────── */
.fdb-synopsis-content { font-size: 1rem; line-height: 1.8; color: var(--fdb-text-2); max-width: 800px; }

/* ── Rights Table ──────────────────────────────────────────────────────── */
.fdb-rights-header { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 24px; }
.fdb-rights-icon { width: 40px; height: 40px; background: var(--fdb-accent-light); border-radius: var(--fdb-radius-sm); display: flex; align-items: center; justify-content: center; color: var(--fdb-accent); flex-shrink: 0; margin-top: 4px; }
.fdb-rights-subtitle { font-size: .875rem; color: var(--fdb-text-2); margin-top: 4px; }
.fdb-rights-table-wrap { overflow-x: auto; border-radius: var(--fdb-radius); border: 1px solid var(--fdb-border); }
.fdb-rights-table { width: 100%; border-collapse: collapse; min-width: 600px; }
.fdb-rights-table th { background: var(--fdb-bg-2); padding: 12px 16px; font-size: .8rem; font-weight: 600; text-align: center; color: var(--fdb-text-2); border-bottom: 1px solid var(--fdb-border); }
.fdb-rights-table td { padding: 12px 16px; text-align: center; border-bottom: 1px solid var(--fdb-border); font-size: .875rem; }
.fdb-rights-table tr:last-child td { border-bottom: none; }
.fdb-rights-territory { text-align: left !important; font-weight: 600; }
.fdb-rights-badge { display: inline-flex; align-items: center; padding: 4px 10px; border-radius: var(--fdb-radius-pill); font-size: .75rem; font-weight: 600; }
.fdb-rights-badge-available     { background: var(--fdb-status-available-bg); color: var(--fdb-status-available); }
.fdb-rights-badge-licensed      { background: var(--fdb-status-licensed-bg);  color: var(--fdb-status-licensed); }
.fdb-rights-badge-not_available { background: var(--fdb-status-not-bg);       color: var(--fdb-status-not-available); }
.fdb-rights-na { color: var(--fdb-text-3); font-size: .75rem; }
.fdb-rights-legend { display: flex; gap: 16px; margin-top: 16px; flex-wrap: wrap; }

/* ── Tech Specs ────────────────────────────────────────────────────────── */
.fdb-tech-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.fdb-tech-item { display: flex; align-items: center; gap: 14px; padding: 16px; background: var(--fdb-bg-2); border-radius: var(--fdb-radius); border: 1px solid var(--fdb-border); }
.fdb-tech-icon { width: 36px; height: 36px; background: var(--fdb-accent-light); border-radius: var(--fdb-radius-sm); display: flex; align-items: center; justify-content: center; color: var(--fdb-accent); flex-shrink: 0; }
[data-theme="dark"] .fdb-tech-icon { background: rgba(26,86,255,.15); }
.fdb-tech-info { display: flex; flex-direction: column; gap: 2px; }
.fdb-tech-label { font-size: .7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--fdb-text-3); }
.fdb-tech-value { font-size: .9rem; font-weight: 600; color: var(--fdb-text); }

/* ── Cast/Crew ─────────────────────────────────────────────────────────── */
.fdb-cast-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 20px; }
.fdb-cast-item { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; }
.fdb-cast-photo { width: 90px; height: 90px; overflow: hidden; flex-shrink: 0; }
.fdb-cast-photo.fdb-photo-circle { border-radius: 50%; }
.fdb-cast-photo.fdb-photo-square { border-radius: var(--fdb-radius); }
.fdb-shape-circle .fdb-cast-photo { border-radius: 50%; }
.fdb-shape-square .fdb-cast-photo { border-radius: var(--fdb-radius); }
.fdb-cast-photo img { width: 100%; height: 100%; object-fit: cover; }
.fdb-cast-photo-placeholder { width: 100%; height: 100%; background: var(--fdb-bg-3); display: flex; align-items: center; justify-content: center; color: var(--fdb-text-3); }
.fdb-cast-name { font-size: .875rem; font-weight: 600; color: var(--fdb-text); }
a.fdb-cast-name:hover { color: var(--fdb-accent); text-decoration: none; }
.fdb-cast-role { font-size: .75rem; color: var(--fdb-text-3); }

/* ── Production Details ────────────────────────────────────────────────── */
.fdb-production-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }
.fdb-production-item { display: flex; flex-direction: column; gap: 4px; padding: 16px; background: var(--fdb-bg-2); border-radius: var(--fdb-radius); border-left: 3px solid var(--fdb-accent); }
.fdb-production-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--fdb-accent); }
.fdb-production-value { font-size: .95rem; font-weight: 500; color: var(--fdb-text); }

/* ── Gallery ───────────────────────────────────────────────────────────── */
.fdb-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.fdb-gallery-item { position: relative; aspect-ratio: 16/9; overflow: hidden; border-radius: var(--fdb-radius); display: block; }
.fdb-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.fdb-gallery-item:hover img { transform: scale(1.05); }
.fdb-gallery-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.4); display: flex; align-items: center; justify-content: center; color: #fff; opacity: 0; transition: opacity var(--fdb-transition); }
.fdb-gallery-item:hover .fdb-gallery-overlay { opacity: 1; }

/* ── Awards ────────────────────────────────────────────────────────────── */
.fdb-awards-bar { display: flex; align-items: center; gap: 20px; background: linear-gradient(135deg, #0d3b5e, #0d7377); color: #fff; padding: 20px 32px; border-radius: var(--fdb-radius); position: relative; overflow: hidden; }
.fdb-awards-icon { flex-shrink: 0; }
.fdb-awards-text { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.fdb-awards-label { font-size: .85rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; opacity: .9; }
.fdb-awards-count { font-size: 1.1rem; font-weight: 700; }
.fdb-awards-sep { opacity: .5; }
.fdb-awards-desc { font-size: .875rem; opacity: .8; }
.fdb-awards-line { flex: 1; height: 1px; background: rgba(255,255,255,.2); min-width: 20px; }
.fdb-awards-star { font-size: 1.5rem; opacity: .6; }

/* ── Action Buttons ────────────────────────────────────────────────────── */
.fdb-actions-wrap { display: flex; gap: 40px; align-items: flex-start; flex-wrap: wrap; }
.fdb-actions-buttons { display: flex; flex-direction: column; gap: 12px; min-width: 260px; }
.fdb-qr-block { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 20px; background: var(--fdb-bg-2); border-radius: var(--fdb-radius); border: 1px solid var(--fdb-border); text-align: center; }
.fdb-qr-label { font-size: .75rem; color: var(--fdb-text-2); font-weight: 600; }
.fdb-qr-code { border-radius: var(--fdb-radius-sm); }

/* ── Sharing ───────────────────────────────────────────────────────────── */
.fdb-sharing-bar { display: flex; flex-wrap: wrap; gap: 10px; }
.fdb-share-btn { display: inline-flex; align-items: center; gap: 8px; padding: 8px 18px; border-radius: var(--fdb-radius-pill); font-size: .8rem; font-weight: 600; color: #fff; text-decoration: none; transition: opacity var(--fdb-transition); }
.fdb-share-btn:hover { opacity: .85; text-decoration: none; }
.fdb-share-twitter   { background: #000; }
.fdb-share-facebook  { background: #1877f2; }
.fdb-share-linkedin  { background: #0a66c2; }
.fdb-share-whatsapp  { background: #25d366; }
.fdb-share-pinterest { background: #e60023; }
.fdb-share-email     { background: var(--fdb-bg-3); color: var(--fdb-text) !important; border: 1px solid var(--fdb-border); }

/* ── Related Titles ────────────────────────────────────────────────────── */
.fdb-related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 20px; }

/* ══════════════════════════════════════════════════════════════════════════
   FILM CARDS
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-film-grid { display: grid; gap: 20px; padding: 32px 0; }
.fdb-cols-3 { grid-template-columns: repeat(3, 1fr); }
.fdb-cols-4 { grid-template-columns: repeat(4, 1fr); }
.fdb-cols-5 { grid-template-columns: repeat(5, 1fr); }
.fdb-cols-6 { grid-template-columns: repeat(6, 1fr); }

/* Poster card */
.fdb-card-poster { background: var(--fdb-card-bg); border-radius: var(--fdb-radius); overflow: hidden; box-shadow: var(--fdb-card-shadow); transition: box-shadow var(--fdb-transition), transform var(--fdb-transition); }
.fdb-card-poster:hover { box-shadow: var(--fdb-card-hover-shadow); transform: translateY(-3px); }
.fdb-card-poster .fdb-card-link { display: block; text-decoration: none; color: inherit; }
.fdb-card-poster-img { aspect-ratio: 2/3; overflow: hidden; }
.fdb-card-poster-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.fdb-card-poster:hover img { transform: scale(1.04); }
.fdb-no-poster { width: 100%; height: 100%; background: var(--fdb-bg-3); display: flex; align-items: center; justify-content: center; color: var(--fdb-text-3); }
.fdb-card-body { padding: 14px; }
.fdb-card-title { font-size: .9rem; font-weight: 700; margin-bottom: 6px; color: var(--fdb-text); line-height: 1.3; }
.fdb-card-meta { display: flex; flex-wrap: wrap; gap: 4px; }

/* Banner card */
.fdb-card-banner { border-radius: var(--fdb-radius); overflow: hidden; box-shadow: var(--fdb-card-shadow); transition: box-shadow var(--fdb-transition), transform var(--fdb-transition); }
.fdb-card-banner:hover { box-shadow: var(--fdb-card-hover-shadow); transform: translateY(-2px); }
.fdb-card-banner-link { display: block; position: relative; aspect-ratio: 16/9; background: var(--fdb-bg-3) center/cover no-repeat; text-decoration: none; }
.fdb-card-banner-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 60%); }
.fdb-card-banner-tags { position: absolute; top: 12px; left: 12px; display: flex; flex-wrap: wrap; gap: 4px; z-index: 1; }
.fdb-banner-tag { padding: 3px 8px; border-radius: var(--fdb-radius-pill); font-size: .7rem; font-weight: 700; }
.fdb-tag-genre   { background: var(--fdb-accent); color: #fff; }
.fdb-tag-format  { background: rgba(255,255,255,.85); color: #111; }
.fdb-tag-runtime { background: rgba(0,0,0,.55); color: #fff; }
.fdb-tag-res     { background: rgba(0,0,0,.55); color: #fff; }

/* New Titles 2-col layout */
.fdb-layout-banner_grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 768px) { .fdb-layout-banner_grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════════════════════════════════════
   LIBRARY / ARCHIVE PAGES
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-library-hero { position: relative; min-height: 420px; background: var(--fdb-bg-3) center/cover no-repeat; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; }
.fdb-library-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.4) 60%, transparent 100%); }
.fdb-library-hero-content { position: relative; z-index: 1; padding: calc(var(--fdb-header-h) + 24px) 0 24px; color: #fff; }
.fdb-library-hero-content h1 { font-size: clamp(1.8rem, 4vw, 3rem); margin-bottom: 10px; }
.fdb-library-hero-meta { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
.fdb-library-hero-excerpt { max-width: 600px; opacity: .85; margin-bottom: 20px; }
.fdb-library-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.fdb-library-hero-strip { position: relative; z-index: 1; display: flex; gap: 8px; padding: 16px 24px; background: rgba(0,0,0,.4); backdrop-filter: blur(8px); overflow-x: auto; }
.fdb-strip-item, .fdb-strip-current { flex: 0 0 70px; height: 100px; overflow: hidden; border-radius: var(--fdb-radius-sm); cursor: pointer; opacity: .6; transition: opacity var(--fdb-transition), border var(--fdb-transition); border: 2px solid transparent; }
.fdb-strip-active, .fdb-strip-item:hover { opacity: 1; border-color: var(--fdb-accent); }
.fdb-strip-item img, .fdb-strip-current img { width: 100%; height: 100%; object-fit: cover; }

/* Filter bar */
.fdb-filter-section { background: var(--fdb-bg); border-bottom: 1px solid var(--fdb-border); padding: 16px 0; position: sticky; top: var(--fdb-header-h); z-index: 100; }
.fdb-filter-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.fdb-filter-search-wrap { display: flex; align-items: center; gap: 8px; background: var(--fdb-bg-2); border: 1px solid var(--fdb-border); border-radius: var(--fdb-radius-sm); padding: 8px 14px; flex: 1; min-width: 200px; color: var(--fdb-text-3); }
.fdb-filter-input { flex: 1; background: transparent; border: none; color: var(--fdb-text); outline: none; font-size: .875rem; }
.fdb-filter-dropdown-wrap select, .fdb-filter-sort-wrap select { background: var(--fdb-bg-2); border: 1px solid var(--fdb-border); color: var(--fdb-text); border-radius: var(--fdb-radius-sm); padding: 9px 14px; font-size: .875rem; cursor: pointer; outline: none; }
.fdb-filter-select:focus { border-color: var(--fdb-accent); }

/* Load more */
.fdb-load-more-wrap { text-align: center; padding: 32px 0; }
.fdb-ajax-loading { text-align: center; padding: 40px; }
.fdb-spinner { width: 36px; height: 36px; border: 3px solid var(--fdb-border); border-top-color: var(--fdb-accent); border-radius: 50%; animation: fdb-spin .7s linear infinite; display: inline-block; }
@keyframes fdb-spin { to { transform: rotate(360deg); } }
.fdb-no-results { text-align: center; padding: 60px 24px; color: var(--fdb-text-2); }
.fdb-no-results svg { margin: 0 auto 16px; opacity: .3; }

/* ══════════════════════════════════════════════════════════════════════════
   TV SERIES PAGE
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-series-page-header { padding: calc(var(--fdb-header-h) + 40px) 0 40px; background: linear-gradient(135deg, #1a1a6e, #2d5a8e); color: #fff; }
.fdb-series-header-content h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); margin-bottom: 10px; }
.fdb-series-header-content p { opacity: .8; margin-bottom: 12px; }
.fdb-series-count { display: inline-flex; align-items: center; gap: 6px; font-size: .875rem; opacity: .7; }
.fdb-series-filter-tabs { border-bottom: 1px solid var(--fdb-border); padding: 12px 0; overflow-x: auto; }
.fdb-genre-tabs { display: flex; gap: 8px; padding: 0 24px; max-width: var(--fdb-container); margin: 0 auto; min-width: max-content; }
.fdb-genre-tab { background: var(--fdb-bg-2); border: 1px solid var(--fdb-border); border-radius: var(--fdb-radius-pill); padding: 6px 18px; font-size: .8rem; font-weight: 600; color: var(--fdb-text-2); cursor: pointer; transition: all var(--fdb-transition); }
.fdb-genre-tab.active, .fdb-genre-tab:hover { background: var(--fdb-accent); border-color: var(--fdb-accent); color: #fff; }
.fdb-series-list { display: flex; flex-direction: column; gap: 20px; padding: 32px 0 60px; }
.fdb-series-card { display: flex; gap: 24px; background: var(--fdb-card-bg); border-radius: var(--fdb-radius); padding: 20px; box-shadow: var(--fdb-card-shadow); border: 1px solid var(--fdb-border); transition: box-shadow var(--fdb-transition); }
.fdb-series-card:hover { box-shadow: var(--fdb-card-hover-shadow); }
.fdb-sc-poster { flex: 0 0 140px; }
.fdb-sc-poster img { width: 140px; border-radius: var(--fdb-radius-sm); aspect-ratio: 2/3; object-fit: cover; }
.fdb-sc-info { flex: 1; display: flex; flex-direction: column; gap: 10px; }
.fdb-sc-title { font-size: 1.2rem; font-weight: 700; }
.fdb-sc-title a { color: var(--fdb-text); text-decoration: none; }
.fdb-sc-title a:hover { color: var(--fdb-accent); }
.fdb-sc-excerpt { color: var(--fdb-text-2); font-size: .9rem; line-height: 1.6; }
.fdb-sc-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.fdb-genre-badge { padding: 3px 10px; background: var(--fdb-accent-light); color: var(--fdb-accent); border-radius: var(--fdb-radius-pill); font-size: .75rem; font-weight: 600; }
[data-theme="dark"] .fdb-genre-badge { background: rgba(26,86,255,.18); }
.fdb-sc-meta { display: flex; flex-wrap: wrap; gap: 14px; color: var(--fdb-text-2); font-size: .85rem; }
.fdb-sc-meta span { display: flex; align-items: center; gap: 5px; }

/* Seasons accordion */
.fdb-seasons-accordion { display: flex; flex-direction: column; gap: 8px; }
.fdb-season-item { border: 1px solid var(--fdb-border); border-radius: var(--fdb-radius-sm); overflow: hidden; }
.fdb-season-toggle { width: 100%; display: flex; align-items: center; gap: 12px; padding: 14px 18px; background: var(--fdb-bg-2); border: none; cursor: pointer; color: var(--fdb-text); font-size: .9rem; font-weight: 600; text-align: left; }
.fdb-season-toggle:hover { background: var(--fdb-bg-3); }
.fdb-season-eps, .fdb-season-year { font-size: .8rem; color: var(--fdb-text-2); margin-left: auto; }
.fdb-season-year { margin-left: 0; }
.fdb-chevron { margin-left: auto; transition: transform .2s; }
.fdb-season-toggle[aria-expanded="true"] .fdb-chevron { transform: rotate(180deg); }
.fdb-season-body { padding: 14px 18px; color: var(--fdb-text-2); font-size: .9rem; }

/* ══════════════════════════════════════════════════════════════════════════
   VIDEO MODAL
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-video-modal { position: fixed; inset: 0; z-index: 9999; display: none; }
.fdb-video-modal.open { display: flex; align-items: center; justify-content: center; }
.fdb-video-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.88); backdrop-filter: blur(6px); }
.fdb-video-modal-inner { position: relative; z-index: 1; width: 90vw; max-width: 960px; }
.fdb-video-modal-close { position: absolute; top: -48px; right: 0; background: none; border: none; color: #fff; font-size: 2rem; cursor: pointer; line-height: 1; }
.fdb-video-modal-player { position: relative; width: 100%; aspect-ratio: 16/9; background: #000; border-radius: var(--fdb-radius); overflow: hidden; }
.fdb-video-modal-player iframe { width: 100%; height: 100%; border: none; }

/* ══════════════════════════════════════════════════════════════════════════
   HOME PAGE
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-hero-slider { position: relative; min-height: 80vh; overflow: hidden; }
.fdb-slide { position: absolute; inset: 0; display: flex; align-items: flex-end; opacity: 0; transition: opacity .8s ease; }
.fdb-slide.active { opacity: 1; position: relative; }
.fdb-slide-bg { position: absolute; inset: 0; background: center/cover no-repeat; }
.fdb-slide-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,.8) 40%, rgba(0,0,0,.2) 100%); }
.fdb-slide-content { position: relative; z-index: 1; color: #fff; padding: calc(var(--fdb-header-h) + 40px) 0 60px; max-width: 600px; }
.fdb-slide-poster { position: absolute; right: 10%; bottom: 0; width: 220px; z-index: 2; }
.fdb-slide-poster img { border-radius: var(--fdb-radius-lg); box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.fdb-slider-dots { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 10; }
.fdb-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.5); border: none; cursor: pointer; }
.fdb-dot.active { background: #fff; width: 24px; border-radius: 4px; }

/* Recently Added section */
.fdb-home-section { padding: 60px 0; }
.fdb-home-section-header { text-align: center; margin-bottom: 36px; }
.fdb-home-section-header h2 { font-size: 1.8rem; font-weight: 800; margin-bottom: 6px; }
.fdb-home-section-header p { color: var(--fdb-text-2); }
.fdb-poster-strip { display: flex; gap: 16px; overflow-x: auto; padding-bottom: 8px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.fdb-poster-strip .fdb-card-poster { flex: 0 0 160px; scroll-snap-align: start; }

/* Platforms marquee */
.fdb-platforms-bar { border-top: 1px solid var(--fdb-border); border-bottom: 1px solid var(--fdb-border); padding: 24px 0; overflow: hidden; background: var(--fdb-bg-2); }
.fdb-platforms-track { display: flex; gap: 60px; align-items: center; animation: fdb-marquee 30s linear infinite; }
.fdb-platforms-track img { height: 28px; width: auto; opacity: .5; filter: grayscale(1); transition: opacity .3s, filter .3s; flex-shrink: 0; }
.fdb-platforms-track img:hover { opacity: 1; filter: none; }
@keyframes fdb-marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* Section cards 2x2 */
.fdb-section-cards { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.fdb-section-card { position: relative; aspect-ratio: 4/2; overflow: hidden; border-radius: var(--fdb-radius-lg); }
.fdb-section-card-bg { position: absolute; inset: 0; background: center/cover no-repeat; transition: transform .6s ease; }
.fdb-section-card:hover .fdb-section-card-bg { transform: scale(1.05); }
.fdb-section-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.8) 0%, transparent 60%); }
.fdb-section-card-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px; color: #fff; }
.fdb-section-card-content h3 { font-size: 1.4rem; margin-bottom: 4px; }
.fdb-section-card-content p { font-size: .875rem; opacity: .8; }
.fdb-section-card-link { position: absolute; inset: 0; z-index: 1; }

/* ══════════════════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-newsletter-bar { background: var(--fdb-accent); color: #fff; padding: 32px 0; }
.fdb-newsletter-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.fdb-newsletter-text h3 { font-size: 1.2rem; margin-bottom: 4px; }
.fdb-newsletter-text p { font-size: .875rem; opacity: .85; }
.fdb-newsletter-form { display: flex; gap: 0; flex: 1; max-width: 400px; }
.fdb-newsletter-form input[type=email] { flex: 1; padding: 12px 16px; border: none; border-radius: var(--fdb-radius-sm) 0 0 var(--fdb-radius-sm); font-size: .9rem; background: rgba(255,255,255,.15); color: #fff; }
.fdb-newsletter-form input::placeholder { color: rgba(255,255,255,.7); }
.fdb-newsletter-form .fdb-btn-accent { border-radius: 0 var(--fdb-radius-sm) var(--fdb-radius-sm) 0; background: rgba(0,0,0,.25); }
.fdb-newsletter-form .fdb-btn-accent:hover { background: rgba(0,0,0,.4); }

.fdb-footer-main { background: var(--fdb-footer-bg); color: var(--fdb-footer-text); padding: 60px 0 40px; }
.fdb-footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }
.fdb-footer-logo-text { font-size: 1.1rem; font-weight: 800; color: #fff; font-family: 'Courier New', monospace; margin-bottom: 12px; }
.fdb-footer-brand p { font-size: .875rem; line-height: 1.6; margin-bottom: 8px; }
.fdb-footer-social { margin-top: 20px; }
.fdb-footer-social span { display: block; font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; opacity: .6; margin-bottom: 8px; }
.fdb-social-icons { display: flex; gap: 8px; }
.fdb-social-icon { width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,.08); display: flex; align-items: center; justify-content: center; color: var(--fdb-footer-text); transition: background var(--fdb-transition), color var(--fdb-transition); }
.fdb-social-icon:hover { background: var(--fdb-accent); color: #fff; text-decoration: none; }
.fdb-footer-col h4 { font-size: .875rem; font-weight: 700; color: #fff; margin-bottom: 16px; text-transform: uppercase; letter-spacing: .08em; }
.fdb-footer-links { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.fdb-footer-links a { color: var(--fdb-footer-text); font-size: .875rem; }
.fdb-footer-links a::before { content: '→ '; opacity: .5; }
.fdb-footer-links a:hover { color: #fff; text-decoration: none; }
.fdb-footer-contact-item { display: flex; align-items: center; gap: 8px; font-size: .875rem; margin-bottom: 8px; }
.fdb-footer-contact-item a { color: var(--fdb-footer-text); }
.fdb-footer-contact-item a:hover { color: #fff; }
.fdb-footer-bottom { background: rgba(0,0,0,.3); padding: 16px 0; border-top: 1px solid var(--fdb-footer-border); }
.fdb-footer-bottom-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.fdb-footer-bottom p { font-size: .8rem; color: var(--fdb-footer-text); opacity: .7; }
.fdb-footer-legal-links { display: flex; gap: 16px; }
.fdb-footer-legal-links a { font-size: .8rem; color: var(--fdb-footer-text); opacity: .6; }
.fdb-footer-legal-links a:hover { opacity: 1; color: #fff; text-decoration: none; }

/* ══════════════════════════════════════════════════════════════════════════
   CAROUSEL
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-carousel { position: relative; overflow: hidden; }
.fdb-carousel-track { display: flex; gap: 16px; transition: transform .4s ease; }
.fdb-carousel-item { flex: 0 0 calc(20% - 13px); }
.fdb-carousel-poster img { width: 100%; aspect-ratio: 2/3; object-fit: cover; border-radius: var(--fdb-radius); }
.fdb-carousel-banner { position: relative; aspect-ratio: 16/9; background: center/cover no-repeat; border-radius: var(--fdb-radius); overflow: hidden; }
.fdb-carousel-info { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px; background: linear-gradient(to top, rgba(0,0,0,.8),transparent); color: #fff; }
.fdb-carousel-info h4 { font-size: .9rem; margin-bottom: 4px; }
.fdb-carousel-title h4 { font-size: .875rem; font-weight: 600; margin-top: 8px; color: var(--fdb-text); }
.fdb-carousel-prev, .fdb-carousel-next { position: absolute; top: 50%; transform: translateY(-50%); background: var(--fdb-bg); border: 1.5px solid var(--fdb-border); border-radius: 50%; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 1.4rem; z-index: 10; transition: all var(--fdb-transition); }
.fdb-carousel-prev { left: -20px; }
.fdb-carousel-next { right: -20px; }
.fdb-carousel-prev:hover, .fdb-carousel-next:hover { background: var(--fdb-accent); border-color: var(--fdb-accent); color: #fff; }

/* ══════════════════════════════════════════════════════════════════════════
   TAXONOMY CLOUD (Elementor widget)
   ══════════════════════════════════════════════════════════════════════════ */
.fdb-taxonomy-cloud { padding: 16px 0; }
.fdb-cloud-title { font-size: 1.2rem; margin-bottom: 16px; }
.fdb-cloud-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.fdb-cloud-tag { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; background: var(--fdb-bg-2); border: 1px solid var(--fdb-border); border-radius: var(--fdb-radius-pill); font-size: .875rem; color: var(--fdb-text); transition: all var(--fdb-transition); }
.fdb-cloud-tag:hover { border-color: var(--fdb-accent); color: var(--fdb-accent); background: var(--fdb-accent-light); text-decoration: none; }
.fdb-tag-count { font-size: .75rem; color: var(--fdb-text-3); }

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .fdb-cols-4 { grid-template-columns: repeat(3,1fr); }
    .fdb-cols-5 { grid-template-columns: repeat(3,1fr); }
    .fdb-cols-6 { grid-template-columns: repeat(4,1fr); }
    .fdb-footer-grid { grid-template-columns: 1fr 1fr; gap: 30px; }
}

@media (max-width: 768px) {
    :root { --fdb-header-h: 60px; }
    .fdb-nav { display: none; }
    .fdb-nav.open { display: block; position: fixed; inset: var(--fdb-header-h) 0 0 0; background: var(--fdb-bg); padding: 20px; overflow-y: auto; z-index: 999; }
    .fdb-nav.open .fdb-nav-menu { flex-direction: column; gap: 4px; }
    .fdb-mobile-toggle { display: flex; }
    .fdb-hero-inner { flex-direction: column; align-items: flex-start; gap: 20px; padding-bottom: 30px; }
    .fdb-hero-poster-wrap { margin-bottom: -60px; }
    .fdb-hero-poster { width: 160px; }
    .fdb-cols-3, .fdb-cols-4, .fdb-cols-5, .fdb-cols-6 { grid-template-columns: repeat(2,1fr); }
    .fdb-tech-grid { grid-template-columns: repeat(2,1fr); }
    .fdb-footer-grid { grid-template-columns: 1fr; }
    .fdb-newsletter-inner { flex-direction: column; }
    .fdb-newsletter-form { max-width: 100%; width: 100%; }
    .fdb-section-cards { grid-template-columns: 1fr; }
    .fdb-back-bar .fdb-container { flex-direction: column; align-items: flex-start; }
    .fdb-actions-wrap { flex-direction: column; }
}

@media (max-width: 480px) {
    .fdb-cols-2, .fdb-cols-3, .fdb-cols-4 { grid-template-columns: repeat(2,1fr); }
    .fdb-hero-title { font-size: 1.6rem; }
    .fdb-cast-grid { grid-template-columns: repeat(3,1fr); }
    .fdb-series-card { flex-direction: column; }
    .fdb-sc-poster { flex: none; width: 100%; }
    .fdb-sc-poster img { width: 100%; aspect-ratio: 16/9; }
}

/* Print styles for PDF export */
@media print {
    .fdb-header, .fdb-back-bar, .fdb-module-sharing, .fdb-module-related, .fdb-newsletter-bar, .fdb-footer { display: none !important; }
    .fdb-hero-banner { min-height: 300px; }
    body { background: #fff; color: #000; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   FIXES v2 — Applied Feb 2026
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Gradient backgrounds (subtle) ────────────────────────────────────────── */
:root {
    --fdb-bg:   #fafbfc;
    --fdb-bg-2: #f0f2f5;
    --fdb-bg-3: #e8eaef;
}
[data-theme="dark"] {
    --fdb-bg:   #0a0e18;
    --fdb-bg-2: #10151f;
    --fdb-bg-3: #151c2a;
}
body {
    background: linear-gradient(180deg, var(--fdb-bg) 0%, var(--fdb-bg-2) 100%) !important;
    background-attachment: fixed !important;
}
[data-theme="dark"] body {
    background: linear-gradient(180deg, #0a0e18 0%, #0d1520 100%) !important;
    background-attachment: fixed !important;
}

/* ── Hero banner — compact, NOT full viewport ──────────────────────────────── */
.fdb-hero-banner {
    min-height: 55vh !important;
    max-height: 70vh !important;
}
@media (max-width: 768px) {
    .fdb-hero-banner { min-height: 45vh !important; max-height: 55vh !important; }
}

/* ── Poster — show full poster, not cropped ────────────────────────────────── */
.fdb-hero-poster-wrap {
    margin-bottom: -100px !important;   /* extend below banner into white area */
    align-self: flex-end !important;
}
.fdb-hero-poster { width: 180px !important; }
.fdb-hero-poster img { 
    width: 100% !important; 
    height: auto !important; 
    aspect-ratio: 2/3 !important;
    object-fit: cover !important;
}
/* More space at bottom of back-bar to accommodate poster bleed */
.fdb-back-bar .fdb-container { padding-top: 120px !important; }

/* ── Remove back to library button ────────────────────────────────────────── */
.fdb-back-link { display: none !important; }

/* ── Action buttons — distinct colours, proper layout ─────────────────────── */
.fdb-actions-layout { display: flex; gap: 32px; align-items: flex-start; flex-wrap: wrap; }
.fdb-actions-buttons { display: flex; flex-direction: column; gap: 10px; flex: 1; max-width: 320px; }
.fdb-btn-primary.fdb-btn-lg { padding: 14px 22px; font-size: 1rem; }
.fdb-btn-imdb  { background: #f5c518 !important; color: #000 !important; }
.fdb-btn-imdb:hover { background: #e0b400 !important; }
.fdb-btn-teal  { background: #0d7377 !important; color: #fff !important; }
.fdb-btn-teal:hover { background: #0a5e61 !important; }
.fdb-btn-dark  { background: #1a1a2e !important; color: #fff !important; border: 1px solid #3a3a5e !important; }
.fdb-btn-dark:hover { background: #252543 !important; }

/* QR block repositioned to right of buttons */
.fdb-qr-block {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 16px !important;
    background: var(--fdb-bg-2) !important;
    border: 1px solid var(--fdb-border) !important;
    border-radius: var(--fdb-radius) !important;
    width: 140px !important;
}
.fdb-qr-code { width: 100px !important; height: 100px !important; border-radius: 6px; }
.fdb-qr-label { font-size: .72rem !important; color: var(--fdb-text-2) !important; text-align:center; }

/* ── Videos — adaptive grid (not horizontal scroll) ───────────────────────── */
.fdb-videos-grid { display: grid !important; gap: 16px !important; }
.fdb-videos-cols-1 { grid-template-columns: 1fr !important; max-width: 640px; }
.fdb-videos-cols-2 { grid-template-columns: repeat(2,1fr) !important; }
.fdb-videos-cols-3 { grid-template-columns: repeat(3,1fr) !important; }
.fdb-videos-cols-4 { grid-template-columns: repeat(4,1fr) !important; }
.fdb-video-card .fdb-video-thumb { 
    width: 100% !important;
    aspect-ratio: 16/9 !important;
    display: block !important;
    border-radius: var(--fdb-radius) !important;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    border: none;
    background: var(--fdb-bg-3);
}
.fdb-video-card .fdb-video-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.fdb-video-card .fdb-video-play-icon { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.fdb-video-label { font-size:.82rem; color:var(--fdb-text-2); margin-top:6px; text-align:center; }
@media (max-width:640px) {
    .fdb-videos-cols-3,.fdb-videos-cols-4 { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── Gallery — adaptive grid ───────────────────────────────────────────────── */
.fdb-gallery-grid { display: grid !important; gap: 10px !important; }
.fdb-gallery-cols-1 { grid-template-columns: 1fr !important; }
.fdb-gallery-cols-2 { grid-template-columns: repeat(2,1fr) !important; }
.fdb-gallery-cols-3 { grid-template-columns: repeat(3,1fr) !important; }
.fdb-gallery-cols-4 { grid-template-columns: repeat(4,1fr) !important; }
.fdb-gallery-item { aspect-ratio: 16/9 !important; }
@media (max-width:640px) {
    .fdb-gallery-cols-3,.fdb-gallery-cols-4 { grid-template-columns: repeat(2,1fr) !important; }
}

/* ── Main nav menu fix — ensure visibility ────────────────────────────────── */
.fdb-nav { display: block !important; }
.fdb-nav-menu { display: flex !important; flex-wrap: wrap !important; }
@media (max-width: 960px) {
    .fdb-nav { display: none !important; }
    .fdb-nav.open { display: block !important; }
    .fdb-mobile-toggle { display: flex !important; }
}

/* ── Trailer — remove bannerimage fallback so only actual thumbnail shows ─── */
.fdb-trailer-thumb-btn { aspect-ratio: 16/9 !important; background: #000 !important; }
.fdb-trailer-thumb { width:100% !important; height:100% !important; object-fit:cover !important; }

/* ── IMDb button gold style ────────────────────────────────────────────────── */
.fdb-btn-imdb { font-weight: 700 !important; letter-spacing: -.02em; }
