/* style.css */

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }



    :root {
      --bg: #0B090A;
      --surface: #161A1D;
      --border: #D3D3D3;
      --accent: #E5383B;
      --text: #F5F3F4;
      --text-muted: #D3D3D3;
      --nav-h: 64px;
      --nav-h-mobile: 80px;
      --red:     #BA181B;
      --red-dim: #660708;
      --ink:      #0B090A;
      --fog:      #1a1a1f;
      --mist:     #252530;
      --radius:   4px;
    }

    body {
      background: var(--bg);
      color: var(--text);
      font-family: 'Montserrat', sans-serif;
      min-height: 100vh;
      overflow-x: hidden;
    }

    /* ── HEADER / NAV ── */
    header {
      position: sticky;
      top: 0;
      z-index: 100;
      background: #0d0d0dee;
      backdrop-filter: blur(10px);
      border-bottom: 1px solid var(--border);
      height: var(--nav-h);
      display: flex;
      align-items: center;
      padding: 0 24px;
      gap: 24px;
    }

    .logo {
      display: flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
      flex-shrink: 0;
    }

    .logo img {
      height: 36px;
      width: auto;
    }

    .logo-text {
      font-size: 1.3rem;
      font-weight: bold;
      letter-spacing: 0.05em;
      color: var(--text);
      white-space: nowrap;
    }

    nav.desktop-nav {
      display: flex;
      align-items: center;
      gap: 6px;
      margin-left: auto;
      flex-wrap: nowrap;
    }

    nav.desktop-nav a {
      color: var(--text-muted);
      text-decoration: none;
      font-size: 0.72rem;
      letter-spacing: 0.12em;
      padding: 6px 10px;
      border-radius: 4px;
      transition: color 0.2s, background 0.2s;
      white-space: nowrap;
    }

    nav.desktop-nav a:hover {
      color: var(--accent);
      background: rgba(201,168,76,0.08);
    }

    /* Hamburger */
    .hamburger {
      display: none;
      background: none;
      border: none;
      cursor: pointer;
      padding: 6px;
      margin-left: auto;
      flex-direction: column;
      gap: 5px;
    }

    .hamburger span {
      display: block;
      width: 24px;
      height: 2px;
      background: var(--text);
      border-radius: 2px;
      transition: transform 0.3s, opacity 0.3s;
    }

    .hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .hamburger.open span:nth-child(2) { opacity: 0; }
    .hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    /* Mobile drawer */
    .mobile-nav {
      display: none;
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: #0d0d0df5;
      z-index: 200;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 28px;
      padding: 40px 24px;
    }

    .mobile-nav.open { display: flex; }

    .mobile-nav .close-btn {
      position: absolute;
      top: 24px;
      right: 24px;
      background: none;
      border: none;
      color: var(--text);
      font-size: 2rem;
      cursor: pointer;
      line-height: 1;
    }

    .mobile-nav a {
      color: var(--text);
      text-decoration: none;
      font-size: 1.4rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      padding: 12px 24px;
      border-bottom: 1px solid var(--border);
      width: 100%;
      text-align: center;
      transition: color 0.2s;
    }

    .mobile-nav a:hover { color: var(--accent); }

    /* ── DISCLAIMER ── */
    .disclaimer {
      text-align: center;
      font-size: 0.72rem;
      color: var(--text-muted);
      letter-spacing: 0.08em;
      padding: 10px 24px;
      border-bottom: 1px solid var(--border);
      font-style: italic;
    }

    /* ── MAIN ── */
    main {
      padding: 40px 24px 60px;
      max-width: 1400px;
      margin: 0 auto;
    }

    /* ── SECTION ── */
    .section { margin-bottom: 56px; }

    .section-title {
      font-size: 0.9rem;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 20px;
      padding-bottom: 10px;
      border-bottom: 1px solid var(--border);
    }

    /* ── POSTER ROW WRAPPER ── */
    .row-wrapper {
      position: relative;
    }

    /* Scroll arrows */
    .scroll-btn {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      z-index: 10;
      background: rgba(13,13,13,0.85);
      border: 1px solid var(--border);
      color: var(--text);
      width: 40px;
      height: 64px;
      border-radius: 6px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      transition: background 0.2s, color 0.2s, opacity 0.2s;
      opacity: 0;
      pointer-events: none;
      flex-shrink: 0;
    }

    .row-wrapper:hover .scroll-btn,
    .row-wrapper.touch-active .scroll-btn { opacity: 1; pointer-events: auto; }

    .scroll-btn:hover { background: var(--accent); color: #000; border-color: var(--accent); }
    .scroll-btn.prev { left: -20px; }
    .scroll-btn.next { right: -20px; }
    .scroll-btn.hidden { visibility: hidden; }

    /* Always visible on mobile */
    @media (max-width: 768px) {
      .scroll-btn { opacity: 1; pointer-events: auto; }
      .scroll-btn.prev { left: -4px; }
      .scroll-btn.next { right: -4px; }
    }

    /* ── POSTER ROW ── */
    .poster-row {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 8px 4px 12px;

  /* Default: both sides fade */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 40px,
    black calc(100% - 40px),
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 40px,
    black calc(100% - 40px),
    transparent 100%
  );
}

