/* ================================================
   WOMAN MADE FILMS — v3
   Navy · Dusty Blush · Deep Blush · Cream
   Playfair Display + Great Vibes + Space Grotesk
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700;1,900&family=Great+Vibes&family=Space+Grotesk:wght@300;400;500;600&display=swap');

:root {
  --navy:        #1a1a2e;
  --navy-mid:    #252545;
  --navy-light:  #2e2e55;
  --blush:       #d4a8b0;
  --blush-deep:  #b07888;
  --blush-light: #e8cdd2;
  --blush-pale:  #f2e0e4;
  --cream:       #f5ede4;
  --cream-dark:  #ede0d4;
  --offwhite:    #faf6f0;
  --silver:      #a8a8b8;
  --dark:        #1a1a2e;
  --muted:       #7a6870;
  --soft:        #9a8090;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-script:  'Great Vibes', cursive;
  --font-body:    'Space Grotesk', sans-serif;

  --nav-h: 52px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--cream); color: var(--navy); font-family: var(--font-body); font-weight: 400; overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img { display: block; width: 100%; height: 100%; object-fit: cover; }
button { cursor: pointer; }

/* ============ NAV ============ */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: var(--nav-h);
  background: var(--blush-deep);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 52px;
  transition: box-shadow 0.3s;
}
#nav.scrolled { box-shadow: 0 2px 24px rgba(176,120,136,0.35); }
.nav-logo {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 700; font-style: italic;
  letter-spacing: 0.5px; color: var(--offwhite);
}
.nav-links { display: flex; gap: 28px; list-style: none; }
.nav-links a {
  font-family: var(--font-body);
  font-size: 9px; font-weight: 600;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: rgba(250,246,240,0.65); transition: color 0.2s;
  padding-bottom: 2px; border-bottom: 1px solid transparent;
}
.nav-links a:hover, .nav-links a.active { color: var(--offwhite); border-bottom-color: var(--offwhite); }
.nav-toggle { display: none; background: none; border: none; font-size: 22px; color: var(--offwhite); }
.mobile-menu {
  display: none; position: fixed; top: var(--nav-h); left: 0; right: 0;
  background: var(--blush-deep); border-bottom: 1px solid rgba(250,246,240,0.15);
  flex-direction: column; padding: 20px 52px; gap: 16px; z-index: 999;
}
.mobile-menu a { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(250,246,240,0.75); }
.mobile-menu.open { display: flex; }

/* ============ BUTTONS ============ */
.btn-p {
  display: inline-block; background: var(--navy); color: var(--cream);
  padding: 12px 28px; font-family: var(--font-body); font-size: 9px;
  font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase;
  border: none; transition: background 0.2s, transform 0.15s;
}
.btn-p:hover { background: var(--blush-deep); transform: translateY(-1px); }
.btn-g {
  display: inline-block; background: transparent; color: var(--navy);
  padding: 11px 28px; font-family: var(--font-body); font-size: 9px;
  font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase;
  border: 1.5px solid rgba(26,26,46,0.25); transition: all 0.2s;
}
.btn-g:hover { border-color: var(--blush-deep); color: var(--blush-deep); transform: translateY(-1px); }
.btn-g-light {
  display: inline-block; background: transparent; color: var(--offwhite);
  padding: 11px 28px; font-family: var(--font-body); font-size: 9px;
  font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase;
  border: 1px solid rgba(250,246,240,0.3); transition: all 0.2s;
}
.btn-g-light:hover { border-color: var(--blush-light); color: var(--blush-light); }

/* ============ SECTION LABELS ============ */
.sl { font-size: 8px; letter-spacing: 3px; text-transform: uppercase; color: var(--blush-deep); margin-bottom: 8px; font-weight: 600; }
.sec-h { font-family: var(--font-display); font-size: clamp(28px, 3.8vw, 48px); font-weight: 900; line-height: 1.0; color: var(--navy); text-transform: uppercase; margin-bottom: 6px; letter-spacing: -0.5px; }
.sec-h em { font-family: var(--font-script); font-size: clamp(36px, 5vw, 58px); font-weight: 400; text-transform: none; color: var(--blush-deep); font-style: normal; display: block; line-height: 1; margin: -4px 0 4px; }
.body-text { font-size: 13px; line-height: 1.9; color: var(--muted); font-weight: 400; }

