*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ──────────────────────────────────────────────
   PALETTE — extracted from brand sheet
   #F2F0ED cream · #CDBEA8 lt beige · #968774 taupe · #5F4D3E walnut
   ────────────────────────────────────────────── */
:root {
  --bg:            #F2F0ED;
  --bg-2:          #ECE6DA;
  --bg-3:          #E5DCCB;
  --bg-dark:       #2C2218;
  --bg-dark-2:     #221A12;
  --surface:       #CDBEA8;
  --accent:        #5F4D3E;
  --accent-mid:    #968774;
  --accent-deep:   #3F3327;
  --text:          #2A2118;
  --text-soft:     #4A3D30;
  --text-muted:    #8B7E6B;
  --hairline:      rgba(95, 77, 62, 0.10);
  --hairline-2:    rgba(95, 77, 62, 0.18);
  --hairline-dk:   rgba(205, 190, 168, 0.14);
  --nav-bg:        rgba(242, 240, 237, 0.86);
  --logo-mark:     url(data:image/png;base64,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);
}

/* Forced overrides via toggle */
[data-theme="dark"] {
  --bg:            #1E1812;
  --bg-2:          #251E17;
  --bg-3:          #2C241B;
  --bg-dark:       #14100B;
  --bg-dark-2:     #1A1510;
  --surface:       #3D3022;
  --accent:        #CDBEA8;
  --accent-mid:    #968774;
  --accent-deep:   #DCCEB6;
  --text:          #EFEAE0;
  --text-soft:     #D4C5AE;
  --text-muted:    #968774;
  --hairline:      rgba(205, 190, 168, 0.10);
  --hairline-2:    rgba(205, 190, 168, 0.22);
  --hairline-dk:   rgba(205, 190, 168, 0.10);
  --nav-bg:        rgba(30, 24, 18, 0.86);
}
[data-theme="light"] {
  --bg:            #F2F0ED;
  --bg-2:          #ECE6DA;
  --bg-3:          #E5DCCB;
  --bg-dark:       #2C2218;
  --bg-dark-2:     #221A12;
  --surface:       #CDBEA8;
  --accent:        #5F4D3E;
  --accent-mid:    #968774;
  --accent-deep:   #3F3327;
  --text:          #2A2118;
  --text-soft:     #4A3D30;
  --text-muted:    #8B7E6B;
  --hairline:      rgba(95, 77, 62, 0.10);
  --hairline-2:    rgba(95, 77, 62, 0.18);
  --hairline-dk:   rgba(205, 190, 168, 0.14);
  --nav-bg:        rgba(242, 240, 237, 0.86);
}

html { scroll-behavior: smooth; }
body {
  font-family: 'Jost', sans-serif;
  background: var(--bg);
  color: var(--text);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  transition: background 0.6s ease, color 0.6s ease;
}
::selection { background: var(--accent); color: var(--bg); }
img { display: block; max-width: 100%; }

/* ────────── NAV ────────── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.75rem 4rem;
  background: var(--nav-bg);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--hairline);
  animation: fadeDown 0.9s 0.1s ease both;
  transition: background 0.6s ease, border-color 0.6s ease;
}
@keyframes fadeDown { from { opacity:0; transform:translateY(-12px);} to { opacity:1; transform:none;} }

.nav-logo { display: flex; align-items: center; gap: 1rem; text-decoration: none; color: inherit; }
.logo-mark {
  width: 40px; height: 40px; flex-shrink: 0;
  background-color: var(--accent);
  -webkit-mask: var(--logo-mark) center / contain no-repeat;
          mask: var(--logo-mark) center / contain no-repeat;
  transition: background-color 0.6s ease;
}
.logo-text {
  display: flex; flex-direction: column;
  font-family: 'Cormorant Garamond', serif;
  font-size: 0.92rem; font-weight: 400;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--text); line-height: 1.25;
}
.logo-text-sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.55rem; font-weight: 300;
  letter-spacing: 0.42em; color: var(--text-muted);
  margin-top: 0.18rem;
}

.nav-links { display: flex; gap: 2.6rem; list-style: none; }
.nav-links a {
  font-size: 0.68rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--text-soft); text-decoration: none; font-weight: 300;
  position: relative; transition: color 0.3s;
}
.nav-links a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -6px;
  height: 1px; background: var(--accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.4s ease;
}
.nav-links a:hover { color: var(--text); }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-links a.is-active { color: var(--text); }
.nav-links a.is-active::after { transform: scaleX(1); }

.nav-right { display: flex; align-items: center; gap: 1.25rem; }

/* Mobile hamburger */
.nav-hamburger {
  display: none;
  background: none; border: none; cursor: pointer; padding: 0;
  width: 20px; height: 13px;
  flex-direction: column; justify-content: space-between;
  flex-shrink: 0;
}
.nav-hamburger span {
  display: block; width: 100%; height: 1px;
  background: var(--text-muted);
  transition: transform 0.35s ease, opacity 0.25s ease;
  transform-origin: center;
}
.nav-hamburger.is-open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-hamburger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger.is-open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* Mobile nav drawer */
.nav-mobile {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: min(240px, 76vw);
  z-index: 99;
  background: var(--bg);
  display: flex; flex-direction: column;
  justify-content: center;
  padding: 3.5rem 2.5rem;
  transform: translateX(-100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), background 0.6s ease;
  border-right: 1px solid var(--hairline);
}
.nav-mobile.is-open { transform: translateX(0); }
.nav-backdrop {
  position: fixed; inset: 0; z-index: 98;
  background: rgba(42, 33, 24, 0.32);
  opacity: 0; pointer-events: none;
  transition: opacity 0.4s ease;
}
.nav-backdrop.is-open { opacity: 1; pointer-events: all; }
.nav-mobile-links {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 1.6rem;
}
.nav-mobile-links a {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.3rem, 5.5vw, 1.55rem);
  font-weight: 300; font-style: italic;
  color: var(--text); text-decoration: none;
  letter-spacing: 0.01em;
  transition: color 0.3s;
}
.nav-mobile-links a:hover,
.nav-mobile-links a.is-active { color: var(--accent); }

