/* ============================================================
   DA ELEMENTS — Editorial Atelier
   Tokens → base → components → sections → responsive
   ============================================================ */

:root {
  /* palette */
  --ink: #16120c;
  --ink-soft: #2a241c;
  --bg: #f4efe6;
  --bg-2: #ebe4d7;
  --bg-3: #e3dac9;
  --paper: #faf7f0;
  --bronze: #a8744a;
  --bronze-2: #c79a6b;
  --muted: #6c6256;
  --line: rgba(22, 18, 12, 0.14);
  --line-light: rgba(244, 239, 230, 0.18);
  --night: #16120c;                       /* always-dark section bg (work/footer/menu/loader) */
  --nav-bg: rgba(244, 239, 230, 0.82);    /* scrolled nav surface */
  --track: rgba(120, 110, 98, 0.4);       /* theme-switch off track */

  /* type */
  --serif: "Fraunces", Georgia, serif;
  --sans: "Manrope", system-ui, sans-serif;

  /* fluid scale */
  --step--1: clamp(0.78rem, 0.74rem + 0.2vw, 0.9rem);
  --step-0: clamp(1rem, 0.95rem + 0.25vw, 1.15rem);
  --step-1: clamp(1.2rem, 1.05rem + 0.7vw, 1.6rem);
  --step-2: clamp(1.6rem, 1.3rem + 1.5vw, 2.6rem);
  --step-3: clamp(2.2rem, 1.6rem + 3vw, 4.2rem);
  --step-4: clamp(3rem, 1.8rem + 6vw, 7.5rem);

  --maxw: 1480px;
  --gutter: clamp(1.25rem, 4vw, 5rem);
  --radius: 4px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- dark theme ---------- */
html[data-theme="dark"] {
  --ink: #efe7da;          /* primary text becomes light */
  --ink-soft: #d6cdbf;
  --bg: #14110d;           /* page surfaces become dark */
  --bg-2: #1b1712;
  --bg-3: #221d17;
  --paper: #faf7f0;        /* stays light: text on always-dark sections */
  --bronze: #bb8d5e;       /* nudged brighter for dark backgrounds */
  --bronze-2: #d4aa79;
  --muted: #9a8f80;
  --line: rgba(239, 231, 218, 0.14);
  --line-light: rgba(239, 231, 218, 0.16);
  --night: #0c0a07;        /* deepen the always-dark sections */
  --nav-bg: rgba(18, 15, 11, 0.82);
  --track: rgba(255, 255, 255, 0.22);
}
html { transition: background-color .5s var(--ease); }
body { transition: background-color .5s var(--ease), color .5s var(--ease); }

/* Day / night ambience for content imagery (not the hero).
   "What we do" service images use REAL night renders (true lighting), crossfaded
   by theme. Work / intro imagery still uses the CSS dim treatment. */

/* Service images: real daytime photo + real night render stacked, crossfaded. */
.svc__media .svc__img--night {
  position: absolute; inset: 0; z-index: 2; opacity: 0;
  transition: opacity .9s var(--ease), transform 1s var(--ease);
}
html[data-theme="dark"] .svc__media .svc__img--night { opacity: 1; }

/* Intro studio image: stopgap CSS dim-to-night treatment.
   (Recent-projects images/videos stay full-brightness in both themes.) */
.intro__figure img {
  transition: transform 1.1s var(--ease), filter .9s var(--ease);
}
html[data-theme="dark"] .intro__figure img {
  filter: brightness(.58) contrast(1.05) saturate(.9);
}
.project__img { position: relative; }

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: var(--step-0);
  line-height: 1.6;
  font-weight: 400;
  overflow-x: hidden;
}
body.lock { overflow: hidden; height: 100vh; }
img, video, canvas { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
ul, ol { list-style: none; }
::selection { background: var(--bronze); color: var(--paper); }

h1, h2, h3, blockquote { font-family: var(--serif); font-weight: 350; line-height: 1.02; letter-spacing: -0.02em; text-wrap: balance; }
em { font-style: italic; }

/* hide native cursor on capable pointers */
@media (hover: hover) and (pointer: fine) {
  body { cursor: none; }
  a, button, [data-magnetic], [data-cursor-hover] { cursor: none; }
}

/* ---------- custom cursor ---------- */
.cursor {
  position: fixed; top: 0; left: 0; z-index: 9999;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--bronze);
  pointer-events: none; mix-blend-mode: normal;
  transform: translate(-50%, -50%);
  transition: width .35s var(--ease), height .35s var(--ease), background .35s var(--ease);
  display: grid; place-items: center;
}
.cursor.is-hover { width: 76px; height: 76px; background: rgba(168,116,74,0.92); }
.cursor.is-down { transform: translate(-50%,-50%) scale(0.7); }
.cursor__label {
  font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--paper); opacity: 0; transform: scale(.6);
  transition: opacity .3s, transform .3s;
}
.cursor.is-hover .cursor__label { opacity: 1; transform: scale(1); }
@media (hover: none), (pointer: coarse) { .cursor { display: none; } }

