/* =================================================================
   THIS IS US — Photo & Film
   Fine art film photography. Warm ivory, French blue, sage.
   ================================================================= */

:root {
  /* palette (from brand) */
  --ivory:        #F5F3EF;
  --ivory-deep:   #ECE8E1;
  --blue:         #55657D;
  --blue-deep:    #3F4C60;
  --blue-pale:    #E4E9EF;   /* soft dusty-blue tint, same family */
  --blue-mist:    #D7DEE7;
  --sage:         #A8B2A1;
  --charcoal:     #3A3A3A;
  --charcoal-soft:#6B6B66;
  --linen:        #EAE5DC;
  --line:         rgba(58,58,58,.16);
  --line-blue:    rgba(85,101,125,.32);
  --line-light:   rgba(245,243,239,.32);

  /* type */
  --display: 'Playfair Display', Georgia, serif;
  --body:    'Cormorant Garamond', Georgia, serif;
  --script:  'Parisienne', cursive;
  --util:    'Jost', system-ui, sans-serif;

  /* scale — tightened for a closer, more editorial rhythm */
  --pad-x: clamp(1.5rem, 6vw, 6rem);
  --section-y: clamp(2.5rem, 5vw, 5rem);
  --max: 1280px;

  /* motion */
  --ease: cubic-bezier(.22, .61, .36, 1);
  --ease-soft: cubic-bezier(.65, 0, .35, 1);
}

html { scroll-behavior: smooth; }
* { scrollbar-color: var(--blue) var(--ivory-deep); }

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--ivory);
  color: var(--charcoal);
  font-family: var(--body);
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  font-weight: 400;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
h1, h2, h3 { margin: 0; font-weight: 500; font-family: var(--display); }
ul, ol { margin: 0; padding: 0; list-style: none; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }
::selection { background: var(--blue); color: #fff; }

/* ---------- shared typographic atoms ---------- */
.eyebrow {
  font-family: var(--util);
  font-weight: 400;
  font-size: .72rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 1.4rem;
}
.eyebrow--light { color: rgba(255,255,255,.82); }
.eyebrow--center { text-align: center; color: var(--charcoal-soft); }

.script { font-family: var(--script); font-weight: 400; line-height: 1; color: var(--blue); }
.script--lg { font-size: clamp(2.6rem, 7vw, 4.6rem); }

.section { padding: var(--section-y) var(--pad-x); }
.section-head { max-width: 760px; margin: 0 auto clamp(1.4rem, 3vw, 2.4rem); text-align: center; }
.section-head__title {
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  line-height: 1.12;
  letter-spacing: -.01em;
}
/* a small blue rule under section eyebrows — recurring blue cue */
.section-head .eyebrow { position: relative; display: inline-block; padding-bottom: .9rem; }
.section-head .eyebrow::after {
  content: ""; position: absolute; left: 50%; bottom: 0; width: 30px; height: 1px;
  background: var(--blue); transform: translateX(-50%);
}

.lede {
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-style: italic;
  line-height: 1.5;
  color: var(--charcoal);
}

.link-underline {
  font-family: var(--util);
  font-size: .74rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  position: relative;
  padding-bottom: 4px;
}
.link-underline::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 100%; height: 1px; background: var(--blue);
  transform: scaleX(1); transform-origin: left; transition: transform .5s var(--ease);
}
.link-underline:hover::after { transform: scaleX(0); transform-origin: right; }

/* ---------- signature: the gallery mat ---------- */
/* borderless blue mat — the profile photo sits on the brand blue */
.matted {
  margin: 0;
  padding: 14px;
  background: linear-gradient(180deg, var(--blue), var(--blue-deep));
  border: none;
  box-shadow: 0 30px 60px -38px rgba(63,76,96,.55);
  transition: box-shadow .7s var(--ease-soft);
}
.matted__frame { overflow: hidden; }
.matted img { width: 100%; transition: transform 1.4s var(--ease-soft); }
.matted:hover { box-shadow: 0 40px 80px -36px rgba(63,76,96,.7); }
.matted:hover img { transform: scale(1.04); }
.matted__caption {
  font-family: var(--util);
  font-size: .68rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  text-align: center;
  padding: 1rem .5rem .2rem;
}

