/* Sabrina Saturno — v20260525
   Editorial refinement: rose reserved, neutral warm dominants,
   premium buttons (Cup of Jo / The Everygirl direction),
   Pinterest Save button overflow fix. */

:root{
  /* Backgrounds — warm neutrals, no pink overload */
  --paper:#fafaf7;
  --surface:#ffffff;
  --surface-warm:#f5f0e8;

  /* Ink — warm near-black to soft taupe */
  --ink:#1a1612;
  --ink-soft:#4a423b;
  --ink-muted:#7a716b;
  --muted:#7a716b; /* alias to ease migration */

  /* Accents — rose reserved for signature moments */
  --rose:#c0164b;
  --rose-light:#f5d0d8;
  --rose-dark:#c0164b; /* alias */
  --sage:#8a9a87;
  --terracotta:#c08960;

  /* Borders */
  --border:#e8e3dc;
  --border-soft:#f0ebe4;
  --line:#e8e3dc; /* alias */

  /* Compat */
  --soft:#f5d0d8;
  --white:#ffffff;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:underline;text-decoration-color:rgba(26,22,18,.22);text-decoration-thickness:.06em;text-underline-offset:.22em;transition:text-decoration-color .25s ease,color .25s ease}
a:hover{text-decoration-color:var(--rose);color:var(--rose)}

.skip-link{position:absolute;left:-999px;top:1rem;background:var(--ink);color:#fff;padding:.7rem 1rem;z-index:10}
.skip-link:focus{left:1rem}

.container{width:min(1180px,calc(100% - 32px));margin-inline:auto}
.narrow{width:min(720px,calc(100% - 32px));margin-inline:auto}

/* Header */
.site-header{position:sticky;top:0;z-index:5;background:rgba(250,250,247,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);box-shadow:0 1px 0 rgba(0,0,0,.02)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.4rem 0}
.brand{display:inline-flex;align-items:center;text-decoration:none}
.brand img{width:120px;height:auto}
.brand:hover{text-decoration:none}

/* Nav — quieter pill, no rose default */
.site-nav{display:flex;gap:.15rem;flex-wrap:wrap;align-items:center;font-size:.88rem;background:transparent;border:none;padding:0}
.site-nav a{padding:.55rem .85rem;border-radius:0;text-decoration:none;line-height:1;color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase;font-size:.78rem;font-weight:600;border-bottom:1.5px solid transparent;transition:border-color .25s ease,color .25s ease}
.site-nav a:hover{color:var(--ink);border-bottom-color:var(--ink)}
.site-nav a[aria-current=page]{color:var(--ink);border-bottom-color:var(--rose)}

/* Hero sections — calmer gradients */
.home-hero{padding:clamp(2.5rem,6vw,6rem) 0 clamp(2rem,4vw,4rem);background:linear-gradient(180deg,var(--surface-warm) 0%,var(--paper) 100%)}
.page-hero,.article-hero{padding:clamp(2.5rem,5vw,5rem) 0 clamp(1.5rem,3vw,3rem)}
.hero-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.home-hero img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:4px;box-shadow:0 24px 64px -16px rgba(26,22,18,.18)}

/* Article image with Pinterest button overflow fix */
.article-image{margin:2rem 0;position:relative;overflow:visible}
.article-image img{width:100%;object-fit:cover;border-radius:4px;box-shadow:0 2px 12px rgba(0,0,0,.06);position:relative;transition:transform .5s ease}
.article-image:hover img{transform:scale(1.005)}
[data-pin-do="buttonHover"]{position:relative}

/* Typography */
h1,h2,h3,h4{font-family:Georgia,"Cormorant Garamond",serif;line-height:1.15;margin:0 0 1rem;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.5vw,4.6rem);font-weight:400}
.article h1{font-size:clamp(2.1rem,4.4vw,3.6rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem);margin-top:2.6rem;font-weight:400}
h3{font-size:1.25rem;margin-top:1.8rem;font-weight:600}
.dek{font-size:clamp(1.08rem,1.7vw,1.3rem);color:var(--ink-soft);max-width:62ch;line-height:1.6}