/* ---------- loader ---------- */
.loader {
  position: fixed; inset: 0; z-index: 10000; background: var(--night);
  display: grid; place-items: center;
}
.loader.is-done { pointer-events: none; }
/* Split-curtain opening */
.loader { background: transparent; }
.loader__panel { position: absolute; left: 0; width: 100%; height: 50%; background: var(--night); will-change: transform; }
.loader__panel--top { top: 0; }
.loader__panel--bottom { bottom: 0; }
.loader__mark { position: relative; z-index: 2; text-align: center; color: var(--paper); display: flex; flex-direction: column; align-items: center; gap: .6rem; }
.loader__mark-row { display: block; overflow: hidden; font-family: var(--serif); font-size: clamp(2rem, 7vw, 4.5rem); letter-spacing: -.02em; line-height: 1; }
.loader__mark-row > span { display: inline-block; transform: translateY(110%); will-change: transform; }
.loader__mark-sub { display: block; overflow: hidden; font-size: 10px; letter-spacing: .36em; text-transform: uppercase; color: var(--bronze-2); }
.loader__mark-sub > span { display: inline-block; transform: translateY(110%); }

/* ---------- scroll progress ---------- */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 2px; width: 100%; transform: scaleX(0);
  transform-origin: 0 50%; background: var(--bronze); z-index: 9000;
}

/* ---------- nav ---------- */
.nav {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 800;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(1rem,2.2vw,1.6rem) var(--gutter);
  color: var(--paper);
  transition: color .5s var(--ease), padding .5s var(--ease), background .5s var(--ease);
}
.nav.is-scrolled {
  color: var(--ink);
  background: var(--nav-bg);
  backdrop-filter: blur(14px);
  padding-top: .85rem; padding-bottom: .85rem;
  border-bottom: 1px solid var(--line);
}
.nav__brand { display: flex; flex-direction: row; align-items: center; gap: clamp(.5rem, 1vw, .8rem); line-height: 1; }
.nav__wordmark { display: flex; flex-direction: column; line-height: 1; }
.nav__logo { font-family: var(--serif); font-size: var(--step-1); letter-spacing: -.01em; }
.nav__tag { font-size: 10px; letter-spacing: .34em; text-transform: uppercase; opacity: .65; margin-top: .35rem; }
.nav__links { display: flex; gap: clamp(1.2rem, 2.4vw, 2.6rem); }
.nav__links a { position: relative; font-size: var(--step--1); letter-spacing: .04em; padding: .2rem 0; }
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; height: 1px; width: 100%;
  background: currentColor; transform: scaleX(0); transform-origin: 100% 50%;
  transition: transform .45s var(--ease);
}
.nav__links a:hover::after { transform: scaleX(1); transform-origin: 0 50%; }

/* Brand logo mark in the header. White over the dark hero; the logo's own
   charcoal once the nav settles onto the light bar (dark theme keeps it white). */
.nav__logo-img { height: clamp(40px, 4.6vw, 56px); width: auto; display: block; filter: brightness(0) invert(1); transition: filter .5s var(--ease); }
.nav.is-scrolled .nav__logo-img { height: clamp(36px, 4vw, 48px); }
.nav.is-scrolled .nav__logo-img { filter: none; }
html[data-theme="dark"] .nav.is-scrolled .nav__logo-img { filter: brightness(0) invert(1); }

/* ---------- theme switch (vanilla port of Ark UI Switch) ---------- */
.nav__actions { display: flex; align-items: center; gap: clamp(.9rem, 2vw, 1.5rem); }
.theme-switch { display: inline-flex; align-items: center; gap: .5rem; color: inherit; }
.theme-switch__icon { width: 1rem; height: 1rem; opacity: .45; transition: opacity .2s var(--ease); }
.theme-switch[aria-checked="false"] .theme-switch__icon--moon { opacity: 1; }
.theme-switch[aria-checked="true"]  .theme-switch__icon--sun  { opacity: 1; }
.theme-switch__control {
  position: relative; display: inline-flex; align-items: center;
  width: 2.75rem; padding: .125rem; border-radius: 9999px;
  background: var(--track); transition: background .2s ease-in-out;
}
.theme-switch[aria-checked="true"] .theme-switch__control { background: var(--bronze); }
.theme-switch:focus-visible { outline: none; }
.theme-switch:focus-visible .theme-switch__control { box-shadow: 0 0 0 2px var(--track); }
.theme-switch__thumb {
  width: 1.25rem; height: 1.25rem; border-radius: 9999px; background: #fff;
  box-shadow: 0 1px 2px rgba(0,0,0,.25); transition: transform .2s ease-in-out;
}
.theme-switch[aria-checked="true"] .theme-switch__thumb { transform: translateX(100%); }

