:root{
  --cream:#FFF8F5;
  --beige:#F4ECE8;
  --blush:#F4ECE8;
  --blush-deep:#EFCBB8;
  --rose:#D89B7A;
  --rose-ink:#A9663F;
  --ink:#0A0A0A;
  --ink-soft:#5c5048;
  --line:rgba(10,10,10,.12);
  --display:'Fraunces',Georgia,serif;
  --body:'Jost',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);color:var(--ink);background:var(--cream);
  line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(60% 50% at 85% 0%, var(--blush) 0%, transparent 60%),
    radial-gradient(55% 45% at 0% 90%, var(--beige) 0%, transparent 55%),
    var(--cream);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--rose-ink);font-weight:400}

/* NAV */
nav{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:15px 28px;background:rgba(255,248,245,.85);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
nav .brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-size:1.25rem;text-decoration:none;color:inherit}
nav .brand b{font-weight:400}
nav .brand i{color:var(--rose);font-style:normal}
nav .badge{width:38px;height:38px;border-radius:50%;overflow:hidden;background:var(--cream);flex-shrink:0}
nav .badge img{width:100%;height:100%;object-fit:cover;transform:scale(1.13);display:block}
.nav-right{display:flex;align-items:center;gap:20px}
nav a.nav-link{text-decoration:none;color:var(--ink);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;position:relative;padding:3px 0}
nav a.nav-link::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--rose);transition:width .35s ease}
nav a.nav-link:hover::after{width:100%}
nav a.cta{
  background:var(--rose);color:#fff;text-decoration:none;border-radius:40px;
  padding:9px 20px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;
  box-shadow:0 10px 22px -12px rgba(216,155,122,.9);transition:background .3s ease,transform .3s ease;white-space:nowrap;
}
nav a.cta:hover{background:var(--rose-ink);transform:translateY(-2px)}
nav a.back{text-decoration:none;color:var(--rose-ink);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--blush-deep);padding-bottom:2px}

/* BLOG INDEX HERO */
.blog-hero{padding:80px 0 30px;text-align:center}
.blog-hero .eyebrow{display:block;margin-bottom:22px}
.blog-hero h1{font-family:var(--display);font-weight:300;font-size:clamp(2.8rem,8vw,5.4rem);line-height:.98;letter-spacing:-.01em}
.blog-hero h1 em{font-style:italic;color:var(--rose)}
.blog-hero p{max-width:540px;margin:26px auto 0;color:var(--ink-soft);font-size:1.05rem}

/* POST GRID */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:50px 0 30px}
.post-card{
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
  background:rgba(255,255,255,.45);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  transition:transform .45s ease,box-shadow .45s ease;
}
.post-card:hover{transform:translateY(-6px);box-shadow:0 34px 56px -34px rgba(156,91,102,.4)}
.post-card .thumb{aspect-ratio:4/3;overflow:hidden;background:linear-gradient(155deg,var(--blush-deep),var(--rose))}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.post-card:hover .thumb img{transform:scale(1.06)}
.post-card .body{padding:24px 26px 30px;display:flex;flex-direction:column;flex:1}
.post-card .tag{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rose-ink)}
.post-card h2{font-family:var(--display);font-weight:400;font-size:1.4rem;line-height:1.18;margin:12px 0 12px;letter-spacing:-.01em}
.post-card p{font-size:.92rem;color:var(--ink-soft);flex:1}
.post-card .more{margin-top:18px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--rose-ink)}
.post-card.featured{grid-column:1 / -1;grid-template-columns:1.1fr 1fr;display:grid}
.post-card.featured .thumb{aspect-ratio:auto;min-height:320px}
.post-card.featured .body{justify-content:center;padding:46px 50px}
.post-card.featured h2{font-size:2rem}
.post-card.featured p{font-size:1rem;flex:none}

/* ARTICLE */
.article-hero{position:relative;height:52vh;min-height:360px;max-height:560px;overflow:hidden}
.article-hero img{width:100%;height:100%;object-fit:cover;display:block}
.article-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,var(--cream) 2%,rgba(255,248,245,.2) 40%,rgba(10,10,10,.28) 100%);
}
.article-head{position:relative;margin-top:-150px;z-index:2}
.article-head .meta{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.article-head .tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:var(--rose);padding:6px 14px;border-radius:30px}
.article-head .date{font-size:.82rem;color:var(--ink-soft)}
.article-head h1{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,5.5vw,3.7rem);line-height:1.04;letter-spacing:-.01em}
.article-head h1 em{font-style:italic;color:var(--rose)}
.article-head .lede{margin-top:22px;font-size:1.18rem;color:var(--ink-soft);max-width:60ch;font-weight:300}