/* Theme toggle */
.theme-toggle {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--hairline-2);
  background: transparent; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); transition: color 0.25s, border-color 0.25s, background 0.25s;
}
.theme-toggle:hover { color: var(--text); border-color: var(--accent-mid); }
.theme-toggle svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.icon-moon { display: none; }
[data-theme="dark"] .icon-sun { display: none; }
[data-theme="dark"] .icon-moon { display: block; }

/* ────────── HERO (home) ────────── */
.hero {
  min-height: 100vh;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  padding: 110px 6vw 6rem;
  margin-bottom: 5rem;
  background:
    linear-gradient(180deg, rgba(32, 22, 14, 0.42) 0%, rgba(32, 22, 14, 0.52) 55%, rgba(20, 14, 8, 0.68) 100%),
    url('https://images.unsplash.com/photo-1721630175454-0ca4517bb530?w=1920&q=75&auto=format&fit=crop') center / cover no-repeat;
  text-align: center;
  overflow: hidden;
}
[data-theme="dark"] .hero {
  background:
    linear-gradient(180deg, rgba(15, 10, 5, 0.60) 0%, rgba(15, 10, 5, 0.68) 55%, rgba(10, 7, 4, 0.78) 100%),
    url('https://images.unsplash.com/photo-1721630175454-0ca4517bb530?w=1920&q=75&auto=format&fit=crop') center / cover no-repeat;
}

.hero-content {
  position: relative; z-index: 2;
  max-width: 920px;
  animation: fadeUp 1.1s 0.35s ease both;
}
@keyframes fadeUp { from { opacity:0; transform:translateY(24px);} to { opacity:1; transform:none;} }

.hero-eyebrow {
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem; letter-spacing: 0.46em; text-transform: uppercase;
  color: rgba(244, 232, 210, 0.78); margin-bottom: 3rem; font-weight: 300;
}

.hero-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(3.4rem, 8vw, 7.8rem);
  font-weight: 300; line-height: 0.96;
  letter-spacing: -0.018em;
  color: #F2E8D6;
  margin-bottom: 2.6rem;
  text-shadow: 0 2px 30px rgba(0,0,0,0.22);
}
.hero-name em { font-style: italic; font-weight: 300; color: #E5D2B0; }

.hero-tagline {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-weight: 300;
  font-size: clamp(1.2rem, 1.8vw, 1.55rem);
  color: rgba(244, 232, 210, 0.92);
  line-height: 1.5;
  max-width: 600px;
  margin: 0 auto 3.4rem;
}

.hero-actions { display: flex; justify-content: center; }
.link-underline {
  font-size: 0.72rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--text); text-decoration: none; font-weight: 300;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--accent);
  transition: color 0.3s, border-color 0.3s, letter-spacing 0.3s;
  display: inline-block;
}
.link-underline:hover { color: var(--accent); letter-spacing: 0.36em; }

.hero .link-underline {
  color: #F2E8D6;
  border-bottom-color: #C9A878;
}
.hero .link-underline:hover {
  color: #E5D2B0;
  border-bottom-color: #E5D2B0;
}

