/* ============================================================
   nicolaiseverin.com — shared stylesheet
   Design language: calm Scandinavian editorial
   ============================================================ */

/* ---------- Design tokens ---------- */
:root {
  --bg-dark:#0E0E0F; --bg-dark-elev:#18181B; --bg-cream:#F2EBDD; --bg-cream-elev:#EAE1D0;
  --ink-on-dark:#F2EBDD; --ink-on-dark-mute:rgba(242,235,221,.62);
  --ink-on-cream:#0E0E0F; --ink-on-cream-mute:rgba(14,14,15,.66);
  --accent-yellow:#FFE03A; --accent-yellow-hi:#FFD000; --accent-green:#2EE599;
  --hairline-dark:rgba(242,235,221,.10); --hairline-cream:rgba(14,14,15,.12);
  --container:1280px; --measure:680px; --gutter:clamp(24px,5vw,56px);
  --section-pad:clamp(72px,11vw,140px);
  --radius:8px;
  --ease:cubic-bezier(.16,1,.3,1); --t-fast:200ms; --t-slow:720ms;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
img{max-width:100%;height:auto;display:block}
button{font:inherit}
body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg-dark);color:var(--ink-on-dark);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.section{padding:var(--section-pad) 0;position:relative;overflow:hidden}
.section--dark{background:var(--bg-dark);color:var(--ink-on-dark)}
.section--cream{background:var(--bg-cream);color:var(--ink-on-cream)}
.section--elev{background:var(--bg-dark-elev)}

