/* =============================================================
   Styli Casa — main.css
   Design tokens come in as CSS custom properties on :root,
   injected by inc/customizer/customizer-output.php (with the
   defaults below as a fallback so the theme looks right even
   before a single Customizer change).
   ============================================================= */

:root {
  --sc-bg: #FAF7F2;
  --sc-content: #FFFFFF;
  --sc-text: #332F2A;
  --sc-muted: #6F6A63;
  --sc-head: #1A1714;
  --sc-accent: #A67C52;
  --sc-accent2: #D8C3A5;
  --sc-border: #E8DED2;
  --sc-link: #A67C52;
  --sc-link-hover: #7D5D3B;
  --sc-btn-bg: #A67C52;
  --sc-btn-text: #FFFFFF;
  --sc-btn-hover-bg: #7D5D3B;
  --sc-btn-hover-text: #FFFFFF;
  --sc-header-bg: #FFFFFF;
  --sc-footer-bg: #F1E8DD;
  --sc-footer-text: #6F6A63;
  --sc-footer-head: #1A1714;

  --sc-font-body: 'Poppins', system-ui, sans-serif;
  --sc-font-head: 'Playfair Display', Georgia, serif;
  --sc-body-size: 17px;
  --sc-body-lh: 1.7;
  --sc-h1: 42px;
  --sc-h2: 34px;
  --sc-h3: 26px;

  --sc-container: 1200px;
  --sc-content-w: 800px;
  --sc-radius: 6px;
  --sc-img-radius: 6px;
  --sc-card-radius: 8px;
  --sc-card-ratio: 3 / 2;
  --sc-btn-radius: 3px;

  --sc-listicle-number: #A67C52;
  --sc-listicle-total: #6F6A63;
  --sc-listicle-divider: #E1D7CC;
  --sc-listicle-heading: #1A1714;
  --sc-listicle-number-size: 34px;
  --sc-listicle-heading-size: 42px;
  --sc-listicle-number-weight: 500;
  --sc-listicle-heading-weight: 700;
  --sc-listicle-total-size: 13px;
}

/* ---------- Reset & base ---------- */
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--sc-bg);
  color: var(--sc-text);
  font-family: var(--sc-font-body);
  font-size: var(--sc-body-size);
  line-height: var(--sc-body-lh);
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 { font-family: var(--sc-font-head); color: var(--sc-head); margin: 0 0 .5em; line-height: 1.18; }
h1 { font-size: var(--sc-h1); font-weight: 700; }
h2 { font-size: var(--sc-h2); font-weight: 700; }
h3 { font-size: var(--sc-h3); font-weight: 600; }
p { margin: 0 0 1.4em; }
a { color: var(--sc-link); text-decoration: none; transition: color .2s; }
a:hover { color: var(--sc-link-hover); }
img { max-width: 100%; height: auto; display: block; }
::selection { background: var(--sc-accent2); }

/* ============================================================
   Overflow hardening — the real fix for mobile "content cut off".
   Grid `1fr` tracks and flex/grid items default to a min size of
   their CONTENT (min-width:auto). An image reports its full
   intrinsic width as that minimum, so a column refuses to shrink
   and the layout blows past the viewport. Two rules cure it:
     1) size tracks with minmax(0, …) (see grid definitions below)
     2) let every grid/flex item shrink with min-width: 0
   ============================================================ */
html, body { max-width: 100%; overflow-x: hidden; }
/* The off-canvas panel is parked off-screen with translateX(100%); clip it on
   the site wrapper so it never widens the page. `clip` keeps the sticky header
   working (unlike `hidden`, which would create a scroll container). */
.sc-site { overflow-x: clip; }
.sc-site, .sc-site-main, .sc-front, .sc-section, .sc-hero, .sc-newsletter, .sc-cta { max-width: 100%; }
img, svg, video, iframe, embed, object, table { max-width: 100%; }

/* Allow grid/flex containers and their children to shrink below content size */
.sc-grid, .sc-hero__grid, .sc-hero__side, .sc-guide, .sc-with-sidebar, .sc-article-body,
.sc-latest-wrap, .sc-editors__grid, .styli-products__grid, .shop-the-look-box .grid,
.image-grid, .styli-before-after .grid, .styli-two-images, .styli-proscons, .styli-stats,
.sc-roomnav, .sc-cats, .sc-footer__cols { min-width: 0; }
.sc-grid > *, .sc-hero__grid > *, .sc-hero__side > *, .sc-guide > *, .sc-with-sidebar > *,
.sc-article-body > *, .sc-latest-wrap > *, .sc-editors__grid > *, .styli-idea-heading > *,
.sc-card, .sc-latest-main, .sc-trending, .sc-primary, .sc-sidebar, .sc-prose, .sc-toc,
.sc-authorhome, .sc-authorhome > * { min-width: 0; }

/* Word-wrapping so long titles/URLs never force a wide line box */
.sc-prose, .sc-card__title, .sc-section__title, .styli-idea-heading h3,
h1, h2, h3, h4, p, li, a, .sc-trending__body h3 { overflow-wrap: break-word; word-wrap: break-word; }
.sc-prose { word-break: break-word; }

/* Media inside article content must never exceed its column */
.sc-prose > *, .entry-content > * { max-width: 100%; }
.sc-prose img, .sc-prose figure, .sc-prose iframe, .sc-prose video,
.sc-prose .alignfull, .sc-prose .alignwide { max-width: 100%; height: auto; }
.sc-prose figure img { width: 100%; }