.hero-scroll {
  position: absolute; bottom: 2.6rem; left: 0; right: 0;
  display: flex; flex-direction: column;
  align-items: center; gap: 1rem;
  animation: fadeUp 1.4s 1.4s ease both;
  z-index: 2;
}
.hero-scroll-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.58rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: rgba(244, 232, 210, 0.72); font-weight: 300;
}
.hero-scroll-line {
  width: 1px; height: 44px;
  background: rgba(244, 232, 210, 0.55);
  transform-origin: top;
  animation: scrollPulse 2.4s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%, 100% { transform: scaleY(0.45); opacity: 0.3; }
  50%      { transform: scaleY(1);    opacity: 0.7; }
}

/* ────────── PAGE HERO (sub-pages) ────────── */
.page-hero {
  padding: 11rem 6vw 4rem;
  text-align: center;
  background: var(--bg);
  transition: background 0.6s ease;
}
.page-hero-inner {
  max-width: 780px; margin: 0 auto;
  animation: fadeUp 1s 0.15s ease both;
}
.page-hero .section-index { display: inline-block; margin-bottom: 1.6rem; }
.page-hero-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.8rem, 6vw, 5rem);
  font-weight: 300; line-height: 1.02;
  letter-spacing: -0.015em; color: var(--text);
}
.page-hero-title em { font-style: italic; color: var(--accent); }
.page-hero-sub {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-weight: 300;
  font-size: clamp(1.15rem, 1.7vw, 1.45rem);
  color: var(--text-soft); line-height: 1.5;
  max-width: 580px; margin: 1.8rem auto 0;
}

/* ────────── SHARED ────────── */
.section-head { margin-bottom: 6rem; max-width: 720px; }
.section-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.2rem, 3.8vw, 3.4rem);
  font-weight: 300; line-height: 1.12;
  color: var(--text); letter-spacing: -0.005em;
}
.section-title em { font-style: italic; color: var(--accent); }
.section-lede {
  font-size: 1.02rem; line-height: 1.95;
  color: var(--text-soft); font-weight: 300;
  max-width: 520px; margin-top: 1.8rem;
}
.section-index {
  font-family: 'Cormorant Garamond', serif;
  font-size: 0.9rem; font-weight: 400; font-style: italic;
  color: var(--accent-mid); letter-spacing: 0.08em;
  margin-bottom: 1.4rem; display: block;
}

/* ────────── ABOUT / NOSOTROS ────────── */
.about {
  padding: 5rem 6vw 6rem;
  background: var(--bg);
  transition: background 0.6s ease;
}
.about-grid {
  display: grid;
  grid-template-columns: 0.9fr 1fr;
  gap: 5.5rem;
  align-items: center;
  max-width: 1240px;
  margin: 0 auto;
}
.about-visual {
  width: 100%; aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--bg-3);
  position: relative;
}
.about-visual-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  transition: transform 1.4s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.about-visual:hover .about-visual-img { transform: scale(1.04); }

.about-text { max-width: 520px; }
.about-lede {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.25rem, 1.7vw, 1.5rem);
  font-style: italic; font-weight: 300;
  color: var(--text);
  line-height: 1.5;
  margin: 1.8rem 0 2rem;
}
.about-body {
  font-size: 1.02rem; line-height: 1.95;
  color: var(--text-soft);
  font-weight: 300;
  margin-bottom: 2.8rem;
}

/* ────────── PORTFOLIO ────────── */
.portfolio {
  padding: 6rem 6vw 10rem;
  background: var(--bg);
  transition: background 0.6s ease;
}
.portfolio-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 2rem; max-width: 1400px; margin: 0 auto 4rem;
}
.portfolio-head .section-title { max-width: 540px; }

.portfolio-grid {
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 3rem 2rem;
  max-width: 1400px; margin: 0 auto;
}
.project { grid-column: span 3; }
.project.is-feature { grid-column: span 6; }
.project.is-feature .project-img { aspect-ratio: 16 / 7; }
.project.span-2 { grid-column: span 2; }
.project.span-2 .project-img { aspect-ratio: 4 / 5; }

.project-link { display: block; text-decoration: none; color: inherit; cursor: pointer; }
.project-img {
  width: 100%; aspect-ratio: 4 / 5;
  background: var(--surface);
  overflow: hidden; position: relative;
}
.project-img img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  filter: saturate(0.92);
  transition: filter 0.7s ease, transform 0.9s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.project-link:hover .project-img img { filter: saturate(1.08); transform: scale(1.025); }
.project-count {
  position: absolute; bottom: 1rem; right: 1rem;
  font-family: 'Jost', sans-serif;
  font-size: 0.58rem; letter-spacing: 0.22em; text-transform: uppercase;
  background: rgba(42, 33, 24, 0.62); color: rgba(242, 240, 237, 0.92);
  padding: 0.28em 0.75em; backdrop-filter: blur(6px);
  pointer-events: none;
}