/* ---------- Type ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:.8125rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-green);margin-bottom:24px}
.eyebrow::before{content:'';width:32px;height:1px;background:currentColor}
.eyebrow--center{justify-content:center}
.eyebrow--ink{color:var(--ink-on-cream-mute)}
h1,h2,h3{font-family:'Poppins','Inter',system-ui,sans-serif;font-weight:600;letter-spacing:-.012em;line-height:1.18;text-wrap:balance}
.h-display{font-size:clamp(1.85rem,4vw,3.1rem);font-weight:600;line-height:1.12;letter-spacing:-.02em}
.h-section{font-size:clamp(1.5rem,2.7vw,2.2rem);font-weight:600;margin-bottom:20px;letter-spacing:-.015em}
.h-card{font-size:1.0625rem;font-weight:600;line-height:1.3;margin-bottom:10px;letter-spacing:-.005em}
em.accent{font-style:normal;font-weight:700;color:var(--accent-green)}
.lead{font-size:clamp(1.0625rem,1.2vw,1.1875rem);line-height:1.7;color:var(--ink-on-dark-mute);max-width:var(--measure)}
.section--cream .lead{color:var(--ink-on-cream-mute)}
.muted{color:var(--ink-on-dark-mute)} .section--cream .muted{color:var(--ink-on-cream-mute)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 24px;font-weight:600;font-size:.8125rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:none;border-radius:6px;cursor:pointer;transition:transform var(--t-fast) var(--ease),background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}
.btn--primary{background:var(--accent-yellow);color:#0E0E0F}
.btn--primary:hover{background:var(--accent-yellow-hi);transform:translateY(-1px)}
.btn--primary .arrow{transition:transform var(--t-fast) var(--ease)}
.btn--primary:hover .arrow{transform:translateX(4px)}
.btn--lg{padding:17px 28px;font-size:.875rem}
.btn--ghost{background:transparent;color:inherit;border:1.5px solid rgba(242,235,221,.28);border-radius:4px;padding:13px 22px;letter-spacing:.08em}
.section--cream .btn--ghost{border-color:rgba(14,14,15,.22)}
.btn--ghost:hover{background:var(--accent-green);border-color:var(--accent-green);color:#0E0E0F;transform:translateY(-1px)}
.btn--ghost .arrow{transition:transform var(--t-fast) var(--ease)}
.btn--ghost:hover .arrow{transform:translateX(4px)}
.svc .btn,.loc .btn,.pcard .btn{align-self:flex-start}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(14,14,15,.78);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--hairline-dark)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px}
.logo{font-family:'Bricolage Grotesque','Inter',sans-serif;font-weight:800;font-size:1.125rem;letter-spacing:-.035em;color:var(--ink-on-dark);text-decoration:none;white-space:nowrap}
.logo__dot{color:var(--accent-green)}
.nav{display:none}
@media(min-width:1024px){.nav{display:flex;align-items:center;gap:clamp(20px,2.6vw,36px)}}
.nav__link{font-size:.8125rem;font-weight:500;color:var(--ink-on-dark);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;transition:color var(--t-fast) var(--ease)}
.nav__link:hover,.nav__link[aria-current]{color:var(--accent-green)}
.menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:1px solid var(--hairline-dark);border-radius:6px;color:var(--ink-on-dark);cursor:pointer}
@media(min-width:1024px){.menu-toggle{display:none}}
@media(max-width:1023px){.site-header .btn--primary{display:none}}

/* ---------- Nav dropdown (Arbejd med mig / Ressourcer) ---------- */
.nav__item--sub{position:relative;display:flex}
.nav__link--sub{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:inherit;font:inherit;cursor:pointer;padding:0;font-family:inherit}
.nav__chev{transition:transform var(--t-fast) var(--ease);flex-shrink:0}
.nav__item--sub:hover .nav__chev,.nav__item--sub.open .nav__chev{transform:rotate(180deg)}
.nav__submenu{position:absolute;top:calc(100% + 14px);left:-14px;min-width:240px;background:rgba(14,14,15,.96);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border:1px solid var(--hairline-dark);border-radius:8px;padding:8px;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity var(--t-fast) var(--ease),transform var(--t-fast) var(--ease);display:flex;flex-direction:column;gap:2px;box-shadow:0 24px 60px -20px rgba(0,0,0,.55)}
/* Invisible bridge so cursor doesn't lose :hover while traversing the gap between trigger and menu */
.nav__submenu::before{content:'';position:absolute;left:0;right:0;top:-14px;height:14px;background:transparent}
.nav__item--sub:hover .nav__submenu,.nav__item--sub:focus-within .nav__submenu,.nav__item--sub.open .nav__submenu{opacity:1;transform:none;pointer-events:auto}
.nav__sublink{display:block;padding:10px 14px;color:var(--ink-on-dark);text-decoration:none;font-size:.8125rem;letter-spacing:.04em;border-radius:6px;text-transform:none;font-weight:500;transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}
.nav__sublink:hover,.nav__sublink:focus-visible{background:rgba(46,229,153,.10);color:var(--accent-green);outline:none}

/* ---------- Hero ---------- */
.hero{padding:clamp(56px,9vw,112px) 0 clamp(64px,8vw,96px)}
.hero__grid{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px);align-items:center}
@media(min-width:960px){.hero__grid{grid-template-columns:1.15fr 1fr}}
.hero__content{max-width:620px}
.hero__title{margin-bottom:28px}
.hero__body{margin-bottom:40px;max-width:540px}
.hero__body strong{color:var(--ink-on-dark);font-weight:500}
.hero__cta-row{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.hero__portrait-wrap{position:relative;isolation:isolate}
.hero__portrait{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius);background:var(--bg-dark-elev);z-index:1}
.hero__portrait img{width:100%;height:100%;object-fit:cover;object-position:center 18%;filter:contrast(1.04) saturate(.95)}
.hero__portrait-wrap::before{content:'';position:absolute;inset:-8% -6% -4% -6%;background:radial-gradient(circle at 70% 30%,rgba(46,229,153,.10),transparent 55%);z-index:0;filter:blur(20px);pointer-events:none;animation:breathe 8s ease-in-out infinite}
.hero__caption{position:absolute;bottom:18px;left:22px;z-index:2;font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:1.0625rem;color:var(--ink-on-dark);text-shadow:0 1px 12px rgba(0,0,0,.7)}