/* ---------- buttons ---------- */
.btn {
  display: inline-block;
  font-family: var(--util);
  font-weight: 400;
  font-size: .74rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  padding: 1.05em 2.4em;
  border: 1px solid transparent;
  transition: background .55s var(--ease-soft), color .55s var(--ease-soft),
              border-color .55s var(--ease-soft), transform .55s var(--ease-soft),
              box-shadow .55s var(--ease-soft);
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn--solid { background: var(--linen); color: var(--charcoal); }
.btn--solid:hover { background: var(--blue); color: #fff; box-shadow: 0 16px 30px -16px rgba(63,76,96,.7); }
.btn--blue { background: var(--blue); color: #fff; border-color: var(--blue); box-shadow: 0 16px 30px -18px rgba(63,76,96,.7); }
.btn--blue:hover { background: var(--blue-deep); border-color: var(--blue-deep); color: #fff; box-shadow: 0 20px 38px -16px rgba(63,76,96,.85); }
.btn--outline { border-color: var(--blue); color: var(--blue); }
.btn--outline:hover { background: var(--blue); color: #fff; box-shadow: 0 16px 30px -16px rgba(63,76,96,.7); }
.btn--ghost-light { border-color: rgba(255,255,255,.6); color: #fff; }
.btn--ghost-light:hover { background: rgba(255,255,255,.95); color: var(--charcoal); }

/* =================================================================
   NAV
   ================================================================= */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 60;
  padding: clamp(1rem, 2vw, 1.6rem) var(--pad-x);
  transition: background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  max-width: var(--max); margin: 0 auto;
}
.brand { display: flex; flex-direction: column; line-height: 1; color: #fff; transition: color .5s var(--ease); }
.brand__name { font-family: var(--display); font-size: 1.3rem; letter-spacing: .04em; }
.brand__sub {
  font-family: var(--util); font-size: .58rem; letter-spacing: .42em;
  text-transform: uppercase; margin-top: 5px; opacity: .85;
}
.nav__links { display: flex; align-items: center; gap: clamp(1.4rem, 2.6vw, 2.8rem); }
.nav__links a {
  color: #fff; font-family: var(--util); font-size: .76rem;
  letter-spacing: .18em; text-transform: uppercase; transition: color .4s var(--ease); position: relative;
}
.nav__links a:not(.nav__inquire)::after {
  content: ""; position: absolute; left: 0; bottom: -6px; width: 100%; height: 1px;
  background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .45s var(--ease);
}
.nav__links a:not(.nav__inquire):hover::after { transform: scaleX(1); }
.nav__inquire { padding: .7em 1.6em; border: 1px solid rgba(255,255,255,.55); }
.nav__inquire:hover { background: #fff; color: var(--charcoal); }

/* scrolled state */
.nav.is-solid {
  background: rgba(245,243,239,.94);
  backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 var(--line);
  padding-top: .9rem; padding-bottom: .9rem;
}
.nav.is-solid .brand { color: var(--charcoal); }
.nav.is-solid .nav__links a { color: var(--charcoal); }
.nav.is-solid .nav__inquire { border-color: var(--blue); color: var(--blue); }
.nav.is-solid .nav__inquire:hover { background: var(--blue); color: #fff; }

/* hamburger */
.nav__toggle { display: none; width: 34px; height: 22px; position: relative; }
.nav__toggle span {
  position: absolute; left: 0; width: 100%; height: 1.5px; background: #fff;
  transition: transform .4s var(--ease), opacity .3s var(--ease), background .4s var(--ease);
}
.nav__toggle span:first-child { top: 4px; }
.nav__toggle span:last-child { bottom: 4px; }
.nav.is-solid .nav__toggle span { background: var(--charcoal); }
body.menu-open .nav__toggle span { background: var(--charcoal); }
body.menu-open .nav__toggle span:first-child { transform: translateY(6px) rotate(45deg); }
body.menu-open .nav__toggle span:last-child { transform: translateY(-6px) rotate(-45deg); }

/* mobile overlay */
.menu {
  position: fixed; inset: 0; z-index: 55;
  background: var(--ivory);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2.5rem; opacity: 0; pointer-events: none; transition: opacity .5s var(--ease);
}
.menu[hidden] { display: none; }
body.menu-open .menu { opacity: 1; pointer-events: auto; }
.menu__links { display: flex; flex-direction: column; align-items: center; gap: 1.6rem; }
.menu__links a {
  font-family: var(--display); font-size: 2rem; color: var(--charcoal);
  opacity: 0; transform: translateY(14px); transition: opacity .5s var(--ease), transform .5s var(--ease);
}
body.menu-open .menu__links a { opacity: 1; transform: none; transition-delay: calc(var(--i, 0) * .07s + .1s); }
.menu__script { font-family: var(--script); font-size: 1.8rem; color: var(--blue); }

/* =================================================================
   HERO
   ================================================================= */
.hero {
  position: relative; min-height: 100svh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; color: #fff; padding: 0 var(--pad-x);
  overflow: hidden;
}
.hero__media { position: absolute; inset: -8% 0; z-index: 0; will-change: transform; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; animation: kenburns 22s ease-out forwards; }
@keyframes kenburns { from { transform: scale(1.12); } to { transform: scale(1); } }
.hero__veil {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(40,46,58,.42) 0%, rgba(40,46,58,.18) 40%, rgba(40,46,58,.5) 100%);
}
.hero__content { position: relative; z-index: 2; max-width: 920px; }
.hero__title {
  font-size: clamp(2.8rem, 8.5vw, 6.4rem);
  font-weight: 500; line-height: 1.02; letter-spacing: -.015em;
  margin: .4rem 0 1.6rem;
}
.hero__title .line { display: block; overflow: hidden; }
.hero__title em { font-style: italic; color: var(--linen); }
.hero__sub {
  font-size: clamp(1.15rem, 2vw, 1.5rem); font-style: italic;
  max-width: 36ch; margin: 0 auto 2.6rem; color: rgba(255,255,255,.92);
}
.hero__actions { display: flex; gap: 1rem; justify-content: center; align-items: center; text-align: center; flex-wrap: wrap; }

.hero__scroll {
  position: absolute; bottom: 2.2rem; left: 50%; transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: .7rem;
  font-family: var(--util); font-size: .6rem; letter-spacing: .3em; text-transform: uppercase; color: #fff;
}
/* a chevron arrow that gently bounces, pointing down to the next section */
.hero__scroll-arrow {
  width: 16px; height: 16px; border-right: 1.5px solid rgba(255,255,255,.8);
  border-bottom: 1.5px solid rgba(255,255,255,.8); transform: rotate(45deg);
  animation: scrollArrow 2s var(--ease) infinite;
}
@keyframes scrollArrow {
  0%, 100% { transform: rotate(45deg) translate(0, 0); opacity: .6; }
  50%      { transform: rotate(45deg) translate(4px, 4px); opacity: 1; }
}

/* =================================================================
   INTRO
   ================================================================= */
.intro__grid {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: 0.85fr 1fr; gap: clamp(1.6rem, 3.5vw, 3.5rem);
  align-items: center;
}
.intro__portrait { transform: none; }
.intro__hello {
  font-size: clamp(2.4rem, 5vw, 3.8rem); line-height: 1.1; margin-bottom: .9rem;
}
.intro__hello .script { font-size: 1.35em; display: inline-block; margin-left: .1em; }
.intro__text p { margin: 0 0 .9rem; max-width: 46ch; }
.intro__text .lede { margin-bottom: 1.2rem; }
.intro__text .eyebrow { margin-bottom: 1.1rem; }

/* =================================================================
   FEATURED
   ================================================================= */
/* the featured section carries the brand blue, echoing the profile mat */
.featured { background: linear-gradient(180deg, var(--blue), var(--blue-deep)); color: #fff; }
.featured .section-head__title { color: #fff; }
.featured .section-head .eyebrow { color: rgba(255,255,255,.82); }
.featured .section-head .eyebrow::after { background: rgba(255,255,255,.6); }
.featured .feat__index { color: rgba(255,255,255,.8); }
.featured .feat__title { color: #fff; }
.featured .feat__title::after { background: var(--linen); }
.featured .album__empty { color: rgba(255,255,255,.78); }
.featured .btn--outline { border-color: rgba(255,255,255,.6); color: #fff; }
.featured .btn--outline:hover { background: #fff; color: var(--blue); box-shadow: none; }
.featured__grid {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 2.5vw, 2.2rem);
}
.feat { display: block; transition: transform .7s var(--ease-soft); }
.feat:hover { transform: translateY(-6px); }
.feat__img { overflow: hidden; position: relative; aspect-ratio: 3/4; }
.feat__img::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(63,76,96,.6));
  opacity: .8; transition: opacity .7s var(--ease-soft);
}
/* a thin blue frame that draws itself on hover */
.feat__img::before {
  content: ""; position: absolute; inset: 12px; z-index: 2; pointer-events: none;
  border: 1px solid rgba(255,255,255,.7);
  opacity: 0; transform: scale(1.04); transition: opacity .6s var(--ease-soft), transform .6s var(--ease-soft);
}
.feat:hover .feat__img::before { opacity: 1; transform: scale(1); }
.feat__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.5s var(--ease-soft); }
.feat:hover .feat__img img { transform: scale(1.07); }
.feat:hover .feat__img::after { opacity: 1; }
.feat__meta { padding: 1.1rem .2rem 0; }
.feat__index {
  font-family: var(--util); font-size: .66rem; letter-spacing: .26em; text-transform: uppercase;
  color: var(--blue); display: block; margin-bottom: .4rem;
  transition: letter-spacing .6s var(--ease-soft);
}
.feat:hover .feat__index { letter-spacing: .34em; }
.feat__title {
  font-size: clamp(1.6rem, 2.6vw, 2.2rem); position: relative; display: inline-block; padding-bottom: 3px;
}
.feat__title::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 1px;
  background: var(--blue); transition: width .6s var(--ease);
}
.feat:hover .feat__title::after { width: 100%; }
/* extra featured cards stay hidden until "Load more" */
.feat--hidden { display: none; }

/* =================================================================
   SUBPAGE HEADER (portfolio.html / album.html)
   ================================================================= */
.page-hero {
  text-align: center; max-width: 820px; margin: 0 auto;
  padding: clamp(6rem, 11vw, 8.5rem) var(--pad-x) clamp(1.2rem, 3vw, 2.4rem);
}
.page-hero__title { font-size: clamp(2.6rem, 6vw, 4.4rem); line-height: 1.04; letter-spacing: -.015em; }
.page-hero__sub {
  font-style: italic; font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  color: var(--charcoal-soft); margin: 1rem auto 0; max-width: 46ch;
}
.page-hero__back { margin: 1.3rem 0 0; }
/* tighten the gap between a subpage header and the grid below it */
.section--top-tight { padding-top: clamp(.5rem, 2vw, 1.5rem); }
.album__empty {
  grid-column: 1 / -1; text-align: center; color: var(--charcoal-soft);
  font-style: italic; padding: 2.5rem 0; width: 100%;
}

/* =================================================================
   EXPERIENCE
   ================================================================= */
.experience { background: linear-gradient(180deg, var(--blue-pale), var(--blue-mist)); }
.steps {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.2rem, 2.4vw, 2.4rem);
}
.step {
  position: relative; padding: 2rem 1.2rem 1.6rem;
  background: rgba(245,243,239,.45);
  transition: background .6s var(--ease-soft), transform .6s var(--ease-soft), box-shadow .6s var(--ease-soft);
}
.step::before {
  content: ""; position: absolute; top: 0; left: 1.2rem; width: 40px; height: 2px; background: var(--blue);
  transition: width .6s var(--ease-soft);
}
.step:hover { background: var(--ivory); transform: translateY(-6px); box-shadow: 0 24px 44px -28px rgba(63,76,96,.55); }
.step:hover::before { width: 64px; }
.step__num {
  font-family: var(--util); font-size: .7rem; letter-spacing: .2em; color: var(--blue);
  position: absolute; top: 1.4rem; right: 1.2rem; opacity: .55;
}
.step__icon {
  display: block; font-size: 1.7rem; color: var(--blue); margin-bottom: .9rem; line-height: 1;
  transition: transform .6s var(--ease-soft);
}
.step:hover .step__icon { transform: translateY(-2px) scale(1.12); }
.step__title { font-size: clamp(1.5rem, 2.4vw, 1.9rem); margin-bottom: .6rem; }
.step p { font-size: 1.02rem; line-height: 1.7; color: var(--charcoal-soft); max-width: 28ch; }

/* =================================================================
   TESTIMONIALS
   ================================================================= */
.quotes {
  background: var(--ivory-deep); color: var(--charcoal);
  padding: clamp(3.5rem, 7vw, 6rem) var(--pad-x);
  text-align: center; position: relative; overflow: hidden;
}
.quotes::before {
  content: "\201C"; position: absolute; top: -2rem; left: 50%; transform: translateX(-50%);
  font-family: var(--display); font-size: 16rem; line-height: 1; color: rgba(85,101,125,.10);
  pointer-events: none;
}
.quotes__track { max-width: 900px; margin: 0 auto; position: relative; min-height: 13rem; }
.quote {
  position: absolute; inset: 0; margin: 0;
  opacity: 0; transform: translateY(18px); pointer-events: none;
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.quote.is-active { position: relative; opacity: 1; transform: none; pointer-events: auto; }
.quote blockquote {
  position: relative; z-index: 1;
  margin: 0 0 1.4rem; font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: clamp(1.6rem, 3.6vw, 2.8rem); line-height: 1.35; letter-spacing: -.01em;
}
.quote figcaption {
  font-family: var(--util); font-size: .72rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--blue);
}
.quotes__dots { display: flex; gap: .7rem; justify-content: center; margin-top: 2rem; }
.quotes__dots button {
  width: 8px; height: 8px; border-radius: 50%; background: rgba(58,58,58,.22);
  transition: background .5s var(--ease-soft), transform .5s var(--ease-soft);
}
.quotes__dots button:hover { background: rgba(58,58,58,.45); transform: scale(1.15); }
.quotes__dots button.is-active { background: var(--blue); transform: scale(1.3); }

/* =================================================================
   PRESS
   ================================================================= */
.press { padding-top: clamp(2.75rem, 5vw, 4.5rem); padding-bottom: clamp(2.75rem, 5vw, 4.5rem); }
.press__strip {
  max-width: var(--max); margin: 0 auto;
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: clamp(1.6rem, 4vw, 3.6rem);
}
.press__strip li {
  font-family: var(--display); font-style: italic; font-size: clamp(1.05rem, 1.8vw, 1.4rem);
  color: var(--charcoal-soft); opacity: .8; transition: opacity .4s var(--ease), color .4s var(--ease);
}
.press__strip li:hover { opacity: 1; color: var(--blue); }

/* =================================================================
   PORTFOLIO — masonry
   ================================================================= */
/* borderless, seamless gallery wall — images sit edge to edge */
.masonry {
  max-width: 1500px; margin: 0 auto;
  columns: 3; column-gap: 0;
}
.masonry__item {
  display: block; width: 100%; margin: 0;
  break-inside: avoid; overflow: hidden; position: relative; padding: 0;
}
.masonry__item img {
  width: 100%; display: block;
  transition: transform 1.6s var(--ease-soft), filter 1s var(--ease-soft);
}
.masonry__item::after {
  content: "View"; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--util); font-size: .7rem; letter-spacing: .34em; text-transform: uppercase; color: #fff;
  background: rgba(63,76,96,.42); opacity: 0; transition: opacity .6s var(--ease-soft);
}
/* a thin inset rule appears on hover so the borderless grid still feels crafted */
.masonry__item::before {
  content: ""; position: absolute; inset: 14px; z-index: 2; pointer-events: none;
  border: 1px solid rgba(255,255,255,.65);
  opacity: 0; transform: scale(1.05); transition: opacity .6s var(--ease-soft), transform .6s var(--ease-soft);
}
.masonry__item:hover img { transform: scale(1.06); }
.masonry__item:hover::after { opacity: 1; }
.masonry__item:hover::before { opacity: 1; transform: scale(1); }
.masonry__item:focus-visible { outline: 2px solid var(--blue); outline-offset: -4px; }
.portfolio__cta {
  display: flex; flex-wrap: wrap; gap: 1rem;
  justify-content: center; align-items: center;
  margin-top: clamp(2rem, 4vw, 3rem);
}

/* =================================================================
   CTA
   ================================================================= */
.cta {
  position: relative; overflow: hidden; text-align: center; color: #fff;
  padding: clamp(4.5rem, 10vw, 8.5rem) var(--pad-x);
}
.cta__media { position: absolute; inset: -8% 0; z-index: 0; will-change: transform; }
.cta__media img { width: 100%; height: 100%; object-fit: cover; }
.cta__veil {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(63,76,96,.62), rgba(45,52,66,.7));
}
.cta__content { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; }
.cta__title { font-size: clamp(2.4rem, 6vw, 4.6rem); line-height: 1.05; margin: .5rem 0 1.1rem; }
.cta__sub { font-style: italic; font-size: clamp(1.1rem, 1.8vw, 1.4rem); margin: 0 auto 2rem; max-width: 42ch; color: rgba(255,255,255,.9); }
.script--lg { color: var(--linen); }

/* =================================================================
   FOOTER
   ================================================================= */
.footer { background: var(--ivory-deep); color: var(--charcoal-soft); padding: clamp(3rem, 6vw, 4.5rem) var(--pad-x) 1.8rem; }
.footer__inner {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(2rem, 5vw, 4rem);
  padding-bottom: 2.4rem; border-bottom: 1px solid var(--line);
}
.footer__brand .brand__name { font-size: 1.8rem; color: var(--charcoal); display: block; }
.footer__brand .brand__sub { color: var(--charcoal-soft); display: block; margin-top: 6px; }
.footer__tag { font-size: 1.7rem; color: var(--blue); margin: 1.1rem 0 0; }
.footer__nav { display: flex; flex-direction: column; gap: .8rem; }
.footer__nav a, .footer__social a {
  font-family: var(--util); font-size: .78rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--charcoal-soft);
  transition: color .45s var(--ease-soft), letter-spacing .45s var(--ease-soft), padding-left .45s var(--ease-soft);
  width: fit-content;
}
.footer__nav a:hover, .footer__social a:hover { color: var(--blue); letter-spacing: .22em; padding-left: 6px; }
.footer__social { display: flex; flex-direction: column; gap: .8rem; margin-bottom: 1.1rem; }
.footer__loc { font-style: italic; font-size: 1.05rem; color: var(--charcoal-soft); margin: 0; }
.footer__base {
  max-width: var(--max); margin: 1.6rem auto 0;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem;
  font-family: var(--util); font-size: .68rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--charcoal-soft);
}

/* =================================================================
   LIGHTBOX
   ================================================================= */
.lightbox {
  position: fixed; inset: 0; z-index: 80;
  background: rgba(33,38,48,.92); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center; padding: 5vw;
  opacity: 0; transition: opacity .4s var(--ease);
}
.lightbox.is-open { opacity: 1; }
.lightbox[hidden] { display: none; }
.lightbox__stage { margin: 0; max-width: 90vw; max-height: 88vh; }
.lightbox__stage img {
  max-width: 90vw; max-height: 88vh; width: auto; height: auto;
  box-shadow: 0 40px 80px -30px rgba(0,0,0,.7);
  border: 10px solid var(--ivory);
}
.lightbox__close { position: absolute; top: 1.4rem; right: 1.8rem; font-size: 2.4rem; color: #fff; line-height: 1; }
.lightbox__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  font-size: 3rem; color: #fff; padding: 0 1rem; opacity: .7; transition: opacity .3s var(--ease);
}
.lightbox__nav:hover { opacity: 1; }
.lightbox__nav--prev { left: 1rem; }
.lightbox__nav--next { right: 1rem; }

/* =================================================================
   REVEAL ANIMATIONS
   ================================================================= */
[data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
[data-reveal].is-in { opacity: 1; transform: none; }
.hero [data-reveal] { transition-delay: .3s; }
.hero [data-reveal]:nth-child(2) { transition-delay: .45s; }
.hero [data-reveal]:nth-child(3) { transition-delay: .65s; }
.hero [data-reveal]:nth-child(4) { transition-delay: .85s; }

/* =================================================================
   CONTACT FORM
   ================================================================= */
/* contact sits on the brand blue, closing the page like the testimonials */
.contact { background: linear-gradient(180deg, var(--blue), var(--blue-deep)); color: #fff; }
.contact .eyebrow { color: rgba(255,255,255,.82); }
.contact__title { color: #fff; }
.contact__title .script { color: var(--linen); }
.contact__intro > p { color: rgba(255,255,255,.85); }
.contact .contact__label { color: rgba(255,255,255,.6); }
.contact .contact__direct a, .contact .contact__direct span[data-site] { color: #fff; }
.contact .contact__direct a:hover { color: var(--linen); }
.contact .field > span { color: rgba(255,255,255,.78); }
.contact .form__note { color: var(--linen); }
.contact .form__note.is-error { color: #f0c9c3; }
.contact__grid {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: 0.85fr 1fr; gap: clamp(2.5rem, 6vw, 6rem);
  align-items: start;
}
.contact__title { font-size: clamp(2rem, 4vw, 3rem); line-height: 1.1; margin-bottom: 1.3rem; }
.contact__title .script { font-size: 1.25em; }
.contact__intro > p { max-width: 40ch; color: rgba(255,255,255,.85); }
.contact__direct { margin-top: 2.4rem; display: grid; gap: 1.1rem; }
.contact__direct li { display: flex; flex-direction: column; gap: 2px; }
.contact__label {
  font-family: var(--util); font-size: .64rem; letter-spacing: .26em;
  text-transform: uppercase; color: var(--sage);
}
.contact__direct a, .contact__direct span[data-site] { font-size: 1.15rem; color: var(--charcoal); }
.contact__direct a:hover { color: var(--blue); }

.form { display: grid; gap: 1.4rem; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.field { display: grid; gap: .5rem; }
.field > span {
  font-family: var(--util); font-size: .66rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--charcoal-soft);
}
.field input, .field select, .field textarea {
  font-family: var(--body); font-size: 1.1rem; color: var(--charcoal);
  background: var(--ivory); border: 1px solid var(--line);
  padding: .85rem 1rem; width: 100%; border-radius: 0;
  transition: border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.field textarea { resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(85,101,125,.12);
}
.form__submit { justify-self: start; margin-top: .4rem; background: var(--ivory); }
.form__note { font-style: italic; color: var(--blue); min-height: 1.4em; margin: 0; }
.form__note.is-error { color: #9a5b54; }

/* =================================================================
   FLOATING CONTACT WIDGET
   ================================================================= */
.fab {
  position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem);
  z-index: 70; display: flex; flex-direction: column; align-items: flex-end; gap: .8rem;
}
.fab__menu {
  display: flex; flex-direction: column; align-items: flex-end; gap: .6rem;
}
.fab__menu[hidden] { display: none; }
.fab__action {
  display: inline-flex; align-items: center; gap: .7rem;
  background: var(--ivory); color: var(--charcoal);
  font-family: var(--util); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase;
  padding: .7rem 1.1rem; box-shadow: 0 14px 30px -16px rgba(63,76,96,.6);
  border: 1px solid var(--line);
  opacity: 0; transform: translateY(10px) scale(.96);
  transition: opacity .35s var(--ease), transform .35s var(--ease), background .35s var(--ease), color .35s var(--ease);
}
.fab.is-open .fab__action { opacity: 1; transform: none; }
.fab.is-open .fab__action:nth-child(1) { transition-delay: .04s; }
.fab.is-open .fab__action:nth-child(2) { transition-delay: .09s; }
.fab.is-open .fab__action:nth-child(3) { transition-delay: .14s; }
.fab.is-open .fab__action:nth-child(4) { transition-delay: .19s; }
.fab__action:hover { background: var(--blue); color: #fff; }
.fab__action svg { width: 18px; height: 18px; fill: var(--blue); transition: fill .35s var(--ease); }
.fab__action:hover svg { fill: #fff; }

.fab__toggle {
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--blue); color: #fff;
  display: grid; place-items: center;
  box-shadow: 0 16px 34px -12px rgba(63,76,96,.75);
  transition: background .4s var(--ease), transform .4s var(--ease);
}
.fab__toggle:hover { background: var(--blue-deep); transform: translateY(-2px); }
.fab__toggle svg { width: 24px; height: 24px; fill: currentColor; position: absolute; transition: opacity .3s var(--ease), transform .3s var(--ease); }
.fab__icon-close { opacity: 0; transform: rotate(-45deg); }
.fab.is-open .fab__icon-open { opacity: 0; transform: rotate(45deg); }
.fab.is-open .fab__icon-close { opacity: 1; transform: none; }
.fab__toggle:focus-visible { outline: 2px solid var(--charcoal); outline-offset: 3px; }

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width: 980px) {
  .intro__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .intro__portrait { max-width: 460px; }
  .steps { grid-template-columns: repeat(2, 1fr); gap: 2.5rem 2rem; }
  .masonry { columns: 2; }
  .contact__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 760px) {
  .nav__links { display: none; }
  .nav__toggle { display: block; }
  .featured__grid { grid-template-columns: 1fr; max-width: 460px; }
  .feat__img { aspect-ratio: 4/5; }
}

@media (max-width: 520px) {
  .steps { grid-template-columns: 1fr; }
  .masonry { columns: 1; }
  .form__row { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr; }
  .footer__base { justify-content: flex-start; }
  .hero__actions .btn { flex: 1; }
}

/* =================================================================
   REDUCED MOTION
   ================================================================= */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  [data-reveal] { opacity: 1; transform: none; }
  .hero__media img { animation: none; transform: none; }
}
