:root {
  --bg: #0a0a0e;
  --bg-2: #101015;
  --bg-3: #17171f;
  --ink: #f5efe0;
  --ink-soft: #c8c2b4;
  --muted: #8a8578;
  --subtle: #5e5a4e;
  --gold: #d4b36a;
  --gold-bright: #e8cc84;
  --gold-dim: #8a7032;
  --border: #2a2732;
  --border-soft: #1f1d27;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: "Inter", system-ui, -apple-system, Segoe UI, sans-serif; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.serif { font-family: "Cormorant Garamond", Georgia, serif; }
.cinzel { font-family: "Cinzel", "Cormorant Garamond", Georgia, serif; }
.container { max-width: 1280px; margin: 0 auto; padding: 0 28px; }
.eyebrow { font-size: 11px; text-transform: uppercase; letter-spacing: 3px; color: var(--gold); font-weight: 600; }
.gold { color: var(--gold); }

/* ================= MAIN NAV (transparent, overlays hero) ================= */
.nav { position: absolute; top: 0; left: 0; right: 0; z-index: 50; background: transparent; transition: background .3s ease, backdrop-filter .3s ease, border-color .3s ease; border-bottom: 1px solid transparent; }
.nav.scrolled { position: fixed; background: rgba(10,10,14,.92); backdrop-filter: blur(14px); border-bottom-color: var(--border-soft); }
.nav-row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; height: 90px; gap: 24px; }
.brand-logo { display: flex; align-items: center; gap: 12px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 26px; font-weight: 500; color: #fff; font-style: italic; }
.brand-logo .crest-small { width: 44px; height: 44px; flex-shrink: 0; }
.brand-logo span.first, .brand-logo span.last { color: #fff; }
.nav ul { display: flex; gap: 30px; list-style: none; padding: 0; margin: 0; justify-content: center; }
.nav a.navlink { font-family: "Inter", sans-serif; font-size: 13px; color: #fff; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; position: relative; padding: 6px 0; }
.nav a.navlink:hover { color: var(--gold); }
.nav a.navlink.active { color: #fff; }
.nav a.navlink.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: #fff; }

/* legacy .nav-socials styles kept for old pages — main nav uses .nav-cta now */
.nav-socials { display: flex; gap: 8px; justify-self: end; }
.nav-socials a { width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; background: var(--gold); color: #0a0a0e; border-radius: 6px; transition: all .2s; }
.nav-socials a:hover { background: var(--gold-bright); transform: translateY(-2px); }
.nav-socials svg { width: 16px; height: 16px; }
@media (max-width: 980px) { .nav-cta { display: none; } }

.nav-menu-btn { display: none; background: none; border: 0; color: #fff; font-size: 26px; cursor: pointer; justify-self: end; }
@media (max-width: 1100px) {
  .nav ul { gap: 20px; }
  .nav a.navlink { font-size: 12px; letter-spacing: 1.5px; }
}
@media (max-width: 980px) {
  .nav-row { grid-template-columns: auto 1fr auto; }
  .nav ul { display: none; }
  .nav-menu-btn { display: block; }
  .nav-socials { display: none; }
  .nav ul.open { display: flex; position: absolute; top: 90px; left: 0; right: 0; background: var(--bg-2); flex-direction: column; padding: 18px 28px; gap: 18px; border-bottom: 1px solid var(--border); }
}

/* ================= HERO (home — full-bleed) ================= */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 80px 24px; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg img, .hero-bg video { width: 100%; height: 100%; object-fit: cover; object-position: center 25%; }
.hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,14,.55) 0%, rgba(10,10,14,.4) 30%, rgba(10,10,14,.65) 70%, rgba(10,10,14,.85) 100%); }
.hero-bg img { animation: slowpan 30s ease-in-out infinite; }
@keyframes slowpan { 0%,100% { transform: scale(1.04) translate(0,0); } 50% { transform: scale(1.08) translate(-.5%, -.3%); } }
.hero-content { position: relative; z-index: 2; text-align: center; width: 100%; max-width: 1100px; padding-top: 60px; }
.hero-name { font-family: "Oswald", "Bebas Neue", Impact, sans-serif; font-size: clamp(48px, 9vw, 110px); font-weight: 600; letter-spacing: clamp(2px, 0.5vw, 6px); color: #f5efe0; text-transform: uppercase; margin: 0; line-height: 1; text-shadow: 0 2px 10px rgba(0,0,0,.4); opacity: 0; animation: fadeDown 1.6s .3s ease-out forwards; }
.hero-rule { display: inline-block; position: relative; height: 8px; width: clamp(280px, 55%, 640px); margin: 26px auto; opacity: 0; animation: widen 1.6s .7s ease-out forwards; }
.hero-rule::before { content: ""; position: absolute; left: 0; right: 0; top: 50%; transform: translateY(-50%); height: 5px; background: var(--gold); border-radius: 1px; }
.hero-rule::after { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 8px; border-left: 5px solid var(--gold); border-right: 5px solid var(--gold); border-radius: 1px; }
@keyframes widen { from { width: 0; opacity: 0; } to { width: clamp(280px, 55%, 640px); opacity: 1; } }
.hero-tagline { font-family: "Cormorant Garamond", serif; font-size: clamp(17px, 2.2vw, 24px); font-weight: 400; font-style: italic; color: rgba(245,239,224,.85); max-width: 900px; margin: 0 auto; line-height: 1.55; text-shadow: 0 1px 6px rgba(0,0,0,.3); opacity: 0; animation: fadeDown 1.6s 1s ease-out forwards; }
.hero-tagline .dot { color: var(--gold); padding: 0 8px; font-weight: 700; }
@keyframes fadeDown { from { opacity: 0; transform: translateY(-16px); } to { opacity: 1; transform: translateY(0); } }

/* ================= PAGE HERO (inner pages — compact banner) ================= */
.page-hero { position: relative; min-height: 46vh; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 160px 24px 70px; }
.page-hero-bg { position: absolute; inset: 0; z-index: 0; }
.page-hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.page-hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,14,.65) 0%, rgba(10,10,14,.55) 50%, rgba(10,10,14,.85) 100%); }
.page-hero-content { position: relative; z-index: 2; text-align: center; width: 100%; max-width: 1100px; }
.page-hero h1 { font-family: "Oswald", "Bebas Neue", Impact, sans-serif; font-size: clamp(38px, 7vw, 72px); font-weight: 700; letter-spacing: clamp(2px, 0.4vw, 5px); color: #fff; text-transform: uppercase; margin: 0; line-height: 1; text-shadow: 0 4px 30px rgba(0,0,0,.55); }
.page-hero .page-rule { display: inline-block; position: relative; height: 8px; width: clamp(180px, 35%, 360px); margin: 20px auto 18px; }
.page-hero .page-rule::before { content: ""; position: absolute; left: 0; right: 0; top: 50%; transform: translateY(-50%); height: 5px; background: var(--gold); border-radius: 1px; }
.page-hero .page-rule::after { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 8px; border-left: 5px solid var(--gold); border-right: 5px solid var(--gold); border-radius: 1px; }
.breadcrumb { font-family: "Inter", sans-serif; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink-soft); font-weight: 500; }
.breadcrumb a { color: var(--gold); }
.breadcrumb a:hover { color: var(--gold-bright); }
.breadcrumb .sep { color: var(--muted); padding: 0 10px; }

/* ================= BUTTONS ================= */
.btn { display: inline-flex; align-items: center; gap: 10px; height: 48px; padding: 0 26px; border-radius: 2px; font-family: "Cinzel", serif; font-weight: 600; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; border: 1px solid transparent; cursor: pointer; transition: all .25s; text-decoration: none; }
.btn-gold { background: var(--gold); color: #0a0a0e; border-color: var(--gold); }
.btn-gold:hover { background: var(--gold-bright); border-color: var(--gold-bright); transform: translateY(-1px); box-shadow: 0 12px 30px -10px rgba(212, 179, 106, .4); }
.btn-outline { background: transparent; color: #fff; border-color: var(--gold); }
.btn-outline:hover { background: var(--gold); color: #0a0a0e; }

/* ================= SECTIONS ================= */
.section { padding: 100px 0; position: relative; border-bottom: 1px solid var(--border-soft); }
.section.alt { background: var(--bg-2); }
.section.cinema { background-image: linear-gradient(rgba(10,10,14,.93), rgba(10,10,14,.97)), url("https://images.unsplash.com/photo-1478720568477-b0829be4aebf?q=80&w=2000&auto=format&fit=crop"); background-size: cover; background-position: center; background-attachment: fixed; }
.section-head { text-align: center; margin-bottom: 56px; }
.section-head .eyebrow-big { display: block; font-family: "Cinzel", serif; font-size: 12px; letter-spacing: 4px; color: var(--gold); text-transform: uppercase; margin-bottom: 14px; }
.section-head h2 { font-family: "Cormorant Garamond", serif; font-size: clamp(32px, 5vw, 54px); font-weight: 500; margin: 0 0 16px; letter-spacing: 0.5px; line-height: 1.1; }
.section-head .flourish-rule { display: flex; align-items: center; justify-content: center; gap: 14px; margin: 8px auto 0; }
.section-head .flourish-rule::before, .section-head .flourish-rule::after { content: ""; display: block; width: 60px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold)); }
.section-head .flourish-rule::after { background: linear-gradient(90deg, var(--gold), transparent); }
.section-head .flourish-rule .diamond { color: var(--gold); font-size: 10px; }
.section-head p.lead { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 18px; color: var(--ink-soft); max-width: 560px; margin: 14px auto 0; line-height: 1.55; }

/* ================= PORTFOLIO ================= */
.portfolio-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; }
@media (max-width: 900px) { .portfolio-grid { grid-template-columns: repeat(2, 1fr); } }
.portfolio-tile { position: relative; aspect-ratio: 3/4; overflow: hidden; border-radius: 3px; cursor: pointer; background: var(--bg-3); }
.portfolio-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.3,1); }
.portfolio-tile:hover img { transform: scale(1.06); }
.portfolio-tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 60%, rgba(10,10,14,.7)); opacity: 0; transition: opacity .3s; }
.portfolio-tile:hover::after { opacity: 1; }
.portfolio-tile .label { position: absolute; left: 12px; bottom: 12px; font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; opacity: 0; transform: translateY(6px); transition: all .3s; z-index: 1; }
.portfolio-tile:hover .label { opacity: 1; transform: translateY(0); }