/* ---------- Trust band ---------- */
.trust{border-top:1px solid var(--hairline-dark);padding:36px 0}
.trust__inner{display:flex;flex-direction:column;gap:20px;align-items:flex-start}
@media(min-width:768px){.trust__inner{flex-direction:row;align-items:center;gap:36px}}
.trust__avatars{display:flex;flex-shrink:0}
.trust__avatar{width:44px;height:44px;border-radius:50%;border:2px solid var(--bg-dark);margin-left:-10px;object-fit:cover;background:#2a2015}
.trust__avatar:first-child{margin-left:0}
.trust__avatar:nth-child(2){background:linear-gradient(135deg,#6b5544,#3a2a1f)}
.trust__avatar:nth-child(3){background:linear-gradient(135deg,#5a4a3a,#2a2015)}
.trust__avatar:nth-child(4){background:linear-gradient(135deg,#6b4a44,#3a1f1a)}
.trust__avatar:nth-child(5){background:linear-gradient(135deg,#5a4a4a,#2a1f1f)}
.trust__text{font-size:.9375rem;line-height:1.6;color:var(--ink-on-dark-mute);max-width:680px}
.trust__text strong{color:var(--ink-on-dark);font-weight:600}

/* ---------- Problem cards ---------- */
.problem__head{max-width:760px;margin:0 auto clamp(48px,6vw,72px);text-align:center}
.problem__grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:640px){.problem__grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.problem__grid{grid-template-columns:repeat(4,1fr);gap:28px}}
.pcard{padding:28px 24px;border:1px solid var(--hairline-dark);border-radius:var(--radius);background:rgba(242,235,221,.015);transition:border-color var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}
.pcard:hover{border-color:rgba(46,229,153,.4);transform:translateY(-3px)}
.pcard__num{font-family:'Fraunces',serif;font-style:italic;font-size:.875rem;color:var(--accent-green);margin-bottom:14px;display:block}
.pcard p{font-size:.9375rem;color:var(--ink-on-dark-mute)}
.problem__reframe{text-align:center;margin-top:clamp(48px,6vw,72px);max-width:680px;margin-left:auto;margin-right:auto}
.problem__reframe p{font-size:clamp(1.125rem,1.6vw,1.375rem);line-height:1.55;margin-bottom:18px}
.problem__reframe strong{color:var(--ink-on-dark);font-weight:600}
.problem__reframe .no{color:var(--accent-yellow);font-weight:600}
/* lys variant — genkendelses-kort på creme-sektioner (inverteret udgave af forsidens mørke sektion) */
.section--cream .pcard{border-color:var(--hairline-cream);background:#fff}
.section--cream .pcard:hover{border-color:rgba(46,229,153,.5)}
.section--cream .pcard p{color:var(--ink-on-cream-mute)}
.section--cream .problem__reframe strong{color:var(--ink-on-cream)}

/* ---------- Split section ---------- */
.split{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px);align-items:center}
@media(min-width:960px){.split{grid-template-columns:1fr 1fr}}
.split--reverse .split__media{order:-1}
@media(min-width:960px){.split--reverse .split__media{order:1}}
.split__media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;background:var(--bg-cream-elev)}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__media--contain{background:transparent;aspect-ratio:auto;overflow:visible}
.split__media--contain img{height:auto;object-fit:contain}
.split__body{max-width:560px}
.split__body p{margin-bottom:18px}
.split__cta{margin-top:28px;display:flex;gap:24px;align-items:center;flex-wrap:wrap}

/* ---------- Placeholder media ---------- */
.media-ph{display:flex;align-items:center;justify-content:center;text-align:center;padding:32px;color:var(--ink-on-cream-mute);font-size:.875rem;border:1px dashed var(--hairline-cream);border-radius:var(--radius);aspect-ratio:4/5;background:var(--bg-cream-elev)}
.section--dark .media-ph{color:var(--ink-on-dark-mute);border-color:var(--hairline-dark);background:var(--bg-dark-elev)}

/* ---------- Services ---------- */
.svc__grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:clamp(40px,5vw,56px)}
@media(min-width:768px){.svc__grid{grid-template-columns:repeat(3,1fr)}}
.svc{display:flex;flex-direction:column;padding:32px 28px;border:1px solid var(--hairline-cream);border-radius:var(--radius);background:#fff;transition:transform var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}
.svc:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(14,14,15,.35)}
.svc__tag{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-green);font-weight:600;margin-bottom:16px}
.svc h3{margin-bottom:10px}
.svc p{font-size:.9375rem;color:var(--ink-on-cream-mute);margin-bottom:24px;flex:1}
.svc__price{font-family:'Fraunces',serif;font-style:italic;font-size:1.05rem;margin-bottom:18px}
.svc__price strong{font-family:'Poppins','Inter',sans-serif;font-style:normal;font-weight:600;font-size:1.5rem;display:block;color:var(--ink-on-cream)}
.svc__per{display:block;font-family:'Inter',sans-serif;font-style:normal;font-size:.8125rem;color:var(--ink-on-cream-mute);margin-top:4px;font-weight:400}
.svc--featured{border-color:var(--accent-green);box-shadow:0 0 0 1px var(--accent-green) inset,0 18px 40px -24px rgba(46,229,153,.25)}
.svc--featured .svc__tag{background:var(--accent-green);color:#0E0E0F;padding:4px 10px;border-radius:4px}

/* ---------- Lead magnet ---------- */
.lead-magnet{display:grid;grid-template-columns:1fr;gap:clamp(36px,5vw,64px);align-items:center}
@media(min-width:900px){.lead-magnet{grid-template-columns:1fr 1fr}}
.embed-slot{border:2px dashed var(--accent-green);border-radius:var(--radius);padding:40px 28px;text-align:center;background:rgba(46,229,153,.05)}
.embed-slot__label{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-green);font-weight:700;margin-bottom:12px}
.embed-slot p{font-size:.875rem;color:var(--ink-on-cream-mute);max-width:420px;margin:0 auto}
.section--dark .embed-slot p{color:var(--ink-on-dark-mute)}

/* ---------- Testimonials ---------- */
.quote-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:clamp(40px,5vw,56px)}
@media(min-width:768px){.quote-grid{grid-template-columns:repeat(3,1fr)}}
.quote{padding:30px 28px;border:1px solid var(--hairline-dark);border-radius:var(--radius);background:rgba(242,235,221,.02)}
.section--cream .quote{border-color:var(--hairline-cream);background:#fff}
.quote__stars{color:var(--accent-yellow);letter-spacing:3px;margin-bottom:16px;font-size:.95rem}
.quote p{font-family:'Fraunces',serif;font-size:1.0625rem;line-height:1.5;margin-bottom:18px}
.quote__foot{display:flex;align-items:center;gap:12px;margin-top:4px}
.quote__avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--hairline-dark)}
.quote__who{font-size:.8125rem;letter-spacing:.04em;color:var(--ink-on-dark-mute)}
.section--cream .quote__who{color:var(--ink-on-cream-mute)}

/* ---------- Locations (homepage band) ---------- */
.loc__grid{display:grid;grid-template-columns:1fr;gap:28px;margin-top:clamp(40px,5vw,56px)}
@media(min-width:768px){.loc__grid{grid-template-columns:1fr 1fr}}
.loc{padding:36px 32px;border:1px solid var(--hairline-cream);border-radius:var(--radius);background:#fff;display:flex;flex-direction:column}
.loc__city{font-family:'Poppins','Inter',sans-serif;font-weight:600;font-size:1.4rem;margin-bottom:6px}
.loc__addr{color:var(--ink-on-cream-mute);font-size:.9375rem;margin-bottom:20px;line-height:1.5}
.loc__map{aspect-ratio:16/9;border-radius:6px;overflow:hidden;background:var(--bg-cream-elev);margin-bottom:24px}
.loc__cta{margin-top:auto}

/* ---------- Location page: info + gallery ---------- */
.info-grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,5vw,56px);align-items:start;margin-top:clamp(40px,5vw,56px)}
@media(min-width:900px){.info-grid{grid-template-columns:1fr 1.25fr}}
.infobox{display:flex;flex-direction:column;gap:22px}
.infobox__row{display:flex;gap:14px;align-items:flex-start}
.infobox__row svg{flex-shrink:0;margin-top:3px;color:var(--accent-green)}
.infobox__label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-on-cream-mute);margin-bottom:3px}
.infobox__val{font-size:1.0625rem}
.infobox__val a{color:inherit;text-decoration:none;border-bottom:1px solid var(--hairline-cream)}
.infobox__val a:hover{color:var(--accent-green);border-color:var(--accent-green)}
.map-embed{aspect-ratio:16/11;border-radius:var(--radius);overflow:hidden;background:var(--bg-cream-elev);border:1px dashed var(--hairline-cream);display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ink-on-cream-mute);font-size:.8125rem;padding:16px}
.map-embed iframe{width:100%;height:100%;border:0;display:block}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:clamp(40px,5vw,56px)}
@media(min-width:768px){.gallery{grid-template-columns:repeat(4,1fr)}}
.gallery img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius)}
.gallery--ph{border:1px dashed var(--hairline-cream);border-radius:var(--radius);padding:48px 24px;text-align:center;color:var(--ink-on-cream-mute);font-size:.875rem;grid-column:1/-1}

