/* ── Tokens ── */
:root {
  --cream:        #FBF6EE;
  --cream-deep:   #F4ECD8;
  --sage:         #D4E6D4;
  --sage-deep:    #B6CDB1;
  --sage-ink:     #4A6B4A;
  --blush:        #F2D3CB;
  --blush-deep:   #E8B6A8;
  --butter:       #F6E6B4;
  --ink:          #2B2118;
  --ink-soft:     #5A4A3C;
  --ink-mute:     #8B7A6B;
  --terra:        #C77D5A;
  --terra-d:      #A55F3F;
  --mustard:      #E8B964;
  --rose:         #D78AA0;
  --line:         #E8DFCE;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --font-script:  'Caveat', cursive;

  --shadow-sm:    0 2px 6px rgba(43,33,24,.06);
  --shadow:       0 8px 24px rgba(43,33,24,.10);
  --shadow-lift:  0 18px 50px rgba(43,33,24,.16);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.thread {
  position: fixed; top: 0; left: 0;
  height: 3px; width: 0%;
  background: linear-gradient(90deg, var(--terra), var(--mustard), var(--rose));
  z-index: 100; transition: width .12s linear;
}

/* ── Masthead ── */
.mast {
  position: sticky; top: 0; z-index: 50;
  background: var(--sage);
  border-bottom: 1.5px dashed rgba(43,33,24,.18);
  backdrop-filter: blur(6px);
}
.mast-inner {
  max-width: 1240px; margin: 0 auto;
  padding: 18px 28px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.wordmark {
  font-family: var(--font-display);
  font-weight: 900; font-size: 1.4rem; letter-spacing: -0.02em;
  color: var(--ink);
  display: flex; align-items: center; gap: 10px;
}
.wordmark .mark { display: inline-block; transform-origin: center; animation: spin 22s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.wordmark .script { font-family: var(--font-script); font-weight: 700; color: var(--terra-d); font-size: 1.5rem; }

.nav { display: flex; gap: 6px; }
.nav a {
  padding: 8px 16px;
  font: 600 0.78rem/1 var(--font-body);
  letter-spacing: 0.14em; text-transform: uppercase;
  border: 1.5px dashed transparent;
  border-radius: 999px;
  transition: all .18s ease;
}
.nav a:hover, .nav a[aria-current="page"] { border-color: var(--ink); background: var(--cream); }
.nav a.cta {
  background: var(--ink); color: var(--cream); border-color: var(--ink);
  border-style: solid;
}
.nav a.cta:hover { background: var(--terra-d); border-color: var(--terra-d); }
@media (max-width: 760px) {
  .nav a:not(.cta) { display: none; }
  .mast-inner { padding: 14px 20px; }
  .wordmark { font-size: 1.2rem; }
  .wordmark .script { font-size: 1.3rem; }
}

/* ── Bands & seams ── */
.band { padding: 96px 0; position: relative; }
@media (max-width: 720px) { .band { padding: 64px 0; } }
@media (max-width: 480px) { .inner { padding: 0 20px; } }
.band--cream  { background: var(--cream); }
.band--sage   { background: var(--sage); }
.band--blush  { background: var(--blush); }
.band--butter { background: var(--butter); }
.inner { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.inner--narrow { max-width: 800px; }

.seam { display: block; width: 100%; height: 56px; line-height: 0; }
@media (max-width: 640px) { .seam { height: 32px; } }

/* ── Stickers ── */
.sticker {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 999px;
  font: 600 0.72rem/1 var(--font-body);
  letter-spacing: 0.18em; text-transform: uppercase;
  border: 1.5px dashed var(--ink);
  background: var(--butter); color: var(--ink);
}
.sticker--blush   { background: var(--blush); }
.sticker--sage    { background: var(--sage); }
.sticker--cream   { background: var(--cream); }
.sticker--terra   { background: var(--terra); color: var(--cream); border-color: var(--cream); }
@keyframes wobble {
  0%,100% { transform: rotate(-2deg); }
  50%     { transform: rotate(2deg); }
}
.wobble { animation: wobble 4s ease-in-out infinite; transform-origin: center; }
.wobble--slow { animation-duration: 6s; }
.wobble--rev  { animation-direction: reverse; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 32px; border-radius: 999px;
  font: 700 0.82rem/1 var(--font-body);
  letter-spacing: 0.18em; text-transform: uppercase;
  background: var(--ink); color: var(--cream);
  border: 1.5px solid var(--ink);
  transition: transform .18s, box-shadow .18s, background .18s;
  cursor: pointer;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); background: var(--terra-d); border-color: var(--terra-d); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--cream); }
.btn .arrow { transition: transform .18s; }
.btn:hover .arrow { transform: translateX(4px); }

/* ── Section heads ── */
.sec-head { text-align: center; max-width: 720px; margin: 0 auto 64px; }
.sec-kicker { font: 600 0.74rem/1 var(--font-body); letter-spacing: 0.28em; text-transform: uppercase; color: var(--terra-d); margin: 0 0 18px; }
.sec-head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; margin: 0 0 16px; letter-spacing: -0.02em; }
.sec-head h2 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; }
.sec-head p { color: var(--ink-soft); font-size: 1.1rem; margin: 0; }

