/* ============================================================================
   site.css — Photographer of Fethiye
   Implements design-system.md ("Mediterranean Editorial").
   Tailwind (CDN) handles utilities; this file owns tokens + component recipes.
   ========================================================================== */

/* ── Fonts ────────────────────────────────────────────────────────────────
   Neue Haas Grotesk self-hosted. Cormorant + Great Vibes load via Google
   Fonts <link> in head-common.php (per design-system.md §11). */
@font-face { font-family:"NHG"; src:url("../fonts/NeueHaasDisplayLight.ttf") format("truetype"); font-weight:300; font-display:swap; }
@font-face { font-family:"NHG"; src:url("../fonts/NeueHaasDisplayRoman.ttf") format("truetype"); font-weight:400; font-display:swap; }
@font-face { font-family:"NHG"; src:url("../fonts/NeueHaasDisplayMediu.ttf") format("truetype"); font-weight:500; font-display:swap; }
@font-face { font-family:"NHG"; src:url("../fonts/NeueHaasDisplayBold.ttf") format("truetype"); font-weight:700; font-display:swap; }

/* ── Design tokens ───────────────────────────────────────────────────────── */
:root {
  /* Surfaces — "Nightfall" dark palette */
  --bg:           #17171A;
  --surface:      #202024;
  --surface-sage: #1E1E22;   /* alternating section band */
  /* Ink (light on dark) */
  --ink:          #ECEAE3;
  --ink-muted:    #9A988F;
  /* Accents — names kept for compatibility; --gold = brass accent */
  --gold:         #C7A06A;
  --gold-dark:    #A9824C;
  --terracotta:   #CC9168;
  --sage:         #8E9A86;
  /* Lines & states */
  --hairline:     rgba(236,234,227,0.18);
  --hairline-2:   rgba(236,234,227,0.30);
  --gold-soft:    rgba(199,160,106,0.16);
  --ink-overlay:  rgba(7,7,9,0.74);
  --shadow:       rgba(0,0,0,0.55);
  /* Constant light tone for text/icons over photos & dark overlays */
  --on-media:     #F2EFE8;
  /* Type */
  --font-display: "Cormorant","Times New Roman",serif;
  --font-body:    "NHG","Inter",system-ui,-apple-system,sans-serif;
  --font-script:  "Great Vibes",cursive;
  /* Spacing (8px base) */
  --space-1:.25rem; --space-2:.5rem;  --space-3:1rem;   --space-4:1.5rem;
  --space-5:2rem;   --space-6:3rem;   --space-7:4rem;   --space-8:6rem;
  --space-9:8rem;   --space-10:12rem;
  /* Motion */
  --ease-out:   cubic-bezier(0.22,1,0.36,1);
  --ease-in:    cubic-bezier(0.55,0,0.68,0.30);
  --ease-inout: cubic-bezier(0.65,0,0.35,1);
  --dur-fast:   .2s;
  --dur-hover:  .35s;
  --dur-reveal: .9s;
  --dur-slide:  1.1s;
  /* Layout */
  --container:  1440px;
  --gutter:     clamp(1.25rem,5vw,6rem);
  --nav-h:      88px;
  /* Radius — rounded everywhere, no sharp corners */
  --radius-sm:  12px;
  --radius:     18px;
  --radius-lg:  26px;
  --radius-pill: 999px;
}

/* ── Reset / base ────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scrollbar-gutter:stable; background:#131316; }
body {
  margin:0;
  background:transparent;
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

/* ── Ambient flow field — continuous luminous backdrop ───────────────────────
   Replaces the flat page colour and the hard alternating blocks. One fixed,
   oversized gradient field (dark base + four soft warm light pools) that every
   section scrolls over, so the whole page reads as a single continuous flow.
   A very slow drift keeps it alive; disabled under prefers-reduced-motion. */