/* Eyebrow — the only place rose appears by default */
.eyebrow{color:var(--rose);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.74rem;margin:0 0 1rem;display:inline-block}
.eyebrow a{color:var(--rose);text-decoration:none;border-bottom:1px solid transparent}
.eyebrow a:hover{border-bottom-color:var(--rose);color:var(--rose)}

/* Buttons — editorial premium */
.button,.btn-primary{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--surface);
  color:var(--ink);
  border:1.5px solid var(--ink);
  padding:14px 28px;
  margin:.25rem .5rem .25rem 0;
  border-radius:0;
  font-family:inherit;
  font-size:.85rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .35s ease;
  cursor:pointer;
  box-shadow:none;
  line-height:1;
  min-height:auto;
}
.button:hover,.btn-primary:hover{background:var(--ink);color:var(--surface);text-decoration:none}
.button::after,.btn-primary::after{content:"→";transition:transform .35s ease;font-size:1rem;line-height:1}
.button:hover::after,.btn-primary:hover::after{transform:translateX(4px)}

.button-outline,.btn-secondary{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:transparent;
  color:var(--ink);
  border:none;
  border-bottom:1.5px solid var(--ink);
  padding:6px 0;
  border-radius:0;
  font-size:.85rem;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  text-decoration:none;
  transition:color .3s ease,border-color .3s ease;
  box-shadow:none;
}
.button-outline:hover,.btn-secondary:hover{color:var(--rose);border-bottom-color:var(--rose);background:transparent;text-decoration:none}

/* Cards grid */
.grid{display:grid;gap:clamp(1.4rem,2vw,2rem)}
.cards{grid-template-columns:repeat(3,minmax(0,1fr));padding:1.5rem 0 4rem}
.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.02);transition:transform .35s ease,box-shadow .35s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 28px -8px rgba(26,22,18,.10)}
.card img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--surface-warm);transition:transform .6s ease}
.card:hover img{transform:scale(1.02)}
.card>div{padding:1.4rem 1.4rem 1.6rem}
.card h2{font-size:1.18rem;margin:.5rem 0 .6rem;line-height:1.3;font-weight:500}
.card a{text-decoration:none;color:var(--ink)}
.card h2 a:hover{color:var(--rose);text-decoration:none}
.card p{font-size:.94rem;color:var(--ink-soft);line-height:1.55;margin:0}

/* Category strip — neutral background, rose reserved for hover */
.soft-band{background:var(--surface-warm);padding:clamp(2rem,4vw,3.5rem) 0;margin:2rem 0 4rem;border-block:1px solid var(--border-soft)}
.category-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.category-strip a{background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;padding:1.4rem 1.2rem;text-decoration:none;transition:border-color .3s ease,transform .3s ease}
.category-strip a:hover{border-color:var(--ink);transform:translateY(-2px);text-decoration:none}
.category-strip strong{color:var(--ink);font-family:Georgia,serif;font-size:1.15rem;font-weight:400;display:block}
.category-strip span{display:block;color:var(--ink-soft);font-size:.92rem;margin-top:.5rem;line-height:1.5}

/* Article layout */
.article-hero .article-image{width:min(1180px,calc(100% - 32px));margin:2.5rem auto 0}
.article-hero .article-image img{aspect-ratio:16/9}
.byline{color:var(--ink-muted);font-size:.88rem;letter-spacing:.04em;text-transform:uppercase}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:clamp(2rem,4vw,4rem);align-items:start;padding-top:1.5rem}
.article-body{background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;padding:clamp(1.25rem,3.5vw,3rem);margin-bottom:4rem}
.article-body p{max-width:65ch;margin:0 0 1.3rem}
.article-body ul li{margin-bottom:.6rem}