/* ── Page-head (for non-home pages) ── */
.page-head { padding: 80px 0 56px; text-align: center; }
.page-head .sec-kicker { margin-bottom: 22px; }
.page-head h1 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: 1.02; letter-spacing: -0.03em;
  margin: 0 auto 20px; max-width: 880px;
}
.page-head h1 .script { font-family: var(--font-script); font-weight: 700; color: var(--terra); font-size: 1.05em; display: inline-block; transform: rotate(-2deg) translateY(-2px); }
.page-head h1 em { font-style: italic; font-weight: 400; }
.page-head .lede { font-size: 1.2rem; color: var(--ink-soft); margin: 0 auto; max-width: 640px; line-height: 1.6; }

/* ── Hero (homepage) ── */
.hero { padding: 80px 0 120px; position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: center; }
.hero-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 0.74rem/1 var(--font-body);
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--terra-d); margin-bottom: 28px;
}
.hero-kicker::before, .hero-kicker::after {
  content: ""; width: 28px; height: 1.5px; background: var(--terra-d);
}
.hero h1 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2.8rem, 6.4vw, 5rem);
  line-height: 0.98; letter-spacing: -0.03em;
  margin: 0 0 28px;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.hero h1 .script {
  font-family: var(--font-script); font-weight: 700;
  color: var(--terra); font-size: 1.05em;
  display: inline-block; transform: rotate(-3deg) translateY(-4px);
}
.hero h1 em { font-style: italic; font-weight: 400; font-variation-settings: "opsz" 9; }
.hero-lede { font-size: 1.18rem; line-height: 1.6; color: var(--ink-soft); max-width: 460px; margin: 0 0 36px; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: 14px; }
.hero-stats { display: flex; gap: 36px; margin-top: 52px; padding-top: 28px; border-top: 1.5px dashed var(--line); }
.stat-num { font-family: var(--font-display); font-weight: 800; font-size: 2rem; color: var(--ink); line-height: 1; }
.stat-label { font: 700 0.7rem/1 var(--font-body); letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-soft); margin-top: 8px; }

.hero-visual { position: relative; height: 560px; }
.polaroid {
  position: absolute; background: var(--cream);
  padding: 14px 14px 50px;
  box-shadow: var(--shadow-lift);
  transform-origin: center;
  color: inherit; text-decoration: none;
  transition: transform .35s ease, box-shadow .35s ease;
}
.polaroid:hover { box-shadow: var(--shadow-lift), 0 0 0 2px var(--mustard); }
.polaroid img { width: 100%; height: auto; aspect-ratio: 4/5; object-fit: cover; }
.polaroid .cap {
  position: absolute; bottom: 12px; left: 0; right: 0;
  text-align: center; font-family: var(--font-script);
  font-weight: 500; font-size: 1.2rem; color: var(--ink-soft);
}
.polaroid::before {
  content: ""; position: absolute;
  top: -14px; left: 50%; width: 84px; height: 24px;
  background: rgba(232,185,100,.55);
  transform: translateX(-50%) rotate(-3deg);
  z-index: 2;
}
.pl-1 { width: 280px; top: 20px;   left: 60px;  transform: rotate(-6deg); z-index: 2; }
.pl-2 { width: 240px; top: 200px;  right: 30px; transform: rotate(7deg);  z-index: 3; }
.pl-3 { width: 210px; bottom: 0;   left: 20px;  transform: rotate(3deg);  z-index: 1; }