.project-meta {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1.5rem; margin-top: 1.4rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--hairline);
  transition: border-color 0.35s;
}
.project-link:hover .project-meta { border-top-color: var(--accent); }
.project-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem; font-weight: 400;
  color: var(--text); letter-spacing: -0.002em;
}
.project-tag {
  font-size: 0.64rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 300; white-space: nowrap;
  text-align: right;
}
.project-loc::before { content: ' · '; }

/* ────────── LIGHTBOX ────────── */
.lightbox {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(26, 20, 14, 0.96);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
}
.lightbox.is-open { opacity: 1; pointer-events: all; }
.lb-img-wrap {
  max-width: 88vw; max-height: 82vh;
  display: flex; align-items: center; justify-content: center;
}
.lb-img {
  max-width: 88vw; max-height: 82vh;
  object-fit: contain; display: block;
  user-select: none;
}
.lb-close {
  position: absolute; top: 1.5rem; right: 2rem;
  background: none; border: none; cursor: pointer;
  color: rgba(242, 240, 237, 0.7); font-size: 2rem; line-height: 1;
  transition: color 0.2s; padding: 0.4rem;
}
.lb-close:hover { color: var(--bg); }
.lb-prev, .lb-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer;
  color: rgba(242, 240, 237, 0.55);
  font-size: 2.6rem; line-height: 1; padding: 1rem;
  transition: color 0.2s;
}
.lb-prev { left: 1rem; }
.lb-next { right: 1rem; }
.lb-prev:hover, .lb-next:hover { color: var(--bg); }
.lb-bar {
  position: absolute; bottom: 2rem; left: 0; right: 0;
  text-align: center;
  font-family: 'Jost', sans-serif;
  font-size: 0.62rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(242, 240, 237, 0.5);
  display: flex; justify-content: center; align-items: center; gap: 2rem;
}
.lb-project { color: rgba(242, 240, 237, 0.75); }

.portfolio-foot { margin-top: 5rem; display: flex; justify-content: flex-end; }

/* ────────── GALLERY (dedicated page) ────────── */
.gallery {
  padding: 4rem 6vw 11rem;
  background: var(--bg);
  transition: background 0.6s ease;
}
.gallery-grid {
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 3.5rem 2.5rem;
  max-width: 1400px; margin: 0 auto;
}

/* ────────── PHILOSOPHY ────────── */
.philosophy {
  padding: 10rem 6vw;
  background: var(--bg-2);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 6rem; align-items: center;
  transition: background 0.6s ease;
}
.quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 2.6vw, 2.3rem);
  font-weight: 300; font-style: italic;
  line-height: 1.32; color: var(--text);
  margin-bottom: 2rem;
  max-width: 700px;
  text-wrap: balance;
}
.quote-attr {
  font-size: 0.65rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 300;
}
.quote-attr-sep { color: var(--accent-mid); margin: 0 0.6rem; }

.phil-text {
  font-size: 1.02rem; line-height: 2; color: var(--text-soft);
  font-weight: 300; margin-bottom: 1.4rem; max-width: 480px;
}
.phil-text em { font-style: italic; color: var(--accent); font-weight: 400; }

.values {
  margin-top: 2.6rem; padding-top: 2rem;
  border-top: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: 1.1rem;
}
.value {
  font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-soft); font-weight: 300; line-height: 1.5;
}

/* ────────── TEAM ────────── */
.team {
  padding: 10rem 6vw;
  background: var(--bg);
  transition: background 0.6s ease;
}
.team-head { text-align: center; max-width: 680px; margin: 0 auto 5.5rem; }
.team-head .section-index { display: inline-block; }
.team-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 3.5rem 3rem; max-width: 1180px; margin: 0 auto;
}
.team-member { text-align: left; }
.team-photo {
  width: 100%; aspect-ratio: 3 / 4;
  overflow: hidden; position: relative;
  background: var(--bg-3); margin-bottom: 1.6rem;
}
.team-photo-img {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform 1.2s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.team-member:hover .team-photo-img { transform: scale(1.045); }
.team-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.55rem; font-weight: 400; color: var(--text);
  letter-spacing: -0.003em; margin-bottom: 0.4rem;
}
.team-role {
  font-size: 0.62rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--accent-mid); font-weight: 300; margin-bottom: 1rem;
}
.team-bio-lede {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem; font-weight: 300; line-height: 1.38;
  color: var(--text); margin-bottom: 0.9rem;
}
.team-bio {
  font-size: 0.92rem; line-height: 1.8; color: var(--text-soft);
  font-weight: 300; max-width: 340px;
}

