/*
Theme Name: Adidol Visuals
Theme URI: https://www.adidolvisuals.co.uk
Author: Adidol Visuals
Author URI: https://www.adidolvisuals.co.uk
Description: A cinematic, dark-editorial WordPress theme for Adidol Visuals — filmmaker & photographer. Includes a custom front page, a filterable portfolio template, and a contact template. Pairs a Bebas Neue display face with Fraunces and Manrope, film-grain overlay, custom cursor, and staggered reveal animations.
Version: 1.1.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: adidol-visuals
*/

/* ============================================================
   BASE / TOKENS
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --gold: #c8a96e;
  --gold-light: #e8d5a8;
  --gold-deep: #9a7c45;
  --dark: #0a0a0a;
  --dark-mid: #0f0f0f;
  --dark-surface: #161616;
  --text-primary: #f5f0e8;
  --text-muted: #8a8078;
  --line: rgba(245,240,232,0.08);
}

html { scroll-behavior: smooth; }

body {
  background: var(--dark);
  color: var(--text-primary);
  font-family: 'Manrope', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}
@media (hover: hover) and (pointer: fine) { body.adidol { cursor: none; } }

::selection { background: var(--gold); color: var(--dark); }

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

/* Custom cursor */
.cursor { position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; }
.cursor-dot { position: absolute; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); transform: translate(-50%, -50%); transition: transform 0.1s ease; }
.cursor-ring { position: absolute; width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--gold-light); transform: translate(-50%, -50%); transition: transform 0.18s ease, width 0.2s ease, height 0.2s ease, opacity 0.2s; opacity: 0.5; }
@media (hover: none), (pointer: coarse) { .cursor { display: none; } }

/* Global grain */
body.adidol::after {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 9998;
  opacity: 0.04; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px;
}

/* ============================================================
   NAV (shared)
   ============================================================ */
.site-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.6rem 4rem; transition: padding 0.4s, background 0.4s, border-color 0.4s;
  border-bottom: 1px solid transparent;
}
.site-nav.scrolled { background: rgba(10,10,10,0.85); backdrop-filter: blur(16px); padding-top: 1.1rem; padding-bottom: 1.1rem; border-color: var(--line); }
.nav-logo { display: flex; align-items: center; gap: 0.9rem; text-decoration: none; }
.nav-logo-mark {
  width: 46px; height: 46px; border: 1px solid var(--gold); border-radius: 50%;
  position: relative; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); overflow: hidden;
  transition: background 0.4s, color 0.4s, box-shadow 0.4s;
}
.nav-logo-mark svg { width: 76%; height: 76%; display: block; }
.nav-logo:hover .nav-logo-mark { background: var(--gold); color: var(--dark); box-shadow: 0 0 0 4px rgba(200,169,110,0.12); }
.nav-logo-text { font-size: 11px; font-weight: 500; letter-spacing: 4px; text-transform: uppercase; color: var(--text-primary); }
.nav-logo-sub { font-size: 8px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-top: 3px; }

.nav-links { display: flex; align-items: center; gap: 2.8rem; list-style: none; }
.nav-links a { text-decoration: none; color: var(--text-muted); font-size: 11px; font-weight: 400; letter-spacing: 2.5px; text-transform: uppercase; transition: color 0.3s; position: relative; }
.nav-links a::after { content: ''; position: absolute; left: 0; bottom: -5px; width: 0; height: 1px; background: var(--gold); transition: width 0.3s ease; }
.nav-links a:hover, .nav-links a.active,
.nav-links .current-menu-item > a, .nav-links .current_page_item > a { color: var(--gold); }
.nav-links a:hover::after, .nav-links a.active::after,
.nav-links .current-menu-item > a::after, .nav-links .current_page_item > a::after { width: 100%; }
/* "Hire Me" button — last menu item, or any item with the nav-cta class */
.nav-links .nav-cta > a, a.nav-cta,
.nav-links li:last-child > a {
  border: 1px solid var(--gold); color: var(--gold); padding: 0.7rem 1.8rem;
  font-size: 10px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase;
  transition: background 0.3s, color 0.3s;
}
.nav-links .nav-cta > a:hover, a.nav-cta:hover,
.nav-links li:last-child > a:hover { background: var(--gold); color: var(--dark); }
.nav-links .nav-cta > a::after, a.nav-cta::after,
.nav-links li:last-child > a::after { display: none; }

.burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; }
.burger span { width: 26px; height: 1.5px; background: var(--text-primary); transition: 0.3s; }

/* ============================================================
   HERO (front page)
   ============================================================ */