body::before {
  content:""; position:fixed; z-index:-1; inset:-25%;
  pointer-events:none;
  background:
    radial-gradient(42% 32% at 80% 6%,  rgba(199,160,106,0.17), transparent 70%),
    radial-gradient(44% 36% at 10% 39%, rgba(142,154,134,0.12), transparent 72%),
    radial-gradient(46% 34% at 88% 71%, rgba(204,145,104,0.16), transparent 70%),
    radial-gradient(54% 42% at 26% 99%, rgba(199,160,106,0.10), transparent 72%),
    linear-gradient(176deg,#18181C 0%,#151518 46%,#121215 100%);
}
@media (prefers-reduced-motion:no-preference){
  body::before { animation:fieldDrift 52s var(--ease-inout) infinite alternate; }
}
@keyframes fieldDrift {
  from { transform:translate3d(-2.2%,-1.6%,0) scale(1.04); }
  to   { transform:translate3d(2.4%,2%,0)     scale(1.10); }
}
img,video { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
h1,h2,h3,h4 { margin:0; font-family:var(--font-display); font-weight:500; }
p { margin:0; }
::selection { background:var(--gold-soft); color:var(--ink); }

/* ── Type scale (design-system §3) ───────────────────────────────────────── */
.t-display { font-family:var(--font-display); font-weight:500; font-size:clamp(3.25rem,7vw,7rem);     line-height:1.02; letter-spacing:-.02em; }
.t-h1      { font-family:var(--font-display); font-weight:500; font-size:clamp(2.5rem,5vw,4.5rem);     line-height:1.06; letter-spacing:-.015em; }
.t-h2      { font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,3.5vw,3.25rem);    line-height:1.10; letter-spacing:-.01em; }
.t-h3      { font-family:var(--font-display); font-weight:600; font-size:clamp(1.5rem,2vw,2rem);       line-height:1.20; letter-spacing:-.005em; }
.t-body-lg { font-size:clamp(1.125rem,1.4vw,1.375rem); line-height:1.55; }
.t-body    { font-size:clamp(1rem,1.1vw,1.0625rem);    line-height:1.65; }
.t-body-sm { font-size:.9375rem; line-height:1.6; }
.t-label   { font-size:.75rem; line-height:1.4; letter-spacing:.18em; text-transform:uppercase; font-weight:600; }
.t-caption { font-size:.8125rem; line-height:1.5; letter-spacing:.04em; }
.t-script  { font-family:var(--font-script); font-weight:400; font-size:clamp(2.5rem,4vw,4rem); line-height:1.1; }
.measure   { max-width:66ch; }
.ink-muted { color:var(--ink-muted); }

/* eyebrow label — sage/terracotta, never gold */
.eyebrow { display:inline-flex; align-items:center; gap:.6rem; color:var(--sage); }
.eyebrow::before { content:""; width:1.75rem; height:1px; background:currentColor; opacity:.7; }
.eyebrow--terracotta { color:var(--terracotta); }

/* ── Layout helpers ──────────────────────────────────────────────────────── */
.container { max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section   { padding-block:var(--space-8); }
@media (min-width:1024px){ .section { padding-block:var(--space-9); } }
.section--lg { padding-block:var(--space-8); }
@media (min-width:1024px){ .section--lg { padding-block:var(--space-10); } }
/* soft tonal swell — fades in at the top and out at the bottom so a banded
   section blends into the ambient field instead of stacking as a hard block */
.band-sage {
  background:linear-gradient(180deg,
    transparent 0%,
    rgba(255,255,255,0.022) 13%,
    rgba(255,255,255,0.022) 87%,
    transparent 100%);
}

/* section header — eyebrow + heading + drawn hairline */
.section-head { display:flex; flex-direction:column; gap:var(--space-3); margin-bottom:var(--space-6); }
.section-rule { height:1px; background:var(--hairline); transform-origin:left center; }

/* ── Film grain (design-system §9) ───────────────────────────────────────── */
.grain {
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:screen;  /* screen = subtle light grain on the dark canvas */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media (prefers-reduced-motion:no-preference){
  .grain { animation:grain-shift .6s steps(2) infinite; }
}
@keyframes grain-shift { 0%{transform:translate(0,0);} 100%{transform:translate(-2%,1%);} }

/* warm grade on imagery */
.media-warm { filter:saturate(1.04) contrast(1.02) brightness(1.01); }
.media-wrap { position:relative; overflow:hidden; }
.media-wrap::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background:rgba(199,160,106,0.06); mix-blend-mode:overlay;
}

/* ── Page-load fade ───────────────────────────────────────────────────────── */
/* Pure-CSS animation: self-reveals even if main.js fails to load (no JS
   dependency = no blank-page risk). Gated on html.js so no-JS users see
   content instantly. Opacity-only — never causes layout shift, and the short
   delay does not gate the hero/LCP paint. */
html.js main[data-page-fade] { animation:pageFadeIn .6s var(--ease-out) .05s both; }
@keyframes pageFadeIn { from { opacity:0; } to { opacity:1; } }

/* ── Scroll reveal (CSS-class based — bfcache safe) ───────────────────────── */
.gs-hidden { opacity:0; transform:translateY(32px); }
.gs-reveal { animation:gsReveal var(--dur-reveal) var(--ease-out) forwards; }
@keyframes gsReveal { to { opacity:1; transform:translateY(0); } }
.gs-line-hidden { transform:scaleX(0); transform-origin:left center; }
.gs-line-reveal { animation:gsLine var(--dur-reveal) var(--ease-out) forwards; }
@keyframes gsLine { to { transform:scaleX(1); } }

/* ── Image reveal — soft clip-path wipe inside a fixed-aspect frame ─────────
   The frame keeps its layout box; only the image's clip-path + scale animate,
   so there is zero reflow / CLS. JS adds .img-reveal-in on scroll-in. */
.img-reveal {
  clip-path:inset(0 0 100% 0);
  transform:scale(1.06);
  will-change:clip-path,transform;
}
.img-reveal-in {
  animation:imgReveal 1.1s var(--ease-out) forwards;
}
@keyframes imgReveal {
  to { clip-path:inset(0 0 0% 0); transform:scale(1); }
}

/* ── Magnetic button — JS writes --mx/--my; CSS owns the transition curve ─── */
.btn[data-magnetic] {
  transform:translate(var(--mx,0),var(--my,0));
  transition:transform .35s var(--ease-out),
             background var(--dur-hover) var(--ease-out),
             border-color var(--dur-hover) var(--ease-out);
}
.btn[data-magnetic]:active { transform:translate(var(--mx,0),calc(var(--my,0) + 1px)); }

/* line-mask headline (Splitting.js .line wrapped) */
.line-mask .word, .line-mask .char { display:inline-block; }
.line-mask.split-ready .char { opacity:0; transform:translateY(.7em); }

/* ── Focus ring (design-system §10) ──────────────────────────────────────── */
/* Focus ring — outline follows each element's own border-radius. */
:focus-visible {
  outline:2px solid var(--gold); outline-offset:3px;
  box-shadow:0 0 0 3px var(--gold-soft);
}

/* skip link */
.skip-link {
  position:absolute; left:1rem; top:-3rem; z-index:200;
  background:var(--ink); color:var(--bg); padding:.6rem 1rem;
  border-radius:var(--radius-pill);
  transition:top var(--dur-fast) var(--ease-out);
}
.skip-link:focus { top:1rem; }

/* ── Buttons — frosted glass (Saorso / Pixieset premium) ─────────────────────
   Backdrop-blur over photos, semi-transparent surface, brass-tinted primary,
   pearl-tinted ghost. Stays readable on any background thanks to the blur. */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  font-family:var(--font-body); font-weight:600;
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  padding:14px 30px; border-radius:var(--radius-pill);
  border:1px solid transparent; line-height:1; cursor:pointer;
  -webkit-backdrop-filter:blur(14px) saturate(120%);
          backdrop-filter:blur(14px) saturate(120%);
  transition:background var(--dur-hover) var(--ease-out),
             border-color var(--dur-hover) var(--ease-out),
             color var(--dur-hover) var(--ease-out),
             box-shadow var(--dur-hover) var(--ease-out);
}
.btn .btn-arrow { transition:transform var(--dur-hover) var(--ease-out); flex:none; }
.btn:hover .btn-arrow { transform:translateX(4px); }
.btn[disabled],.btn[aria-disabled="true"] { opacity:.4; pointer-events:none; }

/* primary — brass-tinted frosted; gold text reads on any surface */
.btn-primary {
  background:rgba(199,160,106,0.18);
  color:var(--gold);
  border-color:rgba(199,160,106,0.42);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.06);
}
.btn-primary:hover {
  background:rgba(199,160,106,0.32);
  border-color:var(--gold);
  color:var(--on-media);
}

