:root{
    --sec: clamp(72px, 10vw, 140px);
    --hero: clamp(42px, 6.4vw, 82px);
    --maxw: 1180px;
  }
  *{ box-sizing:border-box; }
  html,body{ margin:0; padding:0; }
  body{
    background: var(--paper);
    color: var(--ink);
    font-family: var(--serif-font);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
    position:relative;
  }

  /* soft oversized circles drifting through the beige (behind everything;
     the opaque colour bands cover them, so they only read on paper) */
  .page-decor{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
  .page-decor .pd{ position:absolute; border-radius:49% 51% 47% 53% / 54% 46% 56% 44%; filter:url(#wobble); opacity:.26; }
  .page-decor .pd.ring{ background:transparent !important; border:14px solid var(--clay); opacity:.16; }
  .site-head, main, .foot{ position:relative; z-index:1; }
  .site-head{ z-index:50; }
  body.space-airy{ --sec: clamp(80px, 11vw, 156px); --hero: clamp(40px, 6vw, 78px); }
  body.space-cozy{ --sec: clamp(44px, 5.5vw, 80px); --hero: clamp(34px, 5vw, 60px); }

  .filters-defs{ position:absolute; width:0; height:0; overflow:hidden; }
  .wrap{ max-width: var(--maxw); margin:0 auto; padding:0 clamp(22px, 5vw, 64px); }
  a{ color:inherit; text-decoration:none; }

  /* accent words */
  .hl  { color: var(--terracotta); font-style:italic; }
  .hl-2{ color: var(--sage); font-style:italic; }

  /* ---------- Header ---------- */
  .site-head{
    position:sticky; top:0; z-index:50;
    background-color: var(--ink); color: var(--cream);
    background-image:
      repeating-linear-gradient(45deg, rgba(246,239,224,0.09) 0 1.5px, transparent 1.5px 16px),
      repeating-linear-gradient(-45deg, rgba(246,239,224,0.09) 0 1.5px, transparent 1.5px 16px);
    border-bottom: 2px solid color-mix(in srgb, var(--cream) 22%, transparent);
  }
  .site-head .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding-top:18px; padding-bottom:18px; }
  .brand{ font-family: var(--serif-font); font-weight:500; font-size:24px; letter-spacing:-0.01em; line-height:1; color: var(--cream); }
  .brand .dot{ color: var(--terracotta); }
  .nav{ display:flex; align-items:center; gap: clamp(16px, 2.2vw, 32px); }
  .nav a{ font-family: var(--sans-font); font-size:15px; font-weight:500; letter-spacing:0.01em; color: color-mix(in srgb, var(--cream) 72%, transparent); padding:4px 0; position:relative; }
  .nav a:hover{ color: var(--cream); }
  .nav a.active{ color: var(--cream); }
  .nav a.active::after{
    content:""; position:absolute; left:-3px; right:-3px; bottom:-3px; height:7px;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 6'><path d='M0 3 Q 10 0 20 3 T 40 3 T 60 3 T 80 3' stroke='%23a8593a' stroke-width='1.8' fill='none'/></svg>");
    background-size:80px 6px; background-repeat:repeat-x;
  }
  .nav .sub{ margin-left:4px; }
  /* hamburger toggle — hidden on desktop, shown at <=620px (see media query) */
  .nav-toggle, .nav-toggle-cb{ display:none; }

  /* ---------- Hero ---------- */
  .hero{
    position:relative;
    padding-top: clamp(44px, 6vw, 92px); padding-bottom: clamp(40px, 5vw, 72px);
    background:
      radial-gradient(120% 90% at 88% 6%, color-mix(in srgb, var(--ochre) 22%, var(--paper)) 0%, transparent 55%),
      radial-gradient(100% 80% at 0% 100%, color-mix(in srgb, var(--sage) 14%, var(--paper)) 0%, transparent 50%);
  }
  .hero-grid{ display:grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(34px, 5vw, 76px); align-items:center; }
  .eyebrow{ font-family: var(--hand-font); font-size:23px; color: var(--sage); margin:0 0 16px; line-height:1; }
  .hero h1{
    font-family: var(--serif-font); font-weight:300; font-size: var(--hero);
    line-height:1.0; letter-spacing:-0.02em; margin:0; color: var(--ink); text-wrap: balance;
    overflow-wrap:break-word; min-width:0;
  }
  .hero h1 em{ font-style:italic; color: var(--terracotta); font-weight:400; }
  .hero h1 .between{ color: var(--sage); font-style:italic; }
  .hero p.intro{
    font-family: var(--serif-font); font-weight:300; font-size: clamp(17px, 1.55vw, 21px);
    line-height:1.62; color: var(--ink); margin: 28px 0 0; max-width: 33em; text-wrap:pretty;
  }
  .hero-cta{ display:flex; align-items:center; gap: 22px; margin-top: 32px; flex-wrap:wrap; }
  .hero-cta .btn-sketch{ white-space:nowrap; }
  .link-quiet{ font-family: var(--sans-font); font-size:15px; color: var(--ink-soft); border-bottom:1px solid color-mix(in srgb, var(--ink) 30%, transparent); padding-bottom:2px; }
  .link-quiet:hover{ color: var(--ink); border-color: var(--ink); }

  /* hero photo, organic blob crop with a sage shadow echo */
  .hero-photo{ position:relative; justify-self:center; width:100%; max-width: 400px; }
  .blob-wrap{ position:relative; z-index:1; }
  .blob-img{ display:block; width:100%; aspect-ratio:1/1.08; object-fit:cover; object-position:56% 26%;
    border-radius: 16% 13% 15% 12% / 13% 16% 12% 14%;
    border:4px solid var(--cream); box-shadow:0 20px 46px rgba(42,42,28,0.18); }
  .hero-photo::before{ content:""; position:absolute; z-index:0; inset:0; transform:translate(22px,26px);
    background:var(--sage); border-radius: 16% 13% 15% 12% / 13% 16% 12% 14%; }
  .hero-photo .acc{ position:absolute; z-index:2; pointer-events:none; }
  .acc-leaf  { right:-14px; top:-14px;    transform:rotate(26deg) scale(1.5); }
  .acc-flower{ left:-26px;  top:58px;     transform:rotate(-14deg) scale(1.4); }
  .acc-star  { left:-8px;   bottom:64px;  transform:rotate(0deg) scale(1.2); }
  .acc-leaf2 { right:26px;  bottom:-20px; transform:rotate(-34deg) scale(1.25); }
  .hello{ position:absolute; z-index:3; left:-12px; top:-24px; font-family:var(--hand-font); font-weight:700; font-size:36px; color:var(--terracotta); transform:rotate(-9deg); }
  .greeting{ font-family:var(--hand-font); font-weight:700; font-size:clamp(34px,4.4vw,52px); color:var(--sage); margin:0 0 18px; line-height:1; }
  .garden-line{ font-family:var(--serif-font); font-weight:300; font-style:italic; font-size:clamp(22px,2.4vw,30px); color:var(--terracotta); margin:-6px 0 20px; line-height:1.1; }

  /* ---- organic "blob" motif, reused across the site ---- */
  .blobshot{ position:relative; --blob:46% 54% 45% 55% / 57% 43% 57% 43%; --ex:20px; --ey:24px; }
  .blobshot > img{ display:block; width:100%; object-fit:cover; border:4px solid var(--cream); box-shadow:0 18px 42px rgba(42,42,28,.18); border-radius:var(--blob); position:relative; z-index:1; }
  .blobshot::before{ content:""; position:absolute; inset:0; transform:translate(var(--ex),var(--ey)); background:var(--sage); border-radius:var(--blob); z-index:0; }
  .blobshot.flip{ --ex:-20px; }
  .blobshot.b2{ --blob:56% 44% 59% 41% / 43% 57% 43% 57%; }
  .blobshot.b3{ --blob:50% 50% 43% 57% / 55% 47% 53% 45%; }
  .blobshot.echo-terra::before{ background:var(--terracotta); }
  .blobshot.echo-ochre::before{ background:var(--ochre); }
  .blobshot.echo-cream::before{ background:var(--cream); }
  .blobshot.echo-ink::before{ background:var(--ink); }
  /* rectangular image/card sitting on an organic blob backdrop */
  .on-blob{ position:relative; display:inline-block; }
  .on-blob::before{ content:""; position:absolute; z-index:0; inset:-10% -13% -15% -11%; background:var(--sage); border-radius:46% 54% 45% 55% / 57% 43% 57% 43%; }
  .on-blob > *{ position:relative; z-index:1; }
  .on-blob.echo-ochre::before{ background:var(--ochre); }
  .on-blob.echo-cream::before{ background:var(--cream); }
  .on-blob.echo-terra::before{ background:var(--terracotta); }
  /* soft decorative blob accent (no image) */
  .deco-blob{ position:absolute; z-index:0; pointer-events:none; border-radius:48% 52% 44% 56% / 56% 44% 58% 42%; opacity:.42; }
  /* hand-drawn wobble on every organic shape (responds to the Rendering tweak) */
  .blobshot > img, .blobshot::before, .on-blob::before, .deco-blob, .blob-img, .hero-photo::before{ filter:url(#wobble); }

  /* ---------- Quick facts, colour-blocked chips that act as a divider ---------- */
  .facts{ padding: clamp(46px,5.5vw,84px) 0; text-align:center; }
  .facts .label{ font-family: var(--hand-font); font-size: clamp(26px,3vw,38px); color: var(--terracotta); margin:0 0 28px; line-height:1; }
  .facts .chips{ display:flex; flex-wrap:wrap; gap:16px 18px; justify-content:center; align-items:center; max-width: 1000px; margin:0 auto; }
  .fact-chip{
    display:inline-block; font-family: var(--serif-font); font-weight:400;
    font-size: clamp(15px,1.45vw,19px); line-height:1.25;
    padding:11px 20px; border:2px solid var(--ink);
    border-radius: 22px 26px 23px 27px / 26px 22px 27px 23px;
    filter:url(#wobble); box-shadow:3px 3px 0 var(--ink);
  }
  .fact-chip:nth-child(odd){ transform: rotate(-1.5deg); }
  .fact-chip:nth-child(even){ transform: rotate(1.3deg); }
  .fact-chip:nth-child(3n){ transform: rotate(-0.6deg); }
  .fc-terra{ background: var(--terracotta); color: var(--cream); }
  .fc-sage { background: var(--sage);       color: var(--cream); }
  .fc-ochre{ background: var(--ochre);      color: var(--ink); }
  .fc-cream{ background: var(--cream);      color: var(--ink); }
  .fc-clay { background: var(--clay);       color: var(--cream); }
  .fc-ink  { background: var(--ink);        color: var(--cream); }

  /* ---------- full-bleed colour bands ---------- */
  .band{ width:100%;
    background-image:
      repeating-linear-gradient(45deg, rgba(246,239,224,0.07) 0 1.5px, transparent 1.5px 17px),
      repeating-linear-gradient(-45deg, rgba(246,239,224,0.07) 0 1.5px, transparent 1.5px 17px);
  }
  .band-sage{ background-color: var(--sage); color: var(--cream); }
  .band-terra{ background-color: var(--terracotta); color: var(--cream); }
  .band-ink{ background-color: var(--ink); color: var(--cream); }

  /* ---------- Featured (on sage band) ---------- */
  .featured{ padding: var(--sec) 0; }
  .featured .kicker{ font-family: var(--hand-font); font-size:25px; color: var(--ink); margin:0 0 22px; line-height:1; display:flex; align-items:center; gap:10px; }
  .featured .kicker .live{ font-family: var(--sans-font); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color: color-mix(in srgb, var(--ink) 72%, transparent); border:1px solid color-mix(in srgb,var(--ink) 38%,transparent); border-radius:999px; padding:3px 9px 2px; }
  .feat-grid{ display:grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(30px,4.5vw,68px); align-items:center; }
  .feat-cover{ position:relative; display:block; }
  .feat-cover::before{ content:""; position:absolute; inset:0; transform:translate(18px,20px); background:var(--ochre); border-radius:16% 13% 15% 12% / 13% 16% 12% 15%; filter:url(#wobble); z-index:0; }
  .feat-cover img{ position:relative; z-index:1; display:block; width:100%; aspect-ratio:4/3; object-fit:cover; border:4px solid var(--cream); border-radius:16% 13% 15% 12% / 13% 16% 12% 15%; filter:url(#wobble); box-shadow:0 18px 40px rgba(0,0,0,0.24); background: color-mix(in srgb, var(--sage) 60%, #000); }
  .feat-cover .tape{ display:none; }
  .feat-copy{ min-width:0; }
  .featured .meta{ font-family: var(--sans-font); font-size:13px; letter-spacing:0.14em; text-transform:uppercase; color: color-mix(in srgb, var(--cream) 72%, transparent); margin: 0 0 22px; }
  .featured h2{
    font-family: var(--serif-font); font-weight:400; font-size: clamp(28px, 3vw, 40px);
    line-height:1.14; letter-spacing:-0.015em; margin:0; color: var(--cream); text-wrap:pretty;
  }
  .featured h2 em{ font-style:italic; color: var(--ochre); }
  .featured .dek{ font-family: var(--serif-font); font-weight:300; font-size: clamp(16px,1.4vw,19px); line-height:1.62; color: color-mix(in srgb, var(--cream) 88%, transparent); margin:24px 0 0; }
  .featured .read-link{ display:inline-block; margin-top:28px; font-family: var(--hand-font); font-size:23px; color: var(--cream); white-space:nowrap; }
  .featured .read-link:hover{ color: var(--ochre); }
  .featured .older{ display:inline-block; margin-top:26px; font-family: var(--sans-font); font-size:14px; color: color-mix(in srgb, var(--cream) 78%, transparent); border-bottom:1px solid color-mix(in srgb,var(--cream) 40%,transparent); padding-bottom:2px; }
  .featured .older:hover{ color:var(--cream); }

  /* ---------- Newsletter (on terracotta band) ---------- */
  .news{ padding: var(--sec) 0; text-align:center; }
  .news .panel{ position:relative; max-width: 720px; margin:0 auto; }
  .news .nl-tape{ position:absolute; top:-30px; left:50%; margin-left:-48px; }
  .news h3{ font-family: var(--serif-font); font-weight:400; font-size: clamp(30px,4vw,52px); line-height:1.04; margin:0; letter-spacing:-0.01em; color: var(--cream); }
  .news p{ font-family: var(--serif-font); font-weight:300; font-style:italic; font-size: clamp(15px,1.4vw,19px); line-height:1.55; margin: 16px auto 0; max-width: 34em; color: color-mix(in srgb, var(--cream) 90%, transparent); }
  .news form{ display:flex; gap:12px; justify-content:center; margin-top:30px; flex-wrap:wrap; }
  .news input{
    font-family: var(--sans-font); font-size:15px; color: var(--ink);
    background: var(--cream); border:none; padding:13px 18px; min-width: 260px; border-radius: 3px;
  }
  .news input::placeholder{ color: color-mix(in srgb, var(--ink) 45%, transparent); }
  .news .count{ font-family: var(--sans-font); font-size:13px; letter-spacing:0.06em; margin-top:18px; color: color-mix(in srgb, var(--cream) 82%, transparent); }

  /* ---------- Footer (on ink band) ---------- */
  .foot{ position:relative; }
  .foot::before{ content:""; position:absolute; top:0; left:0; right:0; height:50px; pointer-events:none; opacity:.82;
    background-image:
      linear-gradient(var(--cream),var(--cream)),
      repeating-linear-gradient(90deg, var(--cream) 0 2.5px, transparent 2.5px 12px);
    background-repeat:no-repeat, repeat;
    background-size:100% 2.5px, auto;
    background-position:top, top;
    -webkit-mask-image: linear-gradient(to bottom,#000 26%, rgba(0,0,0,0) 92%);
            mask-image: linear-gradient(to bottom,#000 26%, rgba(0,0,0,0) 92%); }
  .foot .wrap{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding-top:80px; padding-bottom:40px; flex-wrap:wrap; }
  .foot .sig{ font-family: var(--hand-font); font-size:24px; color: var(--cream); white-space:nowrap; }
  .foot .links{ display:flex; gap:24px; font-family: var(--sans-font); font-size:14px; color: color-mix(in srgb, var(--cream) 78%, transparent); }
  .foot .links a:hover{ color: var(--cream); }

  /* ---------- Responsive ---------- */
  @media (max-width: 880px){
    .hero-grid{ grid-template-columns: 1fr; gap: 48px; }
    .hero-photo{ max-width: 340px; }
    .facts .chips{ gap:13px 14px; }
    .feat-grid{ grid-template-columns: 1fr; gap: 34px; }
    .feat-cover{ max-width: 460px; }
  }
  @media (max-width: 620px){
    /* show the hamburger; the inline links collapse into a toggled dropdown */
    .site-head .wrap{ flex-wrap:wrap; }
    .nav-toggle{
      display:flex; flex-direction:column; justify-content:center; gap:5px;
      width:42px; height:42px; padding:9px; margin:-9px -9px -9px 0; cursor:pointer;
    }
    .nav-toggle span{ display:block; width:100%; height:2px; border-radius:2px;
      background:var(--cream); transition:transform .2s ease, opacity .2s ease; }
    .nav{ display:none; }
    #nav-toggle:checked ~ .nav{
      display:flex; flex-direction:column; align-items:flex-start;
      flex-basis:100%; gap:2px; padding:6px 0 14px;
    }
    .nav a{ display:block; width:100%; font-size:18px; padding:10px 0; }
    .nav a.active::after{ display:none; }
    .nav .sub{ margin:10px 0 0; }
    /* hamburger morphs into an X when open */
    #nav-toggle:checked ~ .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
    #nav-toggle:checked ~ .nav-toggle span:nth-child(2){ opacity:0; }
    #nav-toggle:checked ~ .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  }

/* ============ generic inner-page helpers (shared) ============ */
.page-head{ position:relative; overflow:hidden; padding: clamp(24px,3.2vw,46px) 0 clamp(16px,2.2vw,30px); }
.page-title{ font-family:var(--serif-font); font-weight:300; font-size: var(--hero); line-height:1.0; letter-spacing:-0.02em; margin:0; color:var(--ink); text-wrap:balance; }
.page-title em{ font-style:italic; color:var(--terracotta); }
.page-intro{ font-family:var(--serif-font); font-weight:300; font-size:clamp(17px,1.6vw,22px); line-height:1.6; color:var(--ink); max-width:38em; margin:24px 0 0; text-wrap:pretty; }
.section{ padding: var(--sec) 0; }
/* tighten the first content block right under a page intro (plain sections;
   leave colour bands with their symmetric padding) */
.page-head + .section:not(.band){ padding-top: clamp(30px,4vw,58px); }
.section-kicker{ font-family:var(--hand-font); font-size:24px; color:var(--terracotta); margin:0 0 12px; line-height:1; }
.band-sage .section-kicker, .band-ink .section-kicker{ color:var(--ochre); }
.section-title{ font-family:var(--serif-font); font-weight:400; font-size:clamp(26px,3.2vw,42px); line-height:1.1; margin:0; letter-spacing:-0.012em; color:var(--ink); text-wrap:pretty; }
.band-sage .section-title, .band-terra .section-title, .band-ink .section-title{ color:var(--cream); }
.band-sage .page-title, .band-terra .page-title, .band-ink .page-title{ color:var(--cream); }
.band-sage .page-intro, .band-terra .page-intro, .band-ink .page-intro{ color: color-mix(in srgb,var(--cream) 90%, transparent); }
.muted{ color: var(--ink-soft); }
.band-sage .muted, .band-terra .muted, .band-ink .muted{ color: color-mix(in srgb,var(--cream) 80%, transparent); }
.btn-sketch{ white-space:nowrap; }

/* ---- standalone statement band (homepage) ---- */
.statement{ background: var(--cream); padding: clamp(72px,10vw,150px) 0; text-align:center; }
.big-statement{ font-family:var(--serif-font); font-weight:300; font-size:var(--hero); line-height:1.0; letter-spacing:-0.02em; margin:0; color:var(--ink); text-wrap:balance; }
.big-statement em{ font-style:italic; color:var(--terracotta); font-weight:400; }
.big-statement .between{ color:var(--sage); font-style:italic; }