/* That Famous Decor Studio — Design System v2
   Palette: warm cream + desaturated coral + deep forest
   Fonts: Fraunces (display) + Inter (body)
   Photo strategy: gradient placeholders with rounded corners (real photos later)
*/

:root{
  /* Palette v2 */
  --c-cream:#FAF4EC;
  --c-cream-2:#F3EADC;
  --c-cream-3:#E8DAC4;
  --c-ink:#1B1916;
  --c-ink-2:#3A3530;
  --c-ink-soft:#6D635A;
  --c-coral:#E85A3C;
  --c-coral-dark:#C8462A;
  --c-coral-soft:#FCEAE2;
  --c-forest:#2D5F4E;
  --c-forest-light:#5A8474;
  --c-forest-soft:#E1ECE7;
  --c-line:#E0D3BC;
  --c-line-soft:#EFE5D2;
  --c-white:#FFFFFF;

  /* Gradient palettes for photo placeholders (each SKU/event variant) */
  --grad-birthday: linear-gradient(135deg, #FFD8C2 0%, #FFA887 45%, #E85A3C 100%);
  --grad-baby-shower: linear-gradient(135deg, #F4E4F0 0%, #E0BCD8 50%, #B891B0 100%);
  --grad-gender-reveal: linear-gradient(135deg, #FFF5E0 0%, #E8DAC4 50%, #A8987F 100%);
  --grad-anniversary: linear-gradient(135deg, #F5D5C8 0%, #C97366 50%, #7A2E22 100%);
  --grad-proposal: linear-gradient(135deg, #FFE0DC 0%, #E85A3C 50%, #8A1F0A 100%);
  --grad-bridal: linear-gradient(135deg, #FFF6F0 0%, #F5D5C8 50%, #D2A48F 100%);
  --grad-graduation: linear-gradient(135deg, #FFEACD 0%, #D4A574 50%, #6B4423 100%);
  --grad-corporate: linear-gradient(135deg, #E1ECE7 0%, #5A8474 50%, #1F3B30 100%);
  --grad-blog: linear-gradient(135deg, #FAF4EC 0%, #F3EADC 50%, #E0D3BC 100%);
  --grad-location: linear-gradient(135deg, #E1ECE7 0%, #C5DCD3 50%, #5A8474 100%);
  --grad-hero: linear-gradient(135deg, #FFD8C2 0%, #FFA887 35%, #E85A3C 65%, #2D5F4E 100%);

  /* Layout tokens */
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px;
  --shadow-1:0 2px 12px rgba(27,25,22,0.06);
  --shadow-2:0 14px 44px rgba(27,25,22,0.14);
  --shadow-3:0 24px 60px rgba(27,25,22,0.20);
  --max:1180px;
  --pad:clamp(18px,4vw,40px);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--c-cream);color:var(--c-ink);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","ss02","cv11";
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--c-coral-dark);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--c-coral);text-decoration:underline}
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:8px;top:8px;background:var(--c-ink);color:#fff;padding:8px 12px;border-radius:var(--r-sm);z-index:9999}
.container{max-width:var(--max);margin:0 auto;padding-inline:var(--pad)}

/* Typography — Fraunces display + Inter body */
h1,h2,h3,h4{
  font-family:'Fraunces','Georgia',serif;
  font-weight:600;
  letter-spacing:-0.012em;
  color:var(--c-ink);
  margin:0 0 .5em;
  font-feature-settings:"ss01";
  font-variation-settings:"opsz" 144, "SOFT" 50;
}
h1{font-size:clamp(2.1rem,5.2vw,3.6rem);line-height:1.05;letter-spacing:-0.02em;font-weight:600}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem);line-height:1.15;font-weight:600}
h3{font-size:clamp(1.15rem,2.2vw,1.45rem);font-weight:600;font-variation-settings:"opsz" 36}
h4{font-size:1.05rem;font-weight:600;font-variation-settings:"opsz" 14}
p{margin:0 0 1em}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:999px;font-weight:600;
  border:1px solid transparent;cursor:pointer;text-align:center;
  font-family:inherit;font-size:.97rem;letter-spacing:.005em;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.btn-primary{background:var(--c-coral);color:#fff;box-shadow:var(--shadow-1)}
.btn-primary:hover{background:var(--c-coral-dark);text-decoration:none;transform:translateY(-1px);box-shadow:var(--shadow-2);color:#fff}
.btn-ghost{background:transparent;color:var(--c-ink);border-color:var(--c-line)}
.btn-ghost:hover{background:var(--c-white);text-decoration:none;border-color:var(--c-ink)}
.btn-forest{background:var(--c-forest);color:#fff}
.btn-forest:hover{background:var(--c-forest-light);color:#fff;text-decoration:none}
.btn-small{padding:9px 16px;font-size:.85rem}

/* Header */
.site-header{
  position:sticky;top:0;
  background:rgba(250,244,236,.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  z-index:50;border-bottom:1px solid var(--c-line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:16px}
.brand{display:flex;align-items:center;gap:12px;color:var(--c-ink);font-family:'Fraunces',serif;font-weight:600}
.brand:hover{text-decoration:none;color:var(--c-ink)}
.brand-mark{
  display:inline-grid;place-items:center;width:44px;height:44px;
  border-radius:50%;background:var(--c-coral);color:#fff;
  font-size:13px;letter-spacing:.06em;font-family:'Inter',sans-serif;font-weight:700;
}
.brand-name{font-size:15px;line-height:1.1;letter-spacing:-0.01em}
.brand-name em{font-style:italic;color:var(--c-forest);font-weight:500}
.nav{display:flex;align-items:center;gap:30px}
.nav a{color:var(--c-ink);font-weight:500;font-size:.95rem}
.nav a:hover{color:var(--c-coral-dark);text-decoration:none}
.nav-cta{padding:10px 20px;border-radius:999px;background:var(--c-ink);color:#fff!important;font-size:.9rem}
.nav-cta:hover{background:var(--c-coral)}
.nav-toggle{display:none;width:42px;height:42px;background:transparent;border:0;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:8px}
.nav-toggle span{display:block;height:2px;background:var(--c-ink);border-radius:2px;transition:transform .2s}
.mobile-nav{display:none;flex-direction:column;border-top:1px solid var(--c-line);background:var(--c-white)}
.mobile-nav a{display:block;padding:15px var(--pad);border-bottom:1px solid var(--c-line);color:var(--c-ink);font-weight:500}
.mobile-nav .nav-cta{background:var(--c-coral);color:#fff!important;text-align:center}
@media (max-width:860px){
  .nav{display:none}
  .nav-toggle{display:flex}
  .mobile-nav[data-open="true"]{display:flex}
}

/* Hero — split layout (image 55% + content 45%) */
.hero{padding:clamp(40px,7vw,80px) 0 clamp(36px,5vw,60px);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.18fr .82fr;gap:clamp(36px,6vw,80px);align-items:center}
@media (max-width:920px){.hero-grid{grid-template-columns:1fr;gap:clamp(28px,5vw,44px)}}
.hero-eyebrow{
  display:inline-block;padding:6px 16px;border-radius:999px;
  background:var(--c-forest-soft);color:var(--c-forest);
  font-size:.78rem;font-weight:600;margin-bottom:20px;letter-spacing:.03em;
  text-transform:uppercase;font-family:'Inter',sans-serif;
}
.hero h1{margin-bottom:20px}
.hero-sub{font-size:clamp(1.08rem,1.7vw,1.25rem);color:var(--c-ink-2);max-width:34em;margin-bottom:30px;line-height:1.55}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px}
.hero-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.hero-chip{
  display:inline-block;padding:8px 14px;border-radius:999px;
  background:var(--c-white);border:1px solid var(--c-line);
  font-size:.85rem;font-weight:600;color:var(--c-ink);
  text-decoration:none;transition:all .15s;
}
.hero-chip:hover{border-color:var(--c-coral);color:var(--c-coral-dark);text-decoration:none}
.hero-chip strong{color:var(--c-coral-dark)}
.hero-meta{margin-top:20px;display:flex;flex-wrap:wrap;gap:22px;font-size:.88rem;color:var(--c-ink-soft)}
.hero-meta span strong{color:var(--c-ink);font-weight:600}
.hero-meta a{color:var(--c-ink);text-decoration:underline;text-decoration-color:var(--c-line)}
.hero-visual{
  aspect-ratio:5/6;border-radius:var(--r-xl);
  background:var(--grad-hero);
  position:relative;box-shadow:var(--shadow-2);
  overflow:hidden;
}
.hero-visual::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 28% 24%, rgba(255,255,255,.42), transparent 55%);
}
.hero-visual::before{
  content:'';position:absolute;inset:auto 8% 8% auto;width:48%;aspect-ratio:1;
  border-radius:50%;background:radial-gradient(circle, rgba(255,255,255,.28), transparent 70%);
}

/* Trust strip */
.trust-strip{
  background:var(--c-cream-2);border-top:1px solid var(--c-line-soft);border-bottom:1px solid var(--c-line-soft);
  padding:18px 0;font-size:.86rem;color:var(--c-ink-soft);
}
.trust-strip-inner{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;align-items:center;text-align:center}
.trust-strip-inner span{display:inline-flex;align-items:center;gap:8px}
.trust-strip-inner strong{color:var(--c-ink);font-weight:600}

/* Sections */
section{padding:clamp(48px,7vw,88px) 0}
.section-eyebrow{
  font-size:.78rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--c-forest);margin-bottom:14px;display:inline-block;
  font-family:'Inter',sans-serif;
}
.section-head{margin-bottom:clamp(28px,4vw,44px);max-width:48em}

/* Package / Product cards — square photos, price chip, single CTA */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.pkg-card{
  background:var(--c-white);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--c-line-soft);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  display:flex;flex-direction:column;position:relative;
}
.pkg-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:var(--c-line)}
.pkg-img{
  aspect-ratio:1;background:var(--grad-birthday);
  border-radius:var(--r-md);margin:14px 14px 0;position:relative;overflow:hidden;
}
.pkg-img::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.32), transparent 55%);
}
/* SKU-specific gradients */
.pkg-img[data-sku="birthday"]{background:var(--grad-birthday)}
.pkg-img[data-sku="baby-shower"]{background:var(--grad-baby-shower)}
.pkg-img[data-sku="gender-reveal"]{background:var(--grad-gender-reveal)}
.pkg-img[data-sku="anniversary"]{background:var(--grad-anniversary)}
.pkg-img[data-sku="proposal"]{background:var(--grad-proposal)}
.pkg-img[data-sku="bridal-shower"]{background:var(--grad-bridal)}
.pkg-img[data-sku="graduation"]{background:var(--grad-graduation)}
.pkg-img[data-sku="corporate"]{background:var(--grad-corporate)}
.pkg-img[data-kind="blog"]{background:var(--grad-blog);aspect-ratio:5/3}
.pkg-img[data-kind="location"]{background:var(--grad-location)}
.pkg-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.pkg-meta{font-size:.78rem;color:var(--c-ink-soft);margin:0;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.pkg-name{
  font-family:'Fraunces',serif;font-size:1.18rem;font-weight:600;margin:0;
  letter-spacing:-0.01em;
}
.pkg-desc{color:var(--c-ink-soft);font-size:.94rem;flex:1;line-height:1.55}
.pkg-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-top:4px}
.pkg-price{
  font-family:'Fraunces',serif;font-size:1.45rem;font-weight:600;color:var(--c-ink);
}
.pkg-price small{font-size:.7em;color:var(--c-ink-soft);font-weight:500;font-family:'Inter',sans-serif;letter-spacing:.02em}
.pkg-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;border-radius:999px;background:var(--c-ink);color:#fff;
  font-weight:600;font-size:.86rem;text-decoration:none;
  transition:background .15s;
}
.pkg-cta:hover{background:var(--c-coral);color:#fff;text-decoration:none}
.pkg-pin{
  position:absolute;top:18px;right:18px;
  background:var(--c-forest);color:#fff;padding:5px 11px;border-radius:999px;
  font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;z-index:2;
}

/* Steps / process */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:24px;counter-reset:step;list-style:none;padding:0}
.step{padding:26px 24px 22px;background:var(--c-white);border-radius:var(--r-lg);border:1px solid var(--c-line-soft);position:relative}
.step::before{
  counter-increment:step;content:counter(step);
  position:absolute;top:-14px;left:24px;background:var(--c-coral);color:#fff;
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  font-weight:700;font-size:.85rem;font-family:'Inter',sans-serif;box-shadow:var(--shadow-1);
}
.step h3{margin-top:8px;font-size:1.12rem;margin-bottom:6px}
.step p{color:var(--c-ink-soft);font-size:.94rem;margin:0;line-height:1.55}

/* Why / value props */
.why{background:var(--c-cream-2)}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px}
.why-item h3{font-size:1.1rem;color:var(--c-ink)}
.why-item p{color:var(--c-ink-soft);font-size:.94rem;margin:0;line-height:1.6}
.why-item-icon{
  display:inline-grid;place-items:center;width:42px;height:42px;
  border-radius:12px;background:var(--c-forest-soft);color:var(--c-forest);
  margin-bottom:14px;font-size:1.05rem;font-weight:700;
}

/* Pricing table */
.price-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:var(--c-white);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-1);border:1px solid var(--c-line-soft);
}
.price-table th,.price-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--c-line-soft)}
.price-table th{
  background:var(--c-cream-2);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.06em;color:var(--c-ink-2);font-weight:600;
}
.price-table tr:last-child td{border-bottom:0}
.price-table tbody tr:hover{background:var(--c-cream)}
.price-table .price-cell{font-weight:700;color:var(--c-ink);white-space:nowrap;font-family:'Fraunces',serif}
.price-table a{color:var(--c-coral-dark);font-weight:600}