/* ============ COLLAGE ELEMENTS ============ */
.tape {
  display: none;
}
.silver-star {
  color: var(--silver);
  filter: drop-shadow(0 1px 2px rgba(140,140,160,0.5));
  line-height: 1; display: inline-block;
  font-family: serif;
}
.sticker {
  position: absolute; z-index: 12;
  display: inline-block; padding: 5px 12px;
  border: 1px solid rgba(26,26,46,0.14);
  background: rgba(250,246,240,0.92);
  box-shadow: 1px 2px 10px rgba(26,26,46,0.08);
  color: var(--blush-deep);
  font-family: var(--font-body); font-size: 8px; font-weight: 600;
  letter-spacing: 1.6px; text-transform: uppercase; white-space: nowrap;
}
.sticker-oval { border-radius: 999px; }
.sticker-ticket { border-style: dashed; background: var(--blush-pale); color: var(--navy); }
.scrap-note {
  position: absolute; z-index: 11;
  background: rgba(250,246,240,0.92); border: 1px solid rgba(26,26,46,0.1);
  padding: 10px 14px; box-shadow: 2px 3px 12px rgba(26,26,46,0.08);
  color: var(--soft); font-family: var(--font-script); font-size: 18px; line-height: 1.1;
}
.collage-label {
  position: absolute; z-index: 13;
  font-family: var(--font-body); font-size: 8px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--navy); background: rgba(232,205,210,0.92);
  border: 1px solid rgba(26,26,46,0.12); padding: 6px 12px;
  box-shadow: 2px 3px 12px rgba(26,26,46,0.08);
}
.film-strip {
  position: absolute; z-index: 7;
  width: 22px; height: 88px; border-radius: 2px;
  background: var(--navy);
  box-shadow: 2px 4px 10px rgba(26,26,46,0.2);
  opacity: 0.7;
}
.film-strip::before, .film-strip::after {
  content: ''; position: absolute; top: 5px; bottom: 5px; width: 4px;
  background: repeating-linear-gradient(to bottom, var(--cream) 0 3px, transparent 3px 8px);
  opacity: 0.7;
}
.film-strip::before { left: 3px; }
.film-strip::after { right: 3px; }

/* ============ POLAROID ============ */
.polaroid {
  background: white; padding: 7px 7px 26px;
  box-shadow: 3px 5px 20px rgba(26,26,46,0.14);
  position: absolute;
}
.polaroid-img { position: relative; overflow: hidden; }
.polaroid-img img {
  width: 100%; height: 100%; object-fit: cover; object-position: top center;
  filter: grayscale(100%) contrast(1.1) brightness(0.92); display: block;
}
.polaroid-img::after {
  content: ''; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.1'/%3E%3C/svg%3E") center/200px;
  mix-blend-mode: overlay; opacity: 0.3; pointer-events: none;
}
.polaroid-caption {
  font-family: var(--font-script); font-size: 14px; color: var(--soft);
  text-align: center; margin-top: 7px; display: block; line-height: 1.2;
}

/* ============ HERO ============ */
.hero {
  padding-top: var(--nav-h); min-height: 100vh;
  position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
  background: var(--blush-pale);
}
/* Cork board grid texture */
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(176,120,136,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(176,120,136,0.08) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none; z-index: 0;
}
.hero-grain {
  position: absolute; inset: 0; opacity: 0.02;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px; pointer-events: none;
}
.hero-left {
  position: relative; z-index: 2;
  padding: 80px 32px 80px 64px;
  display: flex; flex-direction: column; justify-content: center;
}
.hero-brand {
  font-family: var(--font-display);
  font-size: clamp(52px, 7.5vw, 100px);
  font-weight: 900; line-height: 0.88;
  text-transform: uppercase;
  letter-spacing: -2px;
  color: var(--navy);
}
.hero-brand .script-line {
  font-family: var(--font-script);
  font-size: clamp(56px, 8vw, 108px);
  font-weight: 400; color: var(--blush-deep);
  text-transform: none; letter-spacing: 0;
  line-height: 0.92; display: block; margin: -4px 0;
}
.hero-sub {
  font-size: 13px; line-height: 1.9; color: var(--muted);
  max-width: 400px; margin: 20px 0 28px; font-weight: 400;
}
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-collage {
  position: relative; z-index: 1;
  min-height: calc(100vh - var(--nav-h));
  overflow: hidden;
}

/* ============ TICKER ============ */
.ticker { background: var(--navy); padding: 11px 0; overflow: hidden; }
.ticker-inner {
  display: flex; gap: 32px; white-space: nowrap;
  animation: ticker 32s linear infinite;
  font-family: var(--font-display); font-size: 13px; font-style: italic; color: var(--blush-light);
}
.ticker-dot { font-style: normal; opacity: 0.35; font-size: 8px; }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============ MISSION ============ */
.mission {
  padding: 96px 64px; background: var(--offwhite);
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  position: relative; overflow: hidden;
}
.mission::before {
  content: 'woman made films';
  position: absolute; left: 32px; bottom: 16px;
  font-family: var(--font-script); font-size: 42px;
  color: rgba(176,120,136,0.07); transform: rotate(-2deg); pointer-events: none;
}
.mission-card {
  background: white; padding: 24px; border-left: 3px solid var(--blush);
  margin-bottom: 12px; position: relative;
  box-shadow: 1px 2px 16px rgba(26,26,46,0.05); transition: transform 0.2s;
}
.mission-card:hover { transform: translateX(4px); }
.mission-card-num { font-family: var(--font-script); font-size: 32px; color: var(--blush-deep); opacity: 0.2; position: absolute; top: 8px; right: 12px; }
.mission-card-title { font-family: var(--font-display); font-size: 13px; font-weight: 700; color: var(--navy); margin-bottom: 5px; }
.mission-card-body { font-size: 11px; line-height: 1.7; color: var(--soft); }

