/* ============================================================
   EMBER DUSK MEDIA — Master Stylesheet
   ============================================================ */
:root {
  --color-bg:            #0a0a0a;
  --color-surface:       #141414;
  --color-surface-hover: #1e1e1e;
  --color-text:          #e8e4df;
  --color-text-muted:    #8a8279;
  --color-accent:        #d4603a;
  --color-accent-hover:  #e87b55;
  --color-border:        #2a2520;
  --color-overlay:       rgba(10, 10, 10, 0.7);
  --color-overlay-heavy: rgba(10, 10, 10, 0.85);

  --font-body:    'Inter', sans-serif;
  --font-heading: 'Outfit', sans-serif;

  --space-xs:  0.25rem;
  --space-sm:  0.5rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2.5rem;
  --space-2xl: 4rem;
  --space-3xl: 6rem;

  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  12px;
  --radius-xl:  16px;

  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;

  --max-width:        1280px;
  --max-width-narrow: 900px;
  --header-height: 72px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-body); font-size: 1rem; line-height: 1.6; color: var(--color-text); background-color: var(--color-bg); overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); font-weight: 600; line-height: 1.2; color: var(--color-text); }
h1 { font-size: clamp(2rem, 6vw, 4rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2.5rem); }
h3 { font-size: clamp(1.15rem, 3vw, 1.5rem); }
h4 { font-size: 1.125rem; }
p { margin-bottom: var(--space-md); color: var(--color-text-muted); }
.text-accent { color: var(--color-accent); }
.section-label { display: inline-block; font-family: var(--font-body); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--color-accent); margin-bottom: var(--space-sm); }
.section-heading { margin-bottom: var(--space-xl); }
.section-heading::after { content: ''; display: block; width: 48px; height: 3px; background-color: var(--color-accent); margin-top: var(--space-md); border-radius: 2px; }
.section-heading--center { text-align: center; }
.section-heading--center::after { margin-left: auto; margin-right: auto; }

.container { width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 var(--space-lg); }
.section { padding: var(--space-2xl) 0; }
.section--top { padding-top: calc(var(--header-height) + var(--space-2xl)); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm); padding: 0.875rem 2rem; font-family: var(--font-heading); font-size: 0.9rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; border-radius: var(--radius-md); transition: background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast); }
.btn:active { transform: scale(0.97); }
.btn--primary { background-color: var(--color-accent); color: #fff; }
.btn--primary:hover { background-color: var(--color-accent-hover); box-shadow: 0 4px 24px rgba(212, 96, 58, 0.35); }
.btn--outline { border: 1.5px solid var(--color-border); color: var(--color-text); }
.btn--outline:hover { border-color: var(--color-accent); color: var(--color-accent); }

.header { position: fixed; top: 0; left: 0; width: 100%; height: var(--header-height); z-index: 1000; display: flex; align-items: center; transition: background-color var(--transition-base), box-shadow var(--transition-base); }
.header--scrolled { background-color: rgba(10, 10, 10, 0.92); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); box-shadow: 0 1px 0 var(--color-border); }
.header__inner { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 var(--space-lg); }

.logo { font-family: var(--font-heading); font-size: 1.35rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text); transition: color var(--transition-fast); flex-shrink: 0; }
.logo span { color: var(--color-accent); }

.nav { display: none; }
.nav__list { display: flex; align-items: center; gap: var(--space-xl); }
.nav__link { position: relative; font-size: 0.85rem; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-text-muted); transition: color var(--transition-fast); }
.nav__link:hover, .nav__link--active { color: var(--color-text); }
.nav__link::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 2px; background-color: var(--color-accent); transition: width var(--transition-base); }
.nav__link:hover::after, .nav__link--active::after { width: 100%; }

.hamburger { display: flex; flex-direction: column; justify-content: center; gap: 5px; width: 28px; height: 28px; z-index: 1100; }
.hamburger__line { display: block; width: 100%; height: 2px; background-color: var(--color-text); border-radius: 2px; transition: transform var(--transition-base), opacity var(--transition-fast); transform-origin: center; }
.hamburger--active .hamburger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger--active .hamburger__line:nth-child(2) { opacity: 0; }
.hamburger--active .hamburger__line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu { position: fixed; inset: 0; z-index: 1050; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-xl); background-color: var(--color-bg); opacity: 0; visibility: hidden; transition: opacity var(--transition-base), visibility var(--transition-base); }
.mobile-menu--open { opacity: 1; visibility: visible; }
.mobile-menu__link { font-family: var(--font-heading); font-size: 1.75rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--color-text-muted); transition: color var(--transition-fast); }
.mobile-menu__link:hover, .mobile-menu__link--active { color: var(--color-accent); }

.hero { display: none; position: relative; align-items: center; justify-content: center; min-height: 60svh; overflow: hidden; }
.hero__media { position: absolute; inset: 0; z-index: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; }
/* Mobile-first: full-width video at its true 16:9 size (sharp, never upscaled).
   The window is a touch shorter than 16:9 and the video is bottom-aligned, so the
   YouTube title strip along the top is cropped off cleanly. */