/* 🚫 No left fade (at start) */
.poster-row.at-start {
  -webkit-mask-image: linear-gradient(
    to right,
    black 0%,
    black calc(100% - 40px),
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    black 0%,
    black calc(100% - 40px),
    transparent 100%
  );
}

/* 🚫 No right fade (at end) */
.poster-row.at-end {
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 40px,
    black 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 40px,
    black 100%
  );
}

/* 🚫 No fades at all (content fits fully) */
.poster-row.no-scroll {
  -webkit-mask-image: none;
  mask-image: none;
}
    .poster-row::-webkit-scrollbar { display: none; }


    /* ── POSTER CARD ── */
    .poster-card {
      flex: 0 0 auto;
      width: 160px;
      cursor: pointer;
      position: relative;
      border-radius: 6px;
      overflow: hidden;
      transition: transform 0.25s, box-shadow 0.25s;
      background-size: cover;       /* Fills the div without stretching */
      background-position: center;  /* Centers the image */
      background-repeat: no-repeat; /* Prevents tiling */
    }

    .poster-card:hover {
      transform: translateY(-6px) scale(1.02);
      box-shadow: 0 16px 40px rgba(0,0,0,0.6);
    }

    .poster-card img {
      width: 100%;
      aspect-ratio: 2/3;
      object-fit: cover;
      display: block;
      background: var(--surface);
    }

    /* Placeholder when no image */
    .poster-placeholder {
      width: 100%;
      aspect-ratio: 2/3;
      /*background: var(--surface);*/
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 8px;
      border: 1px solid var(--border);
      border-radius: 6px;
    }

    .poster-placeholder .poster-icon {
      font-size: 2rem;
      opacity: 1;
    }

    .poster-placeholder .poster-name {
      font-size: 0.8rem;
      letter-spacing: 0.08em;
      color: var(--text-muted);
      text-align: center;
      padding: 0 8px;
    }

    .poster-label {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: linear-gradient(transparent, rgba(22, 26, 29,0.85) 60%);
      padding: 24px 10px 10px;
      font-size: 0.75rem;
      letter-spacing: 0.05em;
      text-align: center;
      opacity: 0;
      transition: opacity 0.2s;
    }

    .poster-card:hover .poster-label { opacity: 1; }

    /* ── MOBILE OVERRIDES ── */
    @media (max-width: 768px) {
      header {
        height: var(--nav-h-mobile);
        padding: 0 16px;
      }

      .logo img { height: 44px; }    /* bigger logo on mobile */
      .logo-text { font-size: 1.6rem; }

      nav.desktop-nav { display: none; }
      .hamburger { display: flex; }

      main { padding: 24px 16px 60px; }

      .poster-card { width: 130px; }

      .scroll-btn {
        width: 32px;
        height: 52px;
        font-size: 0.9rem;
      }
    }

    @media (max-width: 480px) {
      .logo-text { font-size: 1.4rem; }
      .logo img { height: 35px; }
      .poster-card { width: 115px; }
    }
    
    a:link {
  color: var(--text);

}