/* ============ ARCHIVE TEASE ============ */
.archive-tease {
  padding: 96px 64px; background: var(--blush-pale);
  position: relative; overflow: hidden;
}
.archive-tease::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(176,120,136,0.09) 1px, transparent 1px),
    linear-gradient(90deg, rgba(176,120,136,0.09) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none; z-index: 0;
}
.archive-tease > * { position: relative; z-index: 1; }
.archive-tease-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  margin-top: 48px;
}
.archive-posters {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.archive-poster-card {
  aspect-ratio: 2/3; position: relative; overflow: hidden;
  box-shadow: 2px 4px 16px rgba(26,26,46,0.12); transition: transform 0.25s;
  cursor: pointer;
}
.archive-poster-card:hover { transform: translateY(-4px); }
.archive-poster-card img { width: 100%; height: 100%; object-fit: cover; transition: filter 0.5s ease; filter: grayscale(100%) brightness(0.88); }
.archive-poster-card::before {
  content: ''; position: absolute; inset: 0;
  background: rgba(176,80,110,0.38); mix-blend-mode: multiply;
  transition: opacity 0.5s ease; pointer-events: none; z-index: 1;
}
.archive-poster-card:hover img { filter: grayscale(0%) brightness(1); }
.archive-poster-card:hover::before { opacity: 0; }
.archive-poster-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(26,26,46,0.9) 0%, transparent 55%);
  padding: 12px; display: flex; flex-direction: column; justify-content: flex-end;
}
.archive-poster-dir { font-size: 7px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--blush-light); margin-bottom: 3px; }
.archive-poster-title { font-family: var(--font-display); font-size: 10px; font-style: italic; color: var(--offwhite); line-height: 1.2; }
.archive-poster-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  padding: 12px;
}
.archive-tease-desc { display: flex; flex-direction: column; gap: 20px; }
.archive-tease-title { font-family: var(--font-display); font-size: clamp(36px, 4.5vw, 58px); font-weight: 900; text-transform: uppercase; color: var(--navy); line-height: 1.0; letter-spacing: -0.5px; }
.archive-tease-title em { font-family: var(--font-script); font-size: clamp(44px, 5.8vw, 70px); font-weight: 400; text-transform: none; color: var(--blush-deep); font-style: normal; display: block; line-height: 1; margin: -4px 0 4px; }

/* ============ ARCHIVE PAGE ============ */
.page-header {
  padding: calc(var(--nav-h) + 80px) 64px 64px;
  background: var(--blush-pale);
  position: relative; overflow: hidden;
}
/* Grid texture like events page */
.page-header::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(176,120,136,0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(176,120,136,0.1) 1px, transparent 1px);
  background-size: 52px 52px;
  pointer-events: none; z-index: 0;
}
.page-header-bg {
  position: absolute; bottom: -16px; right: 20px;
  font-family: var(--font-display); font-size: 120px; font-style: italic; font-weight: 900;
  color: rgba(176,120,136,0.08); user-select: none; line-height: 1; text-transform: uppercase;
}
.page-title { font-family: var(--font-display); font-size: clamp(44px, 6.5vw, 74px); font-weight: 900; color: var(--navy); line-height: 0.96; text-transform: uppercase; position: relative; z-index: 1; letter-spacing: -0.7px; }
.page-title em { font-family: var(--font-script); font-size: clamp(52px, 7.5vw, 86px); font-weight: 400; text-transform: none; color: var(--blush-deep); font-style: normal; }
.page-sub { font-size: 13px; color: var(--muted); margin-top: 12px; max-width: 480px; line-height: 1.75; position: relative; z-index: 1; }

.archive-controls {
  padding: 20px 64px; background: var(--offwhite);
  border-bottom: 1px solid rgba(26,26,46,0.07);
  display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
}
.search-input { flex: 1; min-width: 200px; padding: 11px 14px 11px 38px; border: 1px solid rgba(26,26,46,0.12); font-family: var(--font-body); font-size: 12px; color: var(--navy); background: white; outline: none; transition: border-color 0.2s; }
.search-input:focus { border-color: var(--blush-deep); }
.search-wrap { position: relative; flex: 1; min-width: 200px; }
.search-icon { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); font-size: 14px; color: var(--soft); }
.filter-select { padding: 10px 32px 10px 12px; border: 1px solid rgba(26,26,46,0.12); font-family: var(--font-body); font-size: 11px; color: var(--muted); background: white; outline: none; cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239a8090' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; }
.filter-select:focus { border-color: var(--blush-deep); }
.results-count { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--soft); margin-left: auto; white-space: nowrap; }

