/* ──────────────────────────────────────────────────────
   HARLOW SALON · Brighton-style layout system
   Roboto throughout · Italiana for accents
   ────────────────────────────────────────────────────── */

:root {
  --bg:        #ffffff;
  --bg-alt:    #f7f5f0;
  --bg-cream:  #f9f7f2;
  --bg-soft:   #f3f1ec;
  --bg-ink:    #0a0a0a;
  --bg-ink-2:  #141413;

  --ink:       #0a0a0a;
  --ink-soft:  #3a3a3a;
  --ink-mute:  #7a766f;
  --ink-faint: #b3afa8;

  --rule:      #e6e3dc;
  --rule-strong: #cbc5b8;

  /* Brighton-tan accent */
  --gold:      #b89f6e;
  --gold-soft: #d4bf94;
  --gold-deep: #8a7849;

  --serif:    "Roboto", "Helvetica Neue", Arial, sans-serif;
  --display:  "Italiana", "Cormorant Garamond", "Times New Roman", serif;
  --deco:     "Italiana", serif;
  --script:   "Pinyon Script", cursive;

  --wrap:     1240px;
  --wrap-wide: 1480px;
  --pad:      clamp(1.25rem, 4vw, 2.5rem);
}

* { box-sizing: border-box; }
*:before, *:after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--serif);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.7;
  letter-spacing: .005em;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
button { font: inherit; }

.skip { position: absolute; left: -9999px; }
.skip:focus { left: 1rem; top: 1rem; background: var(--ink); color: #fff; padding: .5rem 1rem; z-index: 100; }

.wrap { width: 100%; max-width: var(--wrap); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }
.wrap--wide { max-width: var(--wrap-wide); }

/* ── TYPE ── */
h1, h2, h3, h4 { margin: 0; font-family: var(--display); font-weight: 400; line-height: 1.05; color: var(--ink); letter-spacing: .005em; }
h1 { font-size: clamp(2.6rem, 6vw, 4.8rem); }
h2 { font-size: clamp(2.2rem, 4.6vw, 3.8rem); }
h3 { font-size: clamp(1.5rem, 2.4vw, 1.9rem); }
h4 { font-family: var(--serif); font-size: 1rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; }
p  { margin: 0 0 1em; }

.script { font-family: var(--script); color: var(--gold); line-height: 1; font-weight: 400; }

.eyebrow {
  font-family: var(--serif);
  font-weight: 500;
  font-size: .72rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 1.4rem;
}
.eyebrow--white { color: rgba(255,255,255,.78); }

.kicker {
  font-family: var(--serif); font-weight: 500;
  font-size: .8rem; letter-spacing: .26em; text-transform: uppercase;
  color: var(--ink-mute);
}
.lede {
  font-size: 1rem; line-height: 1.7; color: var(--ink-soft); font-weight: 300;
  max-width: 56ch;
}
.lede.center { margin-left: auto; margin-right: auto; text-align: center; }
.muted { color: var(--ink-mute); }
.small { font-size: .82rem; letter-spacing: .02em; }

/* ── BUTTONS (Brighton-style outlined boxes) ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--serif);
  font-weight: 500;
  font-size: .76rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  padding: 1.1rem 2.4rem;
  text-decoration: none;
  border: 1px solid var(--ink);
  background: transparent;
  color: var(--ink);
  transition: background .25s, color .25s, border-color .25s;
  cursor: pointer;
}
.btn:hover { background: var(--ink); color: #fff; }
.btn:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.btn--filled { background: var(--ink); color: #fff; }
.btn--filled:hover { background: var(--gold); border-color: var(--gold); color: #fff; }
.btn--on-dark { color: #fff; border-color: #fff; }
.btn--on-dark:hover { background: #fff; color: var(--ink); }
.btn--gold { background: var(--gold); border-color: var(--gold); color: #fff; }
.btn--gold:hover { background: var(--gold-deep); border-color: var(--gold-deep); }
.btn--icon { gap: .6rem; }
.btn--sm { padding: .85rem 1.6rem; font-size: .7rem; }
.btn--lg { padding: 1.3rem 2.8rem; font-size: .82rem; }

/* Calendar icon (inline svg) */
.btn .ico-cal {
  width: 14px; height: 14px;
  border: 1.5px solid currentColor; border-radius: 1px;
  position: relative;
}
.btn .ico-cal::before, .btn .ico-cal::after {
  content:""; position: absolute; top: -3px;
  width: 1.5px; height: 4px; background: currentColor;
}
.btn .ico-cal::before { left: 3px; }
.btn .ico-cal::after  { right: 3px; }

/* ── TOP NAV ── */
.top {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.top__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 2rem;
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 1.2rem var(--pad);
}
.brand {
  display: inline-flex; align-items: center;
  text-decoration: none; color: var(--ink);
  font-family: var(--display);
  letter-spacing: .14em;
  font-size: 1.35rem;
  line-height: 1;
}
.brand__logo { height: 38px; width: auto; display: block; }
.nav { display: flex; align-items: center; gap: 2rem; }
.nav a {
  font-family: var(--serif);
  font-weight: 500;
  font-size: .76rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--ink);
  position: relative;
  padding: .35rem 0;
  transition: color .2s;
}
.nav a:hover { color: var(--gold); }
.nav a[aria-current="page"]::after,
.nav a:hover::after {
  content:""; position: absolute; left: 0; right: 0;
  bottom: -2px; height: 1px; background: var(--ink);
}
.nav a[aria-current="page"] { color: var(--ink); }