/* Snippet, answer, TOC boxes — neutral, no rose accent */
.answer-box,.toc,.link-panel,.prompts{background:var(--surface-warm);border:1px solid var(--border-soft);border-left:3px solid var(--ink);border-radius:0 4px 4px 0;padding:1.25rem 1.5rem;margin:1.8rem 0}
.toc h2,.answer-box h2{font-size:1.15rem;margin-top:0;font-weight:600;font-family:inherit;text-transform:uppercase;letter-spacing:.08em}
.snippet{border-left:3px solid var(--ink);background:var(--surface-warm);padding:.85rem 1.1rem;margin:1rem 0 1.6rem;font-size:.96rem;color:var(--ink-soft);border-radius:0 4px 4px 0}

.article-image figcaption{font-size:.88rem;color:var(--ink-muted);margin-top:.6rem;font-style:italic}

/* Ad slot — subtler */
.ad-slot{min-height:110px;border:1px dashed var(--border);border-radius:4px;background:var(--surface);display:block;color:var(--ink-muted);font-size:.82rem;margin:2rem 0;padding:.5rem}
.ad-slot:empty:before{content:"Advertisement"}
.adsbygoogle{min-height:90px}

/* AEO table — neutral borders */
.aeo-table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.92rem}
.aeo-table caption{font-weight:600;padding:.5rem 0;text-align:left;color:var(--ink)}
.aeo-table th,.aeo-table td{border:1px solid var(--border-soft);padding:.6rem .85rem;vertical-align:top;text-align:left}
.aeo-table thead{background:var(--surface-warm)}
.aeo-table tbody tr:nth-child(even){background:rgba(245,240,232,.4)}

/* FAQ */
.faq details{border-top:1px solid var(--border-soft);padding:1.1rem 0}
.faq summary{font-weight:600;cursor:pointer;font-family:Georgia,serif;font-size:1.05rem}

/* Sidebar */
.sidebar{position:sticky;top:96px;background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;padding:1.5rem}
.sidebar a{display:block;padding:.85rem 0;border-top:1px solid var(--border-soft);text-decoration:none;color:var(--ink-soft);font-size:.94rem;line-height:1.4;transition:color .25s ease}
.sidebar a:hover{color:var(--rose);text-decoration:none}
.sidebar a:first-of-type{border-top:none}
.sidebar-title{font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.78rem;color:var(--ink-muted);margin:0 0 .5rem}

/* Page content blocks */
.page-content{background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;padding:clamp(1.25rem,3.5vw,2.5rem);margin-bottom:3rem}

/* Contact form */
.contact-form{display:grid;gap:1.1rem;margin-top:1.5rem}
.contact-form label{display:grid;gap:.35rem;font-weight:600;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--border);border-radius:0;padding:.95rem 1rem;font:inherit;background:var(--surface);color:var(--ink);transition:border-color .25s ease}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--ink)}

/* CH1.4 — category and legal enrichments */
.category-intro{padding:clamp(1.5rem,3vw,2.5rem) 16px;border-bottom:1px solid var(--border-soft);margin-bottom:1.5rem}
.category-intro .eyebrow{margin-bottom:.6rem}
.category-intro .dek{font-size:clamp(1rem,1.4vw,1.15rem);color:var(--ink-soft);line-height:1.75}
.legal-intro{padding:.5rem 16px 1rem;font-size:1.02rem;color:var(--ink-soft);line-height:1.75}
.legal-conclusion{background:var(--surface-warm);border-top:1px solid var(--border-soft);padding:clamp(1.5rem,3vw,2.5rem) 16px;margin:2rem 0 3rem}
.legal-conclusion h2{font-size:1.4rem;margin:0 0 .6rem}

/* CH1.5 — more from sabrina + explore */
.more-from-sabrina,.explore-site{padding:clamp(2rem,4vw,3.5rem) 16px;border-top:1px solid var(--border-soft);margin-top:1.5rem}
.more-from-sabrina h2,.explore-site h2{font-size:clamp(1.4rem,2.5vw,2rem);margin-bottom:.8rem}
.more-from-sabrina .dek{margin-bottom:1.5rem}
.more-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.more-grid a{display:flex;flex-direction:column;gap:.3rem;background:var(--surface);border:1px solid var(--border-soft);padding:1rem 1.25rem;text-decoration:none;transition:border-color .25s ease,transform .25s ease}
.more-grid a:hover{border-color:var(--ink);transform:translateY(-1px);text-decoration:none}
.more-grid strong{color:var(--ink);font-family:Georgia,serif;font-weight:400;font-size:1.05rem;line-height:1.35}
.more-tag{color:var(--rose);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700}