/* ---------- buttons ---------- */
.btn {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  padding: .95em 1.7em; border-radius: 100px; font-size: var(--step--1);
  font-weight: 600; letter-spacing: .03em; overflow: hidden; isolation: isolate;
  border: 1px solid currentColor; transition: color .45s var(--ease);
}
.btn span { position: relative; z-index: 2; }
.btn::before {
  content: ""; position: absolute; inset: 0; z-index: 1; background: var(--bronze);
  transform: scale(1, 0); transform-origin: 50% 100%; transition: transform .5s var(--ease);
}
.btn:hover::before { transform: scale(1, 1); }
.btn--nav { color: inherit; }
.btn--nav:hover, .btn--ghost:hover, .btn--solid:hover { color: var(--paper); border-color: var(--bronze); }
.btn--ghost { color: var(--paper); }
.btn--solid { background: var(--night); color: var(--paper); border-color: var(--night); }
.btn--solid::before { background: var(--bronze); }
.btn--solid:hover { color: var(--paper); }

/* ---------- burger / mobile menu ---------- */
.nav__burger { display: none; width: 40px; height: 40px; position: relative; }
.nav__burger span { position: absolute; left: 8px; right: 8px; height: 1.5px; background: currentColor; transition: transform .4s var(--ease), opacity .3s; }
.nav__burger span:nth-child(1) { top: 16px; }
.nav__burger span:nth-child(2) { top: 23px; }
body.menu-open .nav__burger span:nth-child(1) { transform: translateY(3.5px) rotate(45deg); }
body.menu-open .nav__burger span:nth-child(2) { transform: translateY(-3.5px) rotate(-45deg); }
.menu {
  position: fixed; inset: 0; z-index: 790; background: var(--night); color: var(--paper);
  display: flex; flex-direction: column; justify-content: center; padding: var(--gutter);
  clip-path: inset(0 0 100% 0); transition: clip-path .7s var(--ease);
}
body.menu-open .menu { clip-path: inset(0 0 0 0); }
.menu__links { display: flex; flex-direction: column; gap: .4rem; }
.menu__links a { font-family: var(--serif); font-size: clamp(2.4rem,11vw,4rem); line-height: 1.05; }
.menu__foot { display: flex; gap: 2rem; margin-top: 3rem; font-size: var(--step--1); opacity: .7; flex-wrap: wrap; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: flex-end; padding: var(--gutter); overflow: hidden; }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__slides { position: absolute; inset: 0; }
.hero__slide { position: absolute; inset: 0; opacity: 0; visibility: hidden; transition: opacity 1.2s var(--ease), visibility 1.2s var(--ease); }
.hero__slide.is-active { opacity: 1; visibility: visible; }
.hero__slide img, .hero__video, .hero__img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02) contrast(1.02); }
.hero__img { position: absolute; inset: 0; }
/* interactive hover-to-preview layer */
.hero__peek { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.06); transition: opacity .7s var(--ease), transform 1.4s var(--ease); }
.hero__peek.is-shown { opacity: 1; transform: scale(1); }
/* featured-work rail */
.hero__peeks { position: relative; z-index: 2; max-width: var(--maxw); width: 100%; margin: clamp(1.4rem,4vh,2.4rem) auto 0; color: var(--paper); display: flex; align-items: center; gap: clamp(1rem,3vw,2.4rem); flex-wrap: wrap; border-top: 1px solid rgba(244,239,230,.18); padding-top: 1.1rem; }
.hero__peeks-label { font-size: 10px; letter-spacing: .3em; text-transform: uppercase; color: rgba(244,239,230,.55); white-space: nowrap; }
.hero__peeks-list { display: flex; gap: clamp(1rem,2.6vw,2.2rem); flex-wrap: wrap; }
.hero__peek-btn { position: relative; font-family: var(--serif); font-size: var(--step-1); color: var(--paper); line-height: 1; opacity: .55; transition: opacity .4s var(--ease); }
.hero__peek-btn span { position: relative; }
.hero__peek-btn span::after { content: ""; position: absolute; left: 0; bottom: -4px; height: 1px; width: 100%; background: var(--bronze-2); transform: scaleX(0); transform-origin: 0 50%; transition: transform .45s var(--ease); }
.hero__peek-btn:hover { opacity: 1; }
.hero__peek-btn:hover span::after { transform: scaleX(1); }
/* Ken Burns slow zoom while a slide is active */
.hero__slide img { transform: scale(1.001); }
.hero__slide.is-active img { animation: kenburns 8s var(--ease) forwards; }
@keyframes kenburns { from { transform: scale(1.001); } to { transform: scale(1.12); } }
.hero__gl { position: absolute; inset: 0; width: 100%; height: 100%; mix-blend-mode: soft-light; opacity: .9; pointer-events: none; }
.hero__veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(22,18,12,.55) 0%, rgba(22,18,12,.08) 32%, rgba(22,18,12,.2) 62%, rgba(22,18,12,.82) 100%);
}
.hero__content { position: relative; z-index: 2; color: var(--paper); max-width: var(--maxw); width: 100%; margin: 0 auto; padding-bottom: clamp(1rem, 4vh, 3rem); }

