/* =========================================================================
   Wrenfield — wellbeing practice
   Type: Frank Ruhl Libre (display) · Lexend (body/UI) · DM Mono (labels/stats)
   Palette: slate-blue · greige · soft coral
   Motion: fade + slide from alternating sides
   ========================================================================= */

:root {
  /* palette */
  --slate-900: #1d2733;
  --slate-800: #28384a;
  --slate-700: #34495f;
  --slate-600: #46627f;
  --slate-500: #5d7a98;
  --slate-400: #8298b1;

  --greige-50:  #f6f3ee;
  --greige-100: #efeae1;
  --greige-200: #e4ddd0;
  --greige-300: #d2c8b7;
  --greige-400: #b3a791;

  --coral:      #e98572;
  --coral-soft: #f2a896;
  --coral-deep: #cf6450;
  --coral-tint: #fbe7e0;

  --ink:   #20262e;
  --paper: #f8f5f0;
  --white: #ffffff;

  /* semantic */
  --bg:         var(--paper);
  --bg-alt:     var(--greige-100);
  --fg:         var(--ink);
  --fg-soft:    #51596480;
  --muted:      #5b6675;
  --line:       #dfd6c6;
  --accent:     var(--coral);
  --accent-ink: var(--coral-deep);
  --brand:      var(--slate-700);

  /* type */
  --display: "Frank Ruhl Libre", Georgia, "Times New Roman", serif;
  --body: "Lexend", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono: "DM Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* rhythm */
  --maxw: 1200px;
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --radius: 18px;
  --radius-lg: 28px;

  --shadow-sm: 0 1px 2px rgba(29,39,51,.06), 0 4px 14px rgba(29,39,51,.05);
  --shadow-md: 0 14px 40px -18px rgba(29,39,51,.30), 0 4px 16px -8px rgba(29,39,51,.16);
  --shadow-lg: 0 40px 90px -40px rgba(29,39,51,.42);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--body);
  font-weight: 350;
  color: var(--fg);
  background: var(--bg);
  line-height: 1.65;
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.075rem);
  letter-spacing: .002em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
h1,h2,h3,h4 { font-family: var(--display); font-weight: 500; line-height: 1.08; letter-spacing: -0.01em; margin: 0 0 .5em; color: var(--slate-900); }
p { margin: 0 0 1.1em; }

::selection { background: var(--coral-tint); color: var(--coral-deep); }

/* ---------- a11y ---------- */
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 200;
  background: var(--slate-900); color: #fff; padding: .75rem 1.25rem; border-radius: 0 0 10px 0;
  font-family: var(--mono); font-size: .8rem;
}
.skip-link:focus { left: 0; }

:focus-visible {
  outline: 3px solid var(--coral-deep);
  outline-offset: 3px;
  border-radius: 4px;
}

.visually-hidden {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ---------- layout ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.wrap--narrow { max-width: 760px; }
.section { padding-block: clamp(4.5rem, 9vw, 8rem); position: relative; }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }

.eyebrow {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--accent-ink);
  display: inline-flex; align-items: center; gap: .65rem;
  margin: 0 0 1.25rem;
}
.eyebrow::before {
  content: ""; width: 26px; height: 1px; background: var(--coral); display: inline-block;
}
.eyebrow--center { justify-content: center; }

.lede { font-size: clamp(1.15rem, 1.02rem + 0.6vw, 1.5rem); line-height: 1.5; color: var(--slate-700); font-weight: 350; }