.sc-container { max-width: var(--sc-container); margin: 0 auto; padding: 0 32px; }
.sc-eyebrow { font-size: 12px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--sc-accent); }
.sc-cat-label { font-size: 11px; font-weight: 600; letter-spacing: 1.8px; text-transform: uppercase; color: var(--sc-accent); }
.screen-reader-text { position: absolute !important; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--sc-accent); color: #fff; padding: 12px 20px; z-index: 200; }
.skip-link:focus { left: 8px; top: 8px; color: #fff; }

/* ---------- Buttons ---------- */
.sc-btn {
  display: inline-block; cursor: pointer;
  font-family: var(--sc-font-body); font-size: 13px; font-weight: 600; letter-spacing: .8px; text-transform: uppercase;
  background: var(--sc-btn-bg); color: var(--sc-btn-text);
  padding: 14px 30px; border: 1.5px solid var(--sc-btn-bg); border-radius: var(--sc-btn-radius);
  transition: background .2s, color .2s, border-color .2s;
}
.sc-btn:hover { background: var(--sc-btn-hover-bg); border-color: var(--sc-btn-hover-bg); color: var(--sc-btn-hover-text); }
.button-style-outline .sc-btn,
.sc-btn.is-outline { background: transparent; color: var(--sc-btn-bg); }
.button-style-outline .sc-btn:hover,
.sc-btn.is-outline:hover { background: var(--sc-btn-bg); color: var(--sc-btn-text); }

/* ---------- Top bar ---------- */
.sc-topbar { background: var(--sc-topbar-bg, var(--sc-content)); border-bottom: 1px solid var(--sc-border); }
.sc-topbar .sc-container { height: 42px; display: flex; align-items: center; justify-content: space-between; font-size: 12.5px; color: var(--sc-topbar-text, var(--sc-muted)); }
.sc-topbar__tag { font-family: var(--sc-font-head); font-style: italic; font-size: 14px; color: var(--sc-head); }
.sc-topbar__links { display: flex; align-items: center; gap: 20px; }
.sc-topbar__links a { color: var(--sc-muted); }
.sc-topbar__links a:hover { color: var(--sc-accent); }

/* ---------- Header ---------- */
.sc-site-header { background: var(--sc-header-bg); border-bottom: 1px solid var(--sc-border); }
.sc-site-header.is-sticky { position: sticky; top: 0; z-index: 50; transition: box-shadow .3s; }
.sc-site-header.is-scrolled { box-shadow: 0 6px 24px rgba(40,30,20,.07); }
.sc-header-inner { height: 84px; display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.sc-branding { display: flex; align-items: center; gap: 13px; flex-shrink: 0; }
.sc-mark { width: 40px; height: 40px; border: 1.5px solid var(--sc-accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--sc-font-head); font-size: 19px; font-weight: 700; color: var(--sc-accent); }
.sc-site-title { font-family: var(--sc-font-head); font-size: 25px; font-weight: 700; letter-spacing: .5px; color: var(--sc-head); line-height: 1; }
.sc-site-title a { color: inherit; }
.sc-tagline { display: block; font-size: 10.5px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sc-muted); margin-top: 3px; }
.sc-custom-logo-link img { max-height: 56px; width: auto; }

/* header layout variants */
.header-centered .sc-header-inner { flex-direction: column; height: auto; padding: 18px 0 0; gap: 12px; }
.header-centered .sc-actions { position: absolute; right: 32px; top: 22px; }
.header-magazine .sc-header-inner { flex-direction: column; height: auto; padding: 16px 0 0; gap: 10px; }

/* ---------- Navigation ---------- */
.sc-nav ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 30px; }
.sc-nav { font-size: 14px; font-weight: 500; letter-spacing: .4px; }
.sc-nav a { color: var(--sc-text); white-space: nowrap; padding: 6px 0; display: inline-block; }
.sc-nav a:hover, .sc-nav .current-menu-item > a, .sc-nav .current_page_item > a { color: var(--sc-accent); }
.sc-nav .menu-item-has-children { position: relative; }
.sc-nav .menu-item-has-children > a::after { content: '▾'; font-size: 9px; opacity: .6; margin-left: 5px; }
.sc-nav .sub-menu {
  position: absolute; top: calc(100% + 10px); left: -14px; min-width: 210px;
  background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-radius);
  box-shadow: 0 14px 40px rgba(40,30,20,.13); padding: 8px 0;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity .2s, transform .2s, visibility .2s; z-index: 60;
}
.sc-nav .menu-item-has-children:hover > .sub-menu,
.sc-nav .menu-item-has-children.is-focused > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.sc-nav .sub-menu li { display: block; }
.sc-nav .sub-menu a { display: block; padding: 10px 18px; font-size: 13.5px; white-space: normal; }
.sc-nav .sub-menu a:hover { background: var(--sc-bg); color: var(--sc-accent); }

.sc-actions { display: flex; align-items: center; gap: 18px; flex-shrink: 0; }
.sc-icon-btn { background: none; border: none; cursor: pointer; color: var(--sc-head); display: flex; padding: 4px; }
.sc-burger { display: none; background: none; border: none; cursor: pointer; color: var(--sc-head); padding: 4px; }

/* ---------- Search overlay ---------- */
.sc-search-overlay {
  position: fixed; inset: 0; z-index: 100; background: rgba(250,247,242,.97); backdrop-filter: blur(6px);
  opacity: 0; visibility: hidden; transition: opacity .25s, visibility .25s;
}
.sc-search-overlay.is-open { opacity: 1; visibility: visible; }
.sc-search-inner { max-width: 760px; margin: 0 auto; padding: 90px 32px 0; }
.sc-search-inner form { display: flex; align-items: center; gap: 14px; border-bottom: 2px solid var(--sc-accent); padding-bottom: 14px; }
.sc-search-inner input[type="search"] { flex: 1; border: none; outline: none; background: none; font-family: var(--sc-font-head); font-size: 30px; color: var(--sc-head); }
.sc-search-inner .sc-search-prompt { font-family: var(--sc-font-head); font-style: italic; font-size: 15px; color: var(--sc-muted); margin-bottom: 14px; }
.sc-search-close { background: none; border: none; cursor: pointer; color: var(--sc-muted); font-size: 14px; letter-spacing: 1px; }

/* ---------- Mobile menu ---------- */
.sc-mobile-scrim { position: fixed; inset: 0; z-index: 90; background: rgba(20,15,10,.4); opacity: 0; visibility: hidden; transition: opacity .3s, visibility .3s; }
.sc-mobile-scrim.is-open { opacity: 1; visibility: visible; }
.sc-mobile-panel {
  position: fixed; top: 0; right: 0; bottom: 0; width: 320px; max-width: 85vw; z-index: 91;
  background: var(--sc-content); padding: 28px 30px; overflow-y: auto;
  box-shadow: -10px 0 40px rgba(20,15,10,.18); transform: translateX(100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
}
.sc-mobile-panel.is-open { transform: translateX(0); }
.sc-mobile-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.sc-mobile-close { background: none; border: none; font-size: 26px; color: var(--sc-head); cursor: pointer; line-height: 1; }
.sc-mobile-panel ul { list-style: none; margin: 0; padding: 0; }
.sc-mobile-panel li a { display: block; padding: 15px 0; border-bottom: 1px solid var(--sc-border); font-family: var(--sc-font-head); font-size: 21px; color: var(--sc-head); }
.sc-mobile-panel .sub-menu a { font-size: 16px; padding-left: 16px; color: var(--sc-muted); }

/* ---------- Layout wrappers ---------- */
.sc-main { padding: 54px 0; }
.sc-with-sidebar { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 54px; }
.sidebar-left .sc-with-sidebar { grid-template-columns: 320px minmax(0, 1fr); }
.sidebar-left .sc-with-sidebar .sc-primary { order: 2; }

/* ---------- Article cards ---------- */
.sc-card { display: block; }
.sc-card__media { display: block; position: relative; overflow: hidden; border-radius: var(--sc-img-radius); margin-bottom: 15px; aspect-ratio: var(--sc-card-ratio, 3 / 2); }
.sc-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.card-hover-lift .sc-card { transition: transform .3s ease; }
.card-hover-lift .sc-card:hover { transform: translateY(-4px); }
.image-zoom .sc-card:hover .sc-card__media img { transform: scale(1.05); }
.sc-card__title { font-family: var(--sc-font-head); font-size: 21px; font-weight: 600; color: var(--sc-head); line-height: 1.25; margin: 9px 0 8px; }
.sc-card__title a { color: inherit; }
.sc-card__title a:hover { color: var(--sc-accent); }
.sc-card__excerpt { font-size: 14px; color: var(--sc-muted); line-height: 1.6; margin: 0; }
.sc-card__meta { font-size: 12.5px; color: var(--sc-muted); margin-top: 11px; }
.sc-card.is-shadow { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); padding: 16px; box-shadow: 0 10px 30px rgba(40,30,20,.06); }