.daisy { position: absolute; pointer-events: none; }
.daisy--rotate { animation: spin 32s linear infinite; }
.daisy--rev    { animation: spin 24s linear infinite reverse; }
.float { animation: float 6s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
.hero-stickers { position: absolute; pointer-events: none; }
.hero-stickers .sticker { pointer-events: auto; }

@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-visual { height: 480px; max-width: 520px; margin: 0 auto; }
  .pl-1 { width: 240px; left: 0; }
  .pl-2 { width: 200px; right: 0; }
  .pl-3 { width: 180px; }
}
@media (max-width: 560px) {
  .hero { padding: 48px 0 80px; }
  .hero-stats { gap: 18px; flex-wrap: wrap; }
  .stat-num { font-size: 1.6rem; }
  .stat-label { font-size: 0.62rem; letter-spacing: 0.16em; }
  .hero-visual { height: 420px; }
  .pl-1 { width: 210px; top: 0; left: 4%; }
  .pl-2 { width: 180px; top: 160px; right: 4%; }
  .pl-3 { width: 160px; bottom: 0; left: 12%; }
  .hero-stickers .sticker { font-size: 0.62rem; padding: 6px 12px; }
}

/* ── Marquee ── */
.marquee { background: var(--ink); color: var(--cream); padding: 18px 0; overflow: hidden; border-top: 1.5px dashed rgba(255,255,255,.18); border-bottom: 1.5px dashed rgba(255,255,255,.18); }
.marquee-track { display: flex; white-space: nowrap; animation: scroll 42s linear infinite; width: max-content; }
.marquee-item { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; letter-spacing: -0.005em; display: inline-flex; align-items: center; gap: 24px; padding-right: 24px; }
.marquee-item .script { font-family: var(--font-script); font-weight: 700; color: var(--mustard); font-size: 1.35em; line-height: 1; }
.marquee-item .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--rose); flex: 0 0 auto; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (max-width: 640px) {
  .marquee-item { font-size: 0.95rem; gap: 16px; padding-right: 16px; }
  .marquee-item .dot { width: 5px; height: 5px; }
}

/* ── Post grid ── */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px 28px; }
.post-card { position: relative; display: block; background: var(--cream); border-radius: 18px; padding: 14px 14px 22px; box-shadow: var(--shadow-sm); color: inherit; text-decoration: none; transition: transform .3s ease, box-shadow .3s ease; }
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.post-card-thumb { aspect-ratio: 4/5; overflow: hidden; border-radius: 12px; background: var(--blush); margin-bottom: 16px; }
.post-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; display: block; }
.post-card:hover .post-card-thumb img { transform: scale(1.05); }
.post-card-kicker { font: 700 0.66rem/1 var(--font-body); letter-spacing: 0.22em; text-transform: uppercase; color: var(--terra-d); margin: 0 0 8px; }
.post-card-title { font-family: var(--font-display); font-weight: 700; font-size: 1.08rem; line-height: 1.25; margin: 0 0 10px; letter-spacing: -0.01em; color: var(--ink); }
.post-card-meta { font: 500 0.74rem/1.4 var(--font-body); color: var(--ink-soft); margin: 0; }
.post-card-meta .dot { display: inline-block; width: 3px; height: 3px; border-radius: 50%; background: var(--ink-mute); vertical-align: middle; margin: 0 6px; }
.post-card .new-badge { position: absolute; top: -10px; right: 14px; z-index: 2; font-size: 0.62rem; padding: 6px 12px; }
@media (max-width: 880px) { .post-grid { grid-template-columns: repeat(2, 1fr); gap: 28px 20px; } }
@media (max-width: 540px) { .post-grid { grid-template-columns: 1fr; gap: 24px; } }

/* ── Mood pills ── */
.moods { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; max-width: 920px; margin: 0 auto; }
.mood { display: inline-flex; align-items: center; gap: 10px; padding: 14px 24px; border-radius: 999px; background: var(--cream); color: var(--ink); border: 1.5px solid var(--ink); font: 600 0.84rem/1 var(--font-body); transition: all .18s ease; cursor: pointer; }
.mood:hover { background: var(--ink); color: var(--cream); transform: translateY(-2px) rotate(-1deg); box-shadow: var(--shadow); }
.mood .ico { font-size: 1.2rem; line-height: 1; }
.mood .count { font-size: 0.72rem; opacity: .65; }

