/* ============================================================
   FlowBuilt Studio — Website
   Shared design system  ·  used by every page in /site
   ============================================================ */

:root {
  --cream:      #FBFCFE;
  --cream-2:    #FFFFFF;
  --cream-3:    #EBF0F8;
  --ink:        #161A22;
  --ink-soft:   #2A3240;
  --ink-mute:   #5C6675;
  --clay:       #2F5BD7;
  --clay-deep:  #2348B0;
  --clay-tint:  #DCE5FC;
  --sage:       #3E8A7E;
  --gold:       #C68A2C;
  --line:       rgba(22, 26, 34, 0.12);
  --line-soft:  rgba(22, 26, 34, 0.055);

  --font-display: "Newsreader", Georgia, "Times New Roman", serif;
  --font-sans: "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-hand: "Caveat", "Bradley Hand", cursive;

  --maxw: 1180px;
  --nav-h: 76px;
}

/* ============================================================
   PALETTE VARIANTS  (live switcher · set on <html data-palette>)
   Default markup = crisp white + "Cobalt". Variants stay in the
   cool / clean family.
   ============================================================ */
html[data-palette="slate"] {
  --cream: #F4F6F9; --cream-2: #FCFDFE; --cream-3: #E4E9F1;
  --clay: #4C6FA6; --clay-deep: #36537F; --clay-tint: #DBE4F0;
  --sage: #5E8C84; --gold: #B08A4A;
  --ink: #1A1F27; --ink-soft: #2E3744; --ink-mute: #5E6775;
  --line: rgba(26, 31, 39, 0.12); --line-soft: rgba(26, 31, 39, 0.055);
}
html[data-palette="forest"] {
  --cream: #F6F8F4; --cream-2: #FCFDFB; --cream-3: #E5EDE3;
  --clay: #2F7D5B; --clay-deep: #1F5E42; --clay-tint: #D6EBDF;
  --sage: #6E8C5A; --gold: #B89A3E;
  --ink: #18211C; --ink-soft: #2A382E; --ink-mute: #5A675E;
  --line: rgba(24, 33, 28, 0.13); --line-soft: rgba(24, 33, 28, 0.06);
}
html[data-palette="plum"] {
  --cream: #F8F5F8; --cream-2: #FFFEFF; --cream-3: #EEE6EE;
  --clay: #8A3D62; --clay-deep: #6E2F4E; --clay-tint: #ECD8E4;
  --sage: #7E8C6A; --gold: #C0934E;
  --ink: #221A22; --ink-soft: #382E38; --ink-mute: #685E68;
  --line: rgba(34, 26, 34, 0.13); --line-soft: rgba(34, 26, 34, 0.06);
}
html[data-palette="ink"] {
  --cream: #FAFAFB; --cream-2: #FFFFFF; --cream-3: #ECEDEF;
  --clay: #2B2F36; --clay-deep: #14171C; --clay-tint: #E2E4E7;
  --sage: #6B7178; --gold: #8A7E66;
  --ink: #14171C; --ink-soft: #2B2F36; --ink-mute: #5E646C;
  --line: rgba(20, 23, 28, 0.12); --line-soft: rgba(20, 23, 28, 0.055);
}

* { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.62;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 40px; }
.wrap-narrow { max-width: 880px; margin: 0 auto; padding: 0 40px; }

section { padding: 96px 0; }
.tight { padding: 64px 0; }

/* ---------- type utilities ---------- */
.eyebrow {
  font-size: 12.5px; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--clay-deep); display: inline-flex; align-items: center; gap: 12px; margin: 0 0 22px;
}
.eyebrow::before { content: ""; width: 24px; height: 1.5px; background: var(--clay-deep); display: inline-block; }
.eyebrow.center { justify-content: center; }
.eyebrow.muted { color: var(--ink-mute); }
.eyebrow.muted::before { background: var(--ink-mute); }

h1, h2, h3 { font-family: var(--font-display); font-weight: 400; letter-spacing: -0.018em; margin: 0; text-wrap: balance; }
.display { font-size: clamp(46px, 7vw, 92px); line-height: 0.98; }
.h2 { font-size: clamp(32px, 4.3vw, 52px); line-height: 1.06; }
.h3 { font-size: clamp(22px, 2.4vw, 28px); line-height: 1.15; }
.italic { font-style: italic; }
.clay { color: var(--clay-deep); }
.lede { font-size: clamp(18px, 1.9vw, 21px); color: var(--ink-mute); line-height: 1.6; text-wrap: pretty; }
.muted { color: var(--ink-mute); }
.center { text-align: center; }
.section-head { max-width: 680px; margin-bottom: 52px; }
.section-head.center { margin-left: auto; margin-right: auto; }
.section-head h2 { margin-bottom: 16px; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px; cursor: pointer; white-space: nowrap;
  font-family: var(--font-sans); font-weight: 600; font-size: 15px; letter-spacing: 0.01em;
  padding: 14px 28px; border-radius: 100px; border: 1px solid transparent;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease, color .18s ease;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--clay); color: #fff; }
.btn-primary:hover { background: var(--clay-deep); color: #fff; box-shadow: 0 14px 30px -16px rgba(35,72,176,.6); }
.btn-dark { background: var(--ink); color: var(--cream); }
.btn-dark:hover { background: var(--ink-soft); box-shadow: 0 14px 30px -16px rgba(31,42,55,.6); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--ink); }
.btn .arw { transition: transform .18s ease; }
.btn:hover .arw { transform: translateX(3px); }
.link-arrow { color: var(--clay-deep); font-weight: 600; display: inline-flex; align-items: center; gap: 7px; }
.link-arrow .arw { transition: transform .18s ease; }
.link-arrow:hover .arw { transform: translateX(4px); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--cream) 86%, transparent);
  backdrop-filter: blur(12px) saturate(1.1);
  border-bottom: 1px solid var(--line-soft);
}
.nav-inner { max-width: var(--maxw); margin: 0 auto; padding: 0 40px; height: var(--nav-h);
  display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 11px; color: var(--ink); --mk-accent: var(--clay-deep); }