.archive-grid-wrap { padding: 48px 64px 96px; background: var(--cream); }
.archive-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 14px; }
.archive-card { cursor: pointer; transition: transform 0.25s; }
.archive-card:hover { transform: translateY(-6px); }
.archive-card-inner { aspect-ratio: 2/3; position: relative; overflow: hidden; box-shadow: 2px 4px 18px rgba(26,26,46,0.12); }
.archive-card-inner img { width: 100%; height: 100%; object-fit: cover; transition: filter 0.5s ease, transform 0.4s ease; filter: grayscale(100%) brightness(0.88); }
/* Blush pink tint overlay — fades out on hover */
.archive-card-inner::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(176,80,110,0.38);
  mix-blend-mode: multiply;
  transition: opacity 0.5s ease;
  pointer-events: none; z-index: 1;
}
.archive-card:hover .archive-card-inner img { filter: grayscale(0%) brightness(1); transform: scale(1.04); }
.archive-card:hover .archive-card-inner::after { opacity: 0; }
.archive-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(26,26,46,0.94) 0%, rgba(26,26,46,0.1) 50%, transparent 100%); padding: 12px; display: flex; flex-direction: column; justify-content: flex-end; }
.archive-card-director { font-size: 8px; letter-spacing: 2px; text-transform: uppercase; color: var(--blush-light); margin-bottom: 3px; }
.archive-card-title { font-family: var(--font-display); font-size: 10px; font-style: italic; color: var(--offwhite); line-height: 1.2; }
.archive-card-stub { background: var(--cream); padding: 4px 0; text-align: center; font-size: 8px; color: var(--soft); letter-spacing: 1px; }
.no-results { grid-column: 1/-1; text-align: center; padding: 80px 0; font-family: var(--font-display); font-size: 24px; font-style: italic; color: var(--soft); }

.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(26,26,46,0.8); z-index: 2000; align-items: center; justify-content: center; padding: 32px; backdrop-filter: blur(6px); }
.modal-overlay.open { display: flex; }
.modal { background: white; max-width: 600px; width: 100%; display: grid; grid-template-columns: 200px 1fr; overflow: hidden; max-height: 88vh; overflow-y: auto; position: relative; }
.modal-poster { background: var(--navy); min-height: 280px; }
.modal-poster img { width: 100%; height: 100%; object-fit: cover; }
.modal-info { padding: 32px 28px; display: flex; flex-direction: column; gap: 14px; }
.modal-director { font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--blush-deep); }
.modal-title { font-family: var(--font-display); font-size: 26px; font-style: italic; font-weight: 900; color: var(--navy); line-height: 1.1; }
.modal-meta { font-size: 11px; color: var(--soft); letter-spacing: 1px; }
.modal-desc { font-size: 12px; line-height: 1.85; color: var(--muted); flex: 1; }
.modal-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.modal-tag { font-size: 8px; letter-spacing: 1px; text-transform: uppercase; padding: 3px 8px; background: var(--blush-pale); color: var(--blush-deep); border: 1px solid var(--blush-light); }
.modal-close { position: absolute; top: 14px; right: 14px; background: var(--navy); color: var(--offwhite); border: none; width: 32px; height: 32px; font-size: 16px; display: flex; align-items: center; justify-content: center; transition: background 0.2s; z-index: 10; }
.modal-close:hover { background: var(--blush-deep); }

/* ============ ABOUT PAGE ============ */
.about-hero {
  padding-top: var(--nav-h); min-height: 560px;
  background: var(--blush-deep); position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
}
.about-dots { position: absolute; inset: 0; opacity: 0.06; background-image: radial-gradient(circle, var(--navy) 1.5px, transparent 1.5px); background-size: 14px 14px; }
.about-left { padding: 80px 56px 80px 64px; display: flex; flex-direction: column; justify-content: flex-end; position: relative; z-index: 2; }
.about-meet { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: rgba(250,246,240,0.55); margin-bottom: 6px; }
.about-founder { font-family: var(--font-display); font-size: clamp(44px, 6vw, 72px); font-weight: 900; color: var(--offwhite); line-height: 0.9; text-transform: uppercase; }
.about-name-script { font-family: var(--font-script); font-size: clamp(44px, 6vw, 68px); color: rgba(250,246,240,0.88); line-height: 1; display: block; margin-top: 6px; }
.about-pill { display: inline-block; border: 1.5px solid rgba(250,246,240,0.4); border-radius: 40px; padding: 6px 20px; font-family: var(--font-script); font-size: 18px; color: rgba(250,246,240,0.72); margin-top: 18px; transform: rotate(-1deg); }
.about-right { position: relative; overflow: hidden; }
.about-right img { width: 100%; height: 100%; object-fit: cover; object-position: top center; filter: grayscale(80%) contrast(1.1); }
.about-right::after { content: ''; position: absolute; inset: 0; background: rgba(176,120,136,0.22); mix-blend-mode: multiply; }
.about-name-tag { position: absolute; bottom: 20px; left: 20px; z-index: 3; background: rgba(250,246,240,0.93); padding: 8px 14px; transform: rotate(-1deg); box-shadow: 1px 2px 10px rgba(0,0,0,0.12); }
.about-name-tag-name { font-family: var(--font-display); font-size: 13px; font-style: italic; color: var(--navy); }
.about-name-tag-role { font-size: 8px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--soft); margin-top: 2px; }