/* Editorial (Asterix-style) hero: full-bleed media + giant offset two-word display */
.hero--editorial { justify-content: center; }
.hero--editorial .hero__content { padding-bottom: 0; margin-top: clamp(3rem, 8vh, 6rem); }
.hero__display { font-family: var(--sans); font-weight: 200; line-height: .86; letter-spacing: -.03em; color: var(--paper); display: flex; flex-direction: column; }
.hero__word { display: block; overflow: hidden; }
.hero__word > span { display: inline-block; will-change: transform; }
.hero__word--a { font-size: clamp(3.2rem, 13vw, 12rem); }
.hero__word--b { font-size: clamp(4.4rem, 19vw, 17rem); margin-left: clamp(1.5rem, 16vw, 18rem); margin-top: -.08em; }
.hero__foot {
  position: absolute; left: var(--gutter); right: var(--gutter); bottom: var(--gutter); z-index: 2;
  max-width: var(--maxw); margin: 0 auto; color: var(--paper);
  display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; flex-wrap: wrap;
}
.hero__foot .hero__lede { max-width: 40ch; font-size: var(--step-0); opacity: .9; }
.hero__eyebrow { display: flex; align-items: center; gap: .9rem; flex-wrap: wrap; font-size: var(--step--1); letter-spacing: .22em; text-transform: uppercase; margin-bottom: clamp(1rem,3vh,2rem); opacity: .9; }
.hero__eyebrow i { width: 5px; height: 5px; border-radius: 50%; background: var(--bronze-2); display: inline-block; }
.hero__title { font-size: var(--step-4); line-height: .96; letter-spacing: -.03em; }
.hero__title .line { display: block; overflow: hidden; }
.hero__title .line > * { display: inline-block; }
.hero__title em { color: var(--bronze-2); }
.hero__bottom { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; margin-top: clamp(1.4rem,4vh,2.6rem); flex-wrap: wrap; }
.hero__lede { max-width: 42ch; font-size: var(--step-0); opacity: .9; }
/* showcase controls */
.hero__showcase { position: relative; z-index: 2; color: var(--paper); max-width: var(--maxw); width: 100%; margin: clamp(1.4rem,4vh,2.4rem) auto 0; display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; border-top: 1px solid rgba(244,239,230,.18); padding-top: 1.2rem; }
.hero__caption { display: flex; flex-direction: column; gap: .25rem; min-width: 0; overflow: hidden; }
.hero__caption-label { font-size: 10px; letter-spacing: .3em; text-transform: uppercase; color: var(--bronze-2); }
.hero__caption-name { font-family: var(--serif); font-size: var(--step-1); line-height: 1.05; }
.hero__caption-cat { font-size: var(--step--1); opacity: .7; letter-spacing: .03em; }
.hero__caption-name, .hero__caption-cat { transition: opacity .4s var(--ease), transform .4s var(--ease); }
.hero__showcase.is-changing .hero__caption-name, .hero__showcase.is-changing .hero__caption-cat { opacity: 0; transform: translateY(8px); }
.hero__rail { display: flex; gap: .6rem; }
.hero__thumb { position: relative; width: 64px; height: 44px; border-radius: 4px; overflow: hidden; opacity: .5; transition: opacity .4s var(--ease), transform .4s var(--ease); outline: 1px solid transparent; }
.hero__thumb img { width: 100%; height: 100%; object-fit: cover; }
.hero__thumb::after { content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 100%; transform: scaleX(0); transform-origin: 0 50%; background: var(--bronze-2); }
.hero__thumb:hover { opacity: .85; }
.hero__thumb.is-active { opacity: 1; }
.hero__thumb.is-active::after { animation: thumbProgress 8s linear forwards; }
@keyframes thumbProgress { from { transform: scaleX(0); } to { transform: scaleX(1); } }
.hero__counter { display: flex; align-items: center; gap: .5rem; font-size: var(--step--1); letter-spacing: .1em; font-variant-numeric: tabular-nums; }
.hero__counter [data-sc-index] { color: var(--bronze-2); }
.hero__counter i { width: 22px; height: 1px; background: rgba(244,239,230,.4); display: inline-block; }