article.post{padding:48px 0 40px}
article.post p{margin-bottom:18px;color:#2c241f;font-size:1.06rem}
article.post h2{font-family:var(--display);font-weight:400;font-size:clamp(1.5rem,3.5vw,2rem);margin:44px 0 14px;letter-spacing:-.01em}
article.post h2 em{font-style:italic;color:var(--rose)}
article.post h3{font-family:var(--display);font-weight:400;font-size:1.3rem;margin:30px 0 10px}
article.post ul,article.post ol{margin:0 0 18px 22px;color:#2c241f;font-size:1.06rem}
article.post li{margin-bottom:9px}
article.post li strong{font-weight:500;color:var(--ink)}
article.post a{color:var(--rose-ink)}
article.post blockquote{
  margin:30px 0;padding:6px 0 6px 26px;border-left:2px solid var(--rose);
  font-family:var(--display);font-style:italic;font-weight:300;font-size:1.4rem;line-height:1.4;color:var(--rose-ink);
}
article.post figure{margin:34px 0}
article.post figure img{width:100%;border-radius:16px;display:block}
article.post figcaption{margin-top:10px;font-size:.84rem;color:var(--ink-soft);text-align:center}
.callout{
  background:rgba(239,203,184,.26);border:1px solid var(--blush-deep);border-radius:18px;
  padding:30px 32px;margin:40px 0;
}
.callout h3{font-family:var(--display);font-weight:400;font-size:1.35rem;margin-bottom:8px}
.callout p{font-size:1rem;color:var(--ink-soft);margin-bottom:18px}

/* INLINE CTA BUTTONS */
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;background:var(--rose);color:#fff;text-decoration:none;
  padding:16px 36px;border-radius:50px;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  box-shadow:0 18px 38px -16px rgba(216,155,122,.85);transition:transform .35s ease,background .35s ease;
}
.btn-primary:hover{transform:translateY(-3px);background:var(--rose-ink)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:9px;color:var(--rose-ink);text-decoration:none;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--blush-deep);padding-bottom:3px;transition:border-color .3s ease;
}
.btn-ghost:hover{border-color:var(--rose)}

/* AUTHOR / SIGN-OFF */
.byline{display:flex;align-items:center;gap:14px;margin:14px 0 6px}
.byline .ava{width:46px;height:46px;border-radius:50%;overflow:hidden;background:linear-gradient(155deg,var(--blush-deep),var(--rose));flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-style:italic;color:#fff;font-size:1.2rem}
.byline .ava img{width:100%;height:100%;object-fit:cover}
.byline b{font-weight:500;font-size:.95rem}
.byline span{display:block;font-size:.8rem;color:var(--ink-soft)}

/* RELATED */
.related{border-top:1px solid var(--line);padding:56px 0}
.related h2{font-family:var(--display);font-weight:300;font-size:1.8rem;margin-bottom:30px}
.related h2 em{font-style:italic;color:var(--rose)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* CTA SECTION */
.cta-band{text-align:center;padding:90px 0;border-top:1px solid var(--line)}
.cta-band h2{font-family:var(--display);font-weight:300;font-size:clamp(2rem,6vw,3.4rem);line-height:1.04;margin-bottom:18px}
.cta-band h2 em{font-style:italic;color:var(--rose)}
.cta-band p{color:var(--ink-soft);max-width:480px;margin:0 auto 34px}
.cta-actions{display:flex;flex-direction:column;align-items:center;gap:10px}

/* FOOTER */
footer{border-top:1px solid var(--line);padding:46px 0;text-align:center}
footer .badge{width:64px;height:64px;border-radius:50%;overflow:hidden;background:var(--cream);display:inline-block;margin-bottom:14px}
footer .badge img{width:100%;height:100%;object-fit:cover;transform:scale(1.13)}
footer .brand{font-family:var(--display);font-size:1.4rem;margin-bottom:10px}
footer .brand i{color:var(--rose);font-style:normal}
footer p{font-size:.8rem;color:var(--ink-soft);letter-spacing:.04em}
footer .links{margin-top:14px;font-size:.78rem}
footer .links a{color:var(--rose-ink);text-decoration:none;margin:0 7px}
footer .links a:hover{color:var(--rose)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:860px){
  .wrap{padding:0 22px}
  .posts{grid-template-columns:1fr;gap:24px;padding:36px 0 10px}
  .post-card.featured{grid-template-columns:1fr;grid-column:auto}
  .post-card.featured .thumb{min-height:220px}
  .post-card.featured .body{padding:30px 28px}
  .post-card.featured h2{font-size:1.6rem}
  .related-grid{grid-template-columns:1fr}
  .blog-hero{padding:54px 0 18px}
  .article-hero{height:40vh;min-height:260px}
  .article-head{margin-top:-110px}
  article.post{padding:34px 0 30px}
  .nav-right{gap:14px}
  nav a.nav-link{display:none}
  nav{padding:12px 18px}
}