/* CTA banner */
.cta{background:var(--c-ink);color:#fff;text-align:center}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:rgba(255,255,255,.82);max-width:40em;margin-inline:auto;margin-bottom:28px}
.cta p a{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.4)}
.cta p a:hover{text-decoration-color:#fff}
.cta .btn-primary{background:var(--c-coral)}
.cta .btn-primary:hover{background:var(--c-coral-dark)}

/* Forms */
.form{display:grid;gap:18px;max-width:580px}
.form label{display:block;font-weight:600;font-size:.88rem;margin-bottom:6px;color:var(--c-ink-2)}
.form input,.form select,.form textarea{
  width:100%;padding:13px 15px;border:1px solid var(--c-line);border-radius:var(--r-sm);
  font:inherit;background:var(--c-white);color:var(--c-ink);
  transition:border-color .15s, box-shadow .15s;
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:var(--c-coral);box-shadow:0 0 0 3px var(--c-coral-soft);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}

/* Breadcrumbs */
.crumbs{font-size:.85rem;color:var(--c-ink-soft);margin-bottom:18px}
.crumbs a{color:var(--c-ink-soft)}
.crumbs a:hover{color:var(--c-coral-dark)}
.crumbs span[aria-current]{color:var(--c-ink);font-weight:600}

/* SKU detail page layout */
.sku-detail-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
@media (max-width:920px){.sku-detail-grid{grid-template-columns:1fr;gap:32px}}
.sku-visual{
  aspect-ratio:4/5;border-radius:var(--r-xl);position:relative;overflow:hidden;
  box-shadow:var(--shadow-2);
}
.sku-visual[data-sku="birthday"]{background:var(--grad-birthday)}
.sku-visual[data-sku="baby-shower"]{background:var(--grad-baby-shower)}
.sku-visual[data-sku="gender-reveal"]{background:var(--grad-gender-reveal)}
.sku-visual[data-sku="anniversary"]{background:var(--grad-anniversary)}
.sku-visual[data-sku="proposal"]{background:var(--grad-proposal)}
.sku-visual[data-sku="bridal-shower"]{background:var(--grad-bridal)}
.sku-visual[data-sku="graduation"]{background:var(--grad-graduation)}
.sku-visual[data-sku="corporate"]{background:var(--grad-corporate)}
.sku-visual::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 28% 28%,rgba(255,255,255,.4),transparent 60%)}
.sku-price-hero{
  display:flex;align-items:baseline;gap:14px;margin:24px 0;padding:18px 22px;
  background:var(--c-white);border:1px solid var(--c-line-soft);border-radius:var(--r-lg);
}
.sku-price-hero .price{font-family:'Fraunces',serif;font-size:2.6rem;font-weight:600;color:var(--c-ink);line-height:1}
.sku-price-hero .label{color:var(--c-ink-soft);font-size:.92rem}