/* ================= MOVIES / REEL ================= */
.reel-wrap { max-width: 1100px; margin: 0 auto; }
.reel-frame { position: relative; aspect-ratio: 16/9; border-radius: 4px; overflow: hidden; background: #000; box-shadow: 0 30px 80px -20px rgba(0,0,0,.7), 0 0 0 1px var(--border); }
.reel-frame iframe, .reel-frame video { width: 100%; height: 100%; border: 0; display: block; }
.reel-caption { text-align: center; margin-top: 24px; color: var(--ink-soft); font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 16px; }
.project-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 56px; }
@media (max-width: 900px) { .project-grid { grid-template-columns: 1fr; } }
.project-card { position: relative; aspect-ratio: 16/10; border-radius: 4px; overflow: hidden; background: var(--bg-3); cursor: pointer; }
.project-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.2,.7,.3,1); }
.project-card:hover img { transform: scale(1.08); }
.project-card .project-info { position: absolute; left: 0; right: 0; bottom: 0; padding: 20px; background: linear-gradient(180deg, transparent, rgba(10,10,14,.95)); z-index: 1; }
.project-card .project-info h4 { font-family: "Cormorant Garamond", serif; font-size: 22px; font-weight: 600; margin: 0 0 2px; color: #fff; }
.project-card .project-info .meta { font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; }

/* ================= BIO ================= */
.bio-wrap { max-width: 900px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
@media (max-width: 800px) { .bio-wrap { grid-template-columns: 1fr; gap: 28px; } }
.bio-col h3 { font-family: "Cinzel", serif; font-size: 12px; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; margin: 0 0 18px; font-weight: 600; }
.bio-col p { font-family: "Cormorant Garamond", serif; font-size: 17px; line-height: 1.7; color: var(--ink-soft); margin: 0 0 14px; }

/* ================= RESUME ================= */
.resume-wrap { max-width: 900px; margin: 0 auto; }
.resume-tabs { display: flex; justify-content: center; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 28px; flex-wrap: wrap; }
.tab-btn { padding: 16px 28px; font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; font-weight: 600; color: var(--muted); background: transparent; border: 0; border-bottom: 2px solid transparent; cursor: pointer; transition: all .2s; }
.tab-btn:hover { color: var(--ink); }
.tab-btn.active { color: var(--gold); border-bottom-color: var(--gold); }
.resume-panel { display: none; }
.resume-panel.active { display: block; animation: fadeIn .35s ease-out; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.resume-table { width: 100%; border-collapse: collapse; }
.resume-table td { padding: 18px 12px; border-bottom: 1px solid var(--border-soft); font-size: 14px; color: var(--ink-soft); }
.resume-table td:first-child { font-family: "Cormorant Garamond", serif; font-size: 18px; color: var(--ink); font-weight: 500; font-style: italic; }
.resume-table td:last-child { color: var(--gold); font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 2px; text-align: right; }
.view-pdf { display: inline-flex; align-items: center; gap: 8px; margin-top: 24px; color: var(--gold); font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 600; }
.view-pdf:hover { color: var(--gold-bright); }

/* ================= PRESS / QUOTES ================= */
.quotes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 1000px; margin: 0 auto; }
@media (max-width: 900px) { .quotes-grid { grid-template-columns: 1fr; } }
.quote-box { text-align: center; padding: 32px 20px; border: 1px solid var(--border); background: rgba(255,255,255,.02); border-radius: 3px; }
.quote-box .mark { color: var(--gold); font-family: "Cormorant Garamond", serif; font-size: 64px; line-height: 0; display: inline-block; margin-bottom: 14px; }
.quote-box .q { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 18px; line-height: 1.55; color: var(--ink); margin-bottom: 16px; }
.quote-box .src { font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; }
.awards-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; max-width: 1000px; margin: 56px auto 0; }
@media (max-width: 900px) { .awards-row { grid-template-columns: 1fr; } }
.award { text-align: center; padding: 28px 16px; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.award .laurel { width: 60px; height: 60px; margin: 0 auto 10px; color: var(--gold); }
.award .title { font-family: "Cormorant Garamond", serif; font-size: 20px; font-weight: 600; color: var(--ink); margin: 6px 0 4px; }
.award .sub { font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; }
.award .year { color: var(--muted); font-size: 12px; margin-top: 4px; }

/* ================= MUSIC ================= */
.music-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; max-width: 1000px; margin: 0 auto; }
@media (max-width: 820px) { .music-grid { grid-template-columns: 1fr; } }
.music-embed { background: var(--bg-3); border: 1px solid var(--border); border-radius: 4px; overflow: hidden; }
.music-embed .label { padding: 14px 20px; font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; font-weight: 600; border-bottom: 1px solid var(--border-soft); }
.music-embed iframe { width: 100%; border: 0; display: block; background: #000; }

/* ================= BTS ================= */
.bts-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; max-width: 1100px; margin: 0 auto; }
@media (max-width: 900px) { .bts-grid { grid-template-columns: repeat(3, 1fr); } }
.bts-tile { aspect-ratio: 1; overflow: hidden; background: var(--bg-3); cursor: pointer; }
.bts-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.bts-tile:hover img { transform: scale(1.08); }

/* ================= CONTACT ================= */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 28px; max-width: 1100px; margin: 0 auto; }
@media (max-width: 960px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-card { border: 1px solid var(--border); padding: 36px 28px; background: rgba(255,255,255,.015); }
.contact-card .icon { width: 44px; height: 44px; border: 1px solid var(--gold); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; color: var(--gold); margin-bottom: 18px; }
.contact-card h4 { font-family: "Cinzel", serif; font-size: 12px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); font-weight: 600; margin: 0 0 14px; }
.contact-card p, .contact-card .row { font-family: "Cormorant Garamond", serif; font-size: 17px; color: var(--ink-soft); margin: 0 0 8px; line-height: 1.5; }
.contact-card .row { display: flex; align-items: center; gap: 10px; font-size: 15px; }
.contact-card .row .ci { color: var(--gold); }
.contact-card strong { color: var(--ink); font-weight: 600; }
.contact-cta { background-image: linear-gradient(135deg, rgba(10,10,14,.55), rgba(10,10,14,.88)), url("https://images.unsplash.com/photo-1519456264917-42d0aa2e0625?q=80&w=1400&auto=format&fit=crop"); background-size: cover; background-position: center; display: flex; flex-direction: column; justify-content: center; padding: 40px 32px; min-height: 240px; }
.contact-cta h3 { font-family: "Cormorant Garamond", serif; font-size: 26px; font-weight: 500; line-height: 1.25; margin: 0 0 22px; color: #fff; }

/* ================= FOOTER ================= */
.footer { background: #000; padding: 60px 0 28px; border-top: 1px solid var(--border-soft); }
.footer-inner { text-align: center; }
.footer-crest { width: 56px; height: 56px; margin: 0 auto 18px; color: var(--gold); }
.footer-name { font-family: "Cinzel", serif; font-size: 22px; letter-spacing: 6px; color: var(--ink); margin: 0 0 8px; }
.footer-tag { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 14px; color: var(--muted); margin: 0 0 28px; }
.footer-socials { display: flex; gap: 14px; justify-content: center; margin-bottom: 28px; }
.footer-socials a { width: 38px; height: 38px; border: 1px solid var(--border); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; color: var(--ink-soft); transition: all .2s; }
.footer-socials a:hover { border-color: var(--gold); color: var(--gold); }
.footer-socials svg { width: 16px; height: 16px; }
.footer-bottom { font-size: 11px; color: var(--subtle); font-family: "Cinzel", serif; letter-spacing: 2px; text-transform: uppercase; padding-top: 20px; border-top: 1px solid var(--border-soft); }

/* ================= SCROLL REVEAL ================= */
[data-reveal] { opacity: 0; transform: translateY(30px); transition: opacity 1s cubic-bezier(.22,.61,.36,1), transform 1s cubic-bezier(.22,.61,.36,1); will-change: opacity, transform; }
[data-reveal].revealed { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  .hero-bg img, .hero-name, .hero-rule, .hero-tagline { animation: none; opacity: 1; transform: none; }
}

/* ================= LIGHTBOX ================= */
.lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.97); backdrop-filter: blur(20px); z-index: 100; display: none; align-items: center; justify-content: center; padding: 4vw; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 100%; max-height: 100%; object-fit: contain; animation: lb-in .35s ease-out; }
@keyframes lb-in { from { opacity: 0; transform: scale(.95); } to { opacity: 1; transform: scale(1); } }
.lightbox .lb-btn { position: absolute; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); color: #fff; width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 22px; cursor: pointer; transition: all .2s; }
.lightbox .lb-btn:hover { background: var(--gold); color: #0a0a0e; border-color: var(--gold); }
.lightbox .lb-close { top: 24px; right: 24px; }
.lightbox .lb-prev { left: 24px; top: 50%; transform: translateY(-50%); }
.lightbox .lb-next { right: 24px; top: 50%; transform: translateY(-50%); }
.lightbox .lb-counter { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); color: var(--ink-soft); font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 3px; }
[data-lightbox] { cursor: zoom-in; }