/* ────────── INSTAGRAM ────────── */
.insta {
  padding: 9rem 6vw;
  background: var(--bg);
  transition: background 0.6s ease;
}
.insta-row {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 5.5rem;
  align-items: center;
  max-width: 1240px;
  margin: 0 auto;
}
.insta-copy { max-width: 440px; }
.insta-sub {
  font-size: 1.02rem; line-height: 1.85;
  color: var(--text-soft); font-weight: 300;
  margin: 1.6rem 0 2.4rem;
}
.insta-handle { color: var(--accent); font-style: italic; }
.insta-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.9rem;
}
behold-widget {
  grid-column: 1 / -1;
  display: block;
  width: 100%;
}
.insta-tile {
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
  background: var(--surface);
}
.insta-tile::before {
  content: ''; position: absolute; inset: 0;
  background: inherit;
  filter: saturate(0.92);
  transition: filter 0.6s ease, transform 0.8s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.insta-tile::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(42, 33, 24, 0); transition: background 0.4s;
}
.insta-tile:hover::before { filter: saturate(1.08); transform: scale(1.07); }
.insta-tile:hover::after { background: rgba(42, 33, 24, 0.18); }

.ig-1 { background: url('https://images.unsplash.com/photo-1598928387577-d49b6d399110?w=800&q=78&auto=format&fit=crop') center / cover no-repeat; }
.ig-2 { background: url('https://images.unsplash.com/photo-1643376452350-97eadd2c417f?w=800&q=78&auto=format&fit=crop') center / cover no-repeat; }
.ig-3 { background: url('https://images.unsplash.com/photo-1638885930125-85350348d266?w=800&q=78&auto=format&fit=crop') center / cover no-repeat; }
.ig-4 { background: url('https://images.unsplash.com/photo-1585418694458-dc80a5c20294?w=800&q=78&auto=format&fit=crop') center / cover no-repeat; }

/* ────────── CONTACT (home teaser, dark) ────────── */
.contact {
  padding: 10rem 6vw 8rem;
  background: var(--bg-dark); color: #E8DECB;
  text-align: center;
  transition: background 0.6s ease;
}
.contact .section-index { color: rgba(205, 190, 168, 0.55); margin-bottom: 1.5rem; }
.contact .section-title { color: #EDE5D2; max-width: 580px; margin: 0 auto; }
.contact .section-title em { color: var(--accent-mid); }

.contact-sub {
  font-size: 1.02rem; line-height: 1.95;
  color: rgba(205, 190, 168, 0.7); font-weight: 300;
  max-width: 480px; margin: 2rem auto 4.5rem;
}
.contact-details {
  display: flex; justify-content: center; gap: 5rem;
  margin-bottom: 5rem; flex-wrap: wrap;
}
.contact-detail-label {
  font-size: 0.6rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: rgba(205, 190, 168, 0.55); font-weight: 300;
  margin-bottom: 0.7rem;
}
.contact-detail-val {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem; font-weight: 400; color: #E0D4BA;
  letter-spacing: 0.005em;
}
.contact-detail-val a { color: inherit; text-decoration: none; border-bottom: 1px solid transparent; transition: border-color 0.3s; }
.contact-detail-val a:hover { border-bottom-color: var(--accent-mid); }

.contact .link-underline {
  color: #E8DECB; border-bottom-color: var(--accent-mid);
}
.contact .link-underline:hover { color: var(--accent-mid); }

/* ────────── CONTACT PAGE (form + info) ────────── */
.contact-page {
  padding: 4rem 6vw 9rem;
  background: var(--bg);
  transition: background 0.6s ease;
}
.contact-layout {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 6rem; max-width: 1240px; margin: 0 auto;
  align-items: start;
}

/* Info column */
.contact-info .section-index { display: block; }
.contact-info-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.9rem, 3vw, 2.6rem);
  font-weight: 300; line-height: 1.12; color: var(--text);
  letter-spacing: -0.005em; margin-bottom: 1.6rem;
}
.contact-info-title em { font-style: italic; color: var(--accent); }
.contact-info-lede {
  font-size: 1.02rem; line-height: 1.95; color: var(--text-soft);
  font-weight: 300; max-width: 440px; margin-bottom: 3.2rem;
}
.info-list { display: flex; flex-direction: column; gap: 2rem; }
.info-item { display: block; }
.info-label {
  font-size: 0.6rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 300; margin-bottom: 0.55rem;
}
.info-value {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem; font-weight: 400; color: var(--text);
  letter-spacing: 0.003em; line-height: 1.4;
}
.info-value a {
  color: inherit; text-decoration: none;
  border-bottom: 1px solid transparent; transition: border-color 0.3s;
}
.info-value a:hover { border-bottom-color: var(--accent); }