@media (max-width: 900px) {
  .top__inner { flex-direction: column; gap: 1rem; padding: 1rem var(--pad); }
  .nav { gap: 1.2rem; flex-wrap: wrap; justify-content: center; }
  .nav a { font-size: .7rem; letter-spacing: .22em; }
}

/* ── HERO IMAGE (homepage) ── */
.hero-image {
  background: #000;
  width: 100%;
  display: block;
}
.hero-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* ── STORY INTRO (white below hero) ── */
.story-intro {
  background: var(--bg);
  padding: clamp(4rem, 8vw, 7rem) 0;
  text-align: center;
}
.story-intro__inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--pad);
}
.story-intro__title {
  margin: 0 0 1.6rem;
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.2rem, 4.6vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: .01em;
}
.story-intro__title .script {
  display: block;
  font-size: .55em;
  color: var(--gold);
  margin-bottom: -.1em;
  font-weight: 400;
  letter-spacing: 0;
}
.story-intro__title sup {
  font-size: .55em;
  color: var(--gold);
}
.story-intro p {
  color: var(--ink-soft);
  max-width: 580px;
  margin: 0 auto 2rem;
}

/* ── STYLIST PORTRAIT (full-face) ── */
.stylist__photo .stylist__crop {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 18%;
}

/* ── DARK HERO (legacy / unused but kept) ── */
.story {
  position: relative;
  background: var(--bg-ink);
  color: #fff;
  min-height: 78vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  padding: clamp(5rem, 12vw, 9rem) var(--pad);
  overflow: hidden;
}
.story__watermark {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  font-family: var(--script);
  font-size: clamp(7rem, 22vw, 22rem);
  color: rgba(184,159,110,.16);
  white-space: nowrap;
  pointer-events: none;
  line-height: .85;
  letter-spacing: -.02em;
}
.story__inner { position: relative; max-width: 720px; }
.story__title {
  color: #fff;
  margin: 0 0 1.6rem;
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.6rem, 5.6vw, 4.4rem);
  letter-spacing: .02em;
}
.story p {
  color: rgba(255,255,255,.78);
  font-size: 1rem;
  max-width: 560px; margin: 0 auto 2.4rem;
  line-height: 1.75;
}