/* ================= EPK SECTIONS ================= */
.section { padding: 100px 0; position: relative; }
.section-dark { background: var(--bg-2); }
.section-darker { background: var(--bg); }
.section-head { margin-bottom: 60px; }
.section-head.center { text-align: center; }
.section-head .eyebrow { display: inline-block; margin-bottom: 14px; }
.section-title { font-family: "Cormorant Garamond", serif; font-size: clamp(32px, 5vw, 52px); font-weight: 600; color: var(--ink); margin: 0; line-height: 1.15; letter-spacing: -.5px; }
.section-sub { color: var(--ink-soft); font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 18px; margin: 14px auto 0; max-width: 640px; }
.container.narrow { max-width: 880px; }

.hero-eyebrow { font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 6px; color: rgba(212,179,106,.85); text-transform: uppercase; margin-bottom: 28px; opacity: 0; animation: fadeDown 1.6s .1s ease-out forwards; text-shadow: 0 1px 4px rgba(0,0,0,.4); }
.hero-cta-row { display: flex; gap: 14px; justify-content: center; margin-top: 36px; flex-wrap: wrap; opacity: 0; animation: fadeDown 1.6s 1.3s ease-out forwards; }
.btn-gold, .btn-ghost { display: inline-flex; align-items: center; gap: 8px; padding: 14px 28px; border-radius: 4px; font-family: "Cinzel", serif; font-size: 12px; letter-spacing: 3px; text-transform: uppercase; font-weight: 600; transition: all .25s; cursor: pointer; }
.btn-gold { background: var(--gold); color: #0a0a0e; border: 1px solid var(--gold); }
.btn-gold:hover { background: var(--gold-bright); border-color: var(--gold-bright); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(212,179,106,.3); }
.btn-ghost { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,.4); backdrop-filter: blur(8px); }
.btn-ghost:hover { background: rgba(255,255,255,.08); border-color: #fff; }

.nav-cta { justify-self: end; display: inline-flex; align-items: center; padding: 10px 22px; background: transparent; color: var(--gold) !important; border: 1px solid var(--gold); border-radius: 4px; font-family: "Cinzel", serif; font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; transition: all .2s; }
.nav-cta:hover { background: var(--gold); color: #0a0a0e !important; transform: translateY(-1px); }

.bio { font-family: "Cormorant Garamond", serif; font-size: 21px; line-height: 1.75; color: var(--ink-soft); }
.bio p { margin: 0 0 24px; }

.reel-frame { aspect-ratio: 16/9; max-width: 1100px; margin: 0 auto; border-radius: 8px; overflow: hidden; border: 1px solid var(--border); background: #000; position: relative; box-shadow: 0 30px 80px rgba(0,0,0,.6); }
.reel-frame iframe { width: 100%; height: 100%; border: 0; }
.reel-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; background: linear-gradient(135deg, #1a1820 0%, #0a0a0e 100%); }
.reel-placeholder svg { opacity: .85; }
.reel-placeholder-text { text-align: center; }
.reel-placeholder-text strong { display: block; font-family: "Cormorant Garamond", serif; font-size: 22px; color: var(--ink); margin-bottom: 6px; }
.reel-placeholder-text span { font-size: 13px; color: var(--muted); }
.reel-placeholder code { background: rgba(212,179,106,.15); color: var(--gold); padding: 2px 6px; border-radius: 3px; font-size: 12px; }

.work-cat { font-family: "Cinzel", serif; font-size: 16px; letter-spacing: 4px; color: var(--gold); text-transform: uppercase; margin: 50px 0 24px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.work-cat:first-child { margin-top: 0; }
.work-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }
.work-card { background: var(--bg-3); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; transition: all .3s; }
.work-card:hover { transform: translateY(-4px); border-color: var(--gold-dim); box-shadow: 0 20px 50px rgba(0,0,0,.4); }
.work-img { aspect-ratio: 16/10; background-size: cover; background-position: center; background-color: #1a1a20; }
.work-body { padding: 18px 20px 22px; }
.work-year { font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
.work-card h4 { font-family: "Cormorant Garamond", serif; font-size: 22px; font-weight: 600; color: var(--ink); margin: 0 0 6px; line-height: 1.2; }
.work-card p { font-size: 13px; color: var(--muted); margin: 0; line-height: 1.5; }

.press-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 24px; max-width: 1100px; margin: 0 auto; }
.press-quote { margin: 0; padding: 30px 32px; background: var(--bg-3); border-left: 3px solid var(--gold); border-radius: 4px; position: relative; }
.press-quote p { font-family: "Cormorant Garamond", serif; font-size: 19px; line-height: 1.55; color: var(--ink); margin: 0 0 16px; font-style: italic; }
.press-quote cite { font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; font-style: normal; }
.press-quote cite em { font-style: italic; text-transform: none; letter-spacing: normal; font-family: "Cormorant Garamond", serif; color: var(--ink-soft); }

.music-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; max-width: 980px; margin: 0 auto 50px; }
.music-card { display: flex; align-items: center; gap: 14px; padding: 18px 20px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 8px; transition: all .25s; }
.music-card:hover { border-color: var(--gold); transform: translateY(-2px); }
.music-card svg { width: 32px; height: 32px; flex-shrink: 0; }
.music-card-label { font-family: "Cormorant Garamond", serif; font-size: 18px; font-weight: 600; color: var(--ink); }
.music-card-cta { font-size: 12px; color: var(--gold); margin-top: 2px; }
.spotify-embed, .embed-placeholder { max-width: 880px; margin: 0 auto; min-height: 200px; border-radius: 12px; }
.embed-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px; background: var(--bg-3); border: 1px dashed var(--border); text-align: center; gap: 6px; }
.embed-placeholder strong { font-family: "Cormorant Garamond", serif; font-size: 18px; color: var(--ink-soft); }
.embed-placeholder span { font-size: 12px; color: var(--muted); }

.stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 18px; max-width: 1100px; margin: 0 auto; }
.stat { text-align: center; padding: 36px 20px; background: var(--bg-3); border: 1px solid var(--border); border-radius: 8px; }
.stat-num { font-family: "Oswald", "Bebas Neue", sans-serif; font-size: clamp(40px, 5vw, 56px); font-weight: 700; color: var(--gold); letter-spacing: 1px; line-height: 1; margin-bottom: 10px; }
.stat-label { font-size: 13px; color: var(--ink-soft); }
.stats-note { text-align: center; color: var(--muted); font-size: 12px; margin-top: 28px; font-style: italic; }

.photo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; max-width: 1200px; margin: 0 auto; }
.photo { display: block; position: relative; aspect-ratio: 3/4; overflow: hidden; border-radius: 6px; border: 1px solid var(--border); cursor: zoom-in; }
.photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.photo:hover img { transform: scale(1.05); }
.photo-meta { position: absolute; left: 0; right: 0; bottom: 0; padding: 14px; background: linear-gradient(to top, rgba(0,0,0,.85), transparent); color: var(--ink-soft); font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; }
.press-kit-row { text-align: center; margin-top: 50px; }

.booking-card { background: var(--bg-3); border: 1px solid var(--border); border-radius: 12px; padding: 36px 40px; max-width: 720px; margin: 0 auto; }
.booking-row { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; border-bottom: 1px solid var(--border-soft); flex-wrap: wrap; gap: 12px; }
.booking-row:last-of-type { border-bottom: 0; }
.booking-label { font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; }
.booking-value { color: var(--ink); font-size: 17px; font-weight: 500; }
.booking-value.muted { color: var(--muted); font-style: italic; font-size: 15px; }
a.booking-value { color: var(--ink); transition: color .2s; }
a.booking-value:hover { color: var(--gold); }
.booking-cta-row { display: flex; gap: 14px; justify-content: center; margin-top: 28px; flex-wrap: wrap; }
.socials-bar { display: flex; gap: 12px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.social-pill { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border: 1px solid var(--border); border-radius: 30px; color: var(--ink-soft); font-size: 12px; letter-spacing: 1px; transition: all .2s; }
.social-pill:hover { border-color: var(--gold); color: var(--gold); }
.social-pill svg { width: 14px; height: 14px; }

@media (max-width: 700px) {
  .section { padding: 70px 0; }
  .section-head { margin-bottom: 40px; }
  .booking-card { padding: 24px; }
  .booking-row { flex-direction: column; align-items: flex-start; }
  .bio { font-size: 18px; }
}

/* ================= VIDEO GALLERIES (click-to-play) ================= */
.video-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 18px; max-width: 1200px; margin: 0 auto; }
.more-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; max-width: 1200px; margin: 0 auto; }
.video-card { background: var(--bg-3); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; cursor: pointer; transition: all .3s; padding: 0; text-align: left; font-family: inherit; color: inherit; width: 100%; }
.video-card:hover { transform: translateY(-3px); border-color: var(--gold-dim); box-shadow: 0 20px 50px rgba(0,0,0,.4); }
.video-thumb { aspect-ratio: 16/9; background-size: cover; background-position: center; background-color: #1a1a20; position: relative; overflow: hidden; }
.video-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.55) 100%); pointer-events: none; }
.play-btn { position: absolute; top: 50%; left: 50%; width: 64px; height: 64px; transform: translate(-50%, -50%); background: rgba(212,179,106,.92); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: all .25s; z-index: 1; }
.play-btn::before { content: ""; width: 0; height: 0; border-style: solid; border-width: 14px 0 14px 22px; border-color: transparent transparent transparent #0a0a0e; margin-left: 5px; }
.video-card:hover .play-btn { transform: translate(-50%, -50%) scale(1.1); background: var(--gold-bright); box-shadow: 0 8px 30px rgba(212,179,106,.4); }
.video-duration { position: absolute; bottom: 10px; right: 10px; background: rgba(0,0,0,.85); color: #fff; padding: 3px 8px; border-radius: 3px; font-size: 11px; font-family: "Inter", sans-serif; font-weight: 600; z-index: 1; }
.video-meta { padding: 14px 16px 18px; }
.video-cat { font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; margin-bottom: 6px; }
.video-title { font-family: "Cormorant Garamond", serif; font-size: 19px; font-weight: 600; color: var(--ink); line-height: 1.25; }

/* Video modal */
.video-modal { position: fixed; inset: 0; background: rgba(0,0,0,.95); backdrop-filter: blur(20px); z-index: 200; display: none; align-items: center; justify-content: center; padding: 4vw; }
.video-modal.open { display: flex; }
.video-modal-frame { width: 100%; max-width: 1200px; aspect-ratio: 16/9; background: #000; border-radius: 8px; overflow: hidden; box-shadow: 0 50px 120px rgba(0,0,0,.8); animation: lb-in .35s ease-out; }
.video-modal-frame iframe { width: 100%; height: 100%; border: 0; }
.video-modal-close { position: absolute; top: 24px; right: 24px; width: 48px; height: 48px; border-radius: 50%; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); color: #fff; font-size: 30px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .2s; z-index: 1; }
.video-modal-close:hover { background: var(--gold); color: #0a0a0e; border-color: var(--gold); }

/* ================= HERO GRAIN OVERLAY (cinematic film texture) ================= */
.hero-grain { position: absolute; inset: 0; pointer-events: none; opacity: .12; mix-blend-mode: overlay; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>"); z-index: 1; }

/* ================= FEATURED-IN STRIP ================= */
.featured-strip { background: var(--bg-2); padding: 36px 0; border-top: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); }
.featured-label { text-align: center; font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 4px; color: var(--gold); text-transform: uppercase; margin-bottom: 22px; }
.featured-logos { display: flex; flex-wrap: wrap; justify-content: center; gap: 38px; align-items: center; }
.featured-logo { font-family: "Cinzel", serif; font-size: 18px; font-weight: 600; letter-spacing: 4px; color: var(--ink-soft); opacity: .55; transition: opacity .25s, color .25s; text-transform: uppercase; }
.featured-logo:hover { opacity: 1; color: var(--ink); }

/* ================= BOOKING FORM ================= */
.booking-form { background: var(--bg-3); border: 1px solid var(--border); border-radius: 12px; padding: 36px 40px; max-width: 720px; margin: 0 auto; display: grid; gap: 18px; }
.booking-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.booking-form label { display: flex; flex-direction: column; gap: 6px; }
.booking-form label > span { font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 2.5px; color: var(--gold); text-transform: uppercase; }
.booking-form input, .booking-form select, .booking-form textarea { width: 100%; padding: 12px 14px; background: var(--bg-2); border: 1px solid var(--border); color: var(--ink); border-radius: 6px; font-family: "Inter", sans-serif; font-size: 14px; outline: none; transition: border-color .2s, background .2s; }
.booking-form select option { background: #1a1a20; color: #f5efe0; padding: 8px; }
.booking-form select option:hover, .booking-form select option:checked { background: #d4b36a; color: #0a0a0e; }
.booking-form input:focus, .booking-form select:focus, .booking-form textarea:focus { border-color: var(--gold); background: rgba(212,179,106,.04); }
.booking-form textarea { resize: vertical; min-height: 110px; font-family: "Inter", sans-serif; }
.booking-form-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 6px; }
.booking-form-actions .btn-gold, .booking-form-actions .btn-ghost { font-family: "Cinzel", serif; cursor: pointer; border: 1px solid var(--gold); }
.booking-form-actions .btn-ghost { color: var(--ink-soft); border-color: var(--border); }
.booking-form-actions .btn-ghost:hover { color: var(--gold); border-color: var(--gold); background: transparent; }
.booking-form-note { text-align: center; font-size: 12px; color: var(--muted); margin: 8px 0 0; line-height: 1.6; }
.booking-form-note a { color: var(--gold); }
.booking-form-note a:hover { text-decoration: underline; }
@media (max-width: 600px) {
  .booking-form { padding: 24px; }
  .booking-form-row { grid-template-columns: 1fr; }
}

/* ================= STICKY MOBILE CTA BAR ================= */
.mobile-cta-bar { display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 80; padding: 12px 14px calc(12px + env(safe-area-inset-bottom, 0)); background: rgba(10,10,14,.96); backdrop-filter: blur(16px); border-top: 1px solid var(--border); gap: 10px; }
.mobile-cta-bar .mcb-btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; padding: 13px 12px; border-radius: 6px; font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 2px; font-weight: 600; text-transform: uppercase; transition: all .2s; }
.mcb-primary { background: var(--gold); color: #0a0a0e; }
.mcb-primary:hover { background: var(--gold-bright); }
.mcb-secondary { background: transparent; color: var(--gold); border: 1px solid var(--gold); }
.mcb-secondary:hover { background: rgba(212,179,106,.1); }
@media (max-width: 700px) {
  .mobile-cta-bar { display: flex; }
  body { padding-bottom: 64px; } /* reserve space for the bar so footer isn't hidden */
}

/* Add reveal trigger class for sections (works alongside [data-reveal] base styles) */
section.reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s cubic-bezier(.22,.61,.36,1), transform .9s cubic-bezier(.22,.61,.36,1); }
section.reveal.revealed, [data-reveal].revealed { opacity: 1; transform: translateY(0); }

/* ================= VERTICAL 9:16 REEL ================= */
.vertical-row { display: flex; gap: 18px; justify-content: center; flex-wrap: wrap; max-width: 1100px; margin: 0 auto; }
.vertical-card { background: var(--bg-3); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; cursor: pointer; transition: all .3s; padding: 0; text-align: left; font-family: inherit; color: inherit; width: 280px; max-width: 100%; }
.vertical-card:hover { transform: translateY(-4px); border-color: var(--gold-dim); box-shadow: 0 25px 60px rgba(0,0,0,.5); }
.vertical-thumb { aspect-ratio: 9/16; background-size: cover; background-position: center; background-color: #1a1a20; position: relative; overflow: hidden; }
.vertical-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.7) 100%); pointer-events: none; }
.vertical-meta { padding: 14px 16px 18px; }
.vertical-card .video-cat { font-family: "Cinzel", serif; font-size: 10px; letter-spacing: 3px; color: var(--gold); text-transform: uppercase; margin-bottom: 6px; }
.vertical-card .video-title { font-family: "Cormorant Garamond", serif; font-size: 18px; font-weight: 600; color: var(--ink); line-height: 1.25; }

/* ================= ASK WIDGET (FAQ-as-chat) ================= */
.ask-widget { max-width: 720px; margin: 0 auto; background: var(--bg-3); border: 1px solid var(--border); border-radius: 16px; padding: 28px; }
.ask-bubble { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 18px; }
.ask-bubble.answer { display: none; animation: bubble-in .4s ease-out; }
.ask-bubble.answer.show { display: flex; }
.ask-avatar { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--gold) 0%, var(--gold-dim) 100%); color: #0a0a0e; display: flex; align-items: center; justify-content: center; font-family: "Cinzel", serif; font-weight: 700; font-size: 14px; flex-shrink: 0; }
.ask-msg { background: var(--bg-2); border: 1px solid var(--border-soft); border-radius: 4px 14px 14px 14px; padding: 14px 18px; font-family: "Cormorant Garamond", serif; font-size: 17px; line-height: 1.5; color: var(--ink); flex: 1; }
.ask-msg a { color: var(--gold); text-decoration: underline; }
@keyframes bubble-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.ask-questions { display: flex; flex-wrap: wrap; gap: 8px; padding: 14px 0 8px 48px; border-top: 1px dashed var(--border-soft); }
.ask-q { background: transparent; border: 1px solid var(--border); color: var(--ink-soft); padding: 10px 16px; border-radius: 30px; font-family: "Inter", sans-serif; font-size: 13px; cursor: pointer; transition: all .2s; }
.ask-q:hover { border-color: var(--gold); color: var(--gold); }
.ask-q.active { border-color: var(--gold); color: #0a0a0e; background: var(--gold); }
@media (max-width: 600px) {
  .ask-widget { padding: 20px; }
  .ask-questions { padding-left: 0; padding-top: 14px; }
}

/* ================= PRINT / PDF STYLESHEET (one-sheet view) ================= */
@media print {
  @page { margin: 0.5in; }
  body { background: #fff !important; color: #000 !important; padding-bottom: 0 !important; }
  .nav, .mobile-cta-bar, .video-modal, .hero-bg video, .hero-bg img, .hero-grain, .hero-cta-row,
  .ask-widget, #vertical, #videos, #more, .footer-socials, .press-kit-row, .nav-cta {
    display: none !important;
  }
  .hero { min-height: auto; padding: 0 0 20px; page-break-after: avoid; }
  .hero-bg { display: none; }
  .hero-content { padding-top: 0; }
  .hero-name { color: #000 !important; text-shadow: none !important; font-size: 36pt !important; }
  .hero-tagline, .hero-eyebrow { color: #444 !important; text-shadow: none !important; }
  .section { padding: 18px 0 !important; background: #fff !important; page-break-inside: avoid; }
  .section-title, .work-card h4, .video-title, .booking-value, .stat-num, .ask-msg {
    color: #000 !important;
  }
  .section-sub, .bio, .work-card p { color: #333 !important; }
  .eyebrow, .work-year, .video-cat, .booking-label { color: #b08838 !important; }
  .booking-card, .stat, .work-card, .press-quote, .featured-strip, .booking-form { background: #fafafa !important; border: 1px solid #ddd !important; }
  .video-grid { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; }
  .photo-grid { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; }
  a { color: #b08838 !important; text-decoration: none !important; }
  .footer { background: #fff !important; color: #333 !important; }
  .footer-bottom { color: #666 !important; border-top-color: #ddd !important; }
}