/* ---------- buttons ---------- */
.btn {
  --b: var(--slate-900);
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--body); font-weight: 450; font-size: .96rem; letter-spacing: .005em;
  padding: .92rem 1.7rem; border-radius: 100px; border: 1.5px solid var(--b);
  background: var(--b); color: #fff; cursor: pointer; text-decoration: none;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s, border-color .3s;
  box-shadow: var(--shadow-sm);
}
.btn .arr { transition: transform .35s var(--ease); }
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn:hover .arr { transform: translateX(4px); }
.btn--accent { --b: var(--coral-deep); background: var(--coral); border-color: var(--coral); color: #fff; }
.btn--accent:hover { background: var(--coral-deep); }
.btn--ghost { background: transparent; color: var(--slate-900); border-color: var(--slate-300, #cbc2b2); }
.btn--ghost:hover { border-color: var(--slate-900); background: var(--slate-900); color: #fff; }
.btn--light { background:#fff; color: var(--slate-900); border-color:#fff; }

.textlink {
  color: var(--accent-ink); text-decoration: none; font-weight: 450;
  background-image: linear-gradient(var(--coral), var(--coral));
  background-size: 100% 1.5px; background-position: 0 100%; background-repeat: no-repeat;
  padding-bottom: 1px; transition: background-size .3s var(--ease), color .25s;
}
.textlink:hover { color: var(--coral-deep); background-size: 100% 100%; background-image: linear-gradient(var(--coral-tint), var(--coral-tint)); }

/* =========================================================================
   HEADER
   ========================================================================= */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .4s, background .4s, box-shadow .4s;
}
.site-header.is-scrolled { border-color: var(--line); box-shadow: 0 6px 24px -18px rgba(29,39,51,.5); }
.nav { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 2rem; }
.brand { display: inline-flex; align-items: center; gap: .7rem; text-decoration: none; color: var(--slate-900); }
.brand__mark { width: 34px; height: 34px; flex: 0 0 auto; }
.brand__name { font-family: var(--display); font-weight: 600; font-size: 1.32rem; letter-spacing: -0.01em; }
.brand__name small { font-family: var(--mono); font-weight: 400; font-size: .58rem; letter-spacing: .24em; text-transform: uppercase; color: var(--muted); display: block; margin-top: -2px; }

.nav__links { display: flex; align-items: center; gap: 2.1rem; list-style: none; margin: 0; padding: 0; }
.nav__links a { text-decoration: none; color: var(--slate-700); font-size: .95rem; font-weight: 400; position: relative; padding: .35rem 0; transition: color .25s; }
.nav__links a::after { content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px; background: var(--coral); transition: right .35s var(--ease); }
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--slate-900); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after { right: 0; }
.nav__cta { margin-left: .4rem; }

.nav__toggle { display:none; background:none; border:1.5px solid var(--line); border-radius:10px; width:44px; height:44px; cursor:pointer; align-items:center; justify-content:center; }
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after { content:""; display:block; width:20px; height:2px; background: var(--slate-800); position: relative; transition: .3s; }
.nav__toggle span::before { position:absolute; top:-6px; }
.nav__toggle span::after { position:absolute; top:6px; }

@media (max-width: 860px) {
  .nav__toggle { display:inline-flex; }
  .nav__links {
    position: fixed; inset: 76px 0 auto 0; flex-direction: column; gap: 0;
    background: var(--paper); border-bottom: 1px solid var(--line);
    padding: 1rem var(--gutter) 2rem; align-items: stretch;
    transform: translateY(-120%); transition: transform .4s var(--ease); box-shadow: var(--shadow-md);
  }
  .nav.is-open .nav__links { transform: translateY(0); }
  .nav__links li { border-bottom: 1px solid var(--line); }
  .nav__links a { display:block; padding: 1rem 0; font-size: 1.05rem; }
  .nav__links .nav__cta { margin: 1.25rem 0 0; }
  .nav__links .btn { width: 100%; justify-content: center; }
}

/* =========================================================================
   HERO
   ========================================================================= */
.hero { position: relative; overflow: hidden; padding-block: clamp(3.5rem, 7vw, 6.5rem) clamp(4rem, 8vw, 7rem); }
.hero__bg { position:absolute; inset:0; z-index:-2; }
.hero__bg::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 55% at 78% 18%, rgba(233,133,114,.30), transparent 60%),
    radial-gradient(55% 60% at 12% 30%, rgba(70,98,127,.22), transparent 62%),
    radial-gradient(70% 80% at 50% 110%, rgba(212,200,183,.55), transparent 70%),
    linear-gradient(180deg, #f8f5f0 0%, #f1ece3 100%);
}
.hero__blob { position:absolute; border-radius:50%; filter: blur(46px); opacity:.55; z-index:-1; will-change: transform; }
.hero__blob--1 { width:42vw; height:42vw; max-width:560px; max-height:560px; top:-12%; right:-8%; background: radial-gradient(circle, rgba(233,133,114,.55), transparent 70%); }
.hero__blob--2 { width:38vw; height:38vw; max-width:480px; max-height:480px; bottom:-18%; left:-10%; background: radial-gradient(circle, rgba(93,122,152,.5), transparent 70%); }

.hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
@media (max-width: 920px){ .hero__grid { grid-template-columns: 1fr; gap: 2.5rem; } }

.hero__kicker { font-family: var(--mono); font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color: var(--accent-ink); display:flex; align-items:center; gap:.7rem; margin-bottom: 1.5rem; }
.hero__kicker::before { content:""; width:30px; height:1px; background: var(--coral); }
.hero h1 { font-size: clamp(2.6rem, 1.6rem + 4.2vw, 4.6rem); line-height: 1.02; letter-spacing: -0.02em; margin-bottom: 1.4rem; }
.hero h1 em { font-style: italic; color: var(--coral-deep); }
.hero__lede { font-size: clamp(1.1rem, 1rem + 0.55vw, 1.4rem); color: var(--slate-700); max-width: 34ch; margin-bottom: 2rem; }
.hero__actions { display:flex; flex-wrap:wrap; gap: .9rem; margin-bottom: 2.4rem; }
.hero__meta { display:flex; gap: 2rem; flex-wrap:wrap; align-items:center; }
.hero__meta .stat__num { font-family: var(--display); font-size: 2rem; color: var(--slate-900); line-height:1; }
.hero__meta .stat__lbl { font-family: var(--mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color: var(--muted); margin-top:.35rem; }

.hero__visual { position: relative; }
.hero__frame {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-lg); border: 1px solid rgba(255,255,255,.6);
  aspect-ratio: 4/4.5;
}
.hero__frame img { width:100%; height:100%; object-fit: cover; }
.hero__frame::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 50%, rgba(29,39,51,.28)); }
.hero__chip {
  position:absolute; z-index:3; background: rgba(248,245,240,.92); backdrop-filter: blur(8px);
  border:1px solid var(--line); border-radius: 16px; padding: .85rem 1.1rem; box-shadow: var(--shadow-md);
  display:flex; align-items:center; gap:.7rem;
}
.hero__chip--a { bottom: 8%; left: -6%; }
.hero__chip--b { top: 7%; right: -5%; }
.hero__chip .dot { width:10px; height:10px; border-radius:50%; background: var(--coral); box-shadow: 0 0 0 4px var(--coral-tint); flex:0 0 auto; }
.hero__chip strong { font-family: var(--display); font-size: 1rem; display:block; color: var(--slate-900); }
.hero__chip span { font-family: var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); }
@media (max-width:520px){ .hero__chip--a{left:4%;} .hero__chip--b{right:4%;} }