.sc-grid { display: grid; gap: 34px 28px; }
.sc-grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sc-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.sc-grid.cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

/* horizontal magazine card */
.sc-card--horizontal { display: flex; gap: 18px; align-items: center; }
.sc-card--horizontal .sc-card__media { width: 148px; height: 148px; flex-shrink: 0; aspect-ratio: 1; margin: 0; }

/* minimal (no image) card */
.sc-card--minimal .sc-card__title { font-size: 22px; }
.sc-card--minimal .sc-card__meta { border-top: 1px solid var(--sc-border); padding-top: 12px; }

/* large editorial card */
.sc-card--editorial .sc-card__title { font-size: 26px; }

/* overlay card — text sits on the image */
.sc-card--overlay .sc-card__media { aspect-ratio: 3 / 4; margin-bottom: 0; }
.sc-card--overlay .sc-card__shade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,15,10,.82), rgba(20,15,10,.05) 62%); }
.sc-card--overlay .sc-card__overlay-body { position: absolute; left: 0; right: 0; bottom: 0; padding: 22px; display: flex; flex-direction: column; align-items: flex-start; gap: 5px; }
.sc-card--overlay .sc-card__title { display: block; color: #fff; font-size: 20px; margin: 0; }
.sc-cat-label.is-light { color: var(--sc-accent2); }

/* Pinterest save-for-later button */
.sc-pin { position: absolute; top: 12px; right: 12px; z-index: 3; display: inline-flex; align-items: center; gap: 7px; background: #E60023; color: #fff; font-size: 12px; font-weight: 600; letter-spacing: .3px; padding: 8px 13px; border-radius: 30px; cursor: pointer; opacity: 0; transform: translateY(-4px); transition: opacity .2s, transform .2s, background .2s; box-shadow: 0 4px 14px rgba(20,15,10,.25); }
.sc-pin:hover { background: #ad081b; }
.sc-pin svg { flex-shrink: 0; }
.sc-card__media:hover .sc-pin,
.sc-featured:hover .sc-pin,
.sc-hero__feature:hover .sc-pin,
.sc-pin:focus { opacity: 1; transform: translateY(0); }
.sc-featured { position: relative; }
@media (hover: none) { .sc-pin { opacity: 1; transform: none; } }

/* ---------- Section headers ---------- */
.sc-section { padding: 64px 0; }
.sc-section__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 30px; }
.sc-section__head.is-centered { flex-direction: column; align-items: center; text-align: center; }
.sc-section__title { font-family: var(--sc-font-head); font-size: 30px; font-weight: 700; color: var(--sc-head); margin: 0; }
.sc-viewall { font-size: 13px; font-weight: 600; color: var(--sc-accent); border-bottom: 1px solid var(--sc-accent); padding-bottom: 2px; }

/* ---------- Hero ---------- */
.sc-hero { padding: 54px 0 20px; }
.sc-hero__grid { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr); gap: 30px; }
.sc-hero__feature { display: block; position: relative; border-radius: var(--sc-img-radius); overflow: hidden; aspect-ratio: 5 / 4; }
.sc-hero__feature img { width: 100%; height: 100%; object-fit: cover; }
.sc-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,15,10,.72) 0%, rgba(20,15,10,.15) 45%, transparent 70%); }
.sc-hero__content { position: absolute; left: 0; bottom: 0; padding: 34px; }
.sc-hero__content h2 { color: #fff; font-size: 38px; line-height: 1.12; max-width: 560px; }
.sc-hero__content p { color: rgba(255,255,255,.82); font-size: 15.5px; max-width: 480px; }
.sc-pill { display: inline-block; background: var(--sc-accent); color: #fff; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; padding: 6px 13px; border-radius: 2px; margin-bottom: 14px; }
.sc-hero__side { display: flex; flex-direction: column; gap: 22px; }
.sc-hero__side .sc-divider { height: 1px; background: var(--sc-border); }

/* ---------- Category highlight ---------- */
.sc-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.sc-cat-card { position: relative; border-radius: var(--sc-img-radius); overflow: hidden; aspect-ratio: 3 / 4; display: block; }
.sc-cat-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.sc-cat-card:hover img { transform: scale(1.04); }
.sc-cat-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,15,10,.78), rgba(20,15,10,.05) 60%); }
.sc-cat-card__body { position: absolute; left: 0; right: 0; bottom: 0; padding: 24px; }
.sc-cat-card__body h3 { font-size: 23px; color: #fff; margin: 0; }
.sc-cat-card__count { font-size: 12px; color: rgba(255,255,255,.78); margin-top: 6px; letter-spacing: .5px; }

/* ---------- Trending ---------- */
.sc-trending__item { display: flex; gap: 18px; padding: 18px 0; border-bottom: 1px solid var(--sc-border); }
.sc-trending__num { font-family: var(--sc-font-head); font-size: 26px; font-weight: 600; color: var(--sc-accent2); line-height: 1; min-width: 34px; }
.sc-trending__item h3 { font-size: 16.5px; font-weight: 600; line-height: 1.3; margin: 0; }
.sc-trending__item .sc-card__meta { margin-top: 6px; }

/* ---------- Editor's picks ---------- */
.sc-editors { background: linear-gradient(180deg, var(--sc-bg), var(--sc-content)); }
.sc-editors__head { display: flex; align-items: center; gap: 16px; margin-bottom: 38px; }
.sc-editors__head h2 { font-style: italic; font-size: 32px; font-weight: 600; margin: 0; }
.sc-editors__rule { flex: 1; height: 1px; background: var(--sc-border); }

/* ---------- Featured guide ---------- */
.sc-guide { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); overflow: hidden; display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); }
.sc-guide__text { padding: 60px 56px; display: flex; flex-direction: column; justify-content: center; }
.sc-guide__img { width: 100%; height: 100%; min-height: 360px; object-fit: cover; }