/* ghost — pearl frosted; quietest hairline */
.btn-ghost {
  background:rgba(236,234,227,0.08);
  color:var(--ink);
  border-color:rgba(236,234,227,0.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05);
}
.btn-ghost:hover {
  background:rgba(236,234,227,0.18);
  border-color:rgba(236,234,227,0.55);
}

/* small variant — used in cards & filter chips */
.btn-sm { padding:10px 20px; font-size:.68rem; letter-spacing:.16em; }

/* Solid fallback for browsers without backdrop-filter (older Safari, IE).
   Without the blur the frosted look collapses — give those a flat surface. */
@supports not ((-webkit-backdrop-filter:blur(2px)) or (backdrop-filter:blur(2px))) {
  .btn-primary { background:rgba(199,160,106,0.85); color:var(--bg); border-color:var(--gold); }
  .btn-primary:hover { background:var(--gold); }
  .btn-ghost   { background:rgba(32,32,36,0.85); color:var(--ink); border-color:rgba(236,234,227,0.5); }
  .btn-ghost:hover   { background:rgba(50,50,54,0.92); }
}

/* gold underline link */
.link-gold {
  color:var(--gold); background-image:linear-gradient(var(--gold),var(--gold));
  background-repeat:no-repeat; background-position:0 100%;
  background-size:0 1px; transition:background-size var(--dur-hover) var(--ease-out);
  padding-bottom:1px;
}
.link-gold:hover { background-size:100% 1px; }