/* ── PILLARS (3 icons, white bg) ── */
.pillars {
  padding: clamp(4.5rem, 8vw, 7rem) 0 clamp(4rem, 7vw, 6rem);
  background: var(--bg);
  text-align: center;
}
.pillars__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 4rem);
  max-width: 1100px;
  margin: 0 auto;
}
.pillar { padding: 0 .5rem; }
.pillar__icon {
  width: 84px; height: 84px;
  margin: 0 auto 2rem;
  color: var(--gold);
  display: flex; align-items: center; justify-content: center;
}
.pillar__icon svg { width: 100%; height: 100%; }
.pillar h3 { margin-bottom: 1.2rem; }
.pillar p {
  color: var(--ink-soft);
  font-size: .95rem;
  line-height: 1.7;
  max-width: 26ch;
  margin-left: auto; margin-right: auto;
}
@media (max-width: 760px) { .pillars__grid { grid-template-columns: 1fr; gap: 3rem; } }

/* ── DARK SPLIT (clientele) ── */
.split {
  background: var(--bg-ink);
  color: #fff;
  padding: clamp(4rem, 9vw, 7rem) 0;
  position: relative;
  overflow: hidden;
}
.split__inner {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  position: relative;
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 0 var(--pad);
}
.split__photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.split__photos figure { margin: 0; aspect-ratio: 3/4; overflow: hidden; }
.split__photos img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: grayscale(.35) contrast(1.05); }
.split__copy { position: relative; }
.split__watermark {
  position: absolute;
  right: -3rem; top: -2rem;
  font-family: var(--script);
  font-size: clamp(8rem, 16vw, 16rem);
  color: rgba(184,159,110,.18);
  pointer-events: none;
  line-height: .85;
}
.split__copy h2 { color: #fff; margin: 0 0 1.4rem; position: relative; }
.split__copy p { color: rgba(255,255,255,.78); margin: 0 0 2rem; max-width: 52ch; position: relative; }
.split__copy .btn { position: relative; }

@media (max-width: 820px) {
  .split__inner { grid-template-columns: 1fr; }
  .split__watermark { font-size: 7rem; right: -1rem; top: -3rem; }
}

/* ── GALLERY (3-col on desktop) ── */
.gallery {
  padding: clamp(4rem, 8vw, 7rem) 0;
  background: var(--bg);
}
.gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(.4rem, 1vw, 1rem);
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 0 var(--pad);
}
.gallery__grid figure { margin: 0; aspect-ratio: 3/4; overflow: hidden; background: #000; }
.gallery__grid img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 18%;
  transition: transform .6s ease, filter .4s ease;
  filter: grayscale(.05);
}
.gallery__grid figure:hover img { transform: scale(1.04); filter: grayscale(0); }
.gallery__head { text-align: center; max-width: 720px; margin: 0 auto clamp(2rem, 5vw, 4rem); padding: 0 var(--pad); }
.gallery__head h2 { margin-bottom: 1rem; }

@media (max-width: 760px) { .gallery__grid { grid-template-columns: 1fr 1fr; } }