.about-intro { padding: 80px 64px; background: var(--offwhite); }
.about-intro-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.about-page-title { font-family: var(--font-display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 900; color: var(--navy); margin-bottom: 16px; line-height: 1.05; text-transform: uppercase; }
.about-page-title em { font-family: var(--font-script); font-size: clamp(30px, 4vw, 48px); font-weight: 400; text-transform: none; color: var(--blush-deep); font-style: normal; }

.pillars-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--cream-dark); }
.pillar { background: var(--offwhite); padding: 40px 36px; position: relative; }
.pillar::after { content: 'goal'; position: absolute; top: 16px; right: 16px; padding: 3px 8px; border: 1px dashed rgba(176,120,136,0.35); color: var(--blush-deep); font-size: 7px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase; transform: rotate(2deg); }
.pillar-num { font-family: var(--font-script); font-size: 48px; color: var(--blush-deep); opacity: 0.18; line-height: 1; margin-bottom: 10px; }
.pillar-title { font-family: var(--font-display); font-size: 16px; font-weight: 700; color: var(--navy); margin-bottom: 8px; }
.pillar-body { font-size: 12px; line-height: 1.75; color: var(--soft); }

/* ============ HER CUT PAGE ============ */
.hercut-hero { background: var(--cream); min-height: 100vh; position: relative; overflow: hidden; padding-top: var(--nav-h); }
.cal-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(176,120,136,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(176,120,136,0.06) 1px, transparent 1px); background-size: 60px 60px; }
.hercut-inner { position: relative; z-index: 2; padding: 80px 64px; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; min-height: calc(100vh - var(--nav-h)); align-items: center; }
.hercut-pre { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--soft); margin-bottom: 12px; }
.hercut-title { font-family: var(--font-display); font-size: clamp(64px, 9vw, 120px); font-weight: 900; color: var(--navy); line-height: 0.88; text-transform: uppercase; letter-spacing: -2px; }
.hercut-title em { font-family: var(--font-script); font-size: clamp(72px, 10vw, 132px); font-weight: 400; text-transform: none; color: var(--blush-deep); font-style: normal; display: inline; margin-left: 8px; line-height: 0.88; letter-spacing: 0; }
.hercut-soon { font-family: var(--font-script); font-size: 26px; color: var(--blush-deep); display: inline-block; margin: 14px 0 18px; }
.hercut-body { font-size: 13px; line-height: 1.9; color: var(--muted); max-width: 380px; margin-bottom: 24px; }
.hercut-right { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; position: relative; }
.hercut-card { background: var(--navy); padding: 32px 40px; display: flex; flex-direction: column; align-items: center; gap: 8px; transform: rotate(1.5deg); box-shadow: 6px 6px 0 var(--blush-deep); position: relative; border: 1px solid rgba(250,246,240,0.1); }
.hercut-card-title { font-family: var(--font-display); font-size: clamp(32px, 4.5vw, 48px); font-style: italic; font-weight: 900; color: var(--offwhite); line-height: 1; }
.hercut-card-sub { font-size: 8px; letter-spacing: 3px; text-transform: uppercase; color: rgba(250,246,240,0.25); }
.hercut-sticker { position: absolute; top: -12px; right: -12px; background: var(--offwhite); padding: 5px 12px; font-family: var(--font-script); font-size: 16px; color: var(--blush-deep); transform: rotate(4deg); box-shadow: 1px 1px 8px rgba(0,0,0,0.1); }
.wave { display: flex; align-items: center; gap: 3px; height: 20px; margin: 4px 0; }
.wave span { display: block; width: 2.5px; background: var(--blush-light); border-radius: 1.5px; animation: wave 1.2s ease-in-out infinite; }
.wave span:nth-child(1){height:6px;animation-delay:0s}.wave span:nth-child(2){height:13px;animation-delay:.1s}.wave span:nth-child(3){height:18px;animation-delay:.2s}.wave span:nth-child(4){height:10px;animation-delay:.3s}.wave span:nth-child(5){height:20px;animation-delay:.4s}.wave span:nth-child(6){height:13px;animation-delay:.3s}.wave span:nth-child(7){height:17px;animation-delay:.2s}.wave span:nth-child(8){height:7px;animation-delay:.1s}
@keyframes wave { 0%,100%{transform:scaleY(0.5)} 50%{transform:scaleY(1)} }
.hercut-note { font-family: var(--font-script); font-size: 18px; color: var(--soft); }
.hercut-exclaim { font-family: var(--font-display); font-size: 56px; font-weight: 900; color: var(--blush-deep); opacity: 0.3; line-height: 1; font-style: italic; }
.hercut-dark-band { background: var(--navy); padding: 80px 64px; text-align: center; position: relative; overflow: hidden; }
.hercut-dark-band-whisper { position: absolute; top: 20px; left: 48px; font-family: var(--font-script); font-size: 20px; color: rgba(250,246,240,0.06); transform: rotate(-1.5deg); }
.hercut-about-title { font-family: var(--font-display); font-size: clamp(28px, 3.8vw, 44px); font-weight: 900; color: var(--offwhite); line-height: 1.0; text-transform: uppercase; margin-bottom: 12px; }
.hercut-about-title em { font-family: var(--font-script); font-size: clamp(34px, 4.5vw, 52px); font-weight: 400; text-transform: none; color: var(--blush-light); font-style: normal; }