/* ── Responsive button sizing ── */
@media (max-width:1023px){
  /* the nav CTA is duplicated in the mobile menu — keep the top bar uncluttered */
  .nav .nav-actions .btn { display:none; }
}
@media (max-width:600px){
  .btn { padding:15px 26px; font-size:.72rem; gap:.5rem; }
}
@media (max-width:460px){
  .hero-cta { flex-direction:column; align-items:stretch; }
  .hero-cta .btn { width:100%; justify-content:center; }
  .cta-actions { flex-direction:column; align-items:stretch; }
  .cta-actions .btn { width:100%; justify-content:center; }
}

/* ── Navigation (design-system §7.8) ─────────────────────────────────────── */
.nav {
  position:fixed; inset:0 0 auto 0; z-index:90;
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--space-4); height:var(--nav-h);
  padding-inline:var(--gutter);
  transition:height var(--dur-hover) var(--ease-out),
             background var(--dur-hover) var(--ease-out);
}
.nav::after {
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:var(--hairline); transform:scaleX(0); transform-origin:left;
  transition:transform var(--dur-hover) var(--ease-out);
}
.nav.scrolled {
  height:64px; background:rgba(23,23,26,0.85);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
}
.nav.scrolled::after { transform:scaleX(1); }
/* hero variant — light chrome over a dark photo, reverts once scrolled */
.nav--hero:not(.scrolled) .nav-wordmark,
.nav--hero:not(.scrolled) .nav-link { color:var(--on-media); }
.nav--hero:not(.scrolled) .nav-link::after { background:var(--on-media); }
.nav--hero:not(.scrolled) .nav-link.is-active { color:var(--on-media); }
.nav--hero:not(.scrolled) .lang-toggle a { color:rgba(242,239,232,.7); }
.nav--hero:not(.scrolled) .lang-toggle a.is-active { color:var(--on-media); }
.nav--hero:not(.scrolled) .lang-sep { color:rgba(242,239,232,.4); }
.nav--hero:not(.scrolled) .nav-burger span { background:var(--on-media); }
.nav-wordmark { font-family:var(--font-display); font-weight:600; font-size:1.6rem; letter-spacing:-.01em; }
.nav-wordmark .dot { color:var(--gold); }
.nav-links { display:none; align-items:center; gap:var(--space-5); }
@media (min-width:1024px){ .nav-links { display:flex; } }
.nav-link {
  position:relative; font-size:.75rem; letter-spacing:.16em;
  text-transform:uppercase; font-weight:600; color:var(--ink); padding-block:.4rem;
}
.nav-link::after {
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--gold); transition:width var(--dur-hover) var(--ease-out);
}
.nav-link:hover::after,.nav-link.is-active::after { width:100%; }
.nav-link.is-active { color:var(--gold); }
.nav-actions { display:flex; align-items:center; gap:var(--space-4); }