/* Footer — terracotta accent instead of rose */
.site-footer{background:#0d0a08;color:var(--paper);padding:2rem 0 1.5rem;margin-top:3rem;border-top:2px solid var(--terracotta)}
.footer-grid{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:center}
.footer-logo{width:96px;height:auto;margin-bottom:.25rem;filter:brightness(0) invert(1)}
.site-footer p{margin:.25rem 0 0;max-width:44ch;font-size:.88rem;color:rgba(250,250,247,.78);line-height:1.55}
.footer-right{display:grid;gap:.85rem;justify-items:end}
.footer-links{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}
.footer-links a{color:var(--paper);text-decoration:none;border:1px solid rgba(255,255,255,.14);padding:.4rem .7rem;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500;transition:border-color .3s ease,color .3s ease}
.footer-links a:hover{border-color:var(--terracotta);color:#fff;text-decoration:none}
.footer-social{display:flex;justify-content:flex-end}
.social-icon{width:40px;height:40px;border-radius:0;background:transparent;border:1.5px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center;color:var(--paper);text-decoration:none;transition:all .3s ease}
.social-icon svg{width:18px;height:18px;fill:currentColor}
.social-icon:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff;text-decoration:none}

/* Responsive */
@media (max-width:920px){
  .hero-grid,.article-layout,.footer-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .category-strip{grid-template-columns:1fr 1fr}
  .sidebar{position:static}
  .header-inner{align-items:flex-start;flex-direction:column;gap:.5rem}
  .brand img{width:108px}
  .site-nav{margin-top:.25rem}
  .footer-right,.footer-links,.footer-social{justify-items:start;justify-content:flex-start}
  .article-body{border-left:0;border-right:0;border-radius:0;width:calc(100% + 32px);margin-left:-16px;padding-left:16px;padding-right:16px}
  .more-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .cards,.category-strip{grid-template-columns:1fr}
  h1{font-size:2.4rem}
  .article h1{font-size:2.1rem}
  .site-nav{font-size:.75rem}
  .site-nav a{padding:.4rem .55rem}
  .home-hero,.page-hero,.article-hero{padding-top:2rem}
  .article-body li{margin-bottom:.5rem}
  .footer-logo{width:88px}
  .button,.btn-primary{padding:12px 22px;font-size:.78rem}
}

/* v8 additions — 2026-05-25 */
/* CH3 — Related articles ("You may also love") */
.related-articles{margin:3rem 0 2rem;padding:0;border-top:1px solid var(--border-soft);padding-top:2rem}
.related-articles h2{font-size:clamp(1.5rem,2.5vw,2.1rem);margin:0 0 1.5rem;font-weight:400}
.related-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.1rem}
.related-card{display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:var(--ink);background:var(--surface);border:1px solid var(--border-soft);padding:.85rem;transition:border-color .3s ease,transform .3s ease}
.related-card:hover{border-color:var(--ink);transform:translateY(-2px);text-decoration:none}
.related-card img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:0;background:var(--surface-warm)}
.related-card .related-eyebrow{color:var(--rose);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-top:.3rem}
.related-card h3{font-size:.95rem;line-height:1.32;margin:.1rem 0 0;font-family:Georgia,serif;font-weight:400;color:var(--ink)}
.related-card:hover h3{color:var(--rose)}

/* CH2 — JS-email placeholder span styling (looks like a link until JS runs) */
.js-email{color:var(--ink);border-bottom:1px solid rgba(26,22,18,.3);cursor:default;font-style:italic;font-size:.96em}

@media (max-width:920px){
  .related-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .related-grid{grid-template-columns:1fr}
}