.hero[data-showcase] .hero__scroll, .hero--editorial .hero__scroll, .hero[data-peek-root] .hero__scroll { display: none; }
.hero__scroll { position: absolute; right: var(--gutter); bottom: var(--gutter); z-index: 2; color: var(--paper); display: flex; flex-direction: column; align-items: center; gap: .6rem; font-size: 10px; letter-spacing: .3em; text-transform: uppercase; }
.hero__scroll-line { width: 1px; height: 56px; background: rgba(244,239,230,.3); overflow: hidden; position: relative; }
.hero__scroll-line i { position: absolute; top: -100%; left: 0; width: 100%; height: 100%; background: var(--bronze-2); animation: scrollLine 2.2s var(--ease) infinite; }
@keyframes scrollLine { 0% { top: -100%; } 60%,100% { top: 100%; } }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee { border-block: 1px solid var(--line); background: var(--bg-2); padding: clamp(.8rem,1.6vw,1.3rem) 0; overflow: hidden; }
.marquee__track { display: flex; align-items: center; gap: 2.4rem; white-space: nowrap; width: max-content; }
.marquee__track span { font-family: var(--serif); font-size: clamp(1.6rem,4.5vw,3.4rem); letter-spacing: -.02em; }
.marquee__track i { color: var(--bronze); font-size: clamp(1rem,2vw,1.6rem); font-style: normal; }

/* ============================================================
   INTRO
   ============================================================ */
.section-pad { padding: clamp(4rem,10vw,9rem) var(--gutter); }
.kicker { display: inline-flex; align-items: center; gap: .7rem; font-size: var(--step--1); letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-bottom: 1.4rem; }
.kicker span { color: var(--bronze); font-variant-numeric: tabular-nums; }

.intro { max-width: var(--maxw); margin: 0 auto; padding: clamp(4rem,10vw,9rem) var(--gutter) clamp(3rem,7vw,6rem); }
.intro__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(2rem,6vw,6rem); align-items: start; }
.intro__statement { font-size: var(--step-3); max-width: 14ch; }
.intro__body { padding-top: .5rem; }
.intro__body p { color: var(--ink-soft); max-width: 46ch; margin-bottom: 1.4rem; }
.stats { display: flex; gap: clamp(1.5rem,4vw,3.5rem); margin-top: 2.4rem; flex-wrap: wrap; }
.stat { display: flex; flex-direction: column; }
.stat__num, .stat__suffix { font-family: var(--serif); font-size: var(--step-3); color: var(--ink); line-height: 1; font-variant-numeric: tabular-nums; }
.stat__value { display: inline-flex; align-items: flex-start; }
.stat__suffix { font-size: var(--step-1); color: var(--bronze); line-height: 1; margin-left: .06ch; }
.stat__label { font-size: var(--step--1); color: var(--muted); margin-top: .6rem; letter-spacing: .02em; }
.intro__figure { max-width: var(--maxw); margin: clamp(2rem,5vw,4rem) auto 0; position: relative; overflow: hidden; border-radius: var(--radius); }
.intro__figure { display: grid; }
.intro__figure img { width: 100%; height: clamp(360px,60vh,640px); object-fit: cover; }
.intro__figure figcaption { font-size: var(--step--1); color: var(--muted); margin-top: .9rem; letter-spacing: .03em; }

/* ============================================================
   SERVICES
   ============================================================ */
.services { max-width: var(--maxw); margin: 0 auto; padding: clamp(3rem,7vw,6rem) var(--gutter); }
.services__head { margin-bottom: clamp(2.5rem,6vw,5rem); }
.services__title { font-size: var(--step-3); }
.svc {
  display: grid; grid-template-columns: 5rem 1fr 38%; gap: clamp(1.5rem,4vw,3.5rem);
  align-items: center; padding: clamp(2rem,5vw,4rem) 0; border-top: 1px solid var(--line);
}
.svc:last-child { border-bottom: 1px solid var(--line); }
.svc__index { font-family: var(--serif); font-size: var(--step-1); color: var(--bronze); }
.svc__text h3 { font-size: var(--step-2); margin-bottom: 1rem; }
.svc__text p { color: var(--ink-soft); max-width: 50ch; }
.svc__tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.4rem; }
.svc__tags li { font-size: var(--step--1); color: var(--muted); border: 1px solid var(--line); border-radius: 100px; padding: .35em .9em; }
.svc__media { position: relative; overflow: hidden; border-radius: var(--radius); aspect-ratio: 4/3; display: block; }
.svc__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease); }
.svc__media:hover img { transform: scale(1.06); }