/* ---------- Newsletter ---------- */
.sc-newsletter { background: var(--sc-footer-bg); border-top: 1px solid var(--sc-border); }
.sc-newsletter__inner { max-width: 680px; margin: 0 auto; padding: 74px 32px; text-align: center; }
.sc-newsletter__inner h2 { font-size: 34px; }
.sc-news-form { display: flex; gap: 10px; max-width: 440px; margin: 28px auto 0; }
.sc-news-form input { flex: 1; padding: 15px 18px; border: 1px solid var(--sc-border); border-radius: var(--sc-btn-radius); font-family: var(--sc-font-body); font-size: 14px; background: var(--sc-content); color: var(--sc-text); outline: none; }

/* ---------- Final CTA ---------- */
.sc-cta { background: var(--sc-accent); }
.sc-cta__inner { max-width: 1000px; margin: 0 auto; padding: 74px 32px; text-align: center; }
.sc-cta__inner h2 { color: #fff; font-size: 38px; }
.sc-cta__inner p { color: rgba(255,255,255,.85); max-width: 520px; margin: 16px auto 0; }
.sc-cta__inner .sc-btn { background: #fff; color: var(--sc-accent); border-color: #fff; margin-top: 28px; }
.sc-cta__inner .sc-btn:hover { background: var(--sc-head); color: #fff; border-color: var(--sc-head); }

/* ---------- Single post ---------- */
.sc-article-hero { max-width: 820px; margin: 0 auto; padding: 54px 32px 0; }
.sc-article-hero.align-center { text-align: center; }
.sc-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--sc-muted); margin-bottom: 24px; }
.sc-article-hero.align-center .sc-breadcrumb { justify-content: center; }
.sc-breadcrumb span { opacity: .5; }
.sc-article-hero h1 { font-size: 48px; line-height: 1.1; }
.sc-subtitle { font-family: var(--sc-font-head); font-style: italic; font-size: 21px; color: var(--sc-muted); line-height: 1.5; margin-top: 18px; }
.sc-post-meta { display: flex; align-items: center; gap: 14px; margin-top: 28px; font-size: 13.5px; color: var(--sc-muted); }
.sc-article-hero.align-center .sc-post-meta { justify-content: center; }
.sc-post-meta img { width: 40px; height: 40px; border-radius: 50%; }
.sc-post-meta .sc-author { color: var(--sc-head); font-weight: 600; }
.sc-featured { max-width: 1080px; margin: 38px auto 0; padding: 0 32px; }
.sc-featured img { width: 100%; border-radius: var(--sc-img-radius); }
.sc-featured figcaption { font-size: 12.5px; color: var(--sc-muted); font-style: italic; text-align: center; margin-top: 12px; }

.sc-article-body { max-width: var(--sc-container); margin: 0 auto; padding: 50px 32px 0; display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 56px; }
.sc-article-body.no-toc { grid-template-columns: minmax(0, 1fr); max-width: 860px; }
.sc-toc { position: sticky; top: 96px; align-self: start; max-height: calc(100vh - 120px); overflow: auto; }
.sc-toc__title { font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--sc-muted); margin-bottom: 18px; }
.sc-toc ul { list-style: none; margin: 0; padding: 0; border-left: 1px solid var(--sc-border); }
.sc-toc a { display: block; padding: 8px 0 8px 16px; font-size: 13px; color: var(--sc-muted); line-height: 1.4; margin-left: -1px; }
.sc-toc a:hover, .sc-toc a.is-active { color: var(--sc-accent); border-left: 2px solid var(--sc-accent); }

.sc-prose { max-width: var(--sc-content-w); font-size: 18px; }
.sc-prose p { font-size: 18px; line-height: 1.78; color: var(--sc-text); margin-bottom: 24px; }
.sc-prose h2 { font-size: 32px; margin: 48px 0 18px; }
.sc-prose h3 { font-size: 26px; margin: 40px 0 14px; }
.sc-prose ul, .sc-prose ol { margin: 0 0 24px; padding-left: 24px; line-height: 1.7; }
.sc-prose li { margin-bottom: 8px; }
.sc-prose img { border-radius: var(--sc-img-radius); margin: 8px 0 14px; }
.sc-prose a { color: var(--sc-accent); border-bottom: 1px solid var(--sc-accent2); }
.sc-prose a:hover { border-color: var(--sc-accent); }
.sc-prose blockquote { margin: 36px 0; padding: 6px 0 6px 28px; border-left: 3px solid var(--sc-accent2); }
.sc-prose blockquote p { font-family: var(--sc-font-head); font-style: italic; font-size: 26px; line-height: 1.4; color: var(--sc-head); margin: 0; }
.sc-prose .wp-caption, .sc-prose figure { margin: 24px 0; }
.sc-prose figcaption, .sc-prose .wp-caption-text { font-size: 13px; color: var(--sc-muted); font-style: italic; text-align: center; margin-top: 10px; }
.sc-prose pre { background: var(--sc-head); color: #e8ddcd; border-radius: var(--sc-radius); padding: 20px; overflow: auto; font-size: 14px; }
.sc-prose table { width: 100%; border-collapse: collapse; margin: 24px 0; }
.sc-prose th, .sc-prose td { border: 1px solid var(--sc-border); padding: 12px 14px; text-align: left; }
.sc-prose th { background: var(--sc-bg); }
.sc-prose .dropcap::first-letter,
.sc-prose > p:first-of-type::first-letter { font-family: var(--sc-font-head); font-size: 66px; line-height: .82; font-weight: 700; color: var(--sc-accent); float: left; margin: 6px 14px 0 0; }

/* ---------- Listicle idea heading ---------- */
.styli-idea-heading { display: flex; align-items: flex-start; gap: 24px; margin: 55px 0 28px; flex-wrap: wrap; }
.styli-idea-count { width: 70px; flex-shrink: 0; text-align: right; padding-top: 4px; }
.styli-idea-number { display: block; font-family: var(--sc-font-head); font-size: var(--sc-listicle-number-size); font-weight: var(--sc-listicle-number-weight, 500); color: var(--sc-listicle-number); line-height: 1; }
.styli-idea-total { display: block; font-size: var(--sc-listicle-total-size, 13px); letter-spacing: 1px; color: var(--sc-listicle-total); margin-top: 2px; }
.styli-idea-divider { width: 1px; align-self: stretch; background: var(--sc-listicle-divider); }
.styli-idea-heading h3 { font-family: var(--sc-font-head); font-size: var(--sc-listicle-heading-size); font-weight: var(--sc-listicle-heading-weight, 700); color: var(--sc-listicle-heading); line-height: 1.15; margin: 0; padding-top: 2px; }

/* ---------- Reusable content blocks ---------- */
.decor-tip-box, .pro-tip, .styli-note, .styli-warning, .room-style-box, .inspiration-callout, .resource-box {
  border-radius: 0 var(--sc-card-radius) var(--sc-card-radius) 0; padding: 24px 28px; margin: 32px 0;
}
.decor-tip-box { background: var(--sc-bg); border: 1px solid var(--sc-border); border-left: 3px solid var(--sc-accent); }
.pro-tip { background: var(--sc-content); border: 1px solid var(--sc-accent); border-radius: var(--sc-card-radius); }
.styli-note { background: #FBF6EE; border: 1px solid #e7c9a0; border-radius: var(--sc-card-radius); }
.styli-warning { background: #fbf3f0; border: 1px solid #e2bdb2; border-radius: var(--sc-card-radius); }
.decor-tip-box .sc-block-label, .pro-tip .sc-block-label, .styli-note .sc-block-label, .styli-warning .sc-block-label,
.styli-checklist .sc-block-label, .styli-color-palette .sc-block-label, .shop-the-look-box .sc-block-label {
  display: block; font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sc-accent); margin-bottom: 8px;
}
.decor-tip-box p, .pro-tip p, .styli-note p, .styli-warning p { margin: 0; font-size: 15.5px; line-height: 1.65; color: var(--sc-text); }

.styli-checklist { background: var(--sc-bg); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); padding: 26px 30px; margin: 32px 0; }
.styli-checklist ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.styli-checklist li { display: flex; align-items: flex-start; gap: 12px; font-size: 15px; line-height: 1.5; }
.styli-checklist li::before { content: '✓'; width: 20px; height: 20px; border-radius: 50%; background: var(--sc-accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 11px; flex-shrink: 0; margin-top: 1px; }

.styli-color-palette { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); padding: 26px; margin: 32px 0; }
.styli-color-palette .swatches { display: flex; border-radius: var(--sc-radius); overflow: hidden; border: 1px solid var(--sc-border); }
.styli-color-palette .swatches span { flex: 1; height: 64px; }

.shop-the-look-box, .styli-product-box { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: 10px; padding: 30px; margin: 40px 0; }
.shop-the-look-box .grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.shop-the-look-box .grid img { border-radius: var(--sc-img-radius); }
.shop-the-look-box .price { font-size: 13px; color: var(--sc-accent); margin-top: 3px; }

.styli-before-after .grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 14px; }
.styli-before-after .label { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sc-muted); text-align: center; margin-top: 10px; }
.image-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin: 24px 0; }