/* Generic SVG icon helper — used everywhere category/social icons render */
.cg-icon { display: inline-block; vertical-align: middle; flex: 0 0 auto; }
.mood .cg-icon { color: var(--terra-d); transition: color .18s ease; }
.mood:hover .cg-icon { color: var(--cream); }
.sec-kicker .cg-icon { vertical-align: -2px; color: var(--terra-d); margin-right: 4px; }
.sticker .cg-icon { color: inherit; }

/* Social row in footer */
.social-row { display: flex; gap: 12px; margin-top: 18px; }
.social-row a {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px dashed var(--ink);
  color: var(--ink);
  transition: background .18s, color .18s, transform .18s;
}
.social-row a:hover { background: var(--ink); color: var(--cream); transform: translateY(-2px) rotate(-2deg); }

/* ── Pattern wall ── */
.wall { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px 20px; }
.tile { position: relative; display: block; background: var(--cream); padding: 12px 12px 36px; box-shadow: var(--shadow-sm); color: inherit; text-decoration: none; transition: transform .35s ease, box-shadow .35s ease; }
.tile:nth-child(odd)  { transform: rotate(-1.5deg); }
.tile:nth-child(even) { transform: rotate(1.5deg); }
.tile:hover { transform: rotate(0) translateY(-6px) scale(1.02); box-shadow: var(--shadow-lift); z-index: 2; }
.tile-img { aspect-ratio: 4/5; overflow: hidden; background: var(--blush); }
.tile-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.tile:hover .tile-img img { transform: scale(1.06); }
.tile-cap { position: absolute; bottom: 8px; left: 12px; right: 12px; text-align: center; font-family: var(--font-script); font-weight: 500; font-size: 1.05rem; color: var(--ink-soft); }
@media (max-width: 920px) { .wall { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .wall { grid-template-columns: repeat(2, 1fr); } }

/* ── Steps ── */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.step { text-align: center; }
.step-num { display: inline-block; width: 72px; height: 72px; border-radius: 50%; background: var(--cream); border: 2px dashed var(--ink); line-height: 68px; text-align: center; font-family: var(--font-display); font-weight: 800; font-size: 1.8rem; color: var(--ink); margin-bottom: 24px; position: relative; }
.step-num::after { content: ""; position: absolute; inset: -8px; border-radius: 50%; border: 1.5px solid var(--ink); opacity: .15; }
.step h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.4rem; margin: 0 0 12px; }
.step h3 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 1.2em; }
.step p { color: var(--ink-soft); margin: 0 auto; max-width: 280px; }
@media (max-width: 720px) { .steps { grid-template-columns: 1fr; gap: 48px; } }

/* ── Newsletter card ── */
.nl-card { background: var(--cream); border-radius: 32px; padding: 56px 48px; text-align: center; box-shadow: var(--shadow); max-width: 720px; margin: 0 auto; position: relative; }
.nl-card .env { position: absolute; top: -28px; left: 50%; transform: translateX(-50%) rotate(-6deg); }
.nl-card h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.8rem, 3vw, 2.4rem); line-height: 1.1; margin: 8px 0 14px; letter-spacing: -0.02em; }
.nl-card h2 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 1.2em; }
.nl-card p { color: var(--ink-soft); margin: 0 0 28px; }
.nl-form { display: flex; gap: 10px; max-width: 460px; margin: 0 auto; }
.nl-form input { flex: 1; padding: 16px 22px; border: 1.5px solid var(--ink); border-radius: 999px; background: transparent; color: var(--ink); font: 500 1rem/1 var(--font-body); outline: none; }
.nl-form input::placeholder { color: var(--ink-mute); }
.nl-form input:focus { background: var(--cream-deep); }
.nl-fine { font-size: .8rem; color: var(--ink-mute); margin-top: 18px; }
@media (max-width: 540px) { .nl-form { flex-direction: column; } }