/* ── SCHEDULE CALLOUT (dark band) ── */
.schedule {
  background: var(--bg-ink);
  padding: clamp(2.4rem, 5vw, 4rem) 0;
}
.schedule__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 2rem; flex-wrap: wrap;
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 0 var(--pad);
}
.schedule__copy { color: #fff; flex: 1 1 520px; }
.schedule__copy h2 { color: #fff; margin: 0 0 .8rem; font-size: clamp(1.4rem, 2.6vw, 2rem); }
.schedule__copy p { color: rgba(255,255,255,.78); margin: 0; max-width: 60ch; }

/* ── REVIEWS (kept from prior) ── */
.reviews {
  padding: clamp(4rem, 8vw, 7rem) 0;
  background: var(--bg-cream);
  text-align: center;
}
.reviews__head { max-width: 760px; margin: 0 auto clamp(2.4rem, 5vw, 4rem); padding: 0 var(--pad); }
.reviews__head h2 { margin-bottom: 1rem; }
.reviews__rating { display: flex; align-items: center; justify-content: center; gap: .9rem; flex-wrap: wrap; margin-top: 1.2rem; }
.reviews__stars { color: var(--gold); font-size: 1.3rem; letter-spacing: .15em; }
.reviews__avg { font-family: var(--display); font-size: 1.4rem; color: var(--ink); }
.reviews__count { color: var(--ink-mute); font-size: .9rem; }
.reviews__grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
  max-width: var(--wrap); margin: 0 auto;
  padding: 0 var(--pad);
  text-align: left;
}
.review {
  margin: 0; padding: 2rem 1.6rem;
  background: #fff;
  border: 1px solid var(--rule);
  display: flex; flex-direction: column;
  transition: border-color .25s, transform .25s;
}
.review:hover { border-color: var(--gold); transform: translateY(-2px); }
.review__stars { color: var(--gold); letter-spacing: .15em; margin-bottom: 1rem; }
.review blockquote { margin: 0 0 1.2rem; color: var(--ink-soft); font-size: .95rem; line-height: 1.65; flex: 1; }
.review figcaption { font-size: .82rem; font-weight: 500; letter-spacing: .04em; padding-top: .8rem; border-top: 1px solid var(--rule); }
.review figcaption .muted { font-weight: 400; font-size: .76rem; }
.reviews__foot { margin-top: 2.4rem; }

/* ── PAGE HERO (Services / Stylists) ── */
.page-hero {
  position: relative;
  min-height: 60vh;
  display: flex; align-items: center;
  background: #1c1c1c;
  overflow: hidden;
}
.page-hero__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
}
.page-hero__bg::after {
  content:""; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,.15));
}
/* Harlow hero photo bg: subtle gradient instead of heavy darken so wordmark stays visible */
.page-hero--harlow .page-hero__bg::after {
  background: linear-gradient(180deg, rgba(0,0,0,.2), rgba(0,0,0,.5));
}
.page-hero--harlow .page-hero__inner {
  text-align: center;
}
.page-hero__inner {
  position: relative;
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 5rem var(--pad);
  width: 100%;
  color: #fff;
}
.page-hero__script {
  font-family: var(--script);
  font-size: clamp(2rem, 4.4vw, 3.6rem);
  color: #fff;
  line-height: 1; margin: 0 0 .6rem;
  letter-spacing: 0;
}
.page-hero__title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(3rem, 7.4vw, 5.8rem);
  color: #fff;
  margin: 0;
  letter-spacing: .02em;
  line-height: 1;
}

/* ── SERVICES PAGE ── */
.services {
  background: var(--bg-soft);
  padding: clamp(4rem, 7vw, 6rem) 0;
}
.services__cat {
  display: grid;
  grid-template-columns: minmax(200px, 1fr) minmax(0, 2fr);
  gap: clamp(2rem, 5vw, 4rem);
  max-width: var(--wrap);
  margin: 0 auto clamp(2rem, 5vw, 4rem);
  padding: 0 var(--pad);
  align-items: start;
}
.services__cat__head h2 { font-size: clamp(1.6rem, 2.6vw, 2.2rem); margin: 0 0 .8rem; }
.services__cat__head p { color: var(--ink-mute); font-size: .92rem; line-height: 1.65; }
.services__list { list-style: none; margin: 0; padding: 0; }
.services__item {
  padding: 1.2rem 0;
  border-bottom: 1px dashed var(--rule);
}
.services__item:last-child { border-bottom: 0; }
.services__row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: baseline;
}
.services__name {
  font-family: var(--serif); font-weight: 700;
  font-size: .9rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  white-space: nowrap;
}
.services__cat__head h2 { letter-spacing: .02em; }