.brand svg { width: 32px; height: 32px; }
.brand .nm { font-family: var(--font-display); font-size: 21px; font-weight: 500; letter-spacing: -0.01em; }
.brand .nm .b { font-style: italic; color: var(--clay-deep); }
.nav-links { display: flex; align-items: center; gap: 34px; }
.nav-links > a, .nav-trigger { font-size: 14.5px; color: var(--ink-soft); position: relative; padding: 4px 0; }
.nav-links > a::after, .nav-trigger::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 1.5px;
  background: var(--clay-deep); transition: width .2s ease; }
.nav-links > a:hover::after, .nav-links > a.active::after, .nav-item:hover .nav-trigger::after, .nav-trigger.active::after { width: 100%; }
.nav-links > a.active, .nav-trigger.active { color: var(--ink); }

/* services dropdown */
.nav-item { position: relative; }
.nav-trigger { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; }
.nav-trigger .caret { width: 11px; height: 11px; transition: transform .2s ease; }
.nav-item:hover .nav-trigger .caret { transform: rotate(180deg); }
.dropdown {
  position: absolute; top: calc(100% + 14px); left: 50%; transform: translateX(-50%) translateY(8px);
  width: 340px; background: var(--cream-2); border: 1px solid var(--line); border-radius: 16px;
  box-shadow: 0 30px 60px -30px rgba(31,42,55,.4); padding: 10px; opacity: 0; pointer-events: none;
  transition: opacity .2s ease, transform .2s ease; z-index: 60;
}
.dropdown::before { content: ""; position: absolute; top: -14px; left: 0; right: 0; height: 14px; }
.nav-item:hover .dropdown, .nav-item:focus-within .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: block; padding: 12px 14px; border-radius: 11px; transition: background .15s ease; }
.dropdown a:hover { background: var(--cream-3); }
.dropdown a b { display: flex; align-items: center; gap: 8px; font-family: var(--font-display); font-size: 16px; font-weight: 500; color: var(--ink); }
.dropdown a span { display: block; font-size: 12.5px; color: var(--ink-mute); margin-top: 2px; }
.dropdown .dropdown-all { font-weight: 600; color: var(--clay-deep); font-size: 14px; padding: 13px 14px; border-top: 1px solid var(--line-soft); border-radius: 0 0 11px 11px; margin-top: 4px; }
.dropdown .dropdown-all:hover { background: transparent; color: var(--ink); }
.nav-new { font-family: var(--font-sans); font-size: 9px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--clay-deep); border: 1px solid var(--clay); border-radius: 100px; padding: 2px 7px; }

/* mobile services accordion */
.m-sub { display: none; padding-left: 4px; }
.m-sub.open { display: block; }
.m-sub a { font-size: 18px !important; padding: 9px 0 !important; color: var(--ink-soft); }
.m-acc { display: flex; align-items: center; justify-content: space-between; }
.m-acc .caret { width: 16px; height: 16px; transition: transform .2s ease; }
.m-acc.open .caret { transform: rotate(180deg); }

.nav-cta { display: flex; align-items: center; gap: 18px; }
.nav-toggle { display: none; background: none; border: none; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--ink); margin: 4px 0; transition: .25s; border-radius: 2px; }

/* mobile menu */
.mobile-menu { display: none; }

@media (max-width: 880px) {
  .nav-links, .nav-cta .btn { display: none; }
  .nav-toggle { display: block; }
  .mobile-menu {
    display: block; position: fixed; inset: var(--nav-h) 0 auto 0; z-index: 49;
    background: var(--cream); border-bottom: 1px solid var(--line);
    transform: translateY(-12px); opacity: 0; pointer-events: none; transition: .24s ease;
    padding: 16px 40px 28px;
  }
  .mobile-menu.open { transform: none; opacity: 1; pointer-events: auto; }
  .mobile-menu a { display: block; font-family: var(--font-display); font-size: 26px; padding: 12px 0; border-bottom: 1px solid var(--line-soft); }
  .mobile-menu .btn { margin-top: 22px; display: inline-flex; font-family: var(--font-sans); font-size: 15px; padding: 14px 28px; border-bottom: none; }
  body.menu-open { overflow: hidden; }
  .nav-toggle.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2) { opacity: 0; }
  .nav-toggle.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
}

/* ============================================================
   HERO
   ============================================================ */
.hero { padding: clamp(56px, 9vw, 110px) 0 clamp(60px, 9vw, 104px); position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.12fr 0.88fr; gap: 60px; align-items: center; }
.hero h1 { margin-bottom: 0; }
.hero .em { font-style: italic; color: var(--clay-deep); }
.hero .lede { margin: 28px 0 36px; max-width: 44ch; }
.hero-actions { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.hero-meta { display: flex; gap: 36px; margin-top: 46px; padding-top: 26px; border-top: 1px solid var(--line); flex-wrap: wrap; }
.hero-meta div { font-size: 13.5px; color: var(--ink-mute); }
.hero-meta b { display: block; font-family: var(--font-display); font-size: 26px; color: var(--ink); font-weight: 500; margin-bottom: 2px; }
.hero-flow { position: absolute; right: -6%; top: -10%; width: 44%; max-width: 560px; opacity: .8; pointer-events: none; z-index: -1; }

/* page header (interior pages) */
.page-head { padding: clamp(64px, 9vw, 104px) 0 clamp(40px, 5vw, 64px); }
.page-head .lede { margin-top: 22px; max-width: 56ch; }

/* ============================================================
   GENERIC CARDS / GRIDS
   ============================================================ */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }

.card {
  background: var(--cream-2); border: 1px solid var(--line); border-radius: 18px; padding: 36px 32px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card.hover:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -34px rgba(31,42,55,.5); border-color: var(--clay-tint); }
.card .ic { width: 52px; height: 52px; border-radius: 13px; display: grid; place-items: center; margin-bottom: 22px; --mk-accent: var(--clay-deep); color: var(--ink); background: var(--cream-3); }
.card .ic svg { width: 30px; height: 30px; }
.card h3 { margin-bottom: 10px; }
.card p { color: var(--ink-mute); font-size: 15.5px; margin: 0 0 18px; }
.card .num { font-family: var(--font-display); font-size: 15px; color: var(--clay-deep); font-weight: 600; }

/* values / stats */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.stat .n { font-family: var(--font-display); font-size: clamp(44px, 5vw, 62px); line-height: 1; color: var(--clay-deep); }
.stat .l { font-weight: 600; margin: 14px 0 6px; font-size: 16px; }
.stat p { color: var(--ink-mute); font-size: 14.5px; margin: 0; }

/* ---------- placeholders ---------- */
.ph {
  border-radius: 16px; border: 1px solid var(--line); overflow: hidden;
  background-image: repeating-linear-gradient(135deg, var(--cream-3) 0 14px, var(--cream-2) 14px 28px);
  display: grid; place-items: center; min-height: 320px; position: relative;
}
.ph.tall { min-height: 480px; }
.ph .ph-label {
  font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 12px; color: var(--ink-mute);
  background: var(--cream); padding: 7px 13px; border-radius: 8px; border: 1px solid var(--line); letter-spacing: .02em;
}
.ph.dark { background-image: repeating-linear-gradient(135deg, #25313e 0 14px, #1f2a37 14px 28px); border-color: rgba(255,255,255,.08); }
.ph.dark .ph-label { background: var(--ink); color: rgba(236,241,250,.6); border-color: rgba(255,255,255,.12); }
/* real photos drop into any .ph; fall back to the striped box on error */
.ph img.ph-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; display: block; }
.ph.has-img { background-image: none; }
.ph.has-img .ph-label { display: none; }

/* ============================================================
   WORK CARDS
   ============================================================ */
.work-card { border-radius: 20px; overflow: hidden; background: var(--cream-2); border: 1px solid var(--line);
  transition: transform .2s ease, box-shadow .2s ease; }
.work-card:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -40px rgba(31,42,55,.55); }
.work-card .ph { border: none; border-radius: 0; min-height: 300px; }
.work-card .wc-body { padding: 28px 30px 32px; }
.work-card .wc-tags { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.tag { font-size: 11.5px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--clay-deep);
  background: var(--clay-tint); padding: 5px 11px; border-radius: 100px; }