/* ---------- Final CTA ---------- */
.final{text-align:center}
.final .h-display{margin-bottom:16px}
.final__eyebrow{justify-content:center;margin-bottom:28px}
.final__sub{max-width:520px;margin:0 auto 40px;color:var(--ink-on-dark-mute);font-size:1.0625rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:clamp(40px,5vw,56px) auto 0}
.faq__item{border-bottom:1px solid var(--hairline-dark)}
.section--cream .faq__item{border-color:var(--hairline-cream)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 0;background:transparent;border:none;color:inherit;text-align:left;cursor:pointer;font-family:'Poppins','Inter',sans-serif;font-weight:600;font-size:1.0625rem;letter-spacing:-.01em}
.faq__icon{flex-shrink:0;width:22px;height:22px;position:relative;transition:transform var(--t-fast) var(--ease)}
.faq__icon::before,.faq__icon::after{content:'';position:absolute;background:var(--accent-green);top:50%;left:50%;transform:translate(-50%,-50%)}
.faq__icon::before{width:14px;height:2px}
.faq__icon::after{width:2px;height:14px;transition:transform var(--t-fast) var(--ease)}
.faq__item[open] .faq__icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq__a{padding:0 0 24px;color:var(--ink-on-dark-mute);font-size:1rem;line-height:1.65;max-width:660px}
.section--cream .faq__a{color:var(--ink-on-cream-mute)}
details.faq__item summary{list-style:none}
details.faq__item summary::-webkit-details-marker{display:none}