/* ── SERVICES PAGE — NEW LAYOUT ── */
.svc-intro {
  background: var(--bg);
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
  text-align: center;
}
.svc-intro__inner { max-width: 760px; margin: 0 auto; padding: 0 var(--pad); }
.svc-intro__inner h2 { margin: 0 0 1.4rem; font-size: clamp(2rem, 4.4vw, 3.2rem); }
.svc-intro__inner .lede { margin: 0 auto; max-width: 56ch; }

.svc-band {
  padding: clamp(3.5rem, 7vw, 6rem) 0;
  background: var(--bg);
}
.svc-band--alt { background: var(--bg-cream); }

.svc-band__head {
  text-align: center;
  margin: 0 auto clamp(2.4rem, 5vw, 4rem);
  max-width: 720px;
  padding: 0 var(--pad);
  position: relative;
}
.svc-band__num {
  font-family: var(--serif);
  font-weight: 500;
  font-size: .72rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 1rem;
}
.svc-band__head h2 {
  margin: 0;
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.6rem, 5.6vw, 4.4rem);
  letter-spacing: .02em;
  line-height: 1;
}
.svc-band__amp {
  font-family: var(--script);
  font-weight: 400;
  color: var(--gold);
  margin: 0 .15em;
  font-size: 1.1em;
  letter-spacing: 0;
  vertical-align: -.05em;
}
.svc-band__rule {
  display: block;
  width: 56px;
  height: 1px;
  background: var(--gold);
  margin: 1.4rem auto 0;
}

.svc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(.5rem, 1.5vw, 1.2rem);
  max-width: var(--wrap);
  margin: 0 auto;
  padding: 0 var(--pad);
}
@media (max-width: 980px) { .svc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .svc-grid { grid-template-columns: 1fr; } }

.svc-card {
  margin: 0;
  padding: clamp(1.4rem, 2.5vw, 2rem);
  background: var(--bg);
  border: 1px solid var(--rule);
  transition: border-color .25s, transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
}
.svc-band--alt .svc-card { background: #fff; }
.svc-card:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px -28px rgba(184,159,110,.4);
}
.svc-card__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--rule);
}
.svc-card__name {
  font-family: var(--serif);
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0;
  flex: 1;
}
.svc-card__price {
  font-family: var(--display);
  font-size: 1.1rem;
  letter-spacing: .02em;
  color: var(--gold);
  white-space: nowrap;
}
.svc-card__desc {
  font-size: .92rem;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0;
  flex: 1;
}

/* Image break between bands */
.svc-break {
  position: relative;
  height: clamp(220px, 30vh, 360px);
  overflow: hidden;
}
.svc-break__bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center 30%;
}
.svc-break__bg::after {
  content:""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.45));
}
.page-hero__sub {
  font-family: var(--serif); font-weight: 300;
  font-size: .95rem;
  letter-spacing: .04em;
  color: rgba(255,255,255,.78);
  margin: 1rem 0 0;
}
.services__note {
  text-align: center;
  max-width: var(--wrap);
  margin: 2rem auto 0;
  padding: 0 var(--pad);
  font-size: .9rem;
  color: var(--ink-mute);
  display: flex; align-items: center; justify-content: center;
  gap: .6rem;
}
.services__note .services__bullet {
  color: var(--gold);
  font-size: .65rem;
}
.services__line {
  border-bottom: 1px solid var(--rule);
  height: 0;
  margin-bottom: .35em;
}
.services__price {
  font-family: var(--serif); font-weight: 500;
  font-size: .92rem;
  color: var(--ink);
  white-space: nowrap;
}
.services__desc {
  font-size: .9rem; line-height: 1.6; color: var(--ink-mute);
  margin: .55rem 0 0; max-width: 60ch;
}
@media (max-width: 760px) {
  .services__cat { grid-template-columns: 1fr; }
}