.tag.sage { color: #245049; background: color-mix(in srgb, var(--sage) 36%, white); }
.tag.gold { color: #6b4f16; background: color-mix(in srgb, var(--gold) 38%, white); }
.work-card h3 { margin-bottom: 8px; }
.work-card p { color: var(--ink-mute); font-size: 15px; margin: 0; }

/* ============================================================
   CASE STUDIES (work page)
   ============================================================ */
.case { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.case + .case { margin-top: 104px; }
.case.rev .case-media { order: 2; }
.case-media .ph { min-height: 480px; border-radius: 20px; }
.case-num { font-family: var(--font-display); font-style: italic; font-size: 16px; color: var(--clay-deep); margin: 0 0 14px; }
.case-body .wc-tags { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.case-body h2 { margin: 0 0 18px; }
.case-lead { color: var(--ink-mute); margin: 0 0 18px; text-wrap: pretty; }
.case-metrics { display: flex; gap: 40px; margin: 28px 0; padding: 24px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.case-metrics .m b { font-family: var(--font-display); font-size: 34px; font-weight: 500; color: var(--clay-deep); display: block; line-height: 1; }
.case-metrics .m span { font-size: 13px; color: var(--ink-mute); display: block; margin-top: 6px; max-width: 16ch; }
.case-quote { font-family: var(--font-display); font-size: 20px; line-height: 1.5; font-style: italic; color: var(--ink-soft); margin: 0; text-wrap: pretty; }
.case-quote cite { display: block; font-style: normal; font-family: var(--font-sans); font-size: 13.5px; color: var(--ink-mute); margin-top: 12px; }
.case-quote cite b { color: var(--ink); font-weight: 600; }

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.steps { display: grid; gap: 0; }
.step { display: grid; grid-template-columns: 90px 1fr; gap: 28px; padding: 30px 0; border-top: 1px solid var(--line); align-items: start; }
.step:last-child { border-bottom: 1px solid var(--line); }
.step .sn { font-family: var(--font-display); font-size: 40px; color: var(--clay-deep); line-height: 1; font-style: italic; }
.step h3 { margin-bottom: 8px; }
.step p { color: var(--ink-mute); margin: 0; max-width: 60ch; }

/* ============================================================
   SERVICE CATEGORY CARDS
   ============================================================ */
.svc { background: var(--cream-2); border: 1px solid var(--line); border-radius: 22px; padding: 44px 42px;
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 44px; align-items: start; }
.svc + .svc { margin-top: 26px; }
.svc .svc-intro h2 { margin: 12px 0 16px; }
.svc .svc-intro p { color: var(--ink-mute); margin: 0 0 26px; }
.svc .svc-mark { width: 56px; height: 56px; border-radius: 14px; background: var(--cream-3); display: grid; place-items: center;
  color: var(--ink); --mk-accent: var(--clay-deep); }
.svc .svc-mark svg { width: 32px; height: 32px; }
.price-list { display: grid; gap: 2px; }
.price-row { display: flex; justify-content: space-between; align-items: baseline; gap: 18px;
  padding: 15px 0; border-top: 1px solid var(--line-soft); }
.price-row:first-child { border-top: none; }
.price-row .pr-name { font-weight: 500; font-size: 15.5px; }
.price-row .pr-name span { display: block; color: var(--ink-mute); font-size: 13px; font-weight: 400; margin-top: 2px; }
.price-row .pr-cost { font-family: var(--font-display); font-size: 19px; color: var(--clay-deep); white-space: nowrap; font-weight: 500; }
.price-row .pr-cost .from { font-family: var(--font-sans); font-size: 11px; color: var(--ink-mute); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; margin-right: 5px; }
.pr-new { font-family: var(--font-sans); font-size: 9.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--clay-deep); border: 1px solid var(--clay); border-radius: 100px; padding: 2px 8px; margin-left: 10px; vertical-align: middle; white-space: nowrap; }
.svc .svc-foot { margin-top: 26px; }

/* prompt band */
.prompt {
  background: var(--ink); color: var(--cream); border-radius: 22px; padding: 56px;
  display: flex; align-items: center; justify-content: space-between; gap: 36px; flex-wrap: wrap;
}
.prompt h2 { color: var(--cream); }
.prompt p { color: rgba(236,241,250,.72); margin: 12px 0 0; max-width: 48ch; }
.prompt .btn-primary:hover { background: var(--clay-tint); color: var(--ink); }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band { background: var(--ink); color: var(--cream); text-align: center; }
.cta-band h2 { color: var(--cream); max-width: 16ch; margin: 0 auto 14px; }
.cta-band .em { color: var(--clay); font-style: italic; }
.cta-band p { color: rgba(236,241,250,.7); max-width: 46ch; margin: 0 auto 32px; }
.cta-band .btn-primary:hover { background: var(--clay-tint); color: var(--ink); }

/* ============================================================
   TESTIMONIAL
   ============================================================ */
.quote { max-width: 820px; margin: 0 auto; text-align: center; }
.quote blockquote { font-family: var(--font-display); font-size: clamp(24px, 3.2vw, 38px); line-height: 1.32;
  margin: 0 0 28px; font-weight: 400; text-wrap: balance; }
.quote blockquote .clay { color: var(--clay-deep); }
.quote .cite { display: inline-flex; align-items: center; gap: 14px; }
.quote .cite .av { width: 46px; height: 46px; border-radius: 50%; background: var(--cream-3); border: 1px solid var(--line); }
.quote .cite .who { text-align: left; }
.quote .cite .who b { display: block; font-size: 15px; }
.quote .cite .who span { font-size: 13.5px; color: var(--ink-mute); }

/* ============================================================
   FAQ
   ============================================================ */
.faq { max-width: 820px; margin: 0 auto; }
.faq details { border-top: 1px solid var(--line); padding: 6px 0; }
.faq details:last-child { border-bottom: 1px solid var(--line); }
.faq summary { list-style: none; cursor: pointer; padding: 22px 0; display: flex; justify-content: space-between;
  align-items: center; gap: 20px; font-family: var(--font-display); font-size: 21px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pm { width: 22px; height: 22px; position: relative; flex: none; transition: transform .2s ease; }
.faq summary .pm::before, .faq summary .pm::after { content: ""; position: absolute; background: var(--clay-deep); border-radius: 2px; }
.faq summary .pm::before { left: 0; top: 10px; width: 22px; height: 2px; }
.faq summary .pm::after { left: 10px; top: 0; width: 2px; height: 22px; transition: transform .2s ease; }
.faq details[open] summary .pm::after { transform: rotate(90deg); opacity: 0; }
.faq details p { color: var(--ink-mute); margin: 0 0 22px; max-width: 64ch; }

/* ============================================================
   FORMS
   ============================================================ */
.form { display: grid; gap: 20px; }
.field { display: grid; gap: 8px; }
.field label { font-size: 13.5px; font-weight: 600; letter-spacing: .02em; }
.field label .req { color: var(--clay-deep); }
.field input, .field select, .field textarea {
  font-family: var(--font-sans); font-size: 16px; color: var(--ink);
  background: var(--cream-2); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px;
  width: 100%; transition: border-color .18s ease, box-shadow .18s ease;
}
.field textarea { min-height: 140px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--clay); box-shadow: 0 0 0 3px var(--clay-tint); }
.field.invalid input, .field.invalid select, .field.invalid textarea { border-color: #c0392b; box-shadow: 0 0 0 3px rgba(192,57,43,.14); }
.field .err { font-size: 12.5px; color: #c0392b; display: none; }
.field.invalid .err { display: block; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-success { background: color-mix(in srgb, var(--sage) 22%, var(--cream-2)); border: 1px solid var(--sage);
  border-radius: 14px; padding: 22px 24px; display: none; }
.form-success.show { display: block; }
.form-success b { font-family: var(--font-display); font-size: 20px; font-weight: 500; }
.form-success p { margin: 6px 0 0; color: var(--ink-soft); font-size: 15px; }

.contact-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 64px; align-items: start; }
.expect { display: grid; gap: 18px; margin-top: 32px; }
.expect li { display: flex; gap: 14px; align-items: flex-start; list-style: none; }
.expect .ck { width: 26px; height: 26px; border-radius: 50%; background: var(--clay-tint); color: var(--clay-deep);
  display: grid; place-items: center; flex: none; font-size: 14px; margin-top: 1px; }
.expect b { font-weight: 600; }
.expect span { display: block; color: var(--ink-mute); font-size: 14.5px; }
.expect ul { padding: 0; margin: 0; display: grid; gap: 18px; }
.contact-aside { background: var(--cream-2); border: 1px solid var(--line); border-radius: 20px; padding: 38px 36px; }

/* ---------- quote builder ---------- */
.qb-step { display: flex; align-items: baseline; gap: 12px; margin: 0 0 18px; }
.qb-step .qn { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--clay-deep); font-style: italic; }
.qb-step h3 { font-family: var(--font-display); font-size: 22px; font-weight: 500; letter-spacing: -.01em; }
.qb-step + .qb-hint { margin: -10px 0 20px; color: var(--ink-mute); font-size: 14px; }
.qb-group + .qb-group { margin-top: 26px; }
.qb-group-label { font-size: 11.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 12px; }
.qb-items { display: grid; gap: 10px; }
.qb-item { position: relative; display: grid; grid-template-columns: 22px 1fr auto; gap: 14px; align-items: center;
  padding: 15px 18px; border: 1px solid var(--line); border-radius: 13px; background: var(--cream); cursor: pointer;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease; }
.qb-item:hover { border-color: var(--clay-tint); }
.qb-item input { position: absolute; opacity: 0; pointer-events: none; }
.qb-box { width: 22px; height: 22px; border-radius: 7px; border: 1.5px solid var(--line); display: grid; place-items: center;
  transition: background .16s ease, border-color .16s ease; }
.qb-box svg { width: 13px; height: 13px; opacity: 0; transform: scale(.6); transition: opacity .16s ease, transform .16s ease; color: var(--cream); }
.qb-item .qb-name { font-weight: 500; font-size: 15px; }
.qb-item .qb-name span { display: block; color: var(--ink-mute); font-size: 12.5px; font-weight: 400; margin-top: 2px; }
.qb-item .qb-price { font-family: var(--font-display); font-size: 16px; color: var(--clay-deep); font-weight: 500; white-space: nowrap; }
.qb-item .qb-price .from { font-family: var(--font-sans); font-size: 10px; color: var(--ink-mute); font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin-right: 3px; }
.qb-tag { font-family: var(--font-sans); font-size: 9px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--clay-deep); border: 1px solid var(--clay); border-radius: 100px; padding: 1px 6px; margin-left: 7px; vertical-align: middle; }
.qb-item.selected { border-color: var(--clay); background: color-mix(in srgb, var(--clay-tint) 26%, var(--cream)); box-shadow: 0 0 0 1px var(--clay); }
.qb-item.selected .qb-box { background: var(--clay); border-color: var(--clay); }
.qb-item.selected .qb-box svg { opacity: 1; transform: none; }

.qb-estimate { margin-top: 26px; background: var(--ink); color: var(--cream); border-radius: 16px; padding: 22px 26px; }
.qb-estimate .qe-row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
.qb-estimate .qe-row + .qe-row { margin-top: 12px; padding-top: 12px; border-top: 1px solid rgba(236,241,250,.16); }
.qb-estimate .qe-label { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: rgba(236,241,250,.6); }
.qb-estimate .qe-val { font-family: var(--font-display); font-size: clamp(26px, 3vw, 32px); font-weight: 500; color: var(--clay); white-space: nowrap; }
.qb-estimate .qe-row.qe-monthly .qe-val { font-size: 20px; }
.qb-estimate .qe-note { font-size: 12.5px; color: rgba(236,241,250,.55); margin: 14px 0 0; }
.qb-estimate.is-empty .qe-monthly { display: none; }
.qb-estimate.is-empty #qe-onetime { font-family: var(--font-sans); font-size: 15px; font-weight: 600; letter-spacing: .01em; color: rgba(236,241,250,.6); }
.qb-divider { height: 1px; background: var(--line); margin: 30px 0; border: none; }
.qb-summary { margin: 8px 0 0; font-size: 14px; color: var(--ink-soft); }
.qb-summary b { font-weight: 600; }

/* ============================================================
   BLOG
   ============================================================ */
.featured { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 0; border-radius: 22px; overflow: hidden;
  border: 1px solid var(--line); background: var(--cream-2); }
.featured .ph { border: none; border-radius: 0; min-height: 100%; }
.featured .ft-body { padding: 48px 46px; display: flex; flex-direction: column; justify-content: center; }
.featured h2 { margin: 16px 0 16px; }
.featured p { color: var(--ink-mute); margin: 0 0 26px; max-width: 46ch; }
.featured .meta { font-size: 13px; color: var(--ink-mute); margin-bottom: 8px; }

.filters { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 40px; }
.filter { font-family: var(--font-sans); font-size: 13.5px; font-weight: 600; cursor: pointer;
  padding: 9px 18px; border-radius: 100px; border: 1px solid var(--line); background: transparent; color: var(--ink-soft);
  transition: .18s ease; }
.filter:hover { border-color: var(--ink); }
.filter.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }

.posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.post { display: flex; flex-direction: column; transition: transform .2s ease; }
.post.hide { display: none; }
.post .ph { min-height: 200px; margin-bottom: 18px; }
.post:hover { transform: translateY(-3px); }
.post:hover .post-title { color: var(--clay-deep); }
.post .cat { font-size: 11.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--clay-deep); }
.post .post-title { font-family: var(--font-display); font-size: 23px; margin: 9px 0 8px; line-height: 1.18; transition: color .18s ease; }
.post p { color: var(--ink-mute); font-size: 14.5px; margin: 0 0 14px; }
.post .pmeta { font-size: 12.5px; color: var(--ink-mute); margin-top: auto; display: flex; gap: 10px; align-items: center; }
.post .pmeta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--ink-mute); }

