:root{
  --pink:#D8A1A0; --pink-deep:#C98E8D;
  --yellow:#F3E1A3; --yellow-deep:#ECD488;
  --ink:#1C1C1C; --cream:#FBF4EC; --muted:#6b5d57;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.15}
a{color:inherit}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
section{padding:84px 0}
.eyebrow{font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;opacity:.75;margin-bottom:16px}
.cta{display:inline-block;background:var(--yellow);color:var(--ink);font-weight:500;font-size:17px;text-decoration:none;padding:16px 32px;border-radius:999px;transition:transform .15s ease,background .15s ease;border:none;cursor:pointer}
.cta:hover{background:var(--yellow-deep);transform:translateY(-2px)}
.cta:focus-visible{outline:3px solid var(--ink);outline-offset:3px}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,244,236,.92);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid #eaddd0}
.nav-inner{max-width:1080px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;font-family:'Playfair Display',serif;font-weight:700;font-size:21px;letter-spacing:1px;color:var(--ink)}
.nav-logo svg{display:block}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{text-decoration:none;font-size:15px;color:var(--ink);opacity:.8;transition:opacity .15s}
.nav-links a:hover{opacity:1}
.nav-cta{background:var(--yellow);padding:10px 20px;border-radius:999px;font-weight:500;opacity:1 !important}
.nav-cta:hover{background:var(--yellow-deep)}

/* HERO */
.hero{background:var(--pink);padding:0}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0;min-height:84vh}
.hero-content{padding:64px 56px}
.hero-img{height:100%;width:100%;object-fit:cover;min-height:380px}
.mono{margin-bottom:22px}
.hero h1{font-size:clamp(46px,7vw,78px);letter-spacing:.02em;margin-bottom:20px}
.hero .tagline{font-size:clamp(18px,2.2vw,21px);max-width:26ch;margin-bottom:14px}
.hero .sub{font-size:15px;opacity:.85;margin-bottom:30px;max-width:30ch}