/* ============ EVENTS PAGE ============ */
.events-hero {
  padding-top: var(--nav-h); min-height: 100vh;
  background: var(--blush-pale); position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.events-grid-bg {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(176,120,136,0.09) 1px, transparent 1px), linear-gradient(90deg, rgba(176,120,136,0.09) 1px, transparent 1px);
  background-size: 52px 52px; pointer-events: none;
}
.events-hero-inner { position: relative; z-index: 2; text-align: center; max-width: 720px; padding: 64px 40px; }
.events-title { font-family: var(--font-display); font-size: clamp(48px, 7vw, 96px); font-weight: 900; line-height: 0.9; text-transform: uppercase; letter-spacing: -2px; color: var(--navy); }
.events-title em { font-family: var(--font-script); font-size: clamp(56px, 8vw, 108px); font-weight: 400; text-transform: none; color: var(--blush-deep); font-style: normal; display: block; line-height: 0.92; margin: -4px 0; }
.events-sub { font-size: 13px; line-height: 1.9; color: var(--muted); max-width: 480px; margin: 20px auto 32px; }
.events-types { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 40px 0 48px; text-align: left; }
.event-type-card { background: white; padding: 28px 24px; border-top: 3px solid var(--blush); position: relative; box-shadow: 1px 2px 16px rgba(26,26,46,0.06); }
.event-type-card::after { content: 'coming soon'; position: absolute; top: 14px; right: 14px; font-size: 7px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--blush-deep); border: 1px dashed var(--blush); padding: 2px 7px; }
.event-type-icon { font-size: 28px; margin-bottom: 12px; line-height: 1; }
.event-type-title { font-family: var(--font-display); font-size: 16px; font-weight: 700; color: var(--navy); margin-bottom: 8px; }
.event-type-body { font-size: 11px; line-height: 1.7; color: var(--soft); }