.newsletter { background: var(--cream-3); border-radius: 22px; padding: 56px; text-align: center; }
.newsletter h2 { margin-bottom: 12px; }
.newsletter p { color: var(--ink-mute); max-width: 44ch; margin: 0 auto 28px; }
.news-form { display: flex; gap: 12px; max-width: 480px; margin: 0 auto; }
.news-form input { flex: 1; font-family: var(--font-sans); font-size: 15px; background: var(--cream-2);
  border: 1px solid var(--line); border-radius: 100px; padding: 14px 22px; }
.news-form input:focus { outline: none; border-color: var(--clay); box-shadow: 0 0 0 3px var(--clay-tint); }
.news-note { font-size: 13px; color: var(--ink-mute); margin-top: 14px; }

/* skills/tools (about) */
.tools { display: flex; gap: 12px; flex-wrap: wrap; }
.tool { background: var(--cream-2); border: 1px solid var(--line); border-radius: 100px; padding: 11px 20px;
  font-size: 14.5px; font-weight: 500; display: inline-flex; align-items: center; gap: 9px; }
.tool .d { width: 8px; height: 8px; border-radius: 50%; background: var(--clay); }
.tool .d.sage { background: var(--sage); }
.tool .d.gold { background: var(--gold); }

.about-bio { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: center; }
.about-bio .bio-copy p { margin: 0 0 18px; }
.values { display: grid; grid-template-columns: repeat(3,1fr); gap: 26px; }
.value h3 { margin-bottom: 8px; display: flex; align-items: baseline; gap: 10px; }
.value h3 .vn { font-size: 14px; color: var(--clay-deep); font-weight: 600; font-family: var(--font-sans); }
.value p { color: var(--ink-mute); font-size: 15px; margin: 0; }