/* =========================================================================
   MARQUEE / trust strip
   ========================================================================= */
.trust { border-block: 1px solid var(--line); background: var(--greige-50); }
.trust__inner { display:flex; align-items:center; gap: clamp(1.5rem,4vw,3.5rem); flex-wrap:wrap; justify-content:center; padding-block: 1.6rem; }
.trust__label { font-family: var(--mono); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color: var(--muted); }
.trust__item { font-family: var(--display); font-size: 1.05rem; color: var(--slate-600); white-space: nowrap; }
.trust__dot { width:5px;height:5px;border-radius:50%;background:var(--coral);}

/* =========================================================================
   GENERIC SECTION HEADER
   ========================================================================= */
.sec-head { max-width: 700px; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.sec-head--center { margin-inline:auto; text-align:center; }
.sec-head h2 { font-size: clamp(2rem, 1.4rem + 2.4vw, 3.2rem); margin-bottom: .6rem; }
.sec-head p { color: var(--slate-600); font-size: clamp(1.05rem,1rem+.3vw,1.2rem); margin:0; }

/* =========================================================================
   PILLARS / approach
   ========================================================================= */
.pillars { display:grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
@media (max-width: 900px){ .pillars { grid-template-columns: 1fr; } }
.pillar {
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius);
  padding: 2.1rem 1.9rem; box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  position:relative; overflow:hidden;
}
.pillar::before { content:""; position:absolute; inset:0 auto 0 0; width:3px; background: var(--coral); transform: scaleY(0); transform-origin: top; transition: transform .45s var(--ease); }
.pillar:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: var(--greige-300); }
.pillar:hover::before { transform: scaleY(1); }
.pillar__no { font-family: var(--mono); font-size:.72rem; letter-spacing:.2em; color: var(--accent-ink); }
.pillar__ic { width:46px;height:46px;margin:.4rem 0 1.1rem; color: var(--slate-600); }
.pillar h3 { font-size: 1.4rem; margin-bottom:.5rem; }
.pillar p { color: var(--muted); margin:0; font-size:.98rem; }