/* ── STYLISTS PAGE ── */
.stylists {
  padding: clamp(4rem, 8vw, 7rem) 0;
  background: var(--bg);
  text-align: center;
}
.stylists__intro { max-width: 640px; margin: 0 auto clamp(3rem, 5vw, 4.5rem); padding: 0 var(--pad); }
.stylists__intro h2 { margin: 0 0 1rem; }
.stylists__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 320px));
  gap: clamp(2rem, 5vw, 4rem);
  justify-content: center;
  padding: 0 var(--pad);
}
.stylist {
  text-align: center;
}
.stylist__photo {
  width: 220px; height: 220px;
  margin: 0 auto 1.4rem;
  border-radius: 50%;
  background: var(--bg-soft);
  border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
  position: relative;
  overflow: hidden;
}
.stylist__photo img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.stylist__monogram {
  font-family: var(--display);
  font-size: 6rem;
  color: var(--gold);
  line-height: 1;
}
.stylist__ig {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  color: var(--gold);
  margin-bottom: .5rem;
}
.stylist__ig svg { width: 18px; height: 18px; }
.stylist__name {
  font-family: var(--serif); font-weight: 500;
  font-size: 1.1rem;
  margin: 0 0 .3rem;
  color: var(--ink);
  letter-spacing: .04em;
}
.stylist__skills {
  font-size: .9rem;
  color: var(--ink-mute);
  letter-spacing: .03em;
  margin: 0 0 1rem;
}
.stylist__bio {
  font-size: .9rem;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 30ch;
  margin: 0 auto 1.2rem;
}
@media (max-width: 700px) { .stylists__grid { grid-template-columns: 1fr; max-width: 320px; margin: 0 auto; } }

/* ── CONTACT FORM (kept from prior, minor tweaks) ── */
.contact { padding: clamp(4rem, 8vw, 7rem) 0; background: var(--bg); border-top: 1px solid var(--rule); }
.contact__grid { display: grid; grid-template-columns: minmax(0, 5fr) minmax(0, 6fr); gap: clamp(2rem, 5vw, 4rem); align-items: start; max-width: var(--wrap); margin: 0 auto; padding: 0 var(--pad); }
.contact__intro h2 { margin: 0 0 1rem; }
.contact__intro .lede { margin-bottom: 2rem; }
.contact__details { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1rem; }
.contact__details li { display: grid; grid-template-columns: 80px 1fr; gap: 1rem; align-items: baseline; padding-bottom: 1rem; border-bottom: 1px solid var(--rule); color: var(--ink-soft); word-break: normal; overflow-wrap: anywhere; }
.contact__details .nowrap { white-space: nowrap; }
@media (max-width: 480px) {
  .contact__details li { grid-template-columns: 1fr; gap: .25rem; }
  .contact__details a { font-size: 1.15rem; }
}
.contact__details li:last-child { border-bottom: 0; }
.contact__label { font-family: var(--serif); font-weight: 700; font-size: .7rem; letter-spacing: .3em; text-transform: uppercase; color: var(--gold); }
.contact__details a { color: var(--ink); text-decoration: none; }
.contact__details a:hover { color: var(--gold); }
.contact__details sup { color: var(--gold); font-size: .6em; }

.contact__form { display: flex; flex-direction: column; gap: 1.3rem; background: var(--bg-cream); padding: clamp(1.6rem, 3vw, 2.6rem); border: 1px solid var(--rule); position: relative; }
.field { display: flex; flex-direction: column; gap: .45rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field label { font-family: var(--serif); font-weight: 500; font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink); }
.field label span { color: var(--gold); margin-left: .15em; }
.field input, .field select, .field textarea {
  font-family: var(--serif); font-weight: 400; font-size: 1rem;
  color: var(--ink); background: var(--bg);
  border: 1px solid var(--rule-strong);
  padding: .9rem 1rem; border-radius: 0;
  transition: border-color .2s, box-shadow .2s; width: 100%;
}
.field textarea { resize: vertical; min-height: 120px; }
.field select {
  appearance: none; -webkit-appearance: none; padding-right: 2.4rem; cursor: pointer;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink) 50%), linear-gradient(-45deg, transparent 50%, var(--ink) 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px; background-repeat: no-repeat;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: 0; border-color: var(--ink); box-shadow: 0 0 0 1px var(--ink); }