/* ============================================================
   WORK — horizontal pinned
   ============================================================ */
.work { background: var(--night); color: var(--paper); padding: clamp(3rem,8vw,7rem) 0; overflow: hidden; }
.work__intro { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.work .kicker { color: rgba(244,239,230,.6); }
.work .kicker span { color: var(--bronze-2); }
.work__title { font-size: var(--step-3); }
.work__hint { font-size: var(--step--1); letter-spacing: .2em; text-transform: uppercase; color: rgba(244,239,230,.5); }
.work__viewport { margin-top: clamp(2rem,5vw,4rem); }
.work__track { display: flex; gap: clamp(1.2rem,2.4vw,2.4rem); padding: 0 var(--gutter); width: max-content; will-change: transform; }
.project { width: clamp(240px, 32vw, 430px); flex: 0 0 auto; }
.project__link { display: block; color: inherit; }
.project__img { overflow: hidden; border-radius: var(--radius); aspect-ratio: 3/4; }
.project__img img, .project__img video { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease); backface-visibility: hidden; transform: translateZ(0); }
.project:hover .project__img img, .project:hover .project__img video { transform: scale(1.05); }
.project__meta { margin-top: 1.1rem; display: flex; flex-direction: column; gap: .25rem; }
.project__meta h3 { font-size: var(--step-1); }
.project__meta span { font-size: var(--step--1); color: rgba(244,239,230,.55); letter-spacing: .03em; }
.project--cta { width: clamp(240px,30vw,360px); display: grid; }
.project__cta { border: 1px solid var(--line-light); border-radius: var(--radius); display: flex; flex-direction: column; justify-content: space-between; padding: clamp(1.5rem,3vw,2.4rem); height: 100%; transition: background .5s var(--ease); }
.project__cta:hover { background: var(--bronze); }
.project__cta span { font-family: var(--serif); font-size: var(--step-2); line-height: 1; }
.project__cta i { font-size: var(--step-2); align-self: flex-end; }

/* ============================================================
   BEFORE / AFTER
   ============================================================ */
.ba { max-width: var(--maxw); margin: 0 auto; padding: clamp(4rem,9vw,8rem) var(--gutter); display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(2rem,5vw,5rem); align-items: center; }
.ba__title { font-size: var(--step-3); margin-bottom: 1.2rem; }
.ba__text p { color: var(--ink-soft); max-width: 38ch; }
.ba__compare { position: relative; aspect-ratio: 4/3; overflow: hidden; border-radius: var(--radius); user-select: none; touch-action: pan-y; }
.ba__img { position: absolute; inset: 0; }
.ba__img img { width: 100%; height: 100%; object-fit: cover; pointer-events: none; }
.ba__img--before { -webkit-clip-path: inset(0 50% 0 0); clip-path: inset(0 50% 0 0); }
.ba__badge { position: absolute; top: 1rem; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; padding: .4em .9em; border-radius: 100px; background: rgba(22,18,12,.6); color: var(--paper); backdrop-filter: blur(4px); }
.ba__badge--before { left: 1rem; }
.ba__badge--after { right: 1rem; }
.ba__handle { position: absolute; top: 0; bottom: 0; left: 50%; width: 2px; background: var(--paper); transform: translateX(-50%); }
.ba__handle-grip { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 52px; height: 52px; border-radius: 50%; background: var(--paper); color: var(--ink); display: flex; align-items: center; justify-content: center; gap: 2px; box-shadow: 0 8px 30px rgba(0,0,0,.25); }
.ba__handle-grip i { font-style: normal; font-size: 1.1rem; line-height: 1; }

/* ============================================================
   PROCESS
   ============================================================ */
.process { max-width: var(--maxw); margin: 0 auto; padding: clamp(3rem,7vw,6rem) var(--gutter); }
.process__head { margin-bottom: clamp(2.5rem,6vw,4rem); }
.process__title { font-size: var(--step-3); }
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.2rem,3vw,2.5rem); }
.step { border-top: 1px solid var(--line); padding-top: 1.4rem; }
.step__no { font-family: var(--serif); font-size: var(--step-2); color: var(--bronze); display: block; margin-bottom: 1rem; }
.step h3 { font-size: var(--step-1); margin-bottom: .7rem; }
.step p { font-size: var(--step--1); color: var(--ink-soft); }