.hero { position: relative; width: 100%; min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; overflow: hidden; }
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse at 22% 60%, rgba(200,169,110,0.07) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 30%, rgba(200,169,110,0.05) 0%, transparent 45%),
    linear-gradient(180deg, #070707, #0d0c0a 60%, #0a0a0a);
}
.hero-photo {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center 30%;
  filter: grayscale(0.4) brightness(0.34) contrast(1.05);
  transform: scale(1.05); animation: heroZoom 18s ease-out forwards;
}
.hero-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(7,7,7,0.55) 0%, rgba(7,7,7,0.35) 40%, rgba(10,10,10,0.85) 100%); }
@keyframes heroZoom { to { transform: scale(1); } }
.hero-bg::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background-image: repeating-linear-gradient(90deg, transparent, transparent calc(100vw / 12 - 1px), rgba(200,169,110,0.035) calc(100vw / 12), rgba(200,169,110,0.035) calc(100vw / 12 + 1px));
}
.hero-bg::after { content: ''; position: absolute; inset: 0; box-shadow: inset 0 0 260px 70px rgba(0,0,0,0.85); pointer-events: none; }
.streak { position: absolute; top: -20%; width: 1px; height: 140%; background: linear-gradient(transparent, rgba(200,169,110,0.5), transparent); transform: rotate(14deg); filter: blur(1px); animation: sweep 11s ease-in-out infinite; opacity: 0.45; z-index: 1; }
@keyframes sweep { 0%,100% { left: 24%; } 50% { left: 78%; } }

.hero-content { position: relative; z-index: 2; text-align: center; display: flex; flex-direction: column; align-items: center; padding: 0 1.5rem; }
.hero-eyebrow { font-size: 10px; letter-spacing: 6px; text-transform: uppercase; color: var(--gold); font-weight: 400; opacity: 0; transform: translateY(16px); animation: fadeUp 0.9s 0.3s ease forwards; margin-bottom: 2rem; display: flex; align-items: center; gap: 14px; }
.hero-eyebrow::before, .hero-eyebrow::after { content: ''; width: 30px; height: 1px; background: var(--gold); opacity: 0.6; }
.hero-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(4.5rem, 14vw, 13rem); line-height: 0.86; letter-spacing: 5px; color: var(--text-primary); opacity: 0; transform: translateY(20px); animation: fadeUp 1s 0.55s ease forwards; }
.hero-title span { color: var(--gold); }
.hero-subtitle { font-family: 'Fraunces', serif; font-size: clamp(1rem, 2vw, 1.5rem); font-style: italic; font-weight: 300; letter-spacing: 3px; color: var(--text-muted); opacity: 0; transform: translateY(14px); animation: fadeUp 0.9s 0.85s ease forwards; margin-top: 1.6rem; }
.hero-divider { width: 60px; height: 1px; background: var(--gold); opacity: 0; animation: fadeUp 0.9s 1.05s ease forwards; margin-top: 2.4rem; }
.hero-socials { display: flex; gap: 2rem; align-items: center; opacity: 0; animation: fadeUp 0.9s 1.2s ease forwards; margin-top: 2rem; }
.hero-socials a { text-decoration: none; color: var(--text-muted); font-size: 10px; letter-spacing: 3px; text-transform: uppercase; transition: color 0.3s; display: flex; align-items: center; gap: 8px; }
.hero-socials a svg { width: 16px; height: 16px; fill: currentColor; }
.hero-socials a:hover { color: var(--gold); }
.hero-scroll { position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 10px; opacity: 0; animation: fadeUp 0.9s 1.5s ease forwards; }
.hero-scroll span { font-size: 9px; letter-spacing: 4px; text-transform: uppercase; color: var(--text-muted); }
.scroll-line { width: 1px; height: 48px; background: linear-gradient(to bottom, var(--gold), transparent); animation: scrollPulse 2s 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100% { opacity: 0.4; transform: scaleY(1); } 50% { opacity: 1; transform: scaleY(1.15); } }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; white-space: nowrap; padding: 1.4rem 0; background: var(--dark-mid); }
.marquee-track { display: inline-block; animation: scroll 30s linear infinite; }
.marquee-track span { font-family: 'Fraunces', serif; font-style: italic; font-size: 1.5rem; color: var(--text-muted); margin: 0 2.4rem; opacity: 0.55; }
.marquee-track span b { color: var(--gold); font-style: normal; font-weight: 400; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================
   ABOUT
   ============================================================ */
.about-strip { padding: 7rem 4rem; display: grid; grid-template-columns: 1fr 1.2fr; gap: 8rem; align-items: center; max-width: 1400px; margin: 0 auto; }
.about-label { font-size: 9px; letter-spacing: 5px; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 1rem; }
.about-label::before { content: ''; display: block; width: 30px; height: 1px; background: var(--gold); }
.about-heading { font-family: 'Fraunces', serif; font-size: clamp(2.2rem, 4vw, 3.5rem); font-weight: 300; line-height: 1.2; color: var(--text-primary); margin-bottom: 2rem; }
.about-heading em { color: var(--gold); font-style: italic; }
.about-text { font-size: 14px; line-height: 2; color: var(--text-muted); max-width: 480px; }
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.stat { border-left: 1px solid var(--dark-surface); padding: 1.5rem 2rem; transition: border-color 0.4s; }
.stat:hover { border-left-color: var(--gold); }
.stat-num { font-family: 'Bebas Neue', sans-serif; font-size: 3.5rem; color: var(--gold); line-height: 1; }
.stat-label { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--text-muted); margin-top: 0.5rem; }