/* ---------- Tags / author / related / nav ---------- */
.sc-tags { display: flex; flex-wrap: wrap; gap: 10px; margin: 40px 0 0; padding-top: 30px; border-top: 1px solid var(--sc-border); }
.sc-tags a { font-size: 12.5px; padding: 7px 15px; border: 1px solid var(--sc-border); border-radius: 30px; color: var(--sc-text); }
.sc-tags a:hover { border-color: var(--sc-accent); color: var(--sc-accent); }
.sc-author-box { display: flex; gap: 22px; background: var(--sc-bg); border: 1px solid var(--sc-border); border-radius: 10px; padding: 28px; margin: 36px 0; }
.sc-author-box img { width: 78px; height: 78px; border-radius: 50%; flex-shrink: 0; }
.sc-author-box h3 { font-size: 21px; font-weight: 600; margin: 6px 0 0; }
.sc-author-box p { font-size: 14px; line-height: 1.6; color: var(--sc-muted); margin: 8px 0 0; }
.sc-postnav { display: flex; justify-content: space-between; gap: 20px; margin-top: 50px; padding-top: 30px; border-top: 1px solid var(--sc-border); }
.sc-postnav a { display: flex; flex-direction: column; gap: 6px; max-width: 45%; }
.sc-postnav .sc-next { text-align: right; align-items: flex-end; }
.sc-postnav .sc-dir { font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sc-muted); }
.sc-postnav .sc-postnav-title { font-family: var(--sc-font-head); font-size: 18px; font-weight: 600; color: var(--sc-head); }

/* ---------- Archive / category hero ---------- */
.sc-archive-hero { position: relative; overflow: hidden; background: var(--sc-accent2); }
.sc-archive-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.sc-archive-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,15,10,.55), rgba(20,15,10,.7)); }
.sc-archive-hero__inner { position: relative; max-width: 820px; margin: 0 auto; padding: 80px 32px; text-align: center; }
.sc-archive-hero h1 { font-size: 52px; color: #fff; }
.sc-archive-hero p { font-size: 17px; color: rgba(255,255,255,.88); line-height: 1.7; margin: 18px auto 0; max-width: 560px; }
.sc-archive-hero__meta { font-size: 12.5px; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.7); margin-top: 22px; }

/* ---------- Pagination ---------- */
.sc-pagination { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 48px 0 0; }
.sc-pagination .page-numbers { min-width: 40px; height: 40px; padding: 0 12px; border-radius: var(--sc-radius); border: 1px solid var(--sc-border); display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--sc-text); }
.sc-pagination .page-numbers.current { background: var(--sc-accent); color: #fff; border-color: var(--sc-accent); }
.sc-pagination .page-numbers:hover:not(.current) { border-color: var(--sc-accent); color: var(--sc-accent); }

/* ---------- Sidebar / widgets ---------- */
.sc-sidebar .widget { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); padding: 26px; margin-bottom: 30px; }
.sc-sidebar .widget-title { font-family: var(--sc-font-head); font-size: 18px; font-weight: 600; color: var(--sc-head); margin: 0 0 6px; }
.sc-sidebar .widget-title::after { content: ''; display: block; width: 32px; height: 2px; background: var(--sc-accent); margin-top: 12px; }
.sc-sidebar ul { list-style: none; margin: 0; padding: 0; }
.sc-sidebar li { padding: 9px 0; border-bottom: 1px solid var(--sc-border); font-size: 14px; }
.sc-sidebar li:last-child { border-bottom: none; }