/* ============================================================
   QUOTE
   ============================================================ */
.quote { background: var(--bg-2); padding: clamp(4rem,9vw,7rem) var(--gutter); text-align: center; }
.quote__head { max-width: var(--maxw); margin: 0 auto clamp(2rem,4vw,3.2rem); }
.quote__head .kicker { justify-content: center; }
.quote__title { font-size: var(--step-3); }
.quote__stage { position: relative; max-width: 42ch; min-height: clamp(150px, 20vw, 230px); margin: 0 auto; }
.quote__item { position: absolute; inset: 0; width: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; opacity: 0; visibility: hidden; transform: translateY(22px) scale(.985); filter: blur(7px); pointer-events: none; transition: opacity .8s ease, transform .9s cubic-bezier(.22,1,.36,1), filter .8s ease, visibility .8s; }
.quote__item.is-active { opacity: 1; visibility: visible; transform: none; filter: blur(0); pointer-events: auto; }
@media (prefers-reduced-motion: reduce) { .quote__item { transition: opacity .3s ease; transform: none; filter: none; } }
.quote__item blockquote { font-family: var(--serif); font-weight: 350; font-size: clamp(1.25rem, 1rem + 1vw, 1.9rem); line-height: 1.32; letter-spacing: -.01em; color: var(--ink); }
.quote__item cite { display: block; font-style: normal; font-size: var(--step--1); letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-top: 1.4rem; }
.quote .word { transition: none; }
.quote__dots { display: flex; width: 100%; justify-content: center; align-items: center; gap: .55rem; margin-top: clamp(2rem,4vw,3rem); padding: 0; }
.quote__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--muted); opacity: .35; border: 0; padding: 0; cursor: pointer; transition: opacity .35s var(--ease), background .35s var(--ease), transform .35s var(--ease); }
.quote__dot.is-active { background: var(--bronze); opacity: 1; transform: scale(1.3); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { max-width: var(--maxw); margin: 0 auto; padding: clamp(4rem,9vw,8rem) var(--gutter); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem,6vw,6rem); align-items: start; }
.form__actions { display: flex; align-items: center; gap: clamp(.6rem, 1.6vw, 1rem); flex-wrap: wrap; }
.btn--outline { color: var(--ink); border-color: var(--ink); }
.btn--outline:hover { color: var(--paper); border-color: var(--bronze); }