/* ============ NEWSLETTER ============ */
.newsletter-section { background: var(--navy); padding: 96px 64px; text-align: center; position: relative; overflow: hidden; }
.nl-bg-script { position: absolute; bottom: -30px; right: -20px; font-family: var(--font-script); font-size: 120px; color: rgba(250,246,240,0.03); user-select: none; line-height: 1; }
.nl-title { font-family: var(--font-display); font-size: clamp(32px, 4.5vw, 54px); font-weight: 900; color: var(--offwhite); line-height: 0.95; text-transform: uppercase; margin-bottom: 12px; letter-spacing: -0.5px; }
.nl-title em { font-family: var(--font-script); font-size: clamp(42px, 5.8vw, 66px); font-weight: 400; text-transform: none; color: var(--blush-light); font-style: normal; display: block; line-height: 0.95; }
.nl-body { font-size: 13px; color: rgba(250,246,240,0.5); margin-bottom: 32px; max-width: 440px; margin-left: auto; margin-right: auto; line-height: 1.9; }
.nl-form { display: flex; max-width: 420px; margin: 0 auto 14px; }
.nl-input { flex: 1; padding: 13px 16px; background: rgba(250,246,240,0.07); border: 1px solid rgba(250,246,240,0.14); border-right: none; font-family: var(--font-body); font-size: 13px; color: var(--offwhite); outline: none; transition: border-color 0.2s; }
.nl-input::placeholder { color: rgba(250,246,240,0.3); }
.nl-input:focus { border-color: var(--blush-light); }
.nl-note { font-family: var(--font-script); font-size: 18px; color: rgba(250,246,240,0.28); }
.form-status { margin: 10px auto 0; max-width: 420px; font-size: 10px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase; color: var(--blush-light); }
.form-status.error { color: #ffd3d3; }

/* ============ NEWSLETTER PAGE ============ */
.nl-page-hero { background: var(--navy); min-height: 100vh; padding-top: var(--nav-h); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.nl-page-dots { position: absolute; inset: 0; opacity: 0.04; background-image: radial-gradient(circle, var(--offwhite) 1.5px, transparent 1.5px); background-size: 16px 16px; }
.nl-page-inner { position: relative; z-index: 2; text-align: center; max-width: 560px; padding: 64px 32px; }

/* ============ FOOTER ============ */
footer { background: var(--cream-dark); padding: 56px 64px 28px; border-top: 1px solid rgba(26,26,46,0.08); }
.footer-top { display: flex; justify-content: space-between; padding-bottom: 32px; border-bottom: 1px solid rgba(26,26,46,0.07); flex-wrap: wrap; gap: 32px; }
.footer-logo { font-family: var(--font-display); font-size: 16px; font-style: italic; font-weight: 900; color: var(--navy); margin-bottom: 6px; }
.footer-tagline { font-family: var(--font-script); font-size: 16px; color: var(--soft); margin-bottom: 16px; }
.footer-socials { display: flex; gap: 16px; }
.footer-socials a { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--soft); border-bottom: 1px solid rgba(154,128,144,0.3); padding-bottom: 2px; transition: color 0.2s; }
.footer-socials a:hover { color: var(--blush-deep); }
.footer-nav { display: flex; gap: 56px; }
.footer-col { display: flex; flex-direction: column; gap: 10px; }
.footer-col-title { font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--blush-deep); margin-bottom: 4px; font-weight: 600; }
.footer-col a { font-size: 12px; color: var(--muted); transition: color 0.2s; }
.footer-col a:hover { color: var(--blush-deep); }
.footer-bottom { padding-top: 20px; display: flex; justify-content: space-between; font-size: 10px; color: var(--soft); letter-spacing: 1px; flex-wrap: wrap; gap: 8px; }

/* ============ ANIMATIONS ============ */
@keyframes fadeUp { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: translateY(0); } }
.anim-1 { animation: fadeUp 0.8s 0.1s both; }
.anim-2 { animation: fadeUp 0.8s 0.3s both; }
.anim-3 { animation: fadeUp 0.8s 0.5s both; }
.anim-4 { animation: fadeUp 0.8s 0.7s both; }
.anim-5 { animation: fadeUp 0.8s 0.9s both; }

/* ============ TABLET (961px–1200px) ============ */
@media (min-width: 961px) and (max-width: 1200px) {
  #nav { padding: 0 32px; }
  .nav-links { gap: 18px; }
  .hero-left { padding: 72px 28px 72px 48px; }
  .hero-brand { font-size: clamp(44px, 6.5vw, 80px); }
  .hero-brand .script-line { font-size: clamp(48px, 7vw, 88px); }
  .mission { padding: 72px 48px; gap: 48px; }
  .archive-tease { padding: 72px 48px; }
  .archive-tease-grid { gap: 40px; }
  .page-header { padding: calc(var(--nav-h) + 60px) 48px 52px; }
  .archive-controls { padding: 18px 48px; }
  .archive-grid-wrap { padding: 36px 48px 72px; }
  .archive-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 12px; }
  .about-left { padding: 72px 40px 72px 48px; }
  .about-intro { padding: 72px 48px; }
  .hercut-inner { padding: 72px 48px; }
  .hercut-dark-band { padding: 72px 48px; }
  .events-hero-inner { max-width: 640px; padding: 72px 32px; }
  .events-types { gap: 12px; }
  .newsletter-section { padding: 72px 48px; }
  footer { padding: 48px 48px 24px; }
  .footer-nav { gap: 40px; }
  .polaroid { transform: scale(0.9) !important; }
}