/* ── Footer ── */
.footer { background: var(--sage-deep); color: var(--ink); padding: 80px 0 32px; border-top: 1.5px dashed rgba(43,33,24,.18); }
.foot-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; max-width: 1180px; margin: 0 auto 56px; padding: 0 28px; }
.foot-mark { font-family: var(--font-display); font-weight: 900; font-size: 2rem; letter-spacing: -0.02em; margin: 0 0 12px; }
.foot-mark .script { font-family: var(--font-script); color: var(--ink); font-weight: 700; font-size: 1.3em; }
.foot-blurb { color: var(--ink-soft); max-width: 320px; margin: 0 0 20px; }
.foot-h { font: 700 0.72rem/1 var(--font-body); letter-spacing: 0.24em; text-transform: uppercase; margin: 0 0 18px; color: var(--ink); }
.foot-col ul { list-style: none; padding: 0; margin: 0; }
.foot-col li { margin-bottom: 10px; }
.foot-col a:hover { color: var(--terra-d); }
.foot-bot { border-top: 1.5px dashed rgba(43,33,24,.18); padding: 24px 28px 0; max-width: 1180px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; font-size: .82rem; color: var(--ink-soft); }
.foot-bot .signature { font-family: var(--font-script); font-size: 1.2rem; color: var(--ink); }
@media (max-width: 820px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; } }
@media (max-width: 480px) {
  .footer { padding: 56px 0 24px; }
  .foot-grid { grid-template-columns: 1fr; gap: 32px; padding: 0 20px; }
  .foot-mark { font-size: 1.6rem; }
  .foot-bot { padding: 20px 20px 0; flex-direction: column; align-items: flex-start; }
}

/* ── Article (legal/about/etc) ── */
.article-body { max-width: 720px; margin: 0 auto; padding: 0 28px; font-size: 1.06rem; color: var(--ink); }
.article-body h2 { font-family: var(--font-display); font-weight: 800; font-size: 1.7rem; line-height: 1.15; margin: 56px 0 18px; letter-spacing: -0.01em; }
.article-body h2 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 1.2em; }
.article-body h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; margin: 32px 0 12px; }
.article-body p { margin: 0 0 16px; color: var(--ink-soft); }
.article-body p strong { color: var(--ink); }
.article-body a { color: var(--terra-d); text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 3px; }
.article-body a:hover { color: var(--ink); }
.article-body ul, .article-body ol { padding-left: 24px; margin: 0 0 16px; color: var(--ink-soft); }
.article-body li { margin-bottom: 8px; }
.article-body blockquote {
  margin: 28px 0; padding: 20px 28px;
  border-left: 3px solid var(--terra); background: var(--cream-deep);
  border-radius: 0 14px 14px 0; font-style: italic; color: var(--ink);
}
.article-body hr { border: 0; border-top: 1.5px dashed var(--line); margin: 40px 0; }
.article-body code, .article-body kbd { background: var(--cream-deep); padding: 2px 8px; border-radius: 6px; font-size: 0.9em; }
.article-toc {
  background: var(--cream-deep); border-radius: 18px;
  padding: 28px 32px; margin: 24px auto 48px; max-width: 720px;
}
.article-toc .foot-h { margin-bottom: 14px; }
.article-toc ul { list-style: none; padding: 0; margin: 0; }
.article-toc li { margin-bottom: 8px; }
.article-toc a { color: var(--ink); border-bottom: 1.5px dashed transparent; padding-bottom: 1px; transition: border-color .15s; }
.article-toc a:hover { border-color: var(--terra-d); }

