/* =====================================================================
   MOORES — Brand foundation
   Warm quiet luxury · handcrafted · Sussex
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Jost:wght@300;400;500;600&display=swap');

:root {
  /* ---- Core palette: Warm Quiet Luxury ---- */
  --paper:      #F6F0E5;  /* warm oat — primary background        */
  --paper-deep: #EFE5D4;  /* deeper cream — panels / alt sections */
  --shell:      #FBF7EF;  /* near-white card surface              */
  --ink:        #2A211A;  /* warm espresso — primary text         */
  --ink-soft:   #6F6152;  /* muted brown — secondary text         */
  --line:       #D9CCB7;  /* hairline / borders                   */

  /* ---- Accents ---- */
  --sienna:     #B05E36;  /* burnt sienna — primary accent, CTA   */
  --sienna-deep:#90492A;
  --sage:       #87886A;  /* soft garden sage — secondary accent  */
  --brass:      #A8843E;  /* fine metallic line accent            */

  /* ---- Type ---- */
  --display: 'Cormorant Garamond', Georgia, serif;
  --sans:    'Jost', 'Helvetica Neue', Arial, sans-serif;

  /* ---- Rhythm ---- */
  --measure: 64ch;
  --gut: clamp(20px, 5vw, 64px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

* { box-sizing: border-box; }

html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 300;
  font-size: 17px;
  line-height: 1.7;
  letter-spacing: .01em;
}

/* ---------- Type scale ---------- */
.display {
  font-family: var(--display);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -.01em;
  text-wrap: balance;
}
h1, h2, h3 { font-family: var(--display); font-weight: 500; line-height: 1.05; margin: 0; }

.eyebrow {
  font-family: var(--sans);
  font-weight: 400;
  font-size: clamp(11px, 1vw, 12.5px);
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--sienna);
}
.eyebrow.muted { color: var(--ink-soft); }

p { margin: 0 0 1.1em; max-width: var(--measure); }
a { color: inherit; text-decoration: none; }

.serif-lead {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(20px, 2.4vw, 27px);
  line-height: 1.5;
  color: var(--ink-soft);
}
em, .italic { font-style: italic; }

/* ---------- Buttons ---------- */
.btn {
  --bg: var(--sienna);
  --fg: var(--shell);
  display: inline-flex;
  align-items: center;
  gap: .7em;
  font-family: var(--sans);
  font-weight: 400;
  font-size: 13px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 15px 26px;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid var(--bg);
  border-radius: 2px;
  cursor: pointer;
  transition: background .4s var(--ease), color .4s var(--ease), transform .4s var(--ease);
}
.btn:hover { --bg: var(--sienna-deep); transform: translateY(-1px); }
.btn .arrow { transition: transform .4s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

.btn.ghost {
  --bg: transparent;
  --fg: var(--ink);
  border-color: var(--line);
}
.btn.ghost:hover { --bg: transparent; --fg: var(--sienna); border-color: var(--sienna); }

.link-underline {
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--sienna);
  transition: color .3s var(--ease);
}

/* Inline text link — inherits the surrounding serif so it flows mid-sentence */
.link-inline {
  color: var(--sienna);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: color-mix(in oklab, var(--sienna) 45%, transparent);
  transition: text-decoration-color .3s var(--ease), color .3s var(--ease);
}
.link-inline:hover {
  color: var(--sienna-deep, var(--sienna));
  text-decoration-color: var(--sienna);
}
.link-underline:hover { color: var(--sienna); }

/* ---------- Layout helpers ---------- */
.wrap { max-width: 1280px; margin: 0 auto; padding-inline: var(--gut); }
.rule { height: 1px; background: var(--line); border: 0; margin: 0; }

/* ---------- Warm brand photo treatment ---------- */
.brand-img {
  position: relative;
  overflow: hidden;
}
.brand-img img {
  /* Warm Moores grade is baked into the photo files so every image shares
     the same colour space — no live filter needed (avoids double-grading). */
  filter: none;
  transition: filter .5s var(--ease);
}
.brand-img::after { content: none; }

/* Re-apply the Moores grade for source images that aren't pre-baked (e.g. supplied product shots on a plain/generated background). */
.brand-img--grade img {
  filter: sepia(.18) saturate(.88) brightness(.96) contrast(1.04);
}
.brand-img--grade::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(160deg, color-mix(in oklab, var(--sienna) 14%, transparent), color-mix(in oklab, var(--paper-deep) 10%, transparent));
  mix-blend-mode: multiply;
  pointer-events: none;
}

/* ---------- Scroll reveal ---------- */
[data-reveal] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}
[data-reveal].in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none; }
}

/* ---------- Inner-page components ---------- */
.page-hero { padding-block: clamp(56px, 9vh, 116px) clamp(28px, 5vh, 56px); }
.page-hero .eyebrow { display: block; margin-bottom: 18px; }
.page-hero h1 { font-size: clamp(44px, 6.6vw, 88px); }
.page-hero h1 em { color: var(--sienna); }
.page-hero .serif-lead { margin-top: 26px; }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 88px); align-items: center; }
.split.wide-text { grid-template-columns: 1fr 1.12fr; }
.split.wide-media { grid-template-columns: 1.12fr 1fr; }
.split image-slot { width: 100%; }
.split h2 { font-size: clamp(32px, 4.2vw, 54px); margin: 14px 0 22px; }
@media (max-width: 820px) { .split { grid-template-columns: 1fr; } .split .media-first { order: -1; } }

.prose { max-width: 62ch; }
.full-media { width: 100%; }

/* ---------- Section rhythm (shared by all pages) ---------- */
.pad { padding-block: clamp(72px, 12vh, 150px); }
.alt { background: var(--paper-deep); }

.cta-band { background: var(--ink); color: var(--paper); }
.cta-band .inner { max-width: 760px; margin: 0 auto; text-align: center; }
.cta-band h2 { color: var(--paper); font-size: clamp(34px, 5vw, 62px); margin-bottom: 20px; }
.cta-band h2 em { color: color-mix(in oklab, var(--brass) 88%, white); }
.cta-band .serif-lead { color: color-mix(in oklab, var(--paper) 74%, transparent); margin: 0 auto 32px; }
.cta-band .btn { --bg: var(--brass); --fg: var(--ink); border-color: var(--brass); }
.cta-band .btn:hover { --bg: color-mix(in oklab, var(--brass) 82%, white); }

.steps-list { counter-reset: s; }
.steps-list .step { display: flex; gap: 24px; padding: 26px 0; border-top: 1px solid var(--line); }
.steps-list .step:last-child { border-bottom: 1px solid var(--line); }
.steps-list .step::before { counter-increment: s; content: counter(s, decimal-leading-zero); font-family: var(--display); color: var(--sienna); font-size: 30px; line-height: 1.1; flex: none; min-width: 1.5em; }
.steps-list .step h3 { font-size: 22px; margin: 0 0 6px; }
.steps-list .step p { font-size: 15px; color: var(--ink-soft); margin: 0; max-width: 54ch; }

/* ---------- Form ---------- */
.field { display: grid; gap: 8px; }
.field label { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-soft); }
.field input, .field textarea, .field select {
  font-family: var(--sans); font-size: 16px; font-weight: 300; color: var(--ink);
  background: var(--shell); border: 1px solid var(--line); border-radius: 2px; padding: 13px 15px; width: 100%;
  transition: border-color .3s var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--sienna); }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 480px) { .row2 { grid-template-columns: 1fr; } }