/* ============================================================
   SERVICES
   ============================================================ */
.services { padding: 6rem 4rem; background: var(--dark-surface); }
.services-inner { max-width: 1400px; margin: 0 auto; }
.section-header { text-align: center; margin-bottom: 4.5rem; }
.section-label { font-size: 9px; letter-spacing: 5px; text-transform: uppercase; color: var(--gold); margin-bottom: 1.3rem; display: inline-block; }
.section-title { font-family: 'Fraunces', serif; font-size: clamp(2rem, 4vw, 3rem); font-weight: 300; color: var(--text-primary); }
.section-title em { font-style: italic; color: var(--gold); }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; }
.service-item { padding: 3.5rem 2.5rem; background: var(--dark-mid); border-top: 2px solid transparent; transition: border-color 0.35s, background 0.35s, transform 0.35s; position: relative; overflow: hidden; }
.service-item::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(200,169,110,0.05) 0%, transparent 60%); opacity: 0; transition: opacity 0.35s; }
.service-item:hover { border-top-color: var(--gold); background: #161616; transform: translateY(-4px); }
.service-item:hover::before { opacity: 1; }
.service-num { font-family: 'Bebas Neue', sans-serif; font-size: 4rem; color: rgba(200,169,110,0.12); line-height: 1; margin-bottom: 1.5rem; transition: color 0.35s; }
.service-item:hover .service-num { color: rgba(200,169,110,0.28); }
.service-name { font-family: 'Fraunces', serif; font-size: 1.6rem; font-weight: 300; color: var(--text-primary); margin-bottom: 1rem; }
.service-desc { font-size: 13px; line-height: 1.9; color: var(--text-muted); }

/* ============================================================
   PORTFOLIO TEASER (front page)
   ============================================================ */
.portfolio-teaser { padding: 7rem 4rem; max-width: 1400px; margin: 0 auto; }
.portfolio-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; grid-template-rows: 280px 280px; gap: 3px; margin-top: 4rem; }
.portfolio-item { position: relative; overflow: hidden; background: var(--dark-surface); text-decoration: none; display: block; }
.portfolio-item:first-child { grid-row: span 2; }
.portfolio-placeholder { width: 100%; height: 100%; display: flex; align-items: flex-end; padding: 2rem; transition: transform 0.6s ease; position: relative; background-size: cover; background-position: center; }
.portfolio-item:hover .portfolio-placeholder { transform: scale(1.04); }
.p1 { background: linear-gradient(160deg, #1a1208 0%, #2e1f06 40%, #0d0a05 100%); }
.p2 { background: linear-gradient(160deg, #080d12 0%, #101a22 50%, #060b0e 100%); }
.p3 { background: linear-gradient(160deg, #0f0a10 0%, #1e1025 50%, #080608 100%); }
.p4 { background: linear-gradient(160deg, #100e08 0%, #2a2210 50%, #0a0905 100%); }
.p5 { background: linear-gradient(160deg, #080e10 0%, #102028 50%, #050a0d 100%); }
.portfolio-placeholder::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(255,255,255,0.008) 3px, rgba(255,255,255,0.008) 4px); pointer-events: none; z-index: 1; }
.portfolio-img { position: absolute; inset: 0; background-size: cover; background-position: center; filter: grayscale(0.55) brightness(0.62) contrast(1.05); transform: scale(1.02); transition: filter 0.7s ease, transform 1.2s cubic-bezier(.2,.7,.2,1); z-index: 0; }
.portfolio-item:hover .portfolio-img { filter: grayscale(0) brightness(0.82) contrast(1); transform: scale(1.1); }
.portfolio-placeholder::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,8,8,0.15) 0%, rgba(8,8,8,0.35) 55%, rgba(8,8,8,0.9) 100%); z-index: 1; }
.portfolio-label { position: relative; z-index: 3; }
.portfolio-label span { display: block; font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 6px; }
.portfolio-label h3 { font-family: 'Fraunces', serif; font-size: 1.3rem; font-weight: 300; color: var(--text-primary); }
.portfolio-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0); transition: background 0.4s; display: flex; align-items: center; justify-content: center; }
.portfolio-item:hover .portfolio-overlay { background: rgba(0,0,0,0.25); }
.portfolio-view { opacity: 0; transform: scale(0.85); transition: opacity 0.35s, transform 0.35s; border: 1px solid var(--gold); padding: 0.6rem 1.8rem; font-size: 9px; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); }
.portfolio-item:hover .portfolio-view { opacity: 1; transform: scale(1); }

/* ============================================================
   PORTFOLIO PAGE (template)
   ============================================================ */
.page-hero { position: relative; padding: 12rem 4rem 4rem; overflow: hidden; border-bottom: 1px solid var(--line); }
.page-hero-bg { position: absolute; inset: 0; z-index: 0; background: radial-gradient(ellipse at 75% 10%, rgba(200,169,110,0.08) 0%, transparent 55%), linear-gradient(180deg, #0c0b09, #0a0a0a); }
.page-hero-bg::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(90deg, transparent, transparent calc(100vw / 12 - 1px), rgba(200,169,110,0.03) calc(100vw / 12), rgba(200,169,110,0.03) calc(100vw / 12 + 1px)); }
.page-hero-inner { position: relative; z-index: 2; max-width: 1400px; margin: 0 auto; }
.crumb { font-size: 10px; letter-spacing: 4px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 1.8rem; }
.crumb a { color: var(--gold); text-decoration: none; }
.page-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(3.5rem, 11vw, 9rem); line-height: 0.86; letter-spacing: 4px; }
.page-title span { color: var(--gold); }
.page-intro { font-family: 'Fraunces', serif; font-style: italic; font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--text-muted); margin-top: 1.5rem; max-width: 600px; line-height: 1.5; }

.filter-wrap { position: sticky; top: 0; z-index: 90; background: rgba(10,10,10,0.9); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); }
.filter-bar { max-width: 1400px; margin: 0 auto; display: flex; gap: 0.6rem; flex-wrap: wrap; padding: 1.3rem 4rem; }
.filter-btn { background: transparent; border: 1px solid var(--line); color: var(--text-muted); padding: 0.7rem 1.5rem; font-family: 'Manrope', sans-serif; font-size: 10px; font-weight: 400; letter-spacing: 2.5px; text-transform: uppercase; transition: all 0.3s; white-space: nowrap; }
@media (hover: hover) and (pointer: fine) { .adidol .filter-btn { cursor: none; } }
.filter-btn:hover { border-color: var(--gold); color: var(--gold); }
.filter-btn.active { background: var(--gold); border-color: var(--gold); color: var(--dark); }