/* ── Contact form ── */
.form-card { background: var(--cream); border-radius: 28px; padding: 40px 44px; box-shadow: var(--shadow); max-width: 640px; margin: 0 auto; }
.form-row { margin-bottom: 20px; }
.form-row label { display: block; font: 700 0.72rem/1 var(--font-body); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 8px; }
.form-row input, .form-row textarea, .form-row select {
  width: 100%; padding: 14px 18px;
  background: var(--cream-deep);
  border: 1.5px solid var(--line); border-radius: 14px;
  font: 500 1rem/1.4 var(--font-body); color: var(--ink); outline: none;
  transition: border-color .15s, background .15s;
}
.form-row textarea { min-height: 140px; resize: vertical; }
.form-row input:focus, .form-row textarea:focus, .form-row select:focus { border-color: var(--terra); background: var(--cream); }
.form-msg { padding: 14px 18px; border-radius: 12px; margin-bottom: 20px; font-size: 0.95rem; }
.form-msg--ok  { background: #DDEBD0; color: #2C4423; border: 1.5px dashed #6A8D52; }
.form-msg--err { background: #F2D3CB; color: #6B2A1A; border: 1.5px dashed #A55F3F; }

/* ── Posts archive specific ── */
.archive-toolbar { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin: 0 0 48px; }
.archive-toolbar .mood { padding: 10px 18px; font-size: 0.78rem; }
.archive-toolbar .mood[aria-current="page"] { background: var(--ink); color: var(--cream); }

/* ─────────────── Post (listicle) page ─────────────── */

/* Breadcrumbs */
.breadcrumbs { max-width: 880px; margin: 0 auto; padding: 16px 28px 0; font-size: 0.78rem; color: var(--ink-mute); letter-spacing: 0.04em; }
.breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.breadcrumbs li { display: inline-flex; align-items: center; }
.breadcrumbs li + li::before { content: "→"; margin: 0 8px; color: var(--terra-d); }
.breadcrumbs a { color: var(--ink-soft); border-bottom: 1.5px dashed transparent; padding-bottom: 1px; transition: border-color .15s; }
.breadcrumbs a:hover { border-color: var(--terra-d); }
.breadcrumbs li[aria-current] { color: var(--ink); font-weight: 600; }

/* Hero of an article (kicker + title + byline) */
.hero-edit { max-width: 880px; margin: 0 auto; padding: 32px 28px 24px; text-align: center; }
.hero-kicker {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font: 700 0.74rem/1 var(--font-body);
  letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--terra-d); margin: 0 0 22px;
}
.hero-kicker .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--terra-d); }
.hero-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2rem, 4.6vw, 3.4rem);
  line-height: 1.05; letter-spacing: -0.02em;
  margin: 0 0 22px; color: var(--ink);
}
.hero-title .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; }
.hero-byline {
  font: 500 0.86rem/1.4 var(--font-body);
  color: var(--ink-soft); margin: 0;
}
.hero-byline em { font-style: normal; color: var(--ink-mute); margin: 0 6px; }

/* Article body */
.post-body { max-width: 720px; margin: 0 auto; padding: 0 28px; }
.intro { font-size: 1.12rem; line-height: 1.75; color: var(--ink); margin: 32px 0 40px; }
.intro p { margin: 0 0 18px; }

/* At a glance aside */
.takeaways {
  background: var(--cream-deep); border-radius: 18px;
  padding: 28px 32px; margin: 40px 0;
  border: 1.5px dashed var(--line);
}
.takeaways h2 {
  font-family: var(--font-display); font-weight: 800;
  font-size: 1.3rem; line-height: 1.1; margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.takeaways h2 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 1.2em; }
.takeaways ul { list-style: none; padding: 0; margin: 0; }
.takeaways li {
  position: relative; padding: 4px 0 4px 22px;
  font-size: 0.96rem; color: var(--ink-soft); line-height: 1.55;
}
.takeaways li::before {
  content: ""; position: absolute; left: 0; top: 13px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--mustard);
  box-shadow: 0 0 0 3px var(--cream-deep);
}

/* Ornament */
.ornament { text-align: center; margin: 48px 0; display: flex; justify-content: center; gap: 16px; }
.ornament svg { transition: transform .4s ease; }
.ornament svg:nth-child(2) { transform: translateY(-6px); }
.ornament svg:nth-child(odd) { animation: spin 32s linear infinite; }