/* =========================================================================
   ABOUT / split feature
   ========================================================================= */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4.5rem); align-items:center; }
.split--rev .split__media { order: 2; }
@media (max-width: 880px){ .split { grid-template-columns: 1fr; gap:2.5rem; } .split--rev .split__media{order:0;} }
.split__media { position: relative; }
.split__media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); width:100%; aspect-ratio: 5/4; object-fit: cover; }
.split__media .tag {
  position:absolute; bottom: 1.2rem; left: 1.2rem; background: rgba(248,245,240,.94); backdrop-filter: blur(8px);
  border-radius: 14px; padding:.7rem 1rem; box-shadow: var(--shadow-sm); border:1px solid var(--line);
  font-family: var(--mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color: var(--slate-700);
}
.checklist { list-style:none; margin: 1.6rem 0 2rem; padding:0; display:grid; gap:.9rem; }
.checklist li { display:flex; gap:.85rem; align-items:flex-start; color: var(--slate-700); }
.checklist svg { flex:0 0 auto; margin-top:3px; color: var(--coral-deep); }

/* =========================================================================
   STATS band
   ========================================================================= */
.statband { background: var(--slate-900); color: #fff; position:relative; overflow:hidden; }
.statband::before { content:""; position:absolute; inset:0; background: radial-gradient(50% 90% at 85% 10%, rgba(233,133,114,.30), transparent 60%), radial-gradient(40% 80% at 10% 100%, rgba(93,122,152,.5), transparent 60%); }
.statband__grid { position:relative; display:grid; grid-template-columns: repeat(4,1fr); gap: 2rem; text-align:center; }
@media (max-width: 760px){ .statband__grid { grid-template-columns: repeat(2,1fr); gap:2.5rem 1.5rem; } }
.statband h2 { color: #fff; }
.statband .stat__num { font-family: var(--display); font-size: clamp(2.4rem,1.8rem+2vw,3.6rem); line-height:1; color:#fff; }
.statband .stat__num span { color: var(--coral-soft); }
.statband .stat__lbl { font-family: var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color: var(--greige-300); margin-top:.7rem; }

/* =========================================================================
   SERVICES list (homepage preview + services page)
   ========================================================================= */
.svc-list { display:grid; gap: 1.1rem; }
.svc {
  display:grid; grid-template-columns: auto 1fr auto; gap: 1.5rem; align-items:center;
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius);
  padding: 1.8rem 2rem; box-shadow: var(--shadow-sm); text-decoration:none; color: inherit;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s, background .4s;
}
.svc:hover { transform: translateX(6px); box-shadow: var(--shadow-md); border-color: var(--greige-300); }
.svc__no { font-family: var(--mono); font-size:.8rem; color: var(--accent-ink); letter-spacing:.1em; }
.svc__body h3 { font-size: 1.45rem; margin-bottom:.3rem; }
.svc__body p { color: var(--muted); margin:0; font-size:.97rem; }
.svc__price { font-family: var(--display); font-size: 1.05rem; color: var(--slate-700); white-space:nowrap; }
.svc__price small { display:block; font-family: var(--mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color: var(--muted); }
@media (max-width:620px){ .svc{ grid-template-columns: auto 1fr; } .svc__price{ grid-column: 2; } }

/* services page rich cards */
.svc-card {
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg);
  padding: 2.4rem; box-shadow: var(--shadow-sm); height:100%;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease);
  position: relative; overflow:hidden;
}
.svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.svc-card__ic { width:50px;height:50px;border-radius:14px; background: var(--coral-tint); color: var(--coral-deep); display:grid;place-items:center; margin-bottom:1.4rem; }
.svc-card h3 { font-size:1.6rem; }
.svc-card .feat { list-style:none; padding:0; margin:1.2rem 0 0; display:grid; gap:.6rem; }
.svc-card .feat li { display:flex; gap:.6rem; align-items:flex-start; color: var(--slate-700); font-size:.95rem; }
.svc-card .feat svg { flex:0 0 auto; margin-top:4px; color: var(--coral-deep); }
.grid-2 { display:grid; grid-template-columns: repeat(2,1fr); gap:1.5rem; }
.grid-3 { display:grid; grid-template-columns: repeat(3,1fr); gap:1.5rem; }
@media (max-width:880px){ .grid-2,.grid-3{ grid-template-columns:1fr; } }

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.quotes { display:grid; grid-template-columns: repeat(3,1fr); gap:1.5rem; }
@media (max-width:900px){ .quotes{ grid-template-columns:1fr; } }
.quote {
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg);
  padding: 2.2rem; box-shadow: var(--shadow-sm); display:flex; flex-direction:column; gap:1.2rem;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease);
}
.quote:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.quote__mark { font-family: var(--display); font-size: 3rem; line-height:.5; color: var(--coral); height:1.2rem; }
.quote p { font-family: var(--display); font-size: 1.18rem; line-height:1.45; color: var(--slate-800); font-weight:400; margin:0; flex:1; }
.quote__who { display:flex; align-items:center; gap:.85rem; border-top:1px solid var(--line); padding-top:1.2rem; }
.quote__av { width:42px;height:42px;border-radius:50%; background: linear-gradient(135deg,var(--slate-500),var(--coral)); color:#fff; display:grid;place-items:center; font-family:var(--display); font-size:1.05rem; flex:0 0 auto; }
.quote__who strong { display:block; font-family: var(--body); font-weight:500; font-size:.95rem; color: var(--slate-900); }
.quote__who span { font-family: var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color: var(--muted); }

/* =========================================================================
   TEAM
   ========================================================================= */
.team { display:grid; grid-template-columns: repeat(3,1fr); gap:1.5rem; }
@media (max-width:880px){ .team{ grid-template-columns:1fr; gap:1.25rem; } }
.member { background:var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.member:hover { transform: translateY(-5px); box-shadow:var(--shadow-md); }
.member__ph { aspect-ratio: 1/1; display:grid;place-items:center; background: linear-gradient(150deg, var(--greige-200), var(--greige-100)); position:relative; }
.member__ph .mono { font-family:var(--display); font-size: 3.2rem; color: var(--slate-500); }
.member__ph::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 70% 20%, rgba(233,133,114,.18), transparent 60%);}
.member__body { padding: 1.4rem 1.5rem 1.7rem; }
.member__body h3 { font-size:1.3rem; margin-bottom:.1rem; }
.member__role { font-family: var(--mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color: var(--accent-ink); margin-bottom:.8rem; }
.member__body p { color: var(--muted); font-size:.94rem; margin:0; }

/* =========================================================================
   INSIGHTS (posts)
   ========================================================================= */
.insights { display:grid; grid-template-columns: repeat(3,1fr); gap:1.5rem; }
@media (max-width:980px){ .insights{ grid-template-columns:1fr 1fr; } }
@media (max-width:680px){ .insights{ grid-template-columns:1fr; } }
.post-card {
  display:flex; flex-direction:column; background:var(--white); border:1px solid var(--line);
  border-radius: var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); text-decoration:none; color:inherit;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
}
.post-card:hover { transform: translateY(-6px); box-shadow:var(--shadow-md); border-color: var(--greige-300); }
.post-card__media { aspect-ratio: 16/10; overflow:hidden; position:relative; }
.post-card__media img { width:100%;height:100%;object-fit:cover; transition: transform .6s var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__cat { position:absolute; top:.9rem; left:.9rem; background: rgba(248,245,240,.94); backdrop-filter: blur(6px); font-family: var(--mono); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; color: var(--accent-ink); padding:.4rem .7rem; border-radius:100px; border:1px solid var(--line); }
.post-card__body { padding: 1.5rem 1.5rem 1.7rem; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.post-card__date { font-family: var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); }
.post-card h3 { font-size: 1.32rem; line-height:1.18; margin:0; }
.post-card p { color: var(--muted); font-size:.95rem; margin:0; }
.post-card__more { margin-top:auto; font-family: var(--mono); font-size:.72rem; letter-spacing:.08em; color: var(--accent-ink); display:inline-flex; gap:.4rem; align-items:center; }
.post-card:hover .post-card__more .arr { transform: translateX(4px); }
.post-card__more .arr { transition: transform .35s var(--ease); }

/* =========================================================================
   RESOURCES / blogroll
   ========================================================================= */
.resources { background: var(--bg-alt); }
.resource-list { display:grid; grid-template-columns: repeat(2,1fr); gap: .8rem; margin-top: 1.5rem; }
@media (max-width:720px){ .resource-list{ grid-template-columns:1fr; } }
.resource {
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  background: var(--white); border:1px solid var(--line); border-radius: 14px; padding: 1.1rem 1.3rem;
  text-decoration:none; color: var(--slate-800);
  transition: border-color .3s, transform .3s var(--ease), box-shadow .3s;
}
.resource:hover { border-color: var(--coral); transform: translateX(4px); box-shadow: var(--shadow-sm); color: var(--coral-deep); }
.resource span { font-weight: 450; }
.resource .ext { font-family: var(--mono); font-size:.66rem; color: var(--muted); flex:0 0 auto; }
.resource:hover .ext { color: var(--coral-deep); }

/* =========================================================================
   CTA band
   ========================================================================= */
.cta-band { position:relative; overflow:hidden; }
.cta-card {
  background: linear-gradient(135deg, var(--slate-800), var(--slate-900));
  border-radius: var(--radius-lg); padding: clamp(2.5rem,5vw,4.5rem); color:#fff; position:relative; overflow:hidden;
  display:grid; grid-template-columns: 1.3fr 1fr; gap: 2.5rem; align-items:center;
}
@media (max-width:820px){ .cta-card{ grid-template-columns:1fr; } }
.cta-card::before { content:""; position:absolute; inset:0; background: radial-gradient(45% 80% at 88% 15%, rgba(233,133,114,.4), transparent 60%); }
.cta-card > * { position:relative; }
.cta-card h2 { color:#fff; font-size: clamp(1.9rem,1.4rem+2vw,3rem); }
.cta-card p { color: var(--greige-200); margin:0; }
.cta-card .hero__actions { margin:0; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer { background: var(--slate-900); color: var(--greige-200); padding-block: clamp(3.5rem,6vw,5rem) 2rem; }
.footer__grid { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 2.5rem; }
@media (max-width:820px){ .footer__grid{ grid-template-columns: 1fr 1fr; gap:2.5rem 1.5rem; } }
@media (max-width:520px){ .footer__grid{ grid-template-columns: 1fr; } }
.site-footer .brand__name { color:#fff; }
.site-footer .brand__name small { color: var(--greige-400); }
.footer__about { color: var(--greige-300); font-size:.95rem; max-width: 34ch; margin-top:1.1rem; }
.footer__col h4 { font-family: var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color: var(--greige-400); margin-bottom:1.1rem; font-weight:400; }
.footer__col ul { list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.footer__col a { color: var(--greige-200); text-decoration:none; font-size:.95rem; transition: color .25s; }
.footer__col a:hover { color: var(--coral-soft); }
.footer__bottom { margin-top: 3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-family: var(--mono); font-size:.7rem; letter-spacing:.06em; color: var(--greige-400); }

/* =========================================================================
   ARTICLE
   ========================================================================= */
.article-hero { padding-block: clamp(2.5rem,5vw,4rem) 0; position:relative; }
.breadcrumb { font-family: var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); margin-bottom:1.6rem; display:flex; gap:.5rem; flex-wrap:wrap; align-items:center; }
.breadcrumb a { text-decoration:none; color: var(--slate-600); }
.breadcrumb a:hover { color: var(--coral-deep); }
.breadcrumb .sep { color: var(--greige-400); }
.article-hero h1 { font-size: clamp(2.1rem,1.5rem+3vw,3.6rem); max-width: 18ch; margin-bottom:1.1rem; }
.article-meta { display:flex; gap:1.5rem; flex-wrap:wrap; font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color: var(--muted); margin-bottom: 2.2rem; }
.article-meta .pill { color: var(--accent-ink); }
.article-cover { border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-md); margin-bottom: clamp(2rem,4vw,3.5rem); aspect-ratio: 21/9; }
.article-cover img { width:100%;height:100%;object-fit:cover; }

.prose { font-size: 1.075rem; line-height: 1.75; color: var(--slate-800); }
.prose > p:first-of-type { font-size: 1.22rem; line-height:1.6; color: var(--slate-700); }
.prose h2 { font-size: clamp(1.6rem,1.2rem+1.4vw,2.2rem); margin: 2.4rem 0 .9rem; }
.prose h3 { font-size: 1.35rem; margin: 1.9rem 0 .6rem; color: var(--slate-800); }
.prose p { margin: 0 0 1.2em; }
.prose a { color: var(--accent-ink); font-weight:450; text-decoration: underline; text-decoration-color: var(--coral-soft); text-underline-offset: 3px; text-decoration-thickness: 1.5px; transition: color .25s; }
.prose a:hover { color: var(--coral-deep); text-decoration-color: var(--coral-deep); }
.prose ul, .prose ol { margin: 0 0 1.4em; padding-left: 1.3em; }
.prose li { margin-bottom: .5em; }
.prose ul li::marker { color: var(--coral); }
.prose img { border-radius: var(--radius); box-shadow: var(--shadow-sm); margin: 1.8rem 0; }
.prose strong { color: var(--slate-900); font-weight: 550; }
.prose em { color: var(--slate-700); }
.prose table { width:100%; border-collapse: collapse; margin: 1.8rem 0; font-size:.95rem; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); }
.prose th { background: var(--slate-800); color:#fff; font-family: var(--body); font-weight:500; text-align:left; padding:.9rem 1rem; font-size:.9rem; }
.prose td { padding:.85rem 1rem; border-bottom:1px solid var(--line); background:#fff; }
.prose tr:nth-child(even) td { background: var(--greige-50); }
.prose section { margin: 1.2rem 0; }
.prose h2 + section, .prose section + section { margin-top: 0; }
.prose [itemprop="name"] { font-size:1.2rem; margin-top:1.6rem; }

.article-layout { display:grid; grid-template-columns: minmax(0,1fr) 300px; gap: clamp(2rem,5vw,4rem); align-items:start; }
@media (max-width: 960px){ .article-layout{ grid-template-columns:1fr; } }
.article-aside { position: sticky; top: 100px; display:grid; gap:1.25rem; }
@media (max-width:960px){ .article-aside{ position:static; } }
.aside-card { background: var(--white); border:1px solid var(--line); border-radius: var(--radius); padding: 1.6rem; box-shadow: var(--shadow-sm); }
.aside-card h4 { font-family: var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color: var(--accent-ink); margin-bottom:.9rem; }
.aside-card.brandbox { background: linear-gradient(160deg, var(--slate-800), var(--slate-900)); color:#fff; border:none; }
.aside-card.brandbox h4 { color: var(--coral-soft); }
.aside-card.brandbox p { color: var(--greige-200); font-size:.95rem; }
.aside-link { display:block; padding:.6rem 0; border-bottom:1px solid var(--line); text-decoration:none; color: var(--slate-700); font-size:.95rem; transition: color .25s, padding .25s; }
.aside-link:last-child{border-bottom:none;}
.aside-link:hover { color: var(--coral-deep); padding-left:.3rem; }

.article-cta { margin-top: clamp(2.5rem,5vw,4rem); }

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items:start; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }
.form { background:var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(1.8rem,4vw,2.8rem); box-shadow: var(--shadow-md); }
.field { margin-bottom: 1.4rem; }
.field label { display:block; font-family: var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color: var(--slate-700); margin-bottom:.55rem; }
.field input, .field textarea {
  width:100%; font-family: var(--body); font-size:1rem; color: var(--ink);
  background: var(--greige-50); border:1.5px solid var(--line); border-radius: 12px; padding:.9rem 1.05rem;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.field textarea { resize: vertical; min-height: 130px; }
.field input:focus, .field textarea:focus { outline:none; border-color: var(--coral); background:#fff; box-shadow: 0 0 0 4px var(--coral-tint); }
.field input::placeholder, .field textarea::placeholder { color: #9aa0a8; }
.form .btn { width:100%; justify-content:center; margin-top:.4rem; }
.form__note { font-size:.82rem; color: var(--muted); margin: 1rem 0 0; text-align:center; }
.contact-info { display:grid; gap: 1.5rem; }
.info-card { background: var(--greige-50); border:1px solid var(--line); border-radius: var(--radius); padding: 1.6rem 1.7rem; }
.info-card h3 { font-size:1.15rem; margin-bottom:.4rem; display:flex; align-items:center; gap:.6rem; }
.info-card h3 svg { color: var(--coral-deep); }
.info-card p, .info-card a { color: var(--slate-700); margin:0; text-decoration:none; }
.info-card a:hover { color: var(--coral-deep); }
.hours { display:grid; gap:.4rem; }
.hours div { display:flex; justify-content:space-between; font-size:.92rem; color: var(--slate-700); border-bottom:1px dashed var(--line); padding-bottom:.4rem; }
.hours div:last-child{border-bottom:none;}
.hours span:first-child{font-family:var(--mono);font-size:.78rem;letter-spacing:.05em;}

/* page hero (interior) */
.page-hero { position:relative; overflow:hidden; padding-block: clamp(3.5rem,7vw,6rem) clamp(2.5rem,5vw,4rem); }
.page-hero::before { content:""; position:absolute; inset:0; z-index:-1; background: radial-gradient(55% 70% at 80% 10%, rgba(233,133,114,.20), transparent 60%), radial-gradient(50% 60% at 5% 40%, rgba(70,98,127,.14), transparent 60%), linear-gradient(180deg,#f8f5f0,#f1ece3); }
.page-hero h1 { font-size: clamp(2.4rem,1.6rem+3.4vw,4rem); margin-bottom:1rem; max-width:16ch; }
.page-hero p { font-size: clamp(1.1rem,1rem+.5vw,1.35rem); color: var(--slate-700); max-width: 52ch; }

/* =========================================================================
   MOTION — fade + slide from alternating sides
   ========================================================================= */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); will-change: opacity, transform; }
.reveal.from-left  { transform: translateX(-46px); }
.reveal.from-right { transform: translateX(46px); }
.reveal.is-in { opacity: 1; transform: none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }
.reveal[data-delay="4"]{ transition-delay:.32s; }
.reveal[data-delay="5"]{ transition-delay:.40s; }

/* hero load stagger */
.hero [data-load] { opacity:0; transform: translateY(22px); }
.hero.loaded [data-load] { opacity:1; transform:none; transition: opacity .9s var(--ease), transform .9s var(--ease); }
.hero.loaded [data-load="1"]{ transition-delay:.05s;}
.hero.loaded [data-load="2"]{ transition-delay:.15s;}
.hero.loaded [data-load="3"]{ transition-delay:.25s;}
.hero.loaded [data-load="4"]{ transition-delay:.35s;}
.hero.loaded [data-load="5"]{ transition-delay:.45s;}
.hero.loaded [data-load="6"]{ transition-delay:.55s;}
.hero__visual[data-load]{ transform: translateX(40px) translateY(0); }
.hero.loaded .hero__visual[data-load]{ transform:none; transition: opacity 1s var(--ease) .2s, transform 1s var(--ease) .2s; }

@media (prefers-reduced-motion: reduce) {
  * , *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .reveal, .hero [data-load], .hero__visual[data-load] { opacity:1 !important; transform:none !important; }
  .hero__blob { display:none; }
}