/* ============================================================
   SERVICE HUB CARDS  +  AI FEATURE BAND
   ============================================================ */
.hub-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.hub-card { display: flex; flex-direction: column; background: var(--cream-2); border: 1px solid var(--line); border-radius: 20px;
  padding: 34px 32px; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; position: relative; }
.hub-card:hover { transform: translateY(-4px); box-shadow: 0 28px 56px -36px rgba(31,42,55,.5); border-color: var(--clay-tint); }
.hub-card .ic { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; margin-bottom: 20px;
  --mk-accent: var(--clay-deep); color: var(--ink); background: var(--cream-3); }
.hub-card .ic svg { width: 28px; height: 28px; }
.hub-card h3 { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.hub-card p { color: var(--ink-mute); font-size: 15px; margin: 0 0 18px; flex: 1; }
.hub-card .hub-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.hub-card .hub-price { font-family: var(--font-display); font-size: 16px; color: var(--clay-deep); }
.hub-card .hub-price .from { font-family: var(--font-sans); font-size: 11px; color: var(--ink-mute); font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin-right: 4px; }
.hub-card.featured { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: 44px; background: var(--ink); color: var(--cream);
  border-color: var(--ink); }
.hub-card.featured:hover { border-color: var(--ink); }
.hub-card.featured .ic { background: rgba(236,241,250,.1); color: var(--cream); --mk-accent: var(--clay); }
.hub-card.featured h3 { color: var(--cream); font-size: clamp(26px, 3vw, 34px); }
.hub-card.featured p { color: rgba(236,241,250,.74); font-size: 16px; max-width: 52ch; }
.hub-card.featured .hub-price { color: var(--clay); }
.hub-card.featured .hub-body { flex: 1; }

.ai-band { background: var(--ink); color: var(--cream); border-radius: 24px; padding: 60px; display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center; }
.ai-band .eyebrow { color: var(--clay); }
.ai-band .eyebrow::before { background: var(--clay); }
.ai-band h2 { color: var(--cream); margin-bottom: 16px; }
.ai-band p { color: rgba(236,241,250,.74); margin: 0 0 26px; }
.ai-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.ai-chip { display: inline-flex; align-items: center; gap: 9px; background: rgba(236,241,250,.07); border: 1px solid rgba(236,241,250,.16);
  border-radius: 100px; padding: 11px 18px; font-size: 14px; font-weight: 500; cursor: default;
  transition: transform .16s ease, background .16s ease, border-color .16s ease; }
.ai-chip:hover { transform: translateY(-2px); background: rgba(236,241,250,.13); border-color: var(--clay); }
.ai-chip .d { width: 8px; height: 8px; border-radius: 50%; background: var(--clay); transition: transform .16s ease; }
.ai-chip:hover .d { transform: scale(1.4); }
.ai-band .btn-primary:hover { background: var(--clay-tint); color: var(--ink); }

/* service detail page bits */
.svc-hero { display: grid; grid-template-columns: 1.15fr .85fr; gap: 56px; align-items: end; }
.incl { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 40px; margin: 0; padding: 0; }
.incl li { list-style: none; display: flex; gap: 13px; align-items: flex-start; padding: 14px 0; border-top: 1px solid var(--line-soft); transition: padding-left .18s ease; }
.incl li:hover { padding-left: 8px; }
.incl li .ck { width: 24px; height: 24px; border-radius: 50%; background: var(--clay-tint); color: var(--clay-deep); display: grid; place-items: center; flex: none; margin-top: 1px; transition: background .18s ease, color .18s ease; }
.incl li:hover .ck { background: var(--clay); color: var(--cream); }
.incl li b { font-weight: 600; font-size: 15.5px; }
.incl li span { display: block; color: var(--ink-mute); font-size: 13.5px; margin-top: 2px; }

/* big closing philosophy */
.philosophy { background: var(--cream-3); }
.philosophy .wrap-narrow { text-align: center; }
.philosophy p { font-family: var(--font-display); font-size: clamp(24px, 3.4vw, 40px); line-height: 1.3; font-weight: 400; text-wrap: balance; }
.philosophy .clay { color: var(--clay-deep); font-style: italic; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--ink); color: var(--cream); padding: 76px 0 40px; }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; border-bottom: 1px solid rgba(236,241,250,.14); }
.footer .fbrand { display: flex; align-items: center; gap: 12px; color: var(--cream); --mk-accent: var(--clay); margin-bottom: 18px; }
.footer .fbrand svg { width: 40px; height: 40px; }
.footer .fbrand .nm { font-family: var(--font-display); font-size: 24px; font-weight: 500; }
.footer .fbrand .nm .b { font-style: italic; color: var(--clay); }
.footer .ftag { color: rgba(236,241,250,.66); font-size: 15px; max-width: 30ch; }
.footer .fcol h4 { font-family: var(--font-sans); font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(236,241,250,.5); margin: 0 0 16px; }
.footer .fcol a { display: block; color: rgba(236,241,250,.82); font-size: 15px; padding: 6px 0; transition: color .16s; }
.footer .fcol a:hover { color: var(--clay); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 20px; padding-top: 28px; flex-wrap: wrap; }
.footer-bottom, .footer-bottom a { font-size: 13px; color: rgba(236,241,250,.5); }
.footer-bottom a:hover { color: var(--clay); }