/* Entries (numbered pattern list) */
.entries {
  list-style: none; padding: 0; margin: 0;
  counter-reset: entry;
}
.entry {
  counter-increment: entry;
  background: var(--cream);
  border: 1.5px solid var(--line);
  border-radius: 22px;
  padding: 32px 32px 28px;
  margin-bottom: 28px;
  position: relative;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .25s ease, transform .25s ease;
}
.entry:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.entry::before {
  content: counter(entry, decimal-leading-zero);
  position: absolute;
  top: -16px; left: 28px;
  background: var(--terra); color: var(--cream);
  font: 800 0.78rem/1 var(--font-body);
  letter-spacing: 0.14em;
  padding: 8px 14px; border-radius: 999px;
  border: 1.5px solid var(--cream);
  box-shadow: var(--shadow-sm);
}
.entry-image {
  margin: 0 0 24px;
  border-radius: 16px; overflow: hidden;
  background: var(--blush);
  aspect-ratio: 5/3;
}
.entry-image a { display: block; height: 100%; }
.entry-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.entry:hover .entry-image img { transform: scale(1.03); }
.entry > h2 {
  font-family: var(--font-display); font-weight: 800;
  font-size: 1.4rem; line-height: 1.18;
  margin: 0 0 8px; letter-spacing: -0.01em;
}
.entry > h2 a {
  color: var(--ink);
  border-bottom: 1.5px dashed transparent; padding-bottom: 2px;
  transition: color .15s, border-color .15s;
}
.entry > h2 a:hover { color: var(--terra-d); border-color: var(--terra-d); }
.entry-byline {
  font: 600 0.72rem/1 var(--font-body);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0 0 14px;
}
.entry-body { font-size: 1rem; line-height: 1.62; color: var(--ink-soft); margin: 0 0 16px; }
.entry-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  font: 500 0.78rem/1.4 var(--font-body); color: var(--ink-mute);
  margin: 0 0 20px;
}
.entry-meta .sep { color: var(--line); margin: 0 2px; }
.entry-meta .free {
  display: inline-block; padding: 4px 10px;
  border-radius: 999px; background: var(--sage);
  color: var(--ink); font-weight: 700; font-size: 0.72rem;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.entry-cta { margin: 0; }
.entry-cta a {
  display: inline-flex; align-items: center; gap: 6px;
  font: 700 0.78rem/1 var(--font-body);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--terra-d);
  border-bottom: 1.5px solid var(--terra-d);
  padding-bottom: 4px;
  transition: color .15s, border-color .15s, transform .15s;
}
.entry-cta a:hover { color: var(--ink); border-color: var(--ink); transform: translateX(2px); }
@media (max-width: 720px) {
  .entry { padding: 24px 22px 22px; }
  .entry-image { aspect-ratio: 4/3; }
}

/* Pull quote */
.pull-quote {
  margin: 48px -16px;
  padding: 36px 40px 32px;
  background: linear-gradient(180deg, var(--sage) 0%, color-mix(in srgb, var(--sage) 70%, var(--cream)) 100%);
  border-radius: 22px;
  text-align: center;
  position: relative;
  border: 1.5px dashed rgba(43,33,24,.18);
}
.pull-quote .quote-mark {
  color: var(--terra);
  display: block;
  margin: 0 auto 18px;
  opacity: 0.85;
  transform: rotate(-4deg);
}
.pull-quote blockquote {
  margin: 0; padding: 0;
  font-family: var(--font-display);
  font-style: italic; font-weight: 500;
  font-size: clamp(1.25rem, 2.4vw, 1.6rem);
  line-height: 1.35; letter-spacing: -0.01em;
  color: var(--ink);
  max-width: 560px; margin-inline: auto;
}
.pull-quote blockquote p { margin: 0; }
.pull-quote figcaption {
  margin-top: 18px;
  font-family: var(--font-script); font-weight: 500;
  font-size: 1.1rem; color: var(--terra-d);
}
@media (max-width: 540px) {
  .pull-quote { margin: 36px 0; padding: 28px 24px 24px; }
}

/* Ad slot (kept for compatibility; render removed) */
.ad-slot { margin: 28px 0; }
.ad-slot-inner {
  background: var(--cream-deep);
  border: 1.5px dashed var(--line);
  border-radius: 14px;
  padding: 18px;
  text-align: center;
  font: 600 0.7rem/1 var(--font-body);
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-mute);
}

/* Conclusion */
.conclusion {
  margin: 56px 0 0;
  padding: 32px 0 0;
  border-top: 1.5px dashed var(--line);
}
.conclusion h2 {
  font-family: var(--font-display); font-weight: 800;
  font-size: 1.6rem; margin: 0 0 18px; letter-spacing: -0.01em;
}
.conclusion h2 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 1.2em; }
.conclusion p { font-size: 1.05rem; line-height: 1.7; color: var(--ink-soft); margin: 0 0 16px; }