/* ---------- Footer ---------- */
.sc-footer { background: var(--sc-footer-bg); border-top: 1px solid var(--sc-border); }
.sc-footer__cols { display: grid; grid-template-columns: minmax(0, 1.5fr) repeat(3, minmax(0, 1fr)); gap: 40px; padding: 64px 0 0; }
.sc-footer.cols-3 .sc-footer__cols { grid-template-columns: minmax(0, 2fr) repeat(2, minmax(0, 1fr)); }
.sc-footer.cols-2 .sc-footer__cols { grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); }
.sc-footer__about p { font-size: 14px; color: var(--sc-footer-text); line-height: 1.7; max-width: 300px; }
.sc-footer h4 { font-family: var(--sc-font-body); font-size: 12px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sc-footer-head); margin: 0 0 18px; }
.sc-footer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; font-size: 14px; }
.sc-footer a { color: var(--sc-footer-text); }
.sc-footer a:hover { color: var(--sc-accent); }
.sc-footer__brand { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.sc-footer__brand .sc-site-title { color: var(--sc-footer-head); }
.sc-footer__bottom { display: flex; align-items: center; justify-content: space-between; margin-top: 54px; padding: 26px 0; border-top: 1px solid var(--sc-border); font-size: 13px; color: var(--sc-footer-text); }
.sc-footer__bottom .sc-tagline-italic { font-family: var(--sc-font-head); font-style: italic; }

/* ---------- Back to top + progress ---------- */
.sc-progress-bar { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: var(--sc-accent); z-index: 120; transition: width .08s linear; }
.sc-to-top { position: fixed; right: 26px; bottom: 26px; z-index: 80; width: 46px; height: 46px; border-radius: 50%; background: var(--sc-accent); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 20px rgba(40,30,20,.22); opacity: 0; visibility: hidden; transform: translateY(10px); transition: opacity .3s, transform .3s, visibility .3s; }
.sc-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }

/* ---------- Comments ---------- */
.sc-comments { max-width: var(--sc-content-w); margin: 60px auto 0; padding: 0 32px; }
.sc-comments .comment-list { list-style: none; margin: 0; padding: 0; }
.sc-comments .comment-body { padding: 22px 0; border-bottom: 1px solid var(--sc-border); }
.sc-comments .comment-author { font-weight: 600; color: var(--sc-head); }
.sc-comments .comment-form input[type="text"], .sc-comments .comment-form input[type="email"], .sc-comments .comment-form input[type="url"], .sc-comments .comment-form textarea { width: 100%; padding: 13px 16px; border: 1px solid var(--sc-border); border-radius: var(--sc-radius); font-family: var(--sc-font-body); font-size: 14px; background: var(--sc-content); margin-top: 6px; }

/* ---------- Forms ---------- */
input, textarea, select { font-family: var(--sc-font-body); }
.sc-search-form { display: flex; gap: 8px; }
.sc-search-form input[type="search"] { flex: 1; padding: 13px 16px; border: 1px solid var(--sc-border); border-radius: var(--sc-radius); }

/* ---------- WooCommerce light touch ---------- */
.woocommerce ul.products li.product .price { color: var(--sc-accent); }
.woocommerce a.button, .woocommerce button.button, .woocommerce #respond input#submit { background: var(--sc-btn-bg); color: var(--sc-btn-text); border-radius: var(--sc-btn-radius); }
.woocommerce a.button:hover { background: var(--sc-btn-hover-bg); }

/* ---------- Browse by Category (room icon nav) ---------- */
.sc-roomnav-section { padding-top: 56px; padding-bottom: 56px; }
.sc-roomnav__lead { font-size: 15px; color: var(--sc-muted); line-height: 1.6; max-width: 460px; margin: 12px auto 0; }
.sc-roomnav {
  display: grid;
  grid-template-columns: repeat(var(--sc-roomnav-cols, 4), minmax(0, 1fr));
  gap: 20px; margin-top: 38px;
}
.sc-roomnav__item {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px;
  padding: 30px 18px; border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius);
  background: var(--sc-content); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.sc-roomnav__item:hover { transform: translateY(-4px); border-color: var(--sc-accent); box-shadow: 0 14px 34px rgba(40,30,20,.09); }
.sc-roomnav__badge {
  width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: var(--sc-bg); color: var(--sc-accent); transition: background .25s ease, color .25s ease;
}
.sc-roomnav__item:hover .sc-roomnav__badge { background: var(--sc-accent); color: #fff; }
.sc-roomnav__icon { width: 32px; height: 32px; }
.sc-roomnav__name { font-family: var(--sc-font-head); font-size: 18px; font-weight: 600; color: var(--sc-head); line-height: 1.2; }
.sc-roomnav__count { font-size: 12px; letter-spacing: .4px; color: var(--sc-muted); }

/* ---------- Newsletter (built-in form states) ---------- */
.sc-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.sc-news-status { min-height: 20px; margin: 14px auto 0; font-size: 14px; max-width: 440px; }
.sc-news-status.is-sending { color: var(--sc-muted); }
.sc-news-status.is-ok { color: #2e7d32; }
.sc-news-status.is-error { color: #c0392b; }
.sc-news-form button[disabled] { opacity: .6; cursor: default; }

/* ---------- Extra content blocks ---------- */
/* Two-image and single-image figures */
.styli-figure { margin: 28px 0; }
.styli-figure img { width: 100%; border-radius: var(--sc-img-radius); }
.styli-figure figcaption, .styli-figure .label { font-size: 13px; color: var(--sc-muted); font-style: italic; text-align: center; margin-top: 10px; }
.styli-two-images { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 16px; margin: 28px 0; }
.styli-two-images figure { margin: 0; }
.styli-two-images img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--sc-img-radius); }
.styli-two-images figcaption { font-size: 12.5px; color: var(--sc-muted); font-style: italic; text-align: center; margin-top: 8px; }

/* Before / After */
.styli-before-after { margin: 32px 0; }
.styli-before-after .grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 14px; }
.styli-before-after figure { margin: 0; position: relative; }
.styli-before-after img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--sc-img-radius); }
.styli-before-after .label {
  display: inline-block; margin-top: 10px; font-size: 11px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--sc-accent);
}

/* Materials / supplies list */
.styli-materials { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); padding: 26px 30px; margin: 32px 0; }
.styli-materials ul { list-style: none; margin: 10px 0 0; padding: 0; display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 10px 24px; }
.styli-materials li { display: flex; align-items: flex-start; gap: 10px; font-size: 15px; line-height: 1.45; }
.styli-materials li::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--sc-accent); margin-top: 8px; flex-shrink: 0; }

/* Numbered styling steps */
.styli-steps { counter-reset: sc-step; margin: 32px 0; padding: 0; list-style: none; }
.styli-steps > li { counter-increment: sc-step; display: flex; gap: 18px; padding: 16px 0; border-bottom: 1px solid var(--sc-border); }
.styli-steps > li:last-child { border-bottom: none; }
.styli-steps > li::before {
  content: counter(sc-step, decimal-leading-zero); font-family: var(--sc-font-head); font-size: 22px;
  font-weight: 600; color: var(--sc-accent2); line-height: 1; min-width: 38px;
}

/* Designer quote / pull-callout */
.styli-quote { margin: 36px 0; padding: 8px 0 8px 30px; border-left: 3px solid var(--sc-accent); }
.styli-quote p { font-family: var(--sc-font-head); font-style: italic; font-size: 24px; line-height: 1.4; color: var(--sc-head); margin: 0 0 10px; }
.styli-quote cite { font-style: normal; font-size: 13px; letter-spacing: 1px; text-transform: uppercase; color: var(--sc-muted); }