/* language toggle */
.lang-toggle { display:flex; align-items:center; gap:.45rem; font-size:.75rem; letter-spacing:.1em; font-weight:600; }
.lang-toggle a { color:var(--ink-muted); transition:color var(--dur-fast); }
.lang-toggle a.is-active { color:var(--ink); }
.lang-toggle a:hover { color:var(--gold); }
.lang-sep { color:var(--hairline-2); }

/* hamburger */
.nav-burger { display:inline-flex; flex-direction:column; gap:5px; width:44px; height:44px;
  align-items:center; justify-content:center; background:none; border:none; }
@media (min-width:1024px){ .nav-burger { display:none; } }
.nav-burger span { width:22px; height:1.5px; background:var(--ink); transition:transform var(--dur-hover) var(--ease-out),opacity var(--dur-fast); }
.nav-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* mobile overlay */
.mobile-menu {
  position:fixed; inset:0; z-index:80; background:var(--bg);
  display:flex; flex-direction:column; justify-content:center; gap:var(--space-3);
  padding:var(--gutter); opacity:0; visibility:hidden;
  transition:opacity var(--dur-hover) var(--ease-out),visibility var(--dur-hover);
}
.mobile-menu.open { opacity:1; visibility:visible; }
.mobile-menu a.m-link {
  font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,8vw,3rem);
  color:var(--ink); opacity:0; transform:translateY(20px);
}
.mobile-menu.open a.m-link { animation:mLink .5s var(--ease-out) forwards; animation-delay:calc(var(--i) * .07s); }
@keyframes mLink { to { opacity:1; transform:translateY(0); } }
.mobile-menu .m-foot { margin-top:var(--space-5); display:flex; flex-direction:column; gap:var(--space-3); }