.hero__video-container { position: relative; width: 100%; height: 50vw; overflow: hidden; pointer-events: none; }
.hero__video { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; height: 56.25vw; border: none; }
.hero__image { width: 100%; height: 100%; object-fit: cover; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(10, 10, 10, 0.4) 0%, rgba(10, 10, 10, 0.7) 60%, var(--color-bg) 100%); z-index: 1; pointer-events: none; }
.hero__content { position: relative; z-index: 2; text-align: center; padding: 0 var(--space-lg); max-width: 720px; }
.hero__title { font-size: clamp(2.25rem, 7vw, 4.5rem); font-weight: 700; line-height: 1.1; margin-bottom: var(--space-lg); }
.hero__subtitle { font-size: clamp(1rem, 2.5vw, 1.25rem); color: var(--color-text-muted); margin-bottom: var(--space-xl); max-width: 520px; margin-left: auto; margin-right: auto; }
.hero__cta-group { display: flex; flex-wrap: wrap; gap: var(--space-md); justify-content: center; }

.page-hero { display: flex; align-items: center; justify-content: center; text-align: center; padding: calc(var(--header-height) + var(--space-3xl)) var(--space-lg) var(--space-2xl); background: linear-gradient(to bottom, var(--color-surface) 0%, var(--color-bg) 100%); }
.page-hero__title { font-size: clamp(2rem, 5vw, 3rem); margin-bottom: var(--space-sm); }
.page-hero__subtitle { color: var(--color-text-muted); font-size: clamp(0.95rem, 2vw, 1.125rem); max-width: 480px; margin: 0 auto; }

.hero__scroll { position: absolute; bottom: var(--space-xl); left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: var(--space-sm); color: var(--color-text-muted); font-size: 0.7rem; letter-spacing: 0.15em; text-transform: uppercase; animation: bounce 2s infinite; }
.hero__scroll-icon { width: 20px; height: 20px; border-right: 2px solid var(--color-text-muted); border-bottom: 2px solid var(--color-text-muted); transform: rotate(45deg); }
@keyframes bounce { 0%, 20%, 50%, 80%, 100% { transform: translateX(-50%) translateY(0); } 40% { transform: translateX(-50%) translateY(-8px); } 60% { transform: translateX(-50%) translateY(-4px); } }

.films { padding: calc(var(--header-height) + var(--space-2xl)) 0 var(--space-2xl); }
.films__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
.film-card { position: relative; border-radius: var(--radius-lg); overflow: hidden; background-color: var(--color-surface); transition: transform var(--transition-base), box-shadow var(--transition-base); }
.film-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4); }
.film-card__image-wrapper { position: relative; aspect-ratio: 16 / 9; overflow: hidden; }
.film-card__image { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.film-card:hover .film-card__image { transform: scale(1.05); }
.film-card__image-wrapper::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(10, 10, 10, 0.75) 0%, transparent 50%); pointer-events: none; }
.film-card__body { padding: var(--space-lg); text-align: center; }
.film-card__title { font-size: 1.15rem; font-weight: 600; margin-bottom: 0; }
.film-card__meta { font-size: 0.85rem; color: var(--color-text-muted); }
.films__cta { text-align: center; margin-top: var(--space-2xl); }

.footer { border-top: 1px solid var(--color-border); padding: var(--space-xl) 0; }
.footer__inner { display: flex; flex-direction: column; align-items: center; gap: var(--space-lg); text-align: center; }
.footer__logo { font-family: var(--font-heading); font-size: 1.15rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; }
.footer__logo span { color: var(--color-accent); }
.footer__links { display: flex; gap: var(--space-lg); }
.footer__link { font-size: 0.8rem; color: var(--color-text-muted); transition: color var(--transition-fast); }
.footer__link:hover { color: var(--color-accent); }
.footer__copy { font-size: 0.75rem; color: var(--color-text-muted); margin-bottom: 0; }

.fade-in { opacity: 0; transform: translateY(24px); transition: opacity 0.6s ease, transform 0.6s ease; }
.fade-in--visible { opacity: 1; transform: translateY(0); }

@media (min-width: 768px) {
  .nav { display: block; }
  .hamburger { display: none; }
  .films__grid { grid-template-columns: repeat(2, 1fr); }
  .footer__inner { flex-direction: row; justify-content: space-between; text-align: left; }
  /* Desktop has the hero, so the films section no longer needs header-clearance padding. */
  .films { padding: var(--space-2xl) 0; }

  /* Desktop: show the hero (hidden on mobile) and run it full-bleed cinematic. */
  .hero { display: flex; min-height: 100vh; }
  .hero__video-container { position: absolute; inset: 0; width: 100%; height: 100%; }
  .hero__video {
    bottom: 0; left: 50%;
    transform: translateX(-50%);
    width: 112vw; height: 63vw;
    min-width: 199vh; min-height: 112vh;
  }
}

@media (min-width: 1280px) {
  .films__grid { grid-template-columns: repeat(3, 1fr); }
}

.film-card__link {
  display: block;
  color: inherit;
}