/* Cost / quick-stat strip */
.styli-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin: 32px 0; }
.styli-stats div { background: var(--sc-bg); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); padding: 20px; text-align: center; }
.styli-stats strong { display: block; font-family: var(--sc-font-head); font-size: 28px; color: var(--sc-accent); line-height: 1; }
.styli-stats span { display: block; font-size: 12px; letter-spacing: .8px; text-transform: uppercase; color: var(--sc-muted); margin-top: 8px; }

/* ---------- Extra card styles ---------- */
/* Number-led card */
.sc-card--numbered .sc-card__body { position: relative; padding-left: 0; }
.sc-card--numbered .sc-card__title { font-size: 20px; }

/* Bordered / framed card */
.sc-card--framed { background: var(--sc-content); border: 1px solid var(--sc-border); border-radius: var(--sc-card-radius); overflow: hidden; }
.sc-card--framed .sc-card__media { border-radius: 0; margin-bottom: 0; }
.sc-card--framed .sc-card__body { padding: 20px 22px 24px; }

/* Compact side-by-side (lighter than horizontal) */
.sc-card--compact { display: flex; gap: 14px; align-items: flex-start; }
.sc-card--compact .sc-card__media { width: 110px; height: 88px; flex-shrink: 0; aspect-ratio: auto; margin: 0; }
.sc-card--compact .sc-card__title { font-size: 16.5px; margin: 0 0 5px; }
.sc-card--compact .sc-card__body { padding-top: 2px; }

/* Tall — portrait overlay (great for Pinterest-style feeds) */
.sc-card--tall .sc-card__media { aspect-ratio: 3 / 4.4; margin-bottom: 0; }
.sc-card--tall .sc-card__shade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,15,10,.85), rgba(20,15,10,.05) 60%); }
.sc-card--tall .sc-card__overlay-body { position: absolute; left: 0; right: 0; bottom: 0; padding: 24px; display: flex; flex-direction: column; align-items: flex-start; gap: 6px; }
.sc-card--tall .sc-card__title { display: block; color: #fff; font-size: 22px; line-height: 1.2; margin: 0; }

/* News — slim top accent rule, tighter type */
.sc-card--news .sc-card__body { border-top: 2px solid var(--sc-accent); padding-top: 14px; margin-top: 14px; }
.sc-card--news .sc-cat-label { color: var(--sc-muted); }
.sc-card--news .sc-card__title { font-size: 19px; }

/* Polaroid — white frame with a soft shadow */
.sc-card--polaroid { background: #fff; padding: 12px 12px 6px; border-radius: 4px; box-shadow: 0 12px 30px rgba(40,30,20,.10); border: 1px solid var(--sc-border); }
.sc-card--polaroid .sc-card__media { border-radius: 2px; margin-bottom: 14px; }
.sc-card--polaroid .sc-card__body { padding: 0 6px 10px; }
.sc-card--polaroid .sc-card__title { font-size: 19px; }

/* ---------- Latest + Trending layout (was missing → sections merged) ---------- */
.sc-latest-wrap.is-sidebar { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 48px; align-items: start; }
.sc-latest-wrap.is-stacked { display: flex; flex-direction: column; gap: 56px; }
.sc-latest-main { min-width: 0; }
.sc-trending { min-width: 0; }
.sc-latest-wrap.is-sidebar .sc-trending {
  background: var(--sc-bg); border: 1px solid var(--sc-border);
  border-radius: var(--sc-card-radius); padding: 26px 28px;
}
.sc-trending__head { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.sc-trending__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sc-accent); flex-shrink: 0; }
.sc-trending__list { display: block; }
.sc-trending__body { min-width: 0; }
.sc-trending__body h3 { font-size: 16.5px; font-weight: 600; line-height: 1.3; margin: 0 0 4px; }
.sc-trending__body h3:hover { color: var(--sc-accent); }
/* In the stacked layout, show the trending items in a tidy multi-column flow */
.sc-latest-wrap.is-stacked .sc-trending__list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0 40px; }

/* ---------- Homepage section rhythm (guarantee breathing room) ---------- */
.sc-front > section + section { margin-top: 0; }
.sc-front > .sc-section,
.sc-front > .sc-hero { padding-top: 60px; padding-bottom: 60px; }
.sc-front > .sc-hero { padding-bottom: 24px; }

/* ---------- Homepage author / meet-the-editor ---------- */
.sc-author-section { background: var(--sc-content); border-top: 1px solid var(--sc-border); border-bottom: 1px solid var(--sc-border); }
.sc-authorhome { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 50px; align-items: center; max-width: 900px; margin: 0 auto; }
.sc-authorhome__media { position: relative; }
.sc-authorhome__media img {
  width: 100%; aspect-ratio: 4 / 5; object-fit: cover;
  border-radius: var(--sc-card-radius); display: block;
}
.sc-authorhome__placeholder {
  display: flex; align-items: center; justify-content: center;
  width: 100%; aspect-ratio: 4 / 5; border-radius: var(--sc-card-radius);
  background: var(--sc-accent2); color: #fff; font-family: var(--sc-font-head); font-size: 96px;
}
.sc-authorhome__name { font-size: 30px; margin: 12px 0 2px; }
.sc-authorhome__role { font-size: 13px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sc-accent); margin: 0 0 16px; }
.sc-authorhome__bio { font-size: 16px; color: var(--sc-muted); line-height: 1.75; margin: 0 0 20px; max-width: 480px; }
.sc-authorhome__links { display: flex; flex-wrap: wrap; gap: 20px; margin-bottom: 24px; }
.sc-authorhome__links a { font-size: 13px; font-weight: 600; letter-spacing: .6px; text-transform: uppercase; color: var(--sc-head); border-bottom: 1px solid var(--sc-accent); padding-bottom: 3px; }
.sc-authorhome__links a:hover { color: var(--sc-accent); }
.sc-authorhome__btn { align-self: start; }