.gallery-section { padding: 4rem 4rem 6rem; max-width: 1400px; margin: 0 auto; }
.cat-block { margin-bottom: 5rem; scroll-margin-top: 120px; }
.cat-head { display: flex; align-items: baseline; gap: 1.2rem; margin-bottom: 2rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); }
.cat-head h2 { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(1.6rem, 3vw, 2.4rem); }
.cat-head h2 em { font-style: italic; color: var(--gold); }
.cat-head .count { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--text-muted); }
.cat-desc { font-size: 13px; line-height: 1.8; color: var(--text-muted); max-width: 560px; margin-bottom: 2rem; }

.grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; }
.work { position: relative; overflow: hidden; aspect-ratio: 3/4; background: var(--dark-surface); transition: opacity 0.4s, transform 0.4s; display: block; text-decoration: none; color: var(--text-primary); }
.work.span2 { grid-column: span 2; aspect-ratio: 3/2; }
.work-fill { position: absolute; inset: 0; transition: transform 0.7s cubic-bezier(.2,.7,.2,1), filter 0.6s; filter: grayscale(0.5) brightness(0.78); }
.work-fill.img { background-size: cover; background-position: center; }
.work:hover .work-fill { transform: scale(1.07); filter: grayscale(0) brightness(0.9); }
.work-fill::after { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(255,255,255,0.01) 3px, rgba(255,255,255,0.01) 4px); }
.work-grad { position: absolute; inset: 0; background: linear-gradient(transparent 40%, rgba(7,7,7,0.92)); z-index: 1; }
.work-cap { position: absolute; left: 0; bottom: 0; z-index: 2; padding: 1.4rem; }
.work-cap .tag { font-size: 8px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); }
.work-cap h3 { font-family: 'Fraunces', serif; font-weight: 300; font-size: 1.15rem; margin-top: 5px; }
.work-num { position: absolute; top: 1rem; right: 1.2rem; z-index: 2; font-family: 'Bebas Neue', sans-serif; font-size: 0.9rem; letter-spacing: 2px; color: rgba(245,240,232,0.4); }
.work-view { position: absolute; top: 1rem; left: 1.2rem; z-index: 2; width: 34px; height: 34px; border: 1px solid var(--line); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--text-primary); opacity: 0; transform: translateY(-6px); transition: 0.4s; }
.work:hover .work-view { opacity: 1; transform: translateY(0); background: var(--gold); border-color: var(--gold); color: var(--dark); }