/* Sticky mobile CTA */
.sticky-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:var(--c-white);border-top:1px solid var(--c-line);padding:12px 16px;
  z-index:40;box-shadow:0 -4px 20px rgba(27,25,22,.08);
}
.sticky-cta .price-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.sticky-cta .price{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;color:var(--c-ink)}
.sticky-cta .btn-primary{padding:12px 22px;font-size:.92rem}
@media (max-width:768px){.sticky-cta{display:block}.has-sticky-cta main{padding-bottom:80px}}

/* Palette swatches */
.palette-row{display:flex;flex-wrap:wrap;gap:18px;margin:20px 0}
.palette-card{
  flex:1 1 200px;padding:18px;border-radius:var(--r-md);
  background:var(--c-white);border:1px solid var(--c-line-soft);
}
.palette-swatches{display:flex;gap:4px;margin-bottom:12px}
.palette-swatch{width:30px;height:30px;border-radius:50%;border:2px solid var(--c-white);box-shadow:0 0 0 1px var(--c-line-soft)}
.palette-card h4{font-size:.96rem;margin:0 0 4px;font-family:'Inter',sans-serif;font-weight:600}
.palette-card p{font-size:.84rem;color:var(--c-ink-soft);margin:0;line-height:1.45}

/* FAQ details */
details.faq-item{
  border:1px solid var(--c-line-soft);border-radius:var(--r-md);padding:18px 22px;
  background:var(--c-white);transition:box-shadow .15s, border-color .15s;
}
details.faq-item[open]{box-shadow:var(--shadow-1);border-color:var(--c-line)}
details.faq-item summary{
  font-weight:600;cursor:pointer;list-style:none;font-size:1.02rem;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
}
details.faq-item summary::after{
  content:'+';font-size:1.4rem;color:var(--c-coral);font-weight:300;
  transition:transform .2s;width:24px;height:24px;display:grid;place-items:center;
}
details.faq-item[open] summary::after{transform:rotate(45deg)}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item p{margin:12px 0 0;color:var(--c-ink-soft);line-height:1.65}