/* CHALLENGE */
.lead{font-size:clamp(28px,4.4vw,40px);max-width:18ch}
.intro-p{font-size:18px;color:var(--muted);max-width:46ch;margin-top:14px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.card{background:#fff;border:1px solid #efe3d8;border-radius:20px;padding:30px 26px}
.card .num{width:44px;height:44px;border-radius:50%;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:700;font-size:22px;margin-bottom:18px}
.card h3{font-size:21px;margin-bottom:10px}
.card p{font-size:15.5px;color:var(--muted)}

/* SPLIT ROWS */
.row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.row.rev .text{order:2}
.row img{width:100%;border-radius:24px;object-fit:cover;aspect-ratio:4/5}
.row h2{font-size:clamp(30px,4.4vw,42px);margin-bottom:18px}
.row p{font-size:17px;color:var(--muted);margin-bottom:14px}
.section-cream{background:var(--cream)}
.section-white{background:#fff}

/* CTA BAND */
.band{background:var(--pink);text-align:center}
.band h2{font-size:clamp(30px,5vw,46px);margin-bottom:14px}
.band p{font-size:17px;margin-bottom:30px;opacity:.9}

/* CONTACT */
.contact{background:var(--cream)}
.contact-inner{max-width:620px;margin:0 auto;text-align:center}
.contact h2{font-size:clamp(30px,5vw,44px);margin-bottom:14px}
.contact .intro-p{margin:0 auto 34px}
form{display:grid;gap:16px;text-align:left}
label{font-size:14px;font-weight:500;margin-bottom:6px;display:block}
input,textarea{width:100%;padding:14px 16px;border:1px solid #e2d4c8;border-radius:14px;font-family:inherit;font-size:16px;background:#fff;color:var(--ink)}
input:focus,textarea:focus{outline:2px solid var(--pink);border-color:var(--pink)}
textarea{min-height:130px;resize:vertical}
form .cta{justify-self:center;margin-top:8px}
.maillink{color:var(--ink);font-weight:500;text-decoration:underline;text-decoration-color:var(--pink);text-underline-offset:3px}
.mailalt{margin-top:20px;font-size:15px;color:var(--muted);text-align:center}

/* FOOTER */
footer{background:var(--ink);color:#fff;text-align:center;padding:50px 24px}
footer .fmono{margin-bottom:14px}
footer .fname{font-family:'Playfair Display',serif;font-weight:700;font-size:26px;letter-spacing:2px;margin-bottom:8px}
footer .fsub{font-size:12.5px;letter-spacing:3px;text-transform:uppercase;opacity:.7}

/* BLOG OVERVIEW */
.page-head{background:var(--pink);padding:72px 0 60px;text-align:center}
.page-head h1{font-size:clamp(38px,6vw,60px);margin-bottom:14px}
.page-head p{font-size:18px;max-width:50ch;margin:0 auto;opacity:.9}
.posts{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.post-card{background:#fff;border:1px solid #efe3d8;border-radius:22px;overflow:hidden;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}
.post-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(28,28,28,.08)}
.post-card img{width:100%;height:220px;object-fit:cover}
.post-card .pc-body{padding:26px 26px 30px}
.post-card .pc-tag{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--pink-deep);margin-bottom:10px}
.post-card h2{font-size:23px;line-height:1.25;margin-bottom:10px}
.post-card p{font-size:15px;color:var(--muted);margin-bottom:14px}
.post-card .pc-read{font-size:14px;font-weight:500;text-decoration:underline;text-decoration-color:var(--pink);text-underline-offset:3px}

/* ARTICLE */
.article-hero{background:var(--pink);padding:64px 0 56px}
.article-hero .wrap{max-width:760px}
.article-hero .crumb{font-size:13px;letter-spacing:.04em;margin-bottom:18px}
.article-hero .crumb a{text-decoration:none;opacity:.8}
.article-hero .crumb a:hover{opacity:1;text-decoration:underline}
.article-hero h1{font-size:clamp(32px,5.2vw,52px);margin-bottom:18px}
.article-hero .meta{font-size:14px;opacity:.85}
.article-figure{max-width:980px;margin:-32px auto 0;padding:0 24px}
.article-figure img{width:100%;border-radius:22px;object-fit:cover;max-height:460px;box-shadow:0 14px 34px rgba(28,28,28,.12)}
.article{max-width:720px;margin:0 auto;padding:54px 24px 20px}
.article p{font-size:18px;color:#33302d;margin-bottom:22px}
.article h2{font-size:clamp(26px,3.6vw,34px);margin:46px 0 16px}
.article h3{font-size:21px;margin:32px 0 12px}
.article ul{margin:0 0 22px 0;padding-left:22px}
.article li{font-size:18px;color:#33302d;margin-bottom:10px}
.article a.inline{color:var(--ink);font-weight:500;text-decoration:underline;text-decoration-color:var(--pink);text-underline-offset:3px}
.article figure{margin:34px 0}
.article figure img{width:100%;border-radius:18px;object-fit:cover}
.article figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:10px}
.callout{background:#fff;border:1px solid #efe3d8;border-left:5px solid var(--yellow-deep);border-radius:16px;padding:26px 28px;margin:36px 0}
.callout h3{margin:0 0 10px}
.callout p{font-size:16.5px;margin-bottom:14px}
.faq{max-width:720px;margin:0 auto;padding:10px 24px 30px}
.faq h2{font-size:clamp(24px,3.4vw,30px);margin-bottom:18px}
.faq details{background:#fff;border:1px solid #efe3d8;border-radius:14px;padding:18px 22px;margin-bottom:12px}
.faq summary{font-weight:600;cursor:pointer;font-size:16.5px}
.faq details p{font-size:16px;color:var(--muted);margin:12px 0 0}
.article-cta{background:var(--cream);text-align:center;padding:24px 24px 80px}
.article-cta .inner{max-width:620px;margin:0 auto;background:var(--pink);border-radius:24px;padding:48px 32px}
.article-cta h2{font-size:clamp(26px,4vw,38px);margin-bottom:12px}
.article-cta p{font-size:16.5px;margin-bottom:26px;opacity:.92}

@media (max-width:780px){
  section{padding:60px 0}
  .nav-links{gap:16px}
  .nav-links a:not(.nav-cta){display:none}
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-content{padding:48px 26px 40px}
  .hero-img{order:2;min-height:300px;max-height:58vh}
  .cards{grid-template-columns:1fr;gap:16px}
  .row{grid-template-columns:1fr;gap:28px}
  .row.rev .text{order:0}
  .row img{aspect-ratio:3/2}
  .posts{grid-template-columns:1fr;gap:20px}
  .article p,.article li{font-size:17px}
}