/* Color fills (used where a category has no photo yet) */
.f-gold1 { background: linear-gradient(150deg, #1a1208, #3a2a0c 45%, #0d0a05); }
.f-gold2 { background: linear-gradient(150deg, #211806, #4a3510 50%, #100b04); }
.f-blue1 { background: linear-gradient(150deg, #080d12, #16242e 50%, #060b0e); }
.f-blue2 { background: linear-gradient(150deg, #0a1118, #1d3140 50%, #070d11); }
.f-plum1 { background: linear-gradient(150deg, #0f0a10, #281433 50%, #080608); }
.f-plum2 { background: linear-gradient(150deg, #130b14, #341a40 50%, #0a060b); }
.f-green1 { background: linear-gradient(150deg, #0a0f08, #1f2e15 50%, #070b06); }
.f-rose1 { background: linear-gradient(150deg, #140a0d, #3a1a24 50%, #0c0608); }
.f-teal1 { background: linear-gradient(150deg, #08100f, #143028 50%, #050a09); }

.empty { display: none; text-align: center; padding: 5rem 1rem; color: var(--text-muted); font-family: 'Fraunces', serif; font-style: italic; font-size: 1.3rem; }

/* ============================================================
   CONTACT PAGE (template)
   ============================================================ */
.contact-wrap { min-height: 100vh; display: grid; grid-template-columns: 1fr 1.1fr; }
.contact-info { position: relative; padding: 11rem 4rem 4rem; overflow: hidden; border-right: 1px solid var(--line); display: flex; flex-direction: column; }
.info-bg { position: absolute; inset: 0; z-index: 0; background: radial-gradient(ellipse at 30% 20%, rgba(200,169,110,0.09) 0%, transparent 55%), linear-gradient(180deg, #0c0b09, #0a0a0a); }
.info-bg::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(90deg, transparent, transparent 79px, rgba(200,169,110,0.03) 80px, rgba(200,169,110,0.03) 81px); }
.info-bg::after { content: 'HELLO'; position: absolute; bottom: -3rem; left: -1rem; font-family: 'Bebas Neue', sans-serif; font-size: 13rem; line-height: 1; color: rgba(200,169,110,0.035); letter-spacing: 6px; pointer-events: none; }
.info-inner { position: relative; z-index: 2; }
.contact-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(3rem, 8vw, 6rem); line-height: 0.86; letter-spacing: 3px; }
.contact-title span { color: var(--gold); }
.contact-lede { font-family: 'Fraunces', serif; font-style: italic; font-size: clamp(1.1rem, 2vw, 1.4rem); color: var(--text-muted); margin-top: 1.4rem; max-width: 420px; line-height: 1.55; }

.info-list { margin-top: 3.5rem; display: flex; flex-direction: column; gap: 1.8rem; }
.info-item { display: flex; gap: 1.2rem; align-items: flex-start; }
.info-ic { width: 40px; height: 40px; flex-shrink: 0; border: 1px solid var(--line); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--gold); transition: background 0.3s, color 0.3s, border-color 0.3s; }
.info-ic svg { width: 17px; height: 17px; fill: none; stroke: currentColor; stroke-width: 1.6; }
.info-item:hover .info-ic { background: var(--gold); color: var(--dark); border-color: var(--gold); }
.info-k { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 4px; }
.info-v { font-size: 14px; color: var(--text-primary); text-decoration: none; transition: color 0.3s; }
a.info-v:hover { color: var(--gold); }

.info-socials { margin-top: auto; padding-top: 3rem; display: flex; gap: 1.5rem; position: relative; z-index: 2; }
.info-socials a { width: 42px; height: 42px; border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--text-muted); transition: all 0.3s; }
.info-socials a svg { width: 18px; height: 18px; fill: currentColor; }
.info-socials a:hover { color: var(--gold); border-color: var(--gold); transform: translateY(-3px); }

.contact-form-wrap { padding: 11rem 4rem 4rem; background: var(--dark-mid); display: flex; align-items: center; }
.adidol-form { width: 100%; max-width: 520px; margin: 0 auto; }
.form-head { margin-bottom: 2.5rem; }
.form-head .label { font-size: 9px; letter-spacing: 5px; text-transform: uppercase; color: var(--gold); display: block; margin-bottom: 1rem; }
.form-head h2 { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(1.6rem, 3vw, 2.2rem); }
.form-head h2 em { font-style: italic; color: var(--gold); }

.field { position: relative; margin-bottom: 1.8rem; }
.field label { position: absolute; left: 0; top: 0.9rem; font-size: 13px; color: var(--text-muted); letter-spacing: 0.5px; pointer-events: none; transition: all 0.25s ease; }
.field input, .field textarea, .field select {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--line);
  padding: 0.9rem 0; color: var(--text-primary); font-family: 'Manrope', sans-serif;
  font-size: 14px; font-weight: 300; transition: border-color 0.3s; border-radius: 0;
}
@media (hover: hover) and (pointer: fine) { .adidol .field input, .adidol .field textarea, .adidol .field select { cursor: none; } }
.field textarea { resize: none; min-height: 90px; }
.field select { color: var(--text-muted); }
.field select option { background: var(--dark-surface); color: var(--text-primary); }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-bottom-color: var(--gold); }
.field input:focus ~ label, .field input:valid ~ label,
.field textarea:focus ~ label, .field textarea:valid ~ label {
  top: -0.7rem; font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold);
}
.field.select-field label { top: -0.7rem; font-size: 9px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }

.submit-btn { width: 100%; margin-top: 0.5rem; background: var(--gold); color: var(--dark); border: none; padding: 1.15rem 2rem; font-family: 'Manrope', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; position: relative; overflow: hidden; transition: color 0.4s; }
@media (hover: hover) and (pointer: fine) { .adidol .submit-btn { cursor: none; } }
.submit-btn span { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.8rem; justify-content: center; }
.submit-btn svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 2; }
.submit-btn::before { content: ''; position: absolute; inset: 0; background: var(--gold-light); transform: translateX(-101%); transition: transform 0.45s cubic-bezier(.2,.7,.2,1); }
.submit-btn:hover::before { transform: translateX(0); }
.form-note { font-size: 11px; color: var(--text-muted); margin-top: 1.3rem; line-height: 1.7; }
.form-note a { color: var(--gold); text-decoration: none; }

.success { display: none; text-align: center; padding: 1rem 0; }
.success.show { display: block; animation: fadeUp 0.6s ease forwards; }
.success .check { width: 64px; height: 64px; margin: 0 auto 1.5rem; border: 1px solid var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--gold); }
.success .check svg { width: 28px; height: 28px; fill: none; stroke: currentColor; stroke-width: 1.6; }
.success h3 { font-family: 'Fraunces', serif; font-weight: 300; font-size: 1.8rem; margin-bottom: 0.8rem; }
.success h3 em { font-style: italic; color: var(--gold); }
.success p { font-size: 13px; color: var(--text-muted); line-height: 1.9; max-width: 360px; margin: 0 auto; }

/* ============================================================
   CTA + FOOTER (shared)
   ============================================================ */
.cta-band { padding: 8rem 4rem; text-align: center; background: var(--dark); position: relative; overflow: hidden; }
.cta-band.surface { background: var(--dark-surface); padding: 7rem 4rem; }
.cta-band::before { content: attr(data-ghost); font-family: 'Bebas Neue', sans-serif; font-size: 22vw; color: rgba(200,169,110,0.03); position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); white-space: nowrap; pointer-events: none; line-height: 1; letter-spacing: 8px; }
.cta-band h2 { font-family: 'Fraunces', serif; font-size: clamp(2.2rem, 5vw, 4rem); font-weight: 300; color: var(--text-primary); margin-bottom: 1.5rem; position: relative; z-index: 1; }
.cta-band h2 em { color: var(--gold); font-style: italic; }
.cta-band p { font-size: 14px; color: var(--text-muted); max-width: 500px; margin: 0 auto 3rem; line-height: 2; position: relative; z-index: 1; }
.cta-btn { display: inline-flex; align-items: center; gap: 1rem; background: var(--gold); color: var(--dark); padding: 1.1rem 3.5rem; text-decoration: none; font-size: 10px; font-weight: 500; letter-spacing: 4px; text-transform: uppercase; position: relative; z-index: 1; overflow: hidden; }
.cta-btn span { position: relative; z-index: 1; transition: color 0.4s; display: inline-flex; align-items: center; gap: 1rem; }
.cta-btn::before { content: ''; position: absolute; inset: 0; background: var(--gold-light); transform: translateX(-101%); transition: transform 0.45s cubic-bezier(.2,.7,.2,1); }
.cta-btn:hover::before { transform: translateX(0); }
.cta-btn svg { width: 14px; height: 14px; }

.site-footer { border-top: 1px solid var(--line); padding: 3rem 4rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.5rem; }
.footer-logo { font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem; letter-spacing: 4px; color: var(--text-muted); }
.footer-logo b { color: var(--gold); font-weight: 400; }
.footer-links { display: flex; gap: 2.5rem; flex-wrap: wrap; list-style: none; }
.footer-links a { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; text-decoration: none; color: var(--text-muted); transition: color 0.3s; }
.footer-links a:hover { color: var(--gold); }
.footer-copy { font-size: 11px; color: var(--text-muted); }

/* ============================================================
   ANIMATION / REVEAL
   ============================================================ */
@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) { .grid { grid-template-columns: repeat(2, 1fr); } .work.span2 { grid-column: span 2; } }

@media (max-width: 980px) {
  .contact-wrap { grid-template-columns: 1fr; }
  .contact-info { border-right: none; border-bottom: 1px solid var(--line); padding: 9rem 1.6rem 3rem; }
  .contact-form-wrap { padding: 4rem 1.6rem; }
  .info-socials { padding-top: 2.5rem; }
}

@media (max-width: 900px) {
  .site-nav { padding: 1.3rem 1.6rem; }
  .nav-links { position: fixed; inset: 0 0 0 auto; width: min(78vw, 320px); flex-direction: column; align-items: flex-start; justify-content: center; gap: 2rem; background: rgba(12,12,12,0.97); backdrop-filter: blur(20px); padding: 3rem; transform: translateX(100%); transition: transform 0.45s cubic-bezier(.2,.7,.2,1); border-left: 1px solid var(--line); }
  .nav-links.open { transform: translateX(0); }
  .nav-links a { font-size: 14px; }
  .burger { display: flex; z-index: 101; }
  .burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
  .burger.open span:nth-child(2) { opacity: 0; }
  .burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
  .about-strip { grid-template-columns: 1fr; padding: 4rem 1.6rem; gap: 3rem; }
  .services { padding: 4rem 1.6rem; }
  .services-grid { grid-template-columns: 1fr; }
  .portfolio-teaser { padding: 4rem 1.6rem; }
  .portfolio-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
  .portfolio-item:first-child { grid-row: span 1; }
  .portfolio-placeholder { height: 240px; }
  .page-hero { padding: 9rem 1.6rem 3rem; }
  .filter-bar { padding: 1.1rem 1.6rem; overflow-x: auto; flex-wrap: nowrap; }
  .gallery-section { padding: 3rem 1.6rem 4rem; }
  .cta-band { padding: 5rem 1.6rem; }
  .site-footer { flex-direction: column; text-align: center; }
}

@media (max-width: 560px) { .grid { grid-template-columns: 1fr; } .work.span2 { grid-column: span 1; aspect-ratio: 3/4; } }
@media (max-width: 460px) { .field-row { grid-template-columns: 1fr; gap: 0; } }

/* ============================================================
   VIDEO — hero background, reel button, lightbox, embeds, badges
   ============================================================ */

/* Hero background video (sits above the photo, below the vignette/overlay) */
.hero-video {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.35) brightness(0.4) contrast(1.05);
}
.hero-video + .streak { z-index: 1; }

/* "Play Reel" button */
.reel-btn {
  display: inline-flex; align-items: center; gap: 0.8rem;
  margin-top: 2rem; padding: 0.9rem 1.8rem 0.9rem 0.9rem;
  background: rgba(10,10,10,0.35); color: var(--text-primary);
  border: 1px solid rgba(245,240,232,0.25); border-radius: 50px;
  font-family: 'Manrope', sans-serif; font-size: 11px; font-weight: 500;
  letter-spacing: 3px; text-transform: uppercase;
  backdrop-filter: blur(6px); transition: border-color 0.3s, background 0.3s, transform 0.3s;
}
@media (hover: hover) and (pointer: fine) { .afilms .reel-btn { cursor: none; } }
.reel-btn:hover { border-color: var(--gold); background: rgba(10,10,10,0.55); transform: translateY(-2px); }
.reel-play {
  width: 34px; height: 34px; flex-shrink: 0; border-radius: 50%;
  background: var(--gold); color: var(--dark);
  display: inline-flex; align-items: center; justify-content: center;
}
.reel-play svg { width: 13px; height: 13px; fill: currentColor; margin-left: 2px; }

/* Play badge on tiles that lead to a video project */
.play-badge {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  z-index: 2; width: 54px; height: 54px; border-radius: 50%;
  background: rgba(10,10,10,0.45); border: 1px solid rgba(245,240,232,0.55);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(3px); transition: background 0.35s, border-color 0.35s, transform 0.35s;
  pointer-events: none;
}
.play-badge svg { width: 20px; height: 20px; fill: var(--text-primary); margin-left: 3px; transition: fill 0.35s; }
.work:hover .play-badge { background: var(--gold); border-color: var(--gold); transform: translate(-50%, -50%) scale(1.08); }
.work:hover .play-badge svg { fill: var(--dark); }

/* Responsive embed (single project page) */
.video-embed {
  position: relative; width: 100%; aspect-ratio: 16 / 9;
  background: #000; overflow: hidden; border: 1px solid var(--line);
}
.video-embed iframe,
.video-embed video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.video-embed--auto { aspect-ratio: auto; }
.video-embed--auto iframe { position: static; aspect-ratio: 16 / 9; }

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 10000;
  display: none; align-items: center; justify-content: center;
  background: rgba(5,5,5,0.92); backdrop-filter: blur(8px);
  padding: 4vw;
}
.lightbox.open { display: flex; animation: lbFade 0.3s ease; }
@keyframes lbFade { from { opacity: 0; } to { opacity: 1; } }
.lightbox-inner { width: min(1100px, 100%); }
.lightbox-player { position: relative; width: 100%; aspect-ratio: 16 / 9; background: #000; }
.lightbox-player iframe,
.lightbox-player video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.lightbox-close {
  position: absolute; top: 22px; right: 26px; z-index: 1;
  width: 46px; height: 46px; border-radius: 50%;
  background: transparent; border: 1px solid rgba(245,240,232,0.3);
  color: var(--text-primary); font-size: 26px; line-height: 1;
  transition: background 0.3s, color 0.3s, border-color 0.3s;
}
.lightbox-close:hover { background: var(--gold); color: var(--dark); border-color: var(--gold); }

/* ============================================================
   REDUCED MOTION — honour the user's OS setting
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .hero-photo { animation: none !important; transform: none !important; }
  .hero-video { display: none !important; }
  .streak { animation: none !important; opacity: 0.18; }
  .marquee-track { animation: none !important; }
  .scroll-line { animation: none !important; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .lightbox.open { animation: none !important; }
  html { scroll-behavior: auto; }
}

/* ============================================================
   ICONIC HOMEPAGE — hero watermark, animated title, polish
   ============================================================ */

/* Giant ghost monogram watermark behind the hero */
.hero-watermark {
  position: absolute; z-index: 0; top: 50%; left: 50%;
  width: min(78vh, 760px); height: min(78vh, 760px);
  transform: translate(-50%, -54%);
  color: var(--gold); opacity: 0.05; pointer-events: none;
  display: flex; align-items: center; justify-content: center;
}
.hero-watermark svg { width: 100%; height: 100%; }
.hero-watermark::after {
  content: ''; position: absolute; inset: -8%;
  border: 1px solid rgba(200,169,110,0.10); border-radius: 50%;
}

/* Eyebrow refinement */
.hero-eyebrow { position: relative; z-index: 2; }

/* Animated gold shimmer across the gold title line */
.hero-title span {
  background: linear-gradient(100deg, var(--gold) 0%, #f3e6c6 28%, var(--gold-deep) 55%, var(--gold) 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: goldSweep 7s ease-in-out infinite;
}
@keyframes goldSweep { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }

/* Subtle floating grain/light over the hero for depth */
.hero::before {
  content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(circle at 50% 38%, transparent 55%, rgba(0,0,0,0.45) 100%);
}

/* Refined hero divider with center diamond */
.hero-divider { position: relative; }
.hero-divider::after {
  content: ''; position: absolute; top: 50%; left: 50%; width: 5px; height: 5px;
  background: var(--gold); transform: translate(-50%, -50%) rotate(45deg);
}

/* Section title gets a small kicker rule */
.section-title { position: relative; display: inline-block; }

/* Portfolio tiles: gold edge on hover for a more "gallery" feel */
.portfolio-item { transition: box-shadow 0.4s; }
.portfolio-item:hover { box-shadow: inset 0 0 0 1px rgba(200,169,110,0.6); }

/* Stat numbers get a faint gold underglow */
.stat-num { text-shadow: 0 0 26px rgba(200,169,110,0.18); }

@media (max-width: 900px) {
  .hero-watermark { width: 90vw; height: 90vw; opacity: 0.045; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-title span { animation: none !important; }
}