/* FAQ */
.faq { margin: 56px 0 0; }
.faq h2 {
  font-family: var(--font-display); font-weight: 800;
  font-size: 1.6rem; margin: 0 0 24px; letter-spacing: -0.01em;
}
.faq h2 .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 1.2em; }
.faq-item {
  background: var(--cream);
  border: 1.5px solid var(--line);
  border-radius: 14px;
  padding: 0;
  margin-bottom: 12px;
  overflow: hidden;
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 22px;
  font: 600 1rem/1.4 var(--font-body);
  color: var(--ink);
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.3rem;
  color: var(--terra-d);
  flex: 0 0 auto;
  transition: transform .2s ease;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item[open] summary { border-bottom: 1.5px dashed var(--line); }
.faq-answer { padding: 16px 22px 20px; font-size: 0.96rem; line-height: 1.65; color: var(--ink-soft); }
.faq-answer p { margin: 0; }

/* Colophon */
.colophon { text-align: center; margin: 56px 0 0; }
.colophon .signature {
  font-family: var(--font-script); font-weight: 500;
  font-size: 1.4rem; color: var(--ink-soft); margin: 0;
}

/* Related grid */
.related-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.related-card {
  background: var(--cream);
  border-radius: 16px;
  padding: 12px 12px 18px;
  box-shadow: var(--shadow-sm);
  transition: transform .25s ease, box-shadow .25s ease;
}
.related-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.related-card .thumb {
  display: block; aspect-ratio: 4/5;
  overflow: hidden; border-radius: 10px; margin-bottom: 12px;
  background: var(--blush);
}
.related-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.related-card:hover .thumb img { transform: scale(1.05); }
.related-card .cat {
  font: 700 0.62rem/1 var(--font-body);
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--terra-d); margin: 0 0 6px;
  display: flex; align-items: center; gap: 6px;
}
.related-card h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 0.94rem; line-height: 1.3; letter-spacing: -0.01em;
  margin: 0 0 4px;
}
.related-card h3 a { color: var(--ink); }
.related-card h3 a:hover { color: var(--terra-d); }
.related-card .by { font: 500 0.74rem/1.4 var(--font-body); color: var(--ink-mute); margin: 0; }
@media (max-width: 920px) { .related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .related-grid { grid-template-columns: 1fr; } }

/* ── Cookie banner ── */
.cookie-banner {
  position: fixed; left: 16px; right: 16px; bottom: 16px;
  background: var(--ink); color: var(--cream);
  border-radius: 18px; padding: 18px 22px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  z-index: 90; box-shadow: var(--shadow-lift);
  font: 500 0.92rem/1.45 var(--font-body);
  max-width: 720px; margin: 0 auto;
}
.cookie-banner a { color: var(--mustard); text-decoration: underline; }
.cookie-banner .actions { display: flex; gap: 10px; margin-left: auto; }
.cookie-banner button {
  padding: 10px 18px; border-radius: 999px;
  border: 1.5px solid var(--cream); background: transparent; color: var(--cream);
  font: 600 0.7rem/1 var(--font-body); letter-spacing: 0.16em; text-transform: uppercase;
  cursor: pointer;
}
.cookie-banner button.primary { background: var(--cream); color: var(--ink); }
.cookie-banner.hide { display: none; }
@media (max-width: 540px) {
  .cookie-banner { font-size: 0.84rem; padding: 14px 16px; }
  .cookie-banner .actions { margin-left: 0; width: 100%; }
}

/* ── 404 ── */
.notfound { text-align: center; padding: 120px 28px; }
.notfound .big { font-family: var(--font-display); font-weight: 900; font-size: clamp(5rem, 14vw, 11rem); line-height: 1; letter-spacing: -0.05em; color: var(--ink); margin: 0 0 8px; }
.notfound .big .script { font-family: var(--font-script); color: var(--terra); font-weight: 700; font-size: 0.7em; display: inline-block; transform: rotate(-3deg); }
.notfound h1 { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; margin: 0 0 14px; }
.notfound p { color: var(--ink-soft); margin: 0 0 32px; }

/* ── Reveal ── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ── Empty state ── */
.empty-msg { text-align: center; padding: 48px 24px; color: var(--ink-soft); font-style: italic; }
