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

:root {
  --black:      #0d0d0b;
  --white:      #f8f8f6;
  --surface:    #f0efec;
  --text:       #1a1a1a;
  --muted:      #888880;
  --rule:       rgba(26,26,26,0.12);
  --rule-light: rgba(255,255,255,0.1);
  --overlay:    rgba(0,0,0,0.45);
  --font-sans:  'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-serif: Georgia, 'Times New Roman', serif;
}

html { scroll-behavior: smooth; }
body {
  background: var(--white);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  padding-top: 56px;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ─── TYPOGRAPHY ─── */
h1 { font-size: clamp(48px,7vw,96px); font-weight:200; letter-spacing:0.14em; line-height:1.0; text-transform:uppercase; }
h2 { font-size: clamp(28px,3.5vw,48px); font-weight:200; letter-spacing:0.1em; line-height:1.1; text-transform:uppercase; }
.editorial { font-family:var(--font-serif); font-size:clamp(26px,3vw,46px); font-weight:300; font-style:italic; letter-spacing:0.01em; line-height:1.25; }
.eyebrow { font-size:9px; font-weight:400; letter-spacing:0.45em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:16px; }

/* ─── NAVIGATION ─── */
nav {
  position:fixed; top:0; left:0; right:0; height:56px;
  display:flex; align-items:center;
  padding:0 48px;
  background: rgba(13,13,11,0.92);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 0.5px solid var(--rule-light);
  z-index:100;
  transition: background 0.4s ease, border-color 0.4s ease;
}
.nav-wordmark {
  font-family:var(--font-sans); font-size:12px; font-weight:300;
  letter-spacing:0.22em; text-transform:uppercase; color:#fff;
  white-space:nowrap; flex-shrink:0; margin-right:auto;
}
.nav-links {
  display:flex; gap:32px; list-style:none; flex-shrink:0;
}
.nav-links a {
  font-size:11px; font-weight:300; letter-spacing:0.1em;
  text-transform:uppercase; color:rgba(255,255,255,0.5);
  transition:color 0.2s; white-space:nowrap;
}
.nav-links a:hover, .nav-links a.active { color:#fff; }

/* ─── BUTTONS ─── */
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-sans); font-size:10px; font-weight:400; letter-spacing:0.18em; text-transform:uppercase; padding:13px 32px; border-radius:980px; cursor:pointer; transition:all 0.25s ease; }
.btn-white { background:#fff; color:var(--black); border:none; }
.btn-white:hover { opacity:0.88; }
.btn-outline-white { background:transparent; color:#fff; border:0.5px solid rgba(255,255,255,0.45); }
.btn-outline-white:hover { background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.9); }
.btn-dark { background:var(--text); color:var(--white); border:none; }
.btn-dark:hover { opacity:0.8; }
.btn-outline-dark { background:transparent; color:var(--text); border:0.5px solid var(--text); }
.btn-outline-dark:hover { background:var(--text); color:var(--white); }

/* ─── MARQUEE ─── */
.marquee-section { overflow:hidden; padding:18px 0; background:var(--white); border-top:0.5px solid var(--rule); border-bottom:0.5px solid var(--rule); }
.marquee-track { display:flex; white-space:nowrap; overflow:hidden; }
.marquee-inner { display:flex; align-items:center; flex-shrink:0; animation:marqueeScroll 30s linear infinite; }
.marquee-item { font-size:10px; font-weight:300; letter-spacing:0.3em; text-transform:uppercase; color:var(--muted); padding:0 28px; }
.marquee-gem { color:var(--text); font-size:5px; flex-shrink:0; opacity:0.35; }
@keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ─── SECTION DIVIDER ─── */
.section-divider { height:0.5px; background:var(--rule); margin:0 72px; position:relative; overflow:hidden; }
.section-divider::after { content:''; position:absolute; top:0; left:-100%; width:60%; height:100%; background:linear-gradient(to right,transparent,rgba(26,26,26,0.4),transparent); transition:none; }
.section-divider.is-visible::after { animation:dividerSweep 1.4s cubic-bezier(0.16,1,0.3,1) forwards; }
@keyframes dividerSweep { from{left:-100%} to{left:200%} }

/* ─── SCROLL REVEAL ─── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1); }
.reveal.visible { opacity:1; transform:translateY(0); }
.img-reveal { opacity:0; transition:opacity 1.1s cubic-bezier(0.16,1,0.3,1); }
.img-reveal.visible { opacity:1; }
.rd1 { transition-delay:0.08s; }
.rd2 { transition-delay:0.16s; }
.rd3 { transition-delay:0.24s; }
.rd4 { transition-delay:0.32s; }
.rd5 { transition-delay:0.40s; }

/* ─── PAGE HERO (non-video pages) ─── */
.page-hero { background:var(--black); padding:96px 72px 72px; position:relative; overflow:hidden; min-height:52vh; display:flex; flex-direction:column; justify-content:flex-end; }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(0.3); }
.page-hero h1, .page-hero .eyebrow { position:relative; z-index:1; }
.page-hero h1 { color:#fff; }
.page-hero .eyebrow { color:rgba(255,255,255,0.4); }

/* ─── SITE FOOTER ─── */
.site-footer { padding:64px 72px 48px; background:var(--black); border-top:0.5px solid var(--rule-light); display:flex; flex-direction:column; align-items:center; text-align:center; gap:20px; }
.footer-wordmark { font-size:15px; font-weight:200; letter-spacing:0.3em; text-transform:uppercase; color:#fff; display:block; margin-bottom:8px; text-decoration:none; }
.footer-wordmark:hover { color:rgba(255,255,255,0.7); }
.footer-tagline { font-size:12px; font-style:italic; color:var(--muted); letter-spacing:0.02em; }
.footer-nav { display:flex; gap:32px; flex-wrap:wrap; justify-content:center; }
.footer-nav a { font-size:10px; font-weight:300; letter-spacing:0.15em; text-transform:uppercase; color:rgba(255,255,255,0.35); transition:color 0.2s; }
.footer-nav a:hover { color:rgba(255,255,255,0.7); }
.footer-copy { font-size:10px; color:rgba(255,255,255,0.2); letter-spacing:0.1em; margin-top:8px; }

/* ─── PM CREDIT ─── */
.pm-credit { background:#000; border-top:0.5px solid var(--rule-light); padding:24px 48px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:24px; }
.pm-credit .back-link { font-size:11px; font-weight:300; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.95); transition:color 0.2s; }
.pm-credit .back-link:hover { color:#fff; }
.pm-credit .pm-logo-link { display:flex; align-items:center; justify-content:center; }
.pm-credit img { height:44px; width:auto; filter:brightness(0) invert(1); }

/* ─── RESPONSIVE ─── */
@media (max-width:768px) {
  nav { padding:0 24px; gap:16px; }
  .nav-links { gap:16px; }
  .nav-links a { font-size:10px; }
  .page-hero { padding:80px 24px 52px; }
  .site-footer { padding:48px 24px 36px; }
  .footer-nav { gap: 14px; flex-wrap: wrap; justify-content: center; }
  .pm-credit { padding:20px 24px; }
  .section-divider { margin:0 24px; }
}