/* ── Hero slider (design-system §7.1) ────────────────────────────────────── */
.hero { position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero-stage { position:absolute; inset:0; }
.hero-slide { position:absolute; inset:0; opacity:0; transition:opacity var(--dur-slide) var(--ease-inout); }
.hero-slide.active { opacity:1; }
.hero-slide img { width:100%; height:100%; object-fit:cover; }
.hero-scrim {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(42,38,34,.18) 0%,rgba(42,38,34,0) 38%,rgba(42,38,34,.34) 72%,rgba(42,38,34,.62) 100%);
}
.hero-inner { position:relative; z-index:2; width:100%; padding-bottom:var(--space-8); }
.hero-eyebrow { color:#F2E9D6; }
.hero-eyebrow::before { background:#F2E9D6; }
.hero h1 { color:var(--on-media); max-width:16ch; }
.hero-sub { color:rgba(251,248,243,.86); margin-top:var(--space-4); max-width:44ch; }
.hero-cta { margin-top:var(--space-5); display:flex; flex-wrap:wrap; gap:var(--space-3); }
.hero-meta {
  position:absolute; right:var(--gutter); bottom:var(--space-7); z-index:2;
  display:flex; align-items:center; gap:var(--space-3); color:rgba(251,248,243,.8);
}
.hero-count .now { color:var(--gold); }
.hero-navbtn { background:none; border:none; color:rgba(251,248,243,.8); font-size:.75rem;
  letter-spacing:.14em; text-transform:uppercase; font-weight:600; padding:.4rem; }
.hero-navbtn:hover { color:var(--on-media); }
.hero-scroll {
  position:absolute; left:var(--gutter); bottom:var(--space-7); z-index:2;
  display:flex; align-items:center; gap:.6rem; color:rgba(251,248,243,.7);
  font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
}
.hero-scroll .line { width:48px; height:1px; background:currentColor; position:relative; overflow:hidden; }
.hero-scroll .line::after { content:""; position:absolute; inset:0; background:var(--on-media); animation:scrollLine 2.4s var(--ease-inout) infinite; }
@keyframes scrollLine { 0%{transform:translateX(-100%);} 60%,100%{transform:translateX(100%);} }

/* ── Category grid — emrekazak.com-style cover cards ─────────────────────────
   The photograph fills the whole card; a bottom scrim carries the label
   (eyebrow · title · subtitle · count) over the image. The <a> owns the
   scroll-in reveal, the inner box owns the 3-D tilt — kept on separate
   elements so neither animation locks the other's transform. */
.cat-grid { display:grid; grid-template-columns:1fr; gap:var(--space-5); }
@media (min-width:680px){ .cat-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){
  .cat-grid { grid-template-columns:repeat(3,1fr); gap:var(--space-6); }
  .cat-grid > :nth-child(3n+2) { margin-top:var(--space-8); }
}
.cat-card {
  position:relative; display:block;
  aspect-ratio:4/5; border-radius:var(--radius-lg);
}
.cat-card-inner {
  position:absolute; inset:0; border-radius:inherit; overflow:hidden;
  background:var(--surface-sage);
  transition:box-shadow var(--dur-hover) var(--ease-out);
}
@media (hover:hover){
  .cat-card:hover .cat-card-inner { box-shadow:0 28px 52px -26px rgba(0,0,0,0.8); }
}
.cat-card-media { position:absolute; inset:0; }
.cat-card-media img,.cat-card-media .ph {
  width:100%; height:100%; object-fit:cover;
  transition:transform var(--dur-slide) var(--ease-out);
}
.cat-card:hover .cat-card-media img { transform:scale(1.06); }
/* scrim — keeps the label legible over any photograph */
.cat-card-scrim {
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(to top,
    rgba(7,7,9,0.92) 0%, rgba(7,7,9,0.64) 26%,
    rgba(7,7,9,0.14) 56%, transparent 80%);
}
.cat-card-label {
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  display:flex; flex-direction:column; gap:.5rem;
  padding:var(--space-4);
}
.cat-card-title { color:var(--on-media); transition:transform var(--dur-hover) var(--ease-out); }
.cat-card:hover .cat-card-title { transform:translateY(-3px); }
.cat-card-sub { color:rgba(242,239,232,0.74); }
.cat-card-foot {
  display:flex; align-items:center; gap:.75rem; margin-top:.35rem;
  color:rgba(242,239,232,0.6);
}
.cat-card-foot .rule { flex:1; height:1px; background:rgba(242,239,232,0.22); }
.cat-card-foot .arrow { transition:transform var(--dur-hover) var(--ease-out); }
.cat-card:hover .cat-card-foot .arrow { transform:translateX(4px); }

/* image placeholder when no cover/photo exists */
.ph {
  background:linear-gradient(135deg,var(--surface-sage),var(--bg));
  display:flex; align-items:center; justify-content:center; color:var(--sage);
}
.ph svg { width:38px; height:38px; opacity:.5; }

/* ── Masonry gallery — emrekazak.com-style photo portfolio grid ─────────────
   CSS columns native masonry: zero gaps between mixed aspect ratios, no JS
   layout pass, no ResizeObserver. Items flow top-to-bottom per column.
   Responsive column-gap + item margin match emrekazak.com (16 / 20 / 10 px). */
.masonry { columns:3; column-gap:20px; }
@media (max-width:1023px){ .masonry { columns:2; column-gap:16px; } }
@media (max-width:560px) { .masonry { columns:1; column-gap:0; } }

.masonry-item {
  display:block;
  break-inside:avoid; -webkit-column-break-inside:avoid; page-break-inside:avoid;
  margin-bottom:16px;
  position:relative; overflow:hidden; cursor:pointer;
  background:var(--surface-sage); border-radius:var(--radius-sm);
  transition:transform var(--dur-hover) var(--ease-out),
             box-shadow var(--dur-hover) var(--ease-out);
}
@media (min-width:768px){ .masonry-item { margin-bottom:20px; } }
@media (max-width:480px){ .masonry-item { margin-bottom:10px; } }
.masonry-item img { width:100%; height:auto; display:block; }

/* hover — the whole card lifts (emrekazak.com signature); the soft shadow
   makes that lift read against the dark canvas. Pointer devices only. */
@media (hover:hover){
  .masonry-item:hover {
    transform:translateY(-4px);
    box-shadow:0 18px 38px -18px rgba(0,0,0,.7);
  }
}

/* fade-in stagger — animated on the <img>, not the <figure>: the figure owns
   the :hover lift transform, and an entry animation with fill:both would
   otherwise lock that property. 20ms/item = emrekazak.com cadence. */
.masonry-item.gs-in img {
  animation:fadeUp .45s var(--ease-out) both;
  animation-delay:calc(var(--i,0) * 20ms);
}
@keyframes fadeUp { from{opacity:0;transform:translateY(12px);} to{opacity:1;transform:translateY(0);} }

/* ── Reel card (design-system §7.4) ──────────────────────────────────────── */
.reel-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-4); }
@media (min-width:768px){ .reel-grid { grid-template-columns:repeat(3,1fr); gap:var(--space-5); } }
@media (min-width:1100px){ .reel-grid { grid-template-columns:repeat(4,1fr); } }
.reel-card { display:flex; flex-direction:column; gap:var(--space-3); }
.reel-frame {
  position:relative; aspect-ratio:9/16; overflow:hidden;
  background:var(--surface-sage); border:1px solid var(--hairline);
  border-radius:var(--radius);
}
.reel-frame iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.reel-poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.reel-play {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:56px; height:56px; border-radius:50%; border:1px solid rgba(251,248,243,.7);
  background:var(--ink-overlay); display:flex; align-items:center; justify-content:center;
  transition:background var(--dur-hover),border-color var(--dur-hover),transform var(--dur-hover) var(--ease-out);
}
.reel-frame:hover .reel-play { background:var(--gold); border-color:var(--gold); transform:translate(-50%,-50%) scale(1.06); }
.reel-play svg { width:20px; height:20px; fill:var(--on-media); margin-left:3px; }
.reel-cap { color:var(--ink-muted); }
.reel-link { display:inline-flex; align-items:center; gap:.4rem; }