/* Floating WhatsApp button */
.wa-fab {
  position: fixed; right: clamp(16px, 3vw, 28px); bottom: clamp(16px, 3vw, 28px);
  z-index: 850; width: clamp(52px, 6vw, 60px); height: clamp(52px, 6vw, 60px);
  border-radius: 50%; background: #25d366; color: #fff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 12px 30px -8px rgba(37,211,102,.6), 0 4px 12px rgba(0,0,0,.22);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.wa-fab svg { width: 58%; height: 58%; display: block; }
.wa-fab::before {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  border: 2px solid rgba(37,211,102,.5); animation: waPulse 2.4s var(--ease) infinite;
}
.wa-fab:hover { transform: translateY(-3px) scale(1.06); box-shadow: 0 18px 42px -8px rgba(37,211,102,.7), 0 6px 16px rgba(0,0,0,.24); }
@keyframes waPulse { 0% { transform: scale(1); opacity: .7; } 70% { transform: scale(1.5); opacity: 0; } 100% { transform: scale(1.5); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .wa-fab::before { animation: none; } }

/* Hover tooltip for social links ("Click to visit ↗") */
[data-tip] { position: relative; }
[data-tip]::after {
  content: attr(data-tip);
  position: absolute; left: 50%; bottom: 100%;
  transform: translate(-50%, 4px); transform-origin: 50% 100%;
  margin-bottom: 8px; white-space: nowrap; pointer-events: none;
  background: var(--night); color: var(--paper);
  font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .04em;
  padding: 6px 10px; border-radius: 100px;
  box-shadow: 0 10px 24px -10px rgba(0,0,0,.5);
  opacity: 0; transition: opacity .28s var(--ease), transform .28s var(--ease);
  z-index: 30;
}
[data-tip]::before {
  content: ""; position: absolute; left: 50%; bottom: 100%;
  transform: translateX(-50%); margin-bottom: 3px;
  border: 5px solid transparent; border-top-color: var(--night);
  opacity: 0; transition: opacity .28s var(--ease); z-index: 30; pointer-events: none;
}
[data-tip]:hover::after { opacity: 1; transform: translate(-50%, 0); }
[data-tip]:hover::before { opacity: 1; }
@media (hover: none) { [data-tip]::after, [data-tip]::before { display: none; } }
html[data-theme="dark"] .contact__map iframe { filter: invert(0.9) hue-rotate(180deg) brightness(0.95) contrast(0.9); }
.contact__title { font-size: var(--step-3); margin-bottom: 1.2rem; }
.contact__sub { color: var(--ink-soft); max-width: 40ch; }
.contact__info { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 1.1rem; }
.contact__info li { display: flex; flex-direction: column; gap: .2rem; border-top: 1px solid var(--line); padding-top: 1rem; }
.contact__info span { font-size: var(--step--1); letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.contact__info a { font-size: var(--step-1); font-family: var(--serif); }
.contact__phones { display: flex; flex-direction: column; gap: .15rem; }
.contact__phones a, .contact__phones span { font-size: var(--step-1); font-family: var(--serif); letter-spacing: normal; text-transform: none; }
.contact__phones a { color: var(--ink); border-bottom: 1px solid var(--line); padding-bottom: 1px; width: max-content; transition: color .3s var(--ease), border-color .3s var(--ease); }
.contact__phones a:hover { color: var(--bronze); border-color: var(--bronze); }
.contact__phones span { color: var(--muted); }
.contact__form { display: flex; flex-direction: column; gap: 1.6rem; }
.field { position: relative; }
.field input, .field select, .field textarea {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--line);
  padding: 1.4rem 0 .7rem; font: inherit; color: var(--ink); border-radius: 0; resize: none;
}
.field select { appearance: none; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--bronze); }
.field label { position: absolute; left: 0; top: 1.4rem; color: var(--muted); pointer-events: none; transition: transform .35s var(--ease), font-size .35s var(--ease), color .35s var(--ease); transform-origin: 0 0; }
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label,
.field select:focus + .label--select, .field select:valid + .label--select {
  transform: translateY(-1.5rem) scale(.78); color: var(--bronze);
}
.contact__form .btn { align-self: flex-start; margin-top: .5rem; }
.form__status { font-size: var(--step--1); color: var(--bronze); min-height: 1.2em; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--night); color: var(--paper); padding: clamp(3rem,7vw,6rem) var(--gutter) 2.5rem; }
.footer__top { display: flex; justify-content: space-between; align-items: flex-end; gap: 2rem; flex-wrap: wrap; max-width: var(--maxw); margin: 0 auto; }
.footer__brand { display: inline-block; }
.footer__logo-img { width: clamp(240px, 34vw, 420px); height: auto; display: block; filter: brightness(0) invert(1); opacity: .95; }
.footer__top p { opacity: .6; max-width: 28ch; }
.footer__links { max-width: var(--maxw); margin: 2.5rem auto; display: flex; justify-content: space-between; align-items: center; gap: 2rem; flex-wrap: wrap; border-top: 1px solid var(--line-light); padding-top: 2rem; }
.footer__nav { display: flex; gap: 2rem; flex-wrap: wrap; }
.footer__nav a { font-size: var(--step--1); letter-spacing: .04em; opacity: .8; transition: opacity .3s; }
.footer__nav a:hover { opacity: 1; color: var(--bronze-2); }
.footer__social { display: flex; gap: .75rem; }
.footer__social-link { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 1px solid var(--line-light); border-radius: 50%; color: var(--paper); opacity: .8; transition: opacity .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease); }
.footer__social-link:hover { opacity: 1; color: var(--night); background: var(--bronze-2); border-color: var(--bronze-2); }
.footer__base { max-width: var(--maxw); margin: 0 auto; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: var(--step--1); opacity: .5; }
.footer__credit a { color: var(--paper); border-bottom: 1px solid currentColor; padding-bottom: 1px; transition: color .3s var(--ease); }
.footer__credit a:hover { color: var(--bronze); }

/* ============================================================
   REVEAL ANIMATION STATES
   ============================================================ */
[data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
[data-reveal].is-in { opacity: 1; transform: none; }
.word-line { overflow: hidden; }
.word { display: inline-block; transform: translateY(110%); transition: transform .9s var(--ease); }
.word.is-in { transform: none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .nav__links, .btn--nav { display: none; }
  .nav__burger { display: block; }
  .intro__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .svc { grid-template-columns: 3rem 1fr; }
  .svc__media { grid-column: 1 / -1; margin-top: 1rem; }
  .ba { grid-template-columns: 1fr; }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .contact { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .steps { grid-template-columns: 1fr; }
  .svc { grid-template-columns: 1fr; }
  .svc__index { display: none; }
  .hero__bottom { flex-direction: column; align-items: flex-start; }
  .footer__base { flex-direction: column; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
  [data-reveal], .word { opacity: 1 !important; transform: none !important; }
  .hero__gl { display: none; }
}