.social-row {
  display: flex; gap: 1.5rem; margin-top: 3rem;
  padding-top: 2.4rem; border-top: 1px solid var(--hairline);
}
.social-link {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--hairline-2);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted);
  transition: color 0.3s, border-color 0.3s, transform 0.3s;
}
.social-link:hover { color: var(--accent); border-color: var(--accent-mid); transform: translateY(-2px); }
.social-link svg { width: 17px; height: 17px; fill: currentColor; }

/* Form column */
.contact-form-wrap {
  background: var(--bg-2);
  padding: 3.5rem;
  transition: background 0.6s ease;
}
.contact-form-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.6rem; font-weight: 400; color: var(--text);
  margin-bottom: 0.5rem;
}
.contact-form-note {
  font-size: 0.9rem; line-height: 1.7; color: var(--text-muted);
  font-weight: 300; margin-bottom: 2.8rem;
}
.field { position: relative; margin-bottom: 2.2rem; }
.field label {
  display: block;
  font-size: 0.6rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 300; margin-bottom: 0.7rem;
}
.field input,
.field textarea,
.field select {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--hairline-2);
  padding: 0.6rem 0;
  font-family: 'Jost', sans-serif;
  font-size: 0.98rem; font-weight: 300;
  color: var(--text);
  transition: border-color 0.4s ease;
}
.field textarea { resize: vertical; min-height: 90px; line-height: 1.7; }
.field select { cursor: pointer; }