/* ---------- Footer ---------- */
.footer{background:#0A0A0B;color:var(--ink-on-dark);padding:clamp(56px,7vw,88px) 0 40px;border-top:1px solid var(--hairline-dark)}
.footer__grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){.footer__grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer__brand .logo{font-size:1.25rem;margin-bottom:14px;display:inline-block}
.footer__tag{color:var(--ink-on-dark-mute);font-size:.9375rem;max-width:320px;line-height:1.6}
.footer__dpf{margin-top:24px;display:flex;align-items:center;gap:14px}
.footer__dpf img{height:52px;width:auto;opacity:.92}
.footer__dpf span{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-on-dark-mute);max-width:150px;line-height:1.5}
.footer h4{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-on-dark-mute);margin-bottom:18px;font-family:'Inter',sans-serif;font-weight:600}
.footer__list{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer__list a,.footer__list span{color:var(--ink-on-dark);text-decoration:none;font-size:.9375rem;transition:color var(--t-fast) var(--ease)}
.footer__list a:hover{color:var(--accent-green)}
.footer__bottom{margin-top:56px;padding-top:24px;border-top:1px solid var(--hairline-dark);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;color:var(--ink-on-dark-mute);font-size:.8125rem}

/* ---------- Motion ---------- */
.reveal{opacity:0;transform:translateY(20px);animation:fadeUp 900ms var(--ease) forwards}
.reveal--d1{animation-delay:80ms}.reveal--d2{animation-delay:180ms}.reveal--d3{animation-delay:280ms}.reveal--fade{transform:none;animation-name:fadeIn;animation-duration:1400ms;animation-delay:200ms}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}
@keyframes breathe{0%,100%{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}
.io{opacity:0;transform:translateY(24px);transition:opacity 800ms var(--ease),transform 800ms var(--ease)}
.io.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}.reveal,.io{opacity:1;transform:none}}