/* IG embed placeholder grid */
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:24px}
@media (max-width:560px){.ig-grid{grid-template-columns:repeat(2,1fr)}}
.ig-tile{
  aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;
  background:var(--grad-birthday);position:relative;
}
.ig-tile::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.32),transparent 60%)}

/* Footer */
.site-footer{background:var(--c-white);border-top:1px solid var(--c-line);padding:56px 0 28px;margin-top:64px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand{font-family:'Fraunces',serif;font-weight:600;font-size:1.18rem;margin-bottom:8px}
.footer-tag{font-size:.92rem;color:var(--c-ink-soft);margin-bottom:8px;line-height:1.55}
.footer-ig a{font-weight:600;color:var(--c-coral-dark)}
.footer-col h2{
  font-family:'Inter',sans-serif;font-size:.78rem;text-transform:uppercase;
  letter-spacing:.08em;color:var(--c-ink-soft);font-weight:600;margin-bottom:14px;
}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.footer-col a{color:var(--c-ink);font-size:.94rem}
.footer-col a:hover{color:var(--c-coral-dark)}
.footer-base{margin-top:36px;padding-top:24px;border-top:1px solid var(--c-line-soft);font-size:.85rem;color:var(--c-ink-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* Utility */
.text-center{text-align:center}
.muted{color:var(--c-ink-soft)}
.lead{font-size:1.1rem;line-height:1.65;color:var(--c-ink-2);max-width:38em}
.divider{border:0;border-top:1px solid var(--c-line-soft);margin:48px 0}
.tag-chip{display:inline-block;padding:4px 10px;border-radius:999px;background:var(--c-forest-soft);color:var(--c-forest);font-size:.74rem;font-weight:600;letter-spacing:.03em}

/* Post body (blog) */
.post-body{line-height:1.85;font-size:1.05rem;color:var(--c-ink-2)}
.post-body h2{margin-top:44px;font-size:1.55rem;color:var(--c-ink)}
.post-body h3{margin-top:30px;color:var(--c-ink)}
.post-body ul,.post-body ol{padding-left:26px;margin:12px 0 20px}
.post-body li{margin-bottom:10px}
.post-body p{margin-bottom:1.3em}
.post-body a{color:var(--c-coral-dark);font-weight:500;text-decoration:underline;text-decoration-color:var(--c-coral-soft);text-underline-offset:3px}
.post-body a:hover{text-decoration-color:var(--c-coral)}
.post-body table{width:100%;border-collapse:separate;border-spacing:0;margin:24px 0;background:var(--c-white);border-radius:var(--r-md);overflow:hidden;border:1px solid var(--c-line-soft)}
.post-body table th,.post-body table td{padding:12px 16px;border-bottom:1px solid var(--c-line-soft);text-align:left}
.post-body table th{background:var(--c-cream-2);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600;color:var(--c-ink-2);font-family:'Inter',sans-serif}
.post-body table tr:last-child td{border-bottom:0}
.post-body blockquote{border-left:3px solid var(--c-coral);padding:8px 18px;color:var(--c-ink-2);font-style:italic;margin:20px 0;background:var(--c-cream-2);border-radius:var(--r-sm)}
.post-body code{background:var(--c-cream-2);padding:2px 6px;border-radius:4px;font-size:.92em}
.post-meta{font-size:.88rem;color:var(--c-ink-soft);margin-bottom:8px}
.post-meta strong{color:var(--c-ink);font-weight:600}

/* Cards / panels */
.panel{background:var(--c-white);border:1px solid var(--c-line-soft);border-radius:var(--r-lg);padding:28px}
.panel-forest{background:var(--c-forest-soft);border-color:var(--c-forest-light)}
.panel-cream{background:var(--c-cream-2);border-color:var(--c-line)}
.panel-coral{background:var(--c-coral-soft);border-color:var(--c-coral)}

/* Aside sticky on SKU page */
.sku-aside{position:sticky;top:96px;padding:24px;background:var(--c-white);border-radius:var(--r-lg);border:1px solid var(--c-line-soft);box-shadow:var(--shadow-1)}
.sku-aside-visual{aspect-ratio:1;border-radius:var(--r-md);margin-bottom:18px;position:relative;overflow:hidden}
.sku-aside ul{list-style:none;padding:0;margin:0;display:grid;gap:9px;font-size:.94rem}
.sku-aside li{display:flex;gap:8px;align-items:flex-start}
.sku-aside li::before{content:'✓';color:var(--c-forest);font-weight:700;flex:0 0 14px}
@media (max-width:920px){.sku-aside{position:static}}

/* Responsive image-text grid */
.split-2{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
@media (max-width:760px){.split-2{grid-template-columns:1fr}}

/* Accessibility focus ring */
*:focus-visible{outline:2px solid var(--c-coral);outline-offset:2px;border-radius:4px}

/* Print */
@media print{
  .site-header,.site-footer,.cta,.sticky-cta{display:none}
  body{background:#fff}
}