/* ---------- Pinterest hover-save on content images ---------- */
.sc-pinnable { position: relative; display: inline-block; max-width: 100%; }
.sc-pinnable > img { display: block; }
.sc-img-pin {
  position: absolute; top: 12px; right: 12px; z-index: 3;
  display: inline-flex; align-items: center; gap: 7px;
  background: #E60023; color: #fff; border: none; cursor: pointer;
  font-family: var(--sc-font-body); font-size: 12px; font-weight: 600; letter-spacing: .3px;
  padding: 8px 13px; border-radius: 22px; line-height: 1;
  opacity: 0; transform: translateY(-4px); transition: opacity .2s ease, transform .2s ease, background .2s ease;
  box-shadow: 0 4px 14px rgba(0,0,0,.22);
}
.sc-img-pin svg { width: 14px; height: 14px; fill: currentColor; }
.sc-pinnable:hover .sc-img-pin, .sc-img-pin:focus-visible { opacity: 1; transform: translateY(0); }
.sc-img-pin:hover { background: #ad081b; }
@media (hover: none) { .sc-img-pin { opacity: 1; transform: none; } }

/* ---------- Animations ---------- */
@keyframes scRise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
.animations-on .sc-section, .animations-on .sc-hero { animation: scRise .6s ease both; }

/* =============================================================
   Responsive — desktop (default) → tablet → phone → small phone.
   Heading sizes step down through the Customizer's tablet/mobile
   values (--sc-h*-tablet / --sc-h*-mobile).
   ============================================================= */

/* ---------- Tablet & small laptop (≤ 1024px) ---------- */
@media (max-width: 1024px) {
  .sc-nav, .sc-topbar { display: none; }
  .sc-burger { display: flex; }
  .sc-header-inner { height: 72px; }

  h1 { font-size: var(--sc-h1-tablet, 34px); }
  h2 { font-size: var(--sc-h2-tablet, 28px); }
  h3 { font-size: var(--sc-h3-tablet, 24px); }
  .sc-section__title { font-size: var(--sc-h2-tablet, 28px); }

  .sc-section { padding: 52px 0; }
  .sc-hero { padding: 40px 0 12px; }
  .sc-hero__grid { grid-template-columns: minmax(0, 1fr); gap: 24px; }
  .sc-hero__feature { aspect-ratio: 16 / 10; }
  .sc-guide, .sc-editors__grid, .sc-with-sidebar { grid-template-columns: minmax(0, 1fr) !important; }
  .sc-guide__img { min-height: 280px; }

  .sc-article-body { grid-template-columns: minmax(0, 1fr); gap: 0; }
  .sc-toc { display: none; }

  .sc-grid.cols-3, .sc-grid.cols-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sc-cats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sc-roomnav { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .sc-footer__cols,
  .sc-footer.cols-3 .sc-footer__cols,
  .sc-footer.cols-2 .sc-footer__cols { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sc-footer__about { grid-column: 1 / -1; }
  .sidebar-left .sc-with-sidebar .sc-primary { order: 0; }
  .styli-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* ---------- Phone (≤ 680px) ---------- */
@media (max-width: 680px) {
  body { font-size: var(--sc-body-size-mobile, 16px); }
  .sc-container, .sc-hero__content { padding-left: 20px; padding-right: 20px; }

  h1, .sc-article-hero h1, .sc-archive-hero h1 { font-size: var(--sc-h1-mobile, 30px); }
  h2, .sc-section__title { font-size: var(--sc-h2-mobile, 26px); }
  h3 { font-size: var(--sc-h3-mobile, 22px); }
  .sc-hero__content h2 { font-size: var(--sc-h2-mobile, 26px); }
  .sc-cta__inner h2, .sc-newsletter__inner h2 { font-size: var(--sc-h2-mobile, 26px); }
  .sc-archive-hero h1 { font-size: 38px; }

  .sc-section { padding: 44px 0; }
  .sc-section__head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .sc-section__head.is-centered { align-items: center; }

  /* Every card grid collapses to a single column on phones */
  .sc-grid.cols-2, .sc-grid.cols-3, .sc-grid.cols-4 { grid-template-columns: minmax(0, 1fr); }
  .sc-cats { grid-template-columns: minmax(0, 1fr); }
  .sc-roomnav { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
  .sc-roomnav__item { padding: 22px 12px; }
  .sc-footer__cols,
  .sc-footer.cols-3 .sc-footer__cols,
  .sc-footer.cols-2 .sc-footer__cols { grid-template-columns: minmax(0, 1fr); }
  .sc-footer__bottom { flex-direction: column; gap: 12px; text-align: center; }

  /* Cards: horizontal/compact stay side-by-side but tighten; overlay keeps height */
  .sc-card--horizontal .sc-card__media { width: 120px; height: 120px; }
  .sc-hero__feature { aspect-ratio: 4 / 3; }
  .sc-hero__content { padding: 22px; }

  .sc-editors__grid { gap: 28px !important; }
  .sc-editors__grid > a .sc-card__media { height: 280px !important; }

  .sc-authorhome { grid-template-columns: minmax(0, 1fr); gap: 26px; text-align: center; }
  .sc-authorhome__media { max-width: 220px; margin: 0 auto; }
  .sc-authorhome__bio { margin-left: auto; margin-right: auto; }
  .sc-authorhome__links { justify-content: center; }
  .sc-authorhome__btn { align-self: center; }
  .sc-latest-wrap.is-stacked .sc-trending__list { grid-template-columns: minmax(0, 1fr); }

  .sc-news-form { flex-direction: column; }
  .sc-guide__text { padding: 34px 26px; }

  .styli-idea-heading { gap: 16px; }
  .styli-idea-count { width: 48px; }
  .styli-idea-heading h3 { font-size: 23px; }
  .shop-the-look-box .grid,
  .styli-two-images,
  .styli-before-after .grid,
  .styli-materials ul,
  .styli-stats { grid-template-columns: minmax(0, 1fr); }

  .sc-prose { font-size: 16px; }
  .sc-prose p { font-size: 16px; }
  .sc-prose h2 { font-size: 26px; margin: 36px 0 14px; }
  .sc-prose h3 { font-size: 22px; margin: 30px 0 12px; }
  .sc-prose blockquote p { font-size: 21px; }
  .sc-prose > p:first-of-type::first-letter,
  .sc-prose .dropcap::first-letter { font-size: 54px; }

  .sc-post-meta, .sc-breadcrumb, .sc-tags, .sc-share__icons { flex-wrap: wrap; row-gap: 8px; }
  .sc-featured { padding-left: 20px; padding-right: 20px; }
  .sc-article-hero { padding-left: 20px; padding-right: 20px; }
  .sc-author-box { flex-direction: column; gap: 16px; text-align: center; align-items: center; }
  .sc-postnav { flex-direction: column; gap: 22px; }
  .sc-postnav a, .sc-postnav .sc-next { max-width: 100%; text-align: left; align-items: flex-start; }
  .sc-to-top { right: 16px; bottom: 16px; width: 42px; height: 42px; }
}

/* ---------- Small phone (≤ 400px) ---------- */
@media (max-width: 400px) {
  .sc-container, .sc-hero__content { padding-left: 16px; padding-right: 16px; }
  .sc-roomnav { grid-template-columns: minmax(0, 1fr); }
  .sc-card--horizontal, .sc-card--compact { flex-direction: column; }
  .sc-card--horizontal .sc-card__media,
  .sc-card--compact .sc-card__media { width: 100%; height: auto; aspect-ratio: 3 / 2; }
  .sc-mobile-panel { width: 100%; max-width: 100%; }
  .sc-search-inner input[type="search"] { font-size: 22px; }
}