/* ── Locations strip ─────────────────────────────────────────────────────── */
.loc-list { display:flex; flex-wrap:wrap; gap:.6rem var(--space-3); }
.loc-chip {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-display); font-weight:500; font-size:clamp(1.25rem,2.4vw,2rem);
  color:var(--ink);
}
.loc-chip::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--terracotta); flex-shrink:0; }

/* locations marquee — kinetic place names */
.loc-marquee {
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.loc-track {
  display:flex; align-items:center; width:max-content;
  animation:locScroll 42s linear infinite;
}
/* margin (not gap) so the duplicated set loops seamlessly at translateX(-50%) */
.loc-track .loc-chip { margin-right:var(--space-5); }
.loc-marquee:hover .loc-track,
.loc-marquee:focus-within .loc-track { animation-play-state:paused; }
@keyframes locScroll { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ── Forms (design-system §7.6) ──────────────────────────────────────────── */
.field { display:flex; flex-direction:column; gap:.4rem; }
.field label { color:var(--sage); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; font-weight:600; }
.field .req { color:var(--terracotta); }
.field input,.field textarea,.field select {
  width:100%; background:var(--surface); color:var(--ink);
  border:1px solid var(--hairline); border-radius:var(--radius-sm);
  padding:.85rem 1.1rem; font-family:var(--font-body); font-size:1rem;
  transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);
}
.field input::placeholder,.field textarea::placeholder { color:var(--ink-muted); opacity:.7; }
.field input:focus,.field textarea:focus,.field select:focus {
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-soft);
}
.field textarea { resize:vertical; min-height:130px; }
.field select { appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%239A988F' stroke-width='1.6'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1.1rem center; padding-right:2.6rem;
}
.field.has-error input,.field.has-error textarea,.field.has-error select { border-color:var(--terracotta); }
.field-hint { color:var(--ink-muted); }
.form-note { color:var(--ink-muted); }
.form-msg { padding:var(--space-3) var(--space-4); border:1px solid var(--hairline); margin-bottom:var(--space-4); border-radius:var(--radius-sm); }
.form-msg.ok { border-color:var(--gold); background:var(--gold-soft); }
.form-msg.err { border-color:var(--terracotta); background:rgba(176,118,79,.08); }

/* ── Lightbox (design-system §7.7) ───────────────────────────────────────── */
.lightbox {
  position:fixed; inset:0; z-index:200; display:none;
  align-items:center; justify-content:center; padding:var(--space-5);
  background:rgba(7,7,9,.96); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
}
.lightbox.open { display:flex; }
.lightbox img {
  max-width:100%; max-height:92vh; object-fit:contain;
  opacity:0; transform:scale(.96); box-shadow:0 30px 80px rgba(0,0,0,.55);
  border-radius:var(--radius-sm);
  transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-hover) var(--ease-out);
}
.lightbox.open img { opacity:1; transform:scale(1); }
.lightbox-bar { position:absolute; left:0; right:0; bottom:var(--space-5);
  display:flex; align-items:center; justify-content:center; gap:var(--space-4); color:var(--on-media); }