/* ---------- Blog: index hub ---------- */
.article-grid{display:grid;grid-template-columns:1fr;gap:28px;margin-top:clamp(40px,5vw,56px)}
@media(min-width:680px){.article-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.article-grid{grid-template-columns:repeat(3,1fr)}}
.article-card{display:flex;flex-direction:column;border:1px solid var(--hairline-cream);border-radius:var(--radius);background:#fff;overflow:hidden;text-decoration:none;color:inherit;transition:transform var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}
.article-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(14,14,15,.35)}
.article-card__media{aspect-ratio:16/10;overflow:hidden;background:var(--bg-cream-elev)}
.article-card__media img{width:100%;height:100%;object-fit:cover;transition:transform 600ms var(--ease)}
.article-card:hover .article-card__media img{transform:scale(1.04)}
.article-card__body{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1}
.article-card__cat{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-green);font-weight:600;margin-bottom:12px}
.article-card__title{font-family:'Poppins','Inter',sans-serif;font-weight:600;font-size:1.125rem;line-height:1.3;letter-spacing:-.01em;margin-bottom:10px;color:var(--ink-on-cream)}
.article-card__excerpt{font-size:.9375rem;line-height:1.6;color:var(--ink-on-cream-mute);margin-bottom:18px;flex:1}
.article-card__meta{font-size:.8125rem;color:var(--ink-on-cream-mute);display:flex;gap:10px;align-items:center}
.article-card__meta span{display:inline-flex;align-items:center;gap:6px}
.cluster-note{max-width:720px;margin:clamp(48px,6vw,72px) auto 0;text-align:center;padding:32px 28px;border:1px dashed var(--hairline-cream);border-radius:var(--radius)}
.cluster-note p{color:var(--ink-on-cream-mute);font-size:.9375rem;line-height:1.6}