.field--actions { flex-direction: row; align-items: center; gap: 1.4rem; flex-wrap: wrap; margin-top: .6rem; }
.field--actions .microcopy { margin: 0; font-size: .8rem; font-style: italic; color: var(--ink-mute); flex: 1; min-width: 200px; }
.field--actions .microcopy a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
.field--actions .microcopy a:hover { color: var(--gold); }
@media (max-width: 820px) { .contact__grid { grid-template-columns: 1fr; } .field-row { grid-template-columns: 1fr; } }

/* ── FOOTER (Brighton-style: dark, 3 cols) ── */
.foot {
  background: var(--bg-ink);
  color: rgba(255,255,255,.7);
  padding: clamp(4rem, 7vw, 6rem) 0 1.6rem;
}
.foot__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 0 var(--pad) 3rem;
}
.foot__logo { width: 180px; height: auto; margin-bottom: 1.4rem; filter: invert(1) brightness(.95); }
.foot__brand p { font-size: .9rem; line-height: 1.7; color: rgba(255,255,255,.65); max-width: 42ch; margin-bottom: 1.4rem; }
.foot__social { display: flex; align-items: center; gap: .8rem; margin-bottom: 1.6rem; color: rgba(255,255,255,.5); font-size: .9rem; }
.foot__social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  color: rgba(255,255,255,.7);
  transition: color .2s;
}
.foot__social a:hover { color: var(--gold); }
.foot__social svg { width: 18px; height: 18px; }
.foot__book {
  font-family: var(--serif); font-weight: 500;
  font-size: .76rem; letter-spacing: .28em; text-transform: uppercase;
  color: #fff; text-decoration: none;
  border-bottom: 1px solid var(--gold);
  padding-bottom: .3rem;
  display: inline-block;
}
.foot__book:hover { color: var(--gold); }
.foot__col h4 { color: #fff; margin: 0 0 1.2rem; }
.foot__col p, .foot__col a { font-size: .9rem; color: rgba(255,255,255,.7); text-decoration: none; }
.foot__col a:hover { color: var(--gold); }
.foot__col p { margin: 0 0 .8rem; }
.foot__hours { list-style: none; margin: 0; padding: 0; }
.foot__hours li { display: flex; justify-content: space-between; padding: .25rem 0; font-size: .9rem; color: rgba(255,255,255,.7); border-bottom: 1px solid rgba(255,255,255,.06); }
.foot__hours li:last-child { border-bottom: 0; }
.foot__legal {
  border-top: 1px solid rgba(255,255,255,.08);
  max-width: var(--wrap-wide);
  margin: 0 auto;
  padding: 1.4rem var(--pad) 0;
  text-align: center;
  font-size: .82rem;
  color: rgba(255,255,255,.5);
}
.foot__legal a { color: rgba(255,255,255,.7); text-decoration: none; }
.foot__legal a:hover { color: var(--gold); }
.foot__legal .sep { margin: 0 .6rem; color: rgba(255,255,255,.3); }
@media (max-width: 760px) {
  .foot__inner { grid-template-columns: 1fr; gap: 2.4rem; text-align: left; }
}

/* ── RECKLESS PAGE: kept ── */
.reckless-hero { background: var(--bg-ink); color: #fff; padding: clamp(5rem, 12vw, 8rem) 0 clamp(4rem, 8vw, 6rem); text-align: center; position: relative; overflow: hidden; }
.reckless-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at top, rgba(184,159,110,.18), transparent 60%), radial-gradient(ellipse at bottom, rgba(165,29,45,.12), transparent 60%); pointer-events: none; }
.reckless-hero__inner { position: relative; max-width: 720px; margin: 0 auto; padding: 0 var(--pad); }
.reckless-hero__title { color: #fff; font-size: clamp(3rem, 7.5vw, 5.4rem); margin: .4rem 0 1.6rem; line-height: .95; letter-spacing: .04em; }
.reckless-hero__title .display--script { display: block; line-height: 1; margin-top: .15em; color: var(--gold); font-size: .55em; font-family: var(--script); letter-spacing: 0; text-transform: none; font-weight: 400; }
.reckless-hero .lede { color: rgba(255,255,255,.84); margin: 0 auto 2.4rem; max-width: 560px; }
.reckless-hero__ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.btn--ghost.btn--on-dark { background: transparent; color: #fff; border-color: rgba(255,255,255,.5); }
.btn--ghost.btn--on-dark:hover { background: #fff; color: var(--ink); border-color: #fff; }

/* Reckless intro band */
.reckless-intro {
  background: var(--bg);
  padding: clamp(4rem, 7vw, 6rem) 0;
  text-align: center;
}
.reckless-intro__inner { max-width: 720px; margin: 0 auto; padding: 0 var(--pad); }
.reckless-intro__inner h2 { margin-bottom: 1.4rem; }
.reckless-intro__inner .lede { margin: 0 auto 2rem; }
.reckless-intro__ctas { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

.reckless-strip { background: var(--bg-ink); padding: 0; }
.reckless-strip__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.reckless-strip figure { margin: 0; aspect-ratio: 4/3; background: #000; overflow: hidden; }
.reckless-strip img { width: 100%; height: 100%; object-fit: cover; object-position: center 22%; transition: transform .6s ease; }
.reckless-strip figure:hover img { transform: scale(1.04); }
@media (max-width: 700px) { .reckless-strip__grid { grid-template-columns: 1fr; } .reckless-strip figure { aspect-ratio: 16/9; } }

.shop { padding: 6rem 0; background: var(--bg); }
.shop--alt { background: var(--bg-cream); }
.section-head { text-align: center; max-width: 760px; margin: 0 auto 4rem; padding: 0 var(--pad); }
.section-head h2 { margin-bottom: 1rem; }
.section-head .lede em { font-style: italic; color: var(--gold); }
.product__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.5rem, 3vw, 2.5rem) clamp(1rem, 2vw, 1.5rem); max-width: var(--wrap); margin: 0 auto; padding: 0 var(--pad); }
@media (max-width: 1000px) { .product__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .product__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px)  { .product__grid { grid-template-columns: 1fr; } }
.product { margin: 0; display: flex; flex-direction: column; }
.product__media { display: block; position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--bg-cream); border: 1px solid var(--rule); text-decoration: none; }
.shop--alt .product__media { background: var(--bg); }
.product__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.product__media:hover img { transform: scale(1.04); }
.product__buy { position: absolute; inset: auto 0 0 0; text-align: center; background: rgba(10,10,10,.92); color: #fff; padding: .8rem; font-family: var(--serif); font-weight: 500; font-size: .72rem; letter-spacing: .28em; text-transform: uppercase; transform: translateY(100%); transition: transform .3s ease; }
.product__media:hover .product__buy, .product__media:focus-visible .product__buy { transform: translateY(0); }
.product__body { padding: 1.1rem .25rem 0; }
.product__name { font-family: var(--display); font-size: 1.4rem; margin: 0 0 .25rem; letter-spacing: .005em; color: var(--ink); font-weight: 400; text-transform: none; line-height: 1.1; }
.product__price { font-family: var(--serif); font-weight: 500; font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); margin: 0 0 .55rem; }
.product__desc { font-size: .9rem; line-height: 1.55; color: var(--ink-soft); margin: 0; }

::selection { background: var(--ink); color: #fff; }