.lightbox-btn {
  position:absolute; background:rgba(242,239,232,.12); border:1px solid rgba(242,239,232,.25);
  color:var(--on-media); width:46px; height:46px; display:flex; align-items:center; justify-content:center;
  transition:background var(--dur-fast); border-radius:var(--radius-pill);
}
.lightbox-btn:hover { background:rgba(251,248,243,.24); }
.lightbox-close { top:var(--space-5); right:var(--space-5); }
.lightbox-prev { left:var(--space-4); top:50%; transform:translateY(-50%); }
.lightbox-next { right:var(--space-4); top:50%; transform:translateY(-50%); }
.lightbox-count { font-size:.8125rem; letter-spacing:.08em; }

/* ── Reel video modal — self-hosted reel player ──────────────────────────── */
.reel-modal {
  position:fixed; inset:0; z-index:200; display:none;
  align-items:center; justify-content:center; padding:var(--space-5);
  background:rgba(7,7,9,.96);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
}
.reel-modal.open { display:flex; }
.reel-modal-stage {
  position:relative;
  width:min(94vw, calc(86vh * 9 / 16));
  height:min(86vh, calc(94vw * 16 / 9));
  background:#000; border-radius:var(--radius); overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.reel-modal-video {
  width:100%; height:100%; object-fit:contain; display:block;
  opacity:0; transition:opacity var(--dur-fast) var(--ease-out);
}
.reel-modal.open .reel-modal-video { opacity:1; }
.reel-modal-close {
  position:absolute; top:var(--space-5); right:var(--space-5);
  width:46px; height:46px; border-radius:var(--radius-pill);
  display:flex; align-items:center; justify-content:center;
  background:rgba(242,239,232,.12); border:1px solid rgba(242,239,232,.25);
  color:var(--on-media); transition:background var(--dur-fast) var(--ease-out);
}
.reel-modal-close:hover { background:rgba(251,248,243,.24); }
@media (max-width:600px){
  .reel-modal { padding:0; }
  .reel-modal-stage { width:100vw; height:100svh; border-radius:0; }
  .reel-modal-close { top:12px; right:12px; }
}

/* ── Footer ──────────────────────────────────────────────────────────────── */
.site-foot { background:var(--surface-sage); padding-block:var(--space-8) var(--space-5); }
.foot-grid { display:grid; grid-template-columns:1fr; gap:var(--space-6); }
@media (min-width:768px){ .foot-grid { grid-template-columns:1.6fr 1fr 1fr; } }
.foot-col h4 { font-family:var(--font-body); font-size:.7rem; letter-spacing:.18em;
  text-transform:uppercase; font-weight:600; color:var(--sage); margin-bottom:var(--space-3); }
.foot-col a { display:block; color:var(--ink-muted); padding:.25rem 0; transition:color var(--dur-fast); }
.foot-col a:hover { color:var(--gold); }
.foot-base { margin-top:var(--space-7); padding-top:var(--space-4); border-top:1px solid var(--hairline);
  display:flex; flex-wrap:wrap; gap:var(--space-3); justify-content:space-between; color:var(--ink-muted); }

/* ── Page hero (interior pages) ──────────────────────────────────────────── */
.page-hero { padding-top:calc(var(--nav-h) + var(--space-7)); padding-bottom:var(--space-6); }
.page-hero .crumbs { display:flex; gap:.5rem; color:var(--ink-muted); margin-bottom:var(--space-4); }
.page-hero .crumbs a:hover { color:var(--gold); }

/* ── Reduced motion ──────────────────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.01ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important; }
  .gs-hidden { opacity:1; transform:none; }
  .gs-line-hidden { transform:scaleX(1); }
  .grain { animation:none; }
  .hero-scroll .line::after { animation:none; }
  .loc-marquee { overflow-x:auto; -webkit-mask-image:none; mask-image:none; }
  .loc-track { animation:none; }
  /* new motion layer — instant final state, no transforms */
  html.js main[data-page-fade] { opacity:1 !important; animation:none !important; }
  .img-reveal { clip-path:none !important; transform:none !important; will-change:auto; }
  .btn[data-magnetic] { transform:none !important; }
}