/* ============================================================
   REVEAL ANIMATION  (transform-only + armed by JS: content is
   ALWAYS visible — if JS fails or a tool freezes transitions,
   you see content, never a blank box)
   ============================================================ */
.reveal { transition: transform .6s cubic-bezier(.2,.7,.2,1); }
.js-anim .reveal { transform: translateY(22px); }
.js-anim .reveal.in { transform: none; }
.js-anim .reveal.d1 { transition-delay: .07s; }
.js-anim .reveal.d2 { transition-delay: .14s; }
.js-anim .reveal.d3 { transition-delay: .21s; }
@media (prefers-reduced-motion: reduce) { .js-anim .reveal { transform: none; transition: none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .wrap, .wrap-narrow, .nav-inner { padding-left: 24px; padding-right: 24px; }
  section { padding: 64px 0; }
  .hero-grid, .grid-3, .grid-2, .stats, .svc, .contact-grid, .featured, .posts, .about-bio, .values { grid-template-columns: 1fr; }
  .hub-grid, .ai-band, .svc-hero, .incl, .case { grid-template-columns: 1fr; gap: 32px; }
  .hub-card.featured { flex-direction: column; align-items: flex-start; gap: 24px; }
  .case + .case { margin-top: 64px; }
  .case.rev .case-media { order: 0; }
  .ai-band { padding: 36px 30px; }
  .hero-flow { display: none; }
  .featured .ph { min-height: 280px; }
  .svc { padding: 32px 26px; gap: 28px; }
  .prompt, .newsletter, .cta-band .wrap { padding-left: 28px; padding-right: 28px; }
  .prompt { padding: 36px 30px; }
  .form-row { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .step { grid-template-columns: 60px 1fr; gap: 18px; }
}
@media (max-width: 560px) {
  .footer { padding: 56px 0 34px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 30px 22px; padding-bottom: 36px; }
  .footer-top > :first-child { grid-column: 1 / -1; }
  .footer .fbrand { margin-bottom: 14px; }
  .footer .ftag { max-width: 42ch; }
  .footer .fcol h4 { margin-bottom: 12px; }
  .footer .fcol a { padding: 7px 0; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px; padding-top: 24px; }
  .news-form { flex-direction: column; }
  .news-form .btn { justify-content: center; }
}
@media (max-width: 380px) {
  .footer-top { grid-template-columns: 1fr; gap: 26px; }
}

/* ============================================================
   SCRAPBOOK LAYER  (hand annotations + taped photos)
   ============================================================ */
.scribble { font-family: var(--font-hand); color: var(--clay-deep); font-weight: 600; line-height: 1;
  display: inline-block; transform: rotate(-4deg); }
.scribble.lg { font-size: clamp(26px, 3vw, 38px); }
.scribble.md { font-size: 22px; }
.scribble-arrow { display: inline-block; vertical-align: middle; color: var(--clay-deep); }
/* hand-circled word: wrap text in <span class="circled"> */
.circled { position: relative; display: inline-block; }
.circled::after { content: ""; position: absolute; inset: -8px -14px -10px -14px; border: 2.5px solid var(--clay-deep);
  border-radius: 50%; opacity: .8; transform: rotate(-3deg) scale(1.02); pointer-events: none;
  border-right-color: transparent; }
/* washi-taped, slightly tilted photo; straightens on hover */
.taped { position: relative; transform: rotate(-1.4deg); transition: transform .3s var(--ease-out, ease); }
.taped:nth-of-type(even) { transform: rotate(1.2deg); }
.taped:hover { transform: rotate(0); }
.taped::before { content: ""; position: absolute; top: -13px; left: 50%; width: 116px; height: 26px;
  transform: translateX(-50%) rotate(-2.5deg); background: rgba(47,91,215,.34);
  border: 1px solid rgba(35,72,176,.22); box-shadow: 0 2px 5px rgba(31,42,55,.07); z-index: 3; }
.case-media.taped::before { left: 28px; transform: rotate(-7deg); }
.taped.tape-r::before { left: auto; right: 24px; transform: rotate(6deg); }

/* doodle arrow + handwritten margin notes */
@keyframes fb-bob { 0%, 100% { transform: translateY(0) rotate(var(--r,0deg)); } 50% { transform: translateY(5px) rotate(var(--r,0deg)); } }
.scribble-arrow.bob { animation: fb-bob 1.9s ease-in-out infinite; }
.hand-note { display: inline-flex; align-items: center; gap: 8px; }
.hand-note .scribble { white-space: nowrap; }
@media (prefers-reduced-motion: reduce) { .scribble-arrow.bob { animation: none; } }

/* playful tilt-on-hover for cards/notes */
.tilt { transition: transform .25s var(--ease-out, ease), box-shadow .25s ease; }
.tilt:hover { transform: rotate(-1.5deg) translateY(-4px); }
.stat.note { background: var(--cream-2); border: 1px solid var(--line); border-radius: 4px 16px 6px 14px;
  padding: 26px 24px; box-shadow: 0 10px 26px -18px rgba(31,42,55,.4); transform: rotate(-1deg);
  transition: transform .25s var(--ease-out, ease), box-shadow .25s ease; }
.stat.note:nth-child(even) { transform: rotate(1.2deg); }
.stat.note:hover { transform: rotate(0); box-shadow: 0 18px 36px -20px rgba(31,42,55,.45); }

/* ============================================================
   PALETTE SWITCHER  (floating, preview only)
   ============================================================ */
.palette-fab { position: fixed; left: 18px; bottom: 18px; z-index: 80;
  background: var(--cream-2); border: 1px solid var(--line); border-radius: 100px;
  box-shadow: 0 16px 40px -18px rgba(31,42,55,.4); padding: 9px 14px;
  display: flex; align-items: center; gap: 12px; font-family: var(--font-sans); }
.palette-fab .pf-label { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-mute); }
.palette-fab .pf-dots { display: flex; gap: 8px; }
.palette-fab .pf-dot { width: 22px; height: 22px; border-radius: 50%; cursor: pointer; border: 2px solid transparent;
  padding: 0; position: relative; transition: transform .15s ease; }
.palette-fab .pf-dot:hover { transform: scale(1.15); }
.palette-fab .pf-dot.active { border-color: var(--ink); }
.palette-fab .pf-dot span { position: absolute; inset: 2px; border-radius: 50%; }
@media (max-width: 640px) { .palette-fab .pf-label { display: none; } .palette-fab { padding: 8px 10px; } }
@media print { .palette-fab { display: none !important; } }

/* ============================================================
   TOOLTIPS  ("what is it?" on skill pills + AI chips)
   Shared floating tooltip positioned by JS · keyboard accessible
   ============================================================ */
.fb-tip {
  position: fixed; z-index: 200; max-width: 256px; pointer-events: none;
  background: var(--ink); color: var(--cream); font-family: var(--font-sans);
  font-size: 13px; line-height: 1.46; padding: 12px 15px; border-radius: 12px;
  box-shadow: 0 22px 46px -18px rgba(31,42,55,.62); text-wrap: pretty;
  opacity: 0; transform: translateY(5px) scale(.97); transform-origin: 50% 100%;
  transition: opacity .16s ease, transform .16s ease;
}
.fb-tip.show { opacity: 1; transform: translateY(0) scale(1); }
.fb-tip b { color: var(--clay); font-weight: 700; }
.fb-tip::after {
  content: ""; position: absolute; left: var(--ax, 50%); bottom: -5px;
  width: 11px; height: 11px; background: var(--ink); border-radius: 0 0 3px 0;
  transform: translateX(-50%) rotate(45deg);
}
.fb-tip.below { transform-origin: 50% 0; }
.fb-tip.below::after { bottom: auto; top: -5px; border-radius: 3px 0 0 0; }
/* any pill that carries a definition reads as interactive */
[data-tip] { cursor: help; }
.tool[data-tip]:focus-visible, .ai-chip[data-tip]:focus-visible { outline: 2px solid var(--clay); outline-offset: 3px; }
/* tool pills: lift + gentle wobble + dot pop on hover/focus */
.tool { transition: transform .2s var(--ease-out, cubic-bezier(.2,.7,.2,1)), border-color .2s ease, box-shadow .2s ease, background .2s ease; }
.tool:hover, .tool:focus-visible { transform: translateY(-3px) rotate(-1.6deg); border-color: var(--clay-tint);
  box-shadow: 0 14px 26px -18px rgba(31,42,55,.5); background: var(--cream); }
.tool .d { transition: transform .2s var(--ease-out, ease); }
.tool:hover .d, .tool:focus-visible .d { transform: scale(1.45); }
.ai-chip[data-tip]:focus-visible { outline: 2px solid var(--clay); outline-offset: 3px; }

/* ============================================================
   PAPER GRAIN  (subtle scrapbook tactility over the cream)
   ============================================================ */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: .05;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media print { body::after { display: none; } }

/* ============================================================
   STAMPS  (hand-inked round badges scattered like a maker's mark)
   ============================================================ */
.stamp {
  display: inline-grid; place-items: center; text-align: center; width: 104px; height: 104px;
  border-radius: 50%; border: 2px solid var(--clay-deep); color: var(--clay-deep);
  font-family: var(--font-hand); font-weight: 700; font-size: 16px; line-height: 1.04;
  letter-spacing: .01em; padding: 8px; transform: rotate(-11deg);
  background: color-mix(in srgb, var(--clay-tint) 16%, transparent);
  box-shadow: inset 0 0 0 4px color-mix(in srgb, var(--clay-tint) 30%, transparent);
  transition: transform .3s var(--ease-out, ease);
}
.stamp:hover { transform: rotate(0deg) scale(1.04); }
.stamp.sage { border-color: #5f6e54; color: #4f5e46; box-shadow: inset 0 0 0 4px color-mix(in srgb, var(--sage) 30%, transparent); background: color-mix(in srgb, var(--sage) 14%, transparent); }
.stamp .big { display: block; font-size: 21px; }

/* hand-drawn wavy underline under a word */
.underline-draw {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='12' viewBox='0 0 120 12'%3E%3Cpath d='M2 7 C 22 2, 38 11, 60 6 S 100 1, 118 6' fill='none' stroke='%232348B0' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: 0 1.04em; background-size: 100% .5em;
  padding-bottom: .12em;
}

/* ============================================================
   DRAGGABLE STICKER  (playful, position persists in localStorage)
   ============================================================ */
.drag-sticker { position: absolute; z-index: 14; cursor: grab; user-select: none; -webkit-user-select: none; touch-action: none; }
.drag-sticker:active { cursor: grabbing; }
.drag-sticker.dragging { transition: none !important; }
.drag-sticker .ds-hint {
  position: absolute; left: 50%; top: -22px; transform: translateX(-50%) rotate(-6deg);
  font-family: var(--font-hand); font-size: 16px; color: var(--clay-deep); white-space: nowrap;
  opacity: 0; transition: opacity .2s ease;
}
.drag-sticker:hover .ds-hint { opacity: .9; }
@media (max-width: 880px) { .drag-sticker { display: none; } }
@media print { .drag-sticker { display: none !important; } }