a:visited {
  color: var(--text);

}

a:hover {
  color: var(--text);

}

a:active {
  color: var(--accent);

}

    /* ── RESET & BASE ── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    html { scroll-behavior: smooth; }



    /* ── HERO ── */
    .hero {
      position: relative;
      width: 100%;
      min-height: clamp(280px, 45vw, 520px);
      margin-top: 60px; /* header height */
      overflow: hidden;
      display: flex;
      align-items: flex-end;
    }

    .hero-img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      display: block;
    }

    /* layered gradient: dark top (for nav readability), rich middle, fade to black at bottom */
    .hero-overlay {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(to bottom,
          rgba(13,13,15,0.45) 0%,
          rgba(13,13,15,0.05) 30%,
          rgba(13,13,15,0.05) 55%,
          rgba(13,13,15,0.72) 78%,
          rgba(13,13,15,1.00) 100%
        );
    }

    /* red vignette on sides */
    .hero-vignette {
      position: absolute;
      inset: 0;
      background:
        radial-gradient(ellipse 60% 100% at 0% 50%, rgba(13,13,15,0.55) 0%, transparent 70%),
        radial-gradient(ellipse 60% 100% at 100% 50%, rgba(13,13,15,0.55) 0%, transparent 70%);
    }

    .hero-caption {
      position: relative;
      z-index: 2;
      padding: clamp(24px, 5vw, 56px) clamp(20px, 6vw, 72px);
      padding-top: 0;
    }

    .hero-caption h1 {
      /*font-family: 'Cinzel', serif;(*/
      font-size: clamp(28px, 5.5vw, 64px);
      font-weight: 600;
      letter-spacing: 0.06em;
      color: var(--text);
      line-height: 1.1;
      text-shadow: 0 2px 24px rgba(0,0,0,0.8);
    }

    .hero-caption .subtitle {
      font-family: 'Montserrat', sans-serif;
      font-style: italic;
      font-size: clamp(14px, 2.2vw, 22px);
      color: var(--red);
      letter-spacing: 0.08em;
      margin-top: 6px;
      text-shadow: 0 1px 12px rgba(0,0,0,0.7);
    }

    .hero-divider {
      width: 60px;
      height: 1px;
      background: linear-gradient(90deg, var(--red), transparent);
      margin: 14px 0 10px;
    }


    /* ── MAIN ── */
    main {
      max-width: 1200px;
      margin: 0 auto;
      padding: clamp(32px, 5vw, 60px) clamp(16px, 4vw, 48px) 80px;
    }



    /* ── VIDEO GRID ── */
    .row-wrapper {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(min(100%, 480px), 1fr));
      gap: 20px;
    }

    .video-frame {
      position: relative;
      width: 100%;
      aspect-ratio: 16 / 9;
      background: var(--fog);
      border-radius: var(--radius);
      overflow: hidden;
      border: 1px solid rgba(164, 22, 26,0.12);
      box-shadow: 0 4px 32px rgba(0,0,0,0.5);
      transition: box-shadow 0.3s, border-color 0.3s;
    }

    .video-frame:hover {
      border-color: rgba(164, 22, 26,0.35);
      box-shadow: 0 8px 48px rgba(0,0,0,0.7), 0 0 0 1px rgba(164, 22, 26,0.15);
    }

    .video-frame iframe {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      border: none;
    }

    /* ── RESPONSIVE ── */
    @media (max-width: 680px) {
      nav.desktop-nav { display: none; }
      .hamburger { display: flex; }

      .row-wrapper {
        grid-template-columns: 1fr;
      }

      .hero-caption h1 { letter-spacing: 0.03em; }
    }

    @media (min-width: 681px) {
      .hamburger { display: none; }
    }