/* ============================================================
   Landhart v20 — Vertical Scroll Story / Narrative Longform
   Fonts: Newsreader (display) + Inter (body)
   Palette: cream #F4EEE0 · forest #1A2417 · moss #2F4A33 · gold #B8945F
   ============================================================ */

:root{
  --cream:#F4EEE0;
  --cream-2:#EAE2CE;
  --forest:#1A2417;
  --forest-2:#0F1610;
  --moss:#2F4A33;
  --moss-2:#243A28;
  --gold:#B8945F;
  --gold-2:#A07F4A;
  --ink:#1A2417;
  --ink-soft:#3A4338;

  --display: "Newsreader", "Iowan Old Style", Georgia, serif;
  --body: "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;

  --measure: 62ch;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --rail: clamp(1rem, 3vw, 2.25rem);

  --ease: cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ animation:none !important; transition:none !important; }
}

body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; }

/* ---------- Scroll progress bar ---------- */
.progress{
  position:fixed; top:0; left:0; right:0; height:3px;
  background:rgba(26,36,23,.08);
  z-index:60; pointer-events:none;
}
.progress > span{
  display:block; height:100%; width:100%;
  background:linear-gradient(90deg,var(--gold),var(--moss));
  transform-origin:0 50%;
  transform:scaleX(0);
  transition:transform .08s linear;
}

/* ---------- Masthead (sticky) ---------- */
.masthead{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; gap:var(--gutter);
  padding:.85rem var(--rail);
  background:rgba(244,238,224,.78);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid rgba(26,36,23,.08);
  color:var(--ink);
  transition:background .5s var(--ease), color .5s var(--ease), border-color .5s var(--ease);
}
.masthead[data-tone="forest"],
.masthead[data-tone="moss"]{
  background:rgba(15,22,16,.62);
  color:var(--cream);
  border-bottom-color:rgba(244,238,224,.12);
}
.brand{
  display:inline-flex; align-items:center; gap:.6rem;
  text-decoration:none; color:inherit;
  font-family:var(--display);
  line-height:1;            /* echte glyph-hoogte voor flex-centering */
}
.brand-mark{
  display:inline-block;
  width:1.7em;
  height:auto;            /* aspect-ratio uit viewBox */
  flex-shrink:0;
  color:var(--gold);      /* altijd goud — geen toggle met masthead-text */
  vertical-align:middle;
}
.brand-mark.big{ width:2.4em; color:var(--gold); }
.brand-name{
  font-family:var(--display);
  font-size:1.4rem;
  font-weight:500;
  letter-spacing:.005em;
  line-height:1;
  /* optische correctie: Newsreader-glyphs hangen iets boven het midden */
  transform:translateY(.04em);
}
.masthead-nav{
  margin-left:auto;
  display:flex; gap:.6rem;
  font-family:var(--body);
  font-size:.92rem;
  font-weight:500;
}
.masthead-nav a{
  padding:.5rem 1rem;
  text-decoration:none;
  border-radius:999px;
  opacity:.82;
  transition:opacity .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
}
.masthead-nav a:hover,
.masthead-nav a:focus-visible{ opacity:1; background:rgba(184,148,95,.16); }
@media (max-width:900px){
  .masthead-nav{ gap:.3rem; font-size:.85rem; }
  .masthead-nav a{ padding:.4rem .75rem; }
}
@media (max-width:720px){
  .masthead-nav{ display:none; }
}

/* ---------- Persistent Bel-knop (masthead-cta) ---------- */
.masthead-cta{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.55rem 1.1rem;
  background:var(--gold);
  color:#1A1207;
  border-radius:999px;
  font-family:var(--body);
  font-size:.92rem;
  font-weight:500;
  letter-spacing:.005em;
  text-decoration:none;
  white-space:nowrap;
  flex-shrink:0;
  margin-left:auto;
  position:relative;
  transition:background .25s var(--ease), box-shadow .35s var(--ease), transform .2s var(--ease);
  box-shadow:0 0 0 0 rgba(184,148,95,0);
}
/* desktop: kleinere gap tussen nav en cta. Op mobiel is nav verborgen
   en moet de base margin-left:auto blijven werken, dus deze override
   alleen op desktop laten vuren. */
@media (min-width:721px){
  .masthead-nav ~ .masthead-cta{ margin-left:.5rem; }
}
.masthead-cta:hover{
  background:var(--gold-2);
  box-shadow:0 0 0 4px rgba(184,148,95,.22), 0 0 22px rgba(184,148,95,.40);
  transform:translateY(-1px);
}
.cta-icon{
  display:inline-block;
  flex-shrink:0;
  color:#1A1207;
  transition:transform .35s var(--ease);
}
.masthead-cta:hover .cta-icon{ transform:rotate(-12deg) scale(1.08); }
.cta-num{ display:inline; }
.cta-short{ display:none; }
@media (max-width:480px){
  .masthead-cta{ padding:.5rem .9rem; font-size:.88rem; }
  .cta-num{ display:none; }
  .cta-short{ display:inline; }
}
@media (prefers-reduced-motion: reduce){
  .masthead-cta:hover .cta-icon{ transform:none; }
}

/* ---------- Chapter shell ---------- */
.chapter{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  align-items:center;
  padding:8rem var(--rail) 6rem;
  overflow:hidden;
  isolation:isolate;
}
@media (max-width:720px){
  .chapter{ min-height:auto; padding:7rem var(--rail) 4rem; }
  /* hero blijft schermvullend op telefoon. Kicker+titel zitten als
     groep bovenaan (iets verlaagd onder de masthead); lede+CTA's
     zitten als groep onderaan (iets verhoogd boven de bodem). Het
     auto-gat zit tussen TITEL en LEDE — daar is de hero-foto zichtbaar. */
  .chapter-hero{
    min-height:100svh;
    padding:8.5rem var(--rail) 5.5rem;
    align-items:stretch;
  }
  .chapter-hero .hero-inner{
    display:flex;
    flex-direction:column;
    align-self:stretch;
  }
  .chapter-hero .hero-lede{
    margin-top:auto;          /* duwt lede+cta als blok naar beneden */
    margin-bottom:1.5rem;     /* tight tegen de cta-knoppen */
  }
  .chapter-hero .hero-cta{
    margin-top:0;             /* override: cta volgt direct op lede */
  }
}

.chapter-inner{
  position:relative; z-index:2;
  width:100%;
  max-width:1180px;
  margin:0 auto;
}

/* Chapter tag — bottom corner */
.chapter-tag{
  position:absolute;
  bottom:1.4rem; right:var(--rail);
  z-index:3;
  display:flex; align-items:baseline; gap:.55rem;
  font-family:var(--display);
  color:var(--ink);
  opacity:.85;
}
.chapter-tag.dark{ color:var(--forest); }
.chapter-tag.light{ color:var(--cream); }
.chapter-tag span{
  font-size:clamp(2.4rem, 6vw, 4.2rem);
  font-style:italic; font-weight:400;
  line-height:1;
  color:var(--gold);
}
.chapter-tag small{
  font-family:var(--body);
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
}

/* Background pictures */
.chapter-bg{
  position:absolute; inset:0; z-index:0;
  display:block;
}
.chapter-bg img{
  width:100%; height:100%; object-fit:cover;
}
.chapter-bg.subtle img{ opacity:.55; }
.chapter-veil{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(15,22,16,.78) 0%, rgba(15,22,16,.55) 50%, rgba(15,22,16,.82) 100%);
}
.chapter-veil.light{
  background:linear-gradient(180deg, rgba(15,22,16,.35) 0%, rgba(15,22,16,.55) 100%);
}

/* ---------- Reveal animation ---------- */
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(28px); }
  to  { opacity:1; transform:translateY(0); }
}
.chapter-inner > *{
  animation:fadeUp .9s var(--ease) both;
  animation-timeline:view();
  animation-range:entry 0% entry 60%;
}
@supports not (animation-timeline:view()){
  .chapter-inner > *{ animation:none; }
}

/* ---------- Typography helpers ---------- */
.kicker{
  font-family:var(--body);
  font-size:.78rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  opacity:.75;
  margin:0 0 1.25rem;
}
.chapter-head{ max-width:720px; margin-bottom:3.5rem; }
.chapter-head.light{ color:var(--cream); }
.chapter-title{
  font-family:var(--display);
  font-weight:400;
  font-style:normal;
  font-size:clamp(2.2rem, 5.6vw, 4.8rem);
  line-height:1.04;
  letter-spacing:-.015em;
  margin:0 0 1.2rem;
}
.chapter-lede{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(1.05rem, 1.6vw, 1.35rem);
  line-height:1.55;
  max-width:var(--measure);
  margin:0;
  opacity:.92;
}

/* ---------- HOOFDSTUK I — HERO ---------- */
.chapter-hero{ color:var(--cream); }
.hero-inner{ max-width:1100px; }
.hero-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.6rem, 8vw, 7rem);
  line-height:.98;
  letter-spacing:-.02em;
  margin:0 0 1.6rem;
  max-width:14ch;
}
.hero-title em{
  font-style:italic;
  font-weight:300;
  color:var(--gold);
}
.hero-lede{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(1.05rem, 1.55vw, 1.3rem);
  line-height:1.6;
  max-width:54ch;
  margin:0 0 2rem;
  opacity:.94;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:.85rem; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.95rem 1.5rem;
  font-family:var(--body); font-weight:500;
  font-size:.92rem; letter-spacing:.02em;
  border-radius:999px;
  border:1px solid transparent;
  text-decoration:none;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn-gold{ background:var(--gold); color:#1A1207; }
.btn-gold:hover{ background:var(--gold-2); transform:translateY(-1px); }
.btn-ghost{ background:transparent; color:currentColor; border-color:currentColor; opacity:.85; }
.btn-ghost:hover{ background:rgba(244,238,224,.1); opacity:1; }
.btn-large{ padding:1.1rem 2rem; font-size:1rem; }

/* ---------- HOOFDSTUK II — DIENSTEN ---------- */
.chapter-services{ background:var(--cream); }
.services{
  list-style:none; padding:0; margin:0;
  --gap-x:clamp(1.6rem, 3vw, 2.4rem);
  --gap-y:clamp(2rem, 3.5vw, 2.8rem);
  display:grid;
  grid-template-columns:1fr;
  column-gap:var(--gap-x);
  row-gap:var(--gap-y);
}
@media (min-width:640px){
  .services{ grid-template-columns:1fr 1fr; }
}
@media (min-width:960px){
  .services{ grid-template-columns:repeat(3,1fr); }
}

.service{
  position:relative;
  padding:clamp(1.2rem, 2vw, 1.8rem) clamp(1rem, 1.8vw, 1.4rem);
  background:transparent;
  isolation:isolate;
}

/* Dividers — 3-koloms desktop layout: 6 items in 3×2 grid */
@media (min-width:960px){
  /* Vertical divider RECHTS van items 1, 2, 4, 5 (niet de laatste in elke rij) */
  .service:not(:nth-child(3n))::after{
    content:"";
    position:absolute;
    top:14%; bottom:14%;
    right:calc(var(--gap-x) / -2);
    width:1px;
    background:rgba(26,36,23,.16);
  }
  /* Horizontal divider ONDER items 1, 2, 3 (alleen eerste rij) */
  .service:nth-child(-n+3)::before{
    content:"";
    position:absolute;
    left:12%; right:12%;
    bottom:calc(var(--gap-y) / -2);
    height:1px;
    background:rgba(26,36,23,.16);
  }
}

/* Dividers — 2-koloms tablet: 6 items in 2×3 grid */
@media (min-width:640px) and (max-width:959px){
  /* Vertical divider RECHTS van items 1, 3, 5 */
  .service:not(:nth-child(2n))::after{
    content:"";
    position:absolute;
    top:14%; bottom:14%;
    right:calc(var(--gap-x) / -2);
    width:1px;
    background:rgba(26,36,23,.16);
  }
  /* Horizontal divider ONDER items 1, 2, 3, 4 (niet onder de laatste rij 5+6) */
  .service:not(:nth-last-child(-n+2))::before{
    content:"";
    position:absolute;
    left:12%; right:12%;
    bottom:calc(var(--gap-y) / -2);
    height:1px;
    background:rgba(26,36,23,.16);
  }
}

.service-num{
  font-family:var(--display); font-style:italic;
  font-size:.95rem; color:var(--gold);
  display:inline-block; margin-bottom:1.4rem;
  letter-spacing:.06em;
}
.service h3{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(1.5rem, 2.4vw, 2rem);
  line-height:1.1;
  margin:0 0 .75rem;
  letter-spacing:-.01em;
}
.service p{
  font-family:var(--display);
  font-weight:300;
  font-size:1.02rem;
  line-height:1.55;
  margin:0;
  max-width:34ch;
  opacity:.92;
}

/* ---------- INTERLUDE — PLATE ---------- */
.chapter-plate{
  color:var(--cream);
  align-items:center;
  justify-content:center;
  text-align:center;
}
.plate-quote{
  position:relative; z-index:2;
  margin:0 auto;
  max-width:900px;
  padding:0 var(--rail);
}
.plate-quote blockquote{
  font-family:var(--display);
  font-style:italic;
  font-weight:300;
  font-size:clamp(1.8rem, 4.5vw, 3.4rem);
  line-height:1.18;
  letter-spacing:-.01em;
  margin:0 0 1.4rem;
  color:var(--cream);
}
.plate-quote figcaption{
  font-family:var(--body);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  opacity:.8;
  color:var(--gold);
}

/* ---------- HOOFDSTUK III — PROJECTEN ---------- */
.chapter-projects{
  background:var(--moss);
  color:var(--cream);
}
.chapter-projects .chapter-title,
.chapter-projects{
  display:block;            /* override .chapter flex */
  min-height:auto;          /* override 100vh */
  padding-block:clamp(4rem, 8vw, 6rem);
  padding-inline:0;         /* rail bepaalt zelf padding */
}
.chapter-projects .chapter-inner{
  padding-inline:var(--rail);
  margin-bottom:clamp(1.5rem, 3vw, 2.5rem);
}
.chapter-projects .chapter-lede{ color:var(--cream); }
.chapter-projects .kicker{ color:var(--gold); opacity:1; }

/* Horizontal scrolling project rail */
.projects-rail{
  display:flex;
  gap:clamp(1.2rem, 2.5vw, 2rem);
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-padding-inline:var(--rail);
  padding:1rem var(--rail) 2rem;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--gold) rgba(244,238,224,.1);
  /* Center cards when ze passen in viewport, anders fallback naar start (zodat eerste card bereikbaar blijft) */
  justify-content:safe center;
}
.projects-rail::-webkit-scrollbar{ height:6px; }
.projects-rail::-webkit-scrollbar-thumb{ background:var(--gold); border-radius:3px; }
.projects-rail::-webkit-scrollbar-track{ background:rgba(244,238,224,.08); }
.projects-rail:focus-visible{ outline:2px solid var(--gold); outline-offset:4px; }

.project-card{
  flex:0 0 clamp(280px, 75vw, 380px);
  scroll-snap-align:start;
  display:flex; flex-direction:column;
  gap:1rem;
  color:var(--cream);
}
.project-card figure{
  margin:0;
  position:relative;
  overflow:hidden;
  border-radius:2px;
  box-shadow:0 24px 48px -24px rgba(0,0,0,.55);
  aspect-ratio:4/5;
}
.project-card figure::after{
  content:"";
  position:absolute; inset:0;
  border:1px solid rgba(244,238,224,.12);
  pointer-events:none;
}
.project-card img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 1s var(--ease);
}
.project-card:hover img{ transform:scale(1.05); }

.project-card-body{ display:flex; flex-direction:column; gap:.4rem; }

.project-meta{
  font-family:var(--body);
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0;
}
.project-card h3{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(1.3rem, 2vw, 1.7rem);
  line-height:1.1;
  letter-spacing:-.012em;
  margin:0;
}
.project-card-body p:last-child{
  font-family:var(--display);
  font-weight:300;
  font-size:.98rem;
  line-height:1.5;
  margin:0;
  opacity:.9;
}

.projects-hint{
  text-align:center;
  font-family:var(--body);
  font-size:.74rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--gold);
  opacity:.7;
  margin:0 0 1rem;
}
@media (min-width:1200px){
  .projects-hint{ display:none; }
}

/* ---------- OVER ONS ---------- */
.chapter-about{
  background:var(--cream);
  color:var(--ink);
}
.about-inner{ max-width:1180px; }
.about-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(2rem, 5vw, 4rem);
  align-items:center;
}
@media (min-width:880px){
  .about-grid{ grid-template-columns:1.2fr 1fr; }
}
.about-text{ display:grid; gap:1.1rem; max-width:58ch; }
.about-text p{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(1.05rem, 1.45vw, 1.22rem);
  line-height:1.65;
  margin:0;
  color:var(--ink);
}
.about-pull{
  font-family:var(--display) !important;
  font-style:italic;
  font-weight:400 !important;
  font-size:clamp(1.25rem, 2vw, 1.6rem) !important;
  line-height:1.4 !important;
  color:var(--gold) !important;
  border-left:2px solid var(--gold);
  padding-left:1.2rem;
  margin-top:.6rem !important;
}
.about-photo{
  margin:0;
  border-radius:50%;
  overflow:hidden;
  aspect-ratio:1 / 1;
  background:var(--moss);
  max-width:clamp(240px, 32vw, 340px);
  width:100%;
  justify-self:end;
  align-self:center;
  box-shadow:0 20px 40px -20px rgba(15,22,16,.32);
}
.about-photo picture{ display:block; width:100%; height:100%; }
.about-photo img{
  display:block;
  width:100%; height:100%;
  object-fit:cover;
  object-position:50% 6%;  /* hoofd top-aligned met klein beetje ademruimte boven */
}
@media (max-width:880px){
  .about-photo{
    max-width:clamp(200px, 56vw, 300px);
    justify-self:center;
  }
}

/* ---------- HOOFDSTUK IV — CONTACT ---------- */
.chapter-contact{
  background:var(--cream);
  color:var(--ink);
}
.chapter-contact .chapter-bg{ filter:saturate(.7); }
.chapter-contact .chapter-bg::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(244,238,224,.55), rgba(244,238,224,.92));
}
.contact-inner{ max-width:1180px; }

/* 2-column contact: info left, form right */
.contact-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(2rem, 5vw, 4rem);
  align-items:start;
}
@media (min-width:880px){
  .contact-layout{ grid-template-columns:1fr 1.1fr; }
}

.contact-info{ display:grid; gap:1.4rem; }
.contact-info .btn{ justify-self:start; }

.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.2rem 2.4rem;
  margin:0;
  padding:1.6rem 0;
  border-top:1px solid rgba(26,36,23,.18);
  border-bottom:1px solid rgba(26,36,23,.18);
}
@media (min-width:540px){ .contact-grid{ grid-template-columns:repeat(2,1fr); } }
.contact-grid > div{ margin:0; }
.contact-grid dt{
  font-family:var(--body);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:.45rem;
}
.contact-grid dd{
  margin:0;
  font-family:var(--display);
  font-weight:400;
  font-size:1.18rem;
  line-height:1.5;
}
.contact-grid a{
  text-decoration:none;
  background-image:linear-gradient(var(--gold),var(--gold));
  background-size:100% 1px;
  background-repeat:no-repeat;
  background-position:0 100%;
  transition:background-size .3s var(--ease), color .3s var(--ease);
}
.contact-grid a:hover{ color:var(--gold-2); background-size:100% 2px; }

/* ---------- Contact form ---------- */
.contact-form{
  display:grid;
  gap:1rem;
  padding:clamp(1.5rem, 3vw, 2.2rem);
  background:rgba(26,36,23,.045);
  border:1px solid rgba(26,36,23,.12);
  border-radius:14px;
}
.form-title{
  font-family:var(--display);
  font-size:clamp(1.2rem, 1.6vw, 1.5rem);
  font-weight:500;
  line-height:1.2;
  margin:0 0 .35rem;
  color:var(--ink);
}
.form-row{ display:grid; gap:.4rem; }
.form-row-half{
  display:grid; grid-template-columns:1fr; gap:1rem;
}
@media (min-width:540px){
  .form-row-half{ grid-template-columns:1fr 1fr; }
}
.form-row-half > div{ display:grid; gap:.4rem; }

.contact-form label{
  font-family:var(--body);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--ink-soft);
}
.contact-form .req{ color:var(--gold); margin-left:2px; }

.contact-form input,
.contact-form textarea{
  font-family:var(--body);
  font-size:1rem;
  line-height:1.5;
  color:var(--ink);
  background:var(--cream);
  border:1px solid rgba(26,36,23,.18);
  border-radius:8px;
  padding:.72rem .9rem;
  outline:0;
  width:100%;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.contact-form input:focus,
.contact-form textarea:focus{
  border-color:var(--gold);
  background:#fff;
  box-shadow:0 0 0 3px rgba(184,148,95,.20);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{ color:rgba(26,36,23,.42); }

.contact-form textarea{
  resize:vertical;
  min-height:7rem;
  font-family:var(--display);
  font-size:1.05rem;
  line-height:1.55;
}

.form-hint{
  font-size:.82rem;
  color:var(--ink-soft);
  font-style:italic;
  margin:-.25rem 0 .05rem;
}
.form-error{
  background:rgba(184,148,95,.12);
  border:1px solid rgba(184,148,95,.45);
  color:var(--ink);
  border-radius:8px;
  padding:.7rem .95rem;
  font-size:.92rem;
}
.contact-form button[type="submit"]{
  justify-self:start;
  margin-top:.4rem;
}
.form-fine{
  font-size:.76rem;
  color:var(--ink-soft);
  font-style:italic;
  margin:0;
}

/* ---------- Footer ---------- */
.footer{
  background:var(--forest);
  color:var(--cream);
  padding:4rem var(--rail) 2.5rem;
}
.footer-inner{
  max-width:1180px; margin:0 auto;
  display:grid;
  grid-template-columns:1fr;
  gap:3rem;
}
@media (min-width:880px){
  .footer-inner{ grid-template-columns:1.2fr 2fr; align-items:start; }
}
.footer-mark{ display:flex; flex-direction:column; gap:.6rem; }
.footer-name{
  font-family:var(--display);
  font-size:1.4rem;
  font-weight:400;
  margin:.2rem 0 0;
}
.footer-tag{
  font-family:var(--display);
  font-style:italic;
  font-weight:300;
  font-size:.95rem;
  opacity:.7;
  margin:0;
}
.footer-cols{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:2rem;
}
.footer-cols h4{
  font-family:var(--body);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 .8rem;
  font-weight:600;
}
.footer-cols p{
  font-family:var(--display);
  font-weight:300;
  font-size:1rem;
  line-height:1.7;
  margin:0;
  opacity:.9;
}
.footer-cols a{
  text-decoration:none;
  opacity:.9;
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease), opacity .25s var(--ease);
}
.footer-cols a:hover{ opacity:1; border-bottom-color:var(--gold); }
.footer-fine{
  grid-column:1/-1;
  font-family:var(--body);
  font-size:.78rem;
  letter-spacing:.06em;
  opacity:.55;
  margin:2.5rem 0 0;
  padding-top:1.5rem;
  border-top:1px solid rgba(244,238,224,.12);
}

/* ---------- Selection ---------- */
::selection{ background:var(--gold); color:var(--forest); }