/* ---------- Blog: single article ---------- */
.article-header{max-width:760px;margin:0 auto;text-align:center}
.article-header .h-display{font-size:clamp(1.875rem,4vw,2.875rem);margin:18px 0 20px}
.article-meta{display:inline-flex;flex-wrap:wrap;gap:8px 18px;justify-content:center;align-items:center;font-size:.8125rem;letter-spacing:.04em;color:var(--ink-on-dark-mute)}
.article-meta span{display:inline-flex;align-items:center;gap:7px}
.article-meta .dot{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.5}
.article-hero-img{max-width:920px;margin:clamp(36px,5vw,56px) auto 0;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9}
.article-hero-img img{width:100%;height:100%;object-fit:cover}
.article-body{max-width:680px;margin:0 auto}
.article-body p{margin-bottom:22px;font-size:1.0625rem;line-height:1.78}
.article-body h2{font-family:'Poppins','Inter',sans-serif;font-weight:600;font-size:clamp(1.375rem,2.4vw,1.75rem);line-height:1.25;letter-spacing:-.015em;margin:clamp(40px,5vw,56px) 0 16px}
.article-body h3{font-family:'Poppins','Inter',sans-serif;font-weight:600;font-size:1.1875rem;margin:32px 0 12px}
.article-body strong{font-weight:600;color:var(--ink-on-dark)}
.section--cream .article-body strong{color:var(--ink-on-cream)}
.article-body a{color:var(--accent-green);text-decoration:none;border-bottom:1px solid rgba(46,229,153,.4);transition:border-color var(--t-fast) var(--ease)}
.article-body a:hover{border-color:var(--accent-green)}
.article-body ul,.article-body ol{margin:0 0 22px;padding-left:24px}
.article-body li{font-size:1.0625rem;line-height:1.7;margin-bottom:10px}
.article-body blockquote{margin:32px 0;padding:8px 0 8px 28px;border-left:2px solid var(--accent-green);font-family:'Fraunces',serif;font-style:italic;font-size:1.25rem;line-height:1.5;color:var(--ink-on-dark)}
.section--cream .article-body blockquote{color:var(--ink-on-cream)}
.article-callout{margin:32px 0;padding:28px 26px;border:1px solid var(--hairline-cream);border-radius:var(--radius);background:var(--bg-cream-elev);color:var(--ink-on-cream)}
.article-callout p{margin-bottom:0;font-size:1rem;color:var(--ink-on-cream)}
.article-callout strong{color:var(--ink-on-cream)}
.article-callout a{color:#1f7a52;border-bottom-color:rgba(31,122,82,.4)}
.article-callout a:hover{border-bottom-color:#1f7a52}
/* Author box */
.author-box{max-width:680px;margin:clamp(48px,6vw,72px) auto 0;display:flex;gap:20px;align-items:flex-start;padding:28px;border:1px solid var(--hairline-dark);border-radius:var(--radius);background:rgba(242,235,221,.02)}
.author-box img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-box__name{font-family:'Poppins',sans-serif;font-weight:600;font-size:1.0625rem;margin-bottom:4px}
.author-box__role{font-size:.8125rem;color:var(--accent-green);letter-spacing:.04em;margin-bottom:12px}
.author-box__bio{font-size:.9375rem;line-height:1.6;color:var(--ink-on-dark-mute)}

/* ---------- 3-step pattern (intro, 1-til-1, etc.) ---------- */
.steps{display:grid;grid-template-columns:1fr;gap:28px;margin-top:clamp(40px,5vw,56px)}
@media(min-width:768px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{position:relative;padding:32px 28px;border:1px solid var(--hairline-cream);border-radius:var(--radius);background:#fff}
.step__num{font-family:'Fraunces',serif;font-style:italic;font-size:1.5rem;color:var(--accent-green);margin-bottom:12px}
.step h3{margin-bottom:8px}
.step p{font-size:.9375rem;color:var(--ink-on-cream-mute)}
.section--dark .step{background:rgba(242,235,221,.02);border-color:var(--hairline-dark)}
.section--dark .step p{color:var(--ink-on-dark-mute)}

/* ---------- Long-form / story page utilities ---------- */
.prose{max-width:720px}
.prose p{margin-bottom:18px;font-size:1.0625rem;line-height:1.75}
.prose p:last-child{margin-bottom:0}
.prose strong{font-weight:600}
.pullquote{max-width:820px;margin:0 auto;text-align:center}
.pullquote p{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:400;font-size:clamp(1.5rem,3vw,2.25rem);line-height:1.25;letter-spacing:-.01em;color:var(--ink-on-dark)}
.pullquote cite{display:block;margin-top:20px;font-style:normal;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-green)}
.arrow-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:24px;max-width:680px}
.arrow-list li{display:flex;gap:14px;align-items:flex-start;font-size:1.0625rem;line-height:1.55}
.arrow-list li::before{content:'➨';color:var(--accent-green);flex-shrink:0;font-size:.9375rem;line-height:1.75;font-weight:700}
.modalities{display:grid;grid-template-columns:1fr;gap:14px;max-width:560px;margin-top:24px}
@media(min-width:640px){.modalities{grid-template-columns:1fr 1fr;gap:14px 28px}}
.modalities li{display:flex;gap:10px;align-items:flex-start;font-size:1rem;line-height:1.5;list-style:none}
.modalities li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent-green);margin-top:9px;flex-shrink:0}