/* ============ MOBILE (≤960px) ============ */
@media (max-width: 960px) {
  :root { --nav-h: 48px; }
  #nav { padding: 0 20px; }
  .nav-links { display: none; }
  .nav-toggle { display: block; }
  .mobile-menu { padding: 16px 20px; }

  /* HERO — stack, hide collage entirely on mobile */
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-left { padding: 56px 24px 56px; }
  .hero-brand { font-size: clamp(44px, 12vw, 68px); }
  .hero-brand .script-line { font-size: clamp(48px, 13vw, 76px); }
  .hero-sub { max-width: 100%; }
  /* Hide the entire polaroid collage on mobile */
  .hero-collage { display: none; }

  /* TICKER */
  .ticker-inner { font-size: 11px; gap: 20px; }

  /* MISSION */
  .mission { grid-template-columns: 1fr; padding: 52px 24px; gap: 28px; }
  .mission::before { display: none; }

  /* ARCHIVE TEASE */
  .archive-tease { padding: 52px 24px; }
  .archive-tease-grid { grid-template-columns: 1fr; gap: 28px; }

  /* ARCHIVE PAGE */
  .page-header { padding: calc(var(--nav-h) + 36px) 24px 36px; }
  .page-title { font-size: clamp(36px, 10vw, 52px); }
  /* Hide collage accents on archive header mobile */
  .page-header .sticker,
  .page-header .collage-label,
  .page-header .scrap-note,
  .page-header .film-strip { display: none; }
  .archive-controls { padding: 14px 20px; flex-wrap: wrap; gap: 8px; }
  .search-wrap { min-width: 100%; }
  .filter-select { flex: 1; min-width: 100px; }
  .archive-grid-wrap { padding: 20px 20px 52px; }
  .archive-grid { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 10px; }

  /* MODAL */
  .modal { grid-template-columns: 1fr; max-width: calc(100vw - 32px); }
  .modal-poster { aspect-ratio: 16/9; min-height: auto; }
  .modal-info { padding: 20px; }
  .modal-title { font-size: 20px; }

  /* ABOUT */
  .about-hero { grid-template-columns: 1fr; min-height: auto; }
  .about-left { padding: 52px 24px 28px; }
  .about-right { min-height: 320px; }
  .about-intro { padding: 44px 24px; }
  .about-intro-inner { grid-template-columns: 1fr; gap: 20px; }
  .pillars-grid { grid-template-columns: 1fr; }
  .pillar { padding: 28px 24px; }

  /* HER CUT */
  .hercut-hero { min-height: auto; }
  .hercut-inner { grid-template-columns: 1fr; padding: 52px 24px; gap: 28px; min-height: auto; }
  .hercut-title { font-size: clamp(52px, 14vw, 80px); }
  .hercut-dark-band { padding: 52px 24px; }
  .hercut-about-title { font-size: clamp(24px, 6vw, 36px); }
  .hercut-right { align-items: flex-start; }
  .hercut-card { transform: none; box-shadow: 4px 4px 0 var(--blush-deep); }
  /* Hide collage clutter on Her Cut mobile */
  .hercut-hero .sticker,
  .hercut-hero .collage-label,
  .hercut-hero .scrap-note,
  .hercut-hero .film-strip { display: none; }

  /* EVENTS */
  .events-hero { min-height: auto; padding-bottom: 52px; }
  .events-hero-inner { padding: 52px 24px 28px; }
  .events-title { font-size: clamp(44px, 12vw, 68px); }
  .events-types { grid-template-columns: 1fr; gap: 10px; margin: 20px 0 28px; }
  .event-type-card { padding: 22px 20px; }
  /* Keep some events accents but simplify */
  .events-hero .film-strip { display: none; }
  .events-hero .scrap-note,
  .events-hero .collage-label { display: none; }

  /* NEWSLETTER */
  .newsletter-section { padding: 52px 24px; }
  .nl-title { font-size: clamp(28px, 8vw, 44px); }
  .nl-title em { font-size: clamp(34px, 10vw, 52px); }
  .nl-form { flex-direction: column; }
  .nl-input { border-right: 1px solid rgba(250,246,240,0.14); border-bottom: none; }
  .nl-page-hero { min-height: 100vh; }

  /* FOOTER */
  footer { padding: 40px 24px 20px; }
  .footer-top { flex-direction: column; gap: 24px; padding-bottom: 24px; }
  .footer-nav { gap: 24px; flex-wrap: wrap; }
  .footer-bottom { flex-direction: column; gap: 4px; font-size: 9px; }
}

/* ============ SMALL MOBILE (≤480px) ============ */
@media (max-width: 480px) {
  .hero-left { padding: 44px 20px 48px; }
  .hero-brand { font-size: clamp(40px, 11vw, 60px); }
  .hero-brand .script-line { font-size: clamp(44px, 12vw, 68px); }
  .hero-sub { font-size: 12px; }
  .mission { padding: 40px 20px; }
  .mission-card { padding: 18px; }
  .archive-tease { padding: 40px 20px; }
  .archive-grid { grid-template-columns: repeat(3,1fr); gap: 8px; }
  .about-intro { padding: 36px 20px; }
  .hercut-inner { padding: 40px 20px; }
  .hercut-dark-band { padding: 40px 20px; }
  .events-hero-inner { padding: 44px 20px 24px; }
  .event-type-card { padding: 18px 16px; }
  .newsletter-section { padding: 44px 20px; }
  footer { padding: 32px 20px 16px; }
  .page-header { padding: calc(var(--nav-h) + 28px) 20px 28px; }
  .archive-controls { padding: 12px 20px; }
  .archive-grid-wrap { padding: 16px 20px 44px; }
  .nl-form { gap: 0; }
  .about-left { padding: 44px 20px 24px; }
  .about-right { min-height: 280px; }
  .pillar { padding: 24px 20px; }
}