/* ────────── CUSTOM SELECT ────────── */
.cs {
  position: relative;
}
.cs-trigger {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--hairline-2);
  padding: 0.6rem 0;
  display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
  font-family: 'Jost', sans-serif;
  font-size: 0.98rem; font-weight: 300;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.4s ease;
}
.cs-trigger:focus { outline: none; border-bottom-color: var(--accent); }
.cs[aria-expanded="true"] .cs-trigger { border-bottom-color: var(--accent); }
.cs-val { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.cs-val.is-placeholder { color: var(--text-muted); opacity: 0.55; }
.cs-arrow {
  flex-shrink: 0;
  color: var(--text-muted);
  transition: transform 0.3s ease, color 0.3s ease;
}
.cs[aria-expanded="true"] .cs-arrow { transform: rotate(180deg); color: var(--accent); }
.cs-panel {
  position: absolute; top: calc(100% + 2px); left: 0; right: 0; z-index: 200;
  background: var(--bg-2);
  border: 1px solid var(--hairline-2);
  list-style: none; margin: 0; padding: 0.4rem 0;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s, background 0.6s ease;
}
.cs[aria-expanded="true"] .cs-panel {
  opacity: 1; visibility: visible; transform: none;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s;
}
.cs-group {
  padding: 0.7rem 1rem 0.3rem;
  font-size: 0.6rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--accent-mid); font-weight: 400; font-family: 'Jost', sans-serif;
  pointer-events: none;
}
.cs-group + .cs-group { margin-top: 0.4rem; border-top: 1px solid var(--hairline); padding-top: 0.9rem; }
.cs-opt {
  padding: 0.55rem 1rem 0.55rem 1.5rem;
  font-family: 'Jost', sans-serif;
  font-size: 0.92rem; font-weight: 300;
  color: var(--text);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.cs-opt:hover, .cs-opt.is-focused { background: var(--bg-3); color: var(--text); }
.cs-opt.is-selected { color: var(--accent); }
.cs-opt.is-selected::before { content: '—'; margin-right: 0.5rem; color: var(--accent-mid); font-size: 0.7rem; }
.field input::placeholder,
.field textarea::placeholder { color: var(--text-muted); opacity: 0.55; }
.field input:focus,
.field textarea:focus,
.field select:focus { outline: none; border-bottom-color: var(--accent); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; }

.btn-submit {
  margin-top: 0.6rem;
  background: var(--accent);
  color: var(--bg);
  border: none; cursor: pointer;
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem; letter-spacing: 0.28em; text-transform: uppercase;
  font-weight: 400;
  padding: 1.1rem 2.6rem;
  transition: background 0.35s ease, letter-spacing 0.35s ease, transform 0.2s ease;
}
.btn-submit:hover { background: var(--accent-deep); letter-spacing: 0.32em; }
.btn-submit:active { transform: translateY(1px); }
.btn-submit:disabled { opacity: 0.55; cursor: default; letter-spacing: 0.28em; }

.form-status {
  margin-top: 1.6rem; font-size: 0.9rem; line-height: 1.6;
  font-weight: 300; min-height: 1.2em;
}
.form-status.is-success { color: var(--accent); }
.form-status.is-error { color: #B4543E; }

/* ────────── FAQ ────────── */
.faq {
  padding: 9rem 6vw;
  background: var(--bg-2);
  transition: background 0.6s ease;
}
.faq-inner { max-width: 860px; margin: 0 auto; }
.faq-head { text-align: center; margin-bottom: 4.5rem; }
.faq-head .section-index { display: inline-block; }
.faq-list { border-top: 1px solid var(--hairline); }
.faq-item { border-bottom: 1px solid var(--hairline); }
.faq-q {
  width: 100%; background: none; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  gap: 2rem; text-align: left;
  padding: 2rem 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.35rem; font-weight: 400; color: var(--text);
  letter-spacing: -0.002em;
  transition: color 0.3s;
}
.faq-q:hover { color: var(--accent); }
.faq-icon {
  position: relative; flex-shrink: 0;
  width: 16px; height: 16px;
}
.faq-icon::before,
.faq-icon::after {
  content: ''; position: absolute; background: var(--accent-mid);
  transition: transform 0.4s ease, opacity 0.3s ease;
}
.faq-icon::before { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
.faq-icon::after { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); }
.faq-item.is-open .faq-icon::after { transform: translateX(-50%) scaleY(0); opacity: 0; }
.faq-a {
  overflow: hidden; max-height: 0;
  transition: max-height 0.5s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.faq-a-inner {
  padding: 0 0 2rem;
  font-size: 1rem; line-height: 1.95; color: var(--text-soft);
  font-weight: 300; max-width: 680px;
}

/* ────────── PROSE (privacy) ────────── */
.prose-section {
  padding: 4rem 6vw 9rem;
  background: var(--bg);
  transition: background 0.6s ease;
}
.prose {
  max-width: 720px; margin: 0 auto;
}
.prose-meta {
  font-size: 0.7rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 300; margin-bottom: 3.5rem;
}
.prose h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.7rem; font-weight: 400; color: var(--text);
  letter-spacing: -0.003em;
  margin: 3rem 0 1.1rem;
}
.prose h2:first-of-type { margin-top: 0; }
.prose p {
  font-size: 1rem; line-height: 1.95; color: var(--text-soft);
  font-weight: 300; margin-bottom: 1.2rem;
}
.prose ul { list-style: none; margin: 0 0 1.4rem; padding: 0; }
.prose li {
  position: relative; padding-left: 1.4rem; margin-bottom: 0.7rem;
  font-size: 1rem; line-height: 1.9; color: var(--text-soft); font-weight: 300;
}
.prose li::before {
  content: '—'; position: absolute; left: 0; color: var(--accent-mid);
}
.prose a { color: var(--accent); text-decoration: none; border-bottom: 1px solid var(--hairline-2); transition: border-color 0.3s; }
.prose a:hover { border-bottom-color: var(--accent); }

/* ────────── FOOTER ────────── */
footer {
  padding: 2.4rem 6vw;
  background: var(--bg-dark-2);
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem; flex-wrap: wrap;
  border-top: 1px solid var(--hairline-dk);
  transition: background 0.6s ease;
}
footer p {
  font-size: 0.62rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(205, 190, 168, 0.42); font-weight: 300;
}
.footer-links { display: flex; gap: 2.4rem; list-style: none; }
.footer-links a {
  font-size: 0.62rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(205, 190, 168, 0.42); text-decoration: none;
  transition: color 0.3s;
}
.footer-links a:hover { color: var(--accent-mid); }

/* ────────── REVEAL ────────── */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 1s ease, transform 1s ease; }
.reveal.visible { opacity: 1; transform: none; }
.reveal-d1 { transition-delay: 0.08s; }
.reveal-d2 { transition-delay: 0.18s; }
.reveal-d3 { transition-delay: 0.28s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero-scroll-line { animation: none; }
}

/* ────────── RESPONSIVE: TABLET (≤1024px) ────────── */
@media (max-width: 1024px) {
  nav { padding: 1.5rem 2.5rem; }
  .nav-links { gap: 1.8rem; }
  .nav-links a { font-size: 0.66rem; }

  .hero { padding: 100px 2.5rem 5rem; margin-bottom: 2rem; }
  .hero-name { font-size: clamp(2.8rem, 8vw, 4.6rem); }

  .page-hero { padding: 12rem 2.5rem 4rem; }

  .about { padding: 3rem 2.5rem 7rem; }
  .about-grid { grid-template-columns: 1fr; gap: 3.5rem; max-width: 560px; }
  .about-visual { aspect-ratio: 4 / 5; max-width: 440px; margin: 0 auto; }

  .portfolio { padding: 7rem 2.5rem; }
  .portfolio-grid { gap: 2.5rem 1.5rem; }
  .project, .project.is-feature { grid-column: span 6; }
  .project.is-feature .project-img { aspect-ratio: 16 / 9; }

  .gallery { padding: 3rem 2.5rem 8rem; }
  .gallery-grid { gap: 2.8rem 1.8rem; }
  .project.span-2 { grid-column: span 3; }

  .philosophy { padding: 7rem 4rem; grid-template-columns: 1fr; gap: 4rem; }

  .team { padding: 7rem 2.5rem; }
  .team-grid { grid-template-columns: repeat(2, 1fr); gap: 3rem 2.5rem; }

  .insta { padding: 7rem 2.5rem; }
  .insta-row { grid-template-columns: 1fr; gap: 3.5rem; max-width: 560px; }
  .insta-grid { grid-template-columns: repeat(2, 1fr); }

  .contact { padding: 7rem 2.5rem 5rem; }

  .contact-page { padding: 3rem 2.5rem 7rem; }
  .contact-layout { grid-template-columns: 1fr; gap: 4rem; max-width: 600px; }
  .contact-form-wrap { padding: 2.6rem; }

  .faq { padding: 7rem 2.5rem; }

  .prose-section { padding: 3rem 2.5rem 7rem; }

  footer { padding: 2rem 2.5rem; }
}

/* ────────── RESPONSIVE: MOBILE (≤768px) ────────── */
@media (max-width: 768px) {
  nav { padding: 1.1rem 1.75rem; }
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  .nav-logo { position: absolute; left: 50%; transform: translateX(-50%); }
  .logo-mark { width: 34px; height: 34px; }
  .logo-text { font-size: 0.82rem; letter-spacing: 0.28em; white-space: nowrap; }
  .logo-text-sub { font-size: 0.5rem; letter-spacing: 0.36em; }

  .hero { padding: 4rem 1.75rem; margin-bottom: 7rem; min-height: 100svh; }
  .hero-name { font-size: clamp(2.6rem, 11vw, 3.8rem); margin-bottom: 2rem; }
  .hero-tagline { margin-bottom: 2.6rem; }
  .hero-scroll-line { height: 30px; }

  .page-hero { padding: 8rem 1.75rem 3.5rem; }

  .about { padding: 2.5rem 1.75rem 5.5rem; }
  .about-grid { gap: 3rem; }
  .about-visual { max-width: none; }
  .section-head { margin-bottom: 4rem; }

  .portfolio { padding: 5.5rem 1.75rem; }
  .portfolio-head { flex-direction: column; align-items: flex-start; gap: 1.2rem; margin-bottom: 3.5rem; }
  .portfolio-grid { gap: 3rem 1rem; }
  .project, .project.is-feature { grid-column: span 6; }
  .project-img { aspect-ratio: 4 / 5; }
  .project.is-feature .project-img { aspect-ratio: 4 / 5; }

  .project-tag { display: flex; flex-direction: column; align-items: flex-end; gap: 0.15rem; white-space: normal; }
  .project-loc::before { content: none; }

  .gallery { padding: 2.5rem 1.75rem 6.5rem; }
  .gallery-grid { gap: 3rem 1rem; }
  .project.span-2 { grid-column: span 6; }

  .philosophy { padding: 6rem 2.5rem; gap: 3rem; }

  .team { padding: 6rem 1.75rem; }
  .team-grid { grid-template-columns: 1fr; gap: 3.5rem; max-width: 360px; margin: 0 auto; }
  .team-bio { max-width: none; }

  .insta { padding: 6rem 1.75rem; }
  .insta-row { gap: 3rem; }

  .contact { padding: 6rem 1.75rem 5rem; }
  .contact-details { gap: 2.5rem; }

  .contact-page { padding: 2.5rem 1.75rem 6rem; }
  .contact-form-wrap { padding: 2.4rem 1.75rem; }
  .field-row { grid-template-columns: 1fr; gap: 0; }

  .faq { padding: 6.5rem 1.75rem; }
  .faq-q { font-size: 1.18rem; }

  .prose-section { padding: 2.5rem 1.75rem 6.5rem; }

  footer { padding: 2rem 1.75rem; flex-direction: column; align-items: flex-start; gap: 1rem; }
  .footer-links { flex-wrap: wrap; gap: 1.4rem; }
}

/* ────────── RESPONSIVE: SMALL MOBILE (≤480px) ────────── */
@media (max-width: 480px) {
  .hero-name { font-size: 2.6rem; }
  .section-title { font-size: 1.95rem; }
  .quote { font-size: 1.45rem; }
  .contact-details { gap: 1.8rem; }
  .insta-grid { grid-template-columns: repeat(2, 1fr); gap: 0.6rem; }
}
