/*
Theme Name: Vayura-Studio Bakery
Theme URI: https://vayura.studio/themes/bakery
Author: Vayura Studio
Author URI: https://vayura.studio
Description: Editorial "Journal Light" FSE block theme for artisan bakeries. Cormorant Garamond serifs, Inter sans, paper background. Fluid typography, fully editable from the Site Editor — no CSS overrides on typography or colors so every right-sidebar setting works.
Version: 18
Requires at least: 6.5
Tested up to: 6.7
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vayura-studio-bakery
Tags: full-site-editing, block-theme, editorial, one-column, custom-colors, custom-menu, custom-logo
*/

/* ================================================================
   BASE
   ================================================================ */
:root {
  --sb-content: 780px;
  --sb-wide:    1400px;
  --sb-rule:        rgba(30, 26, 20, 0.12);
  --sb-rule-strong: rgba(30, 26, 20, 0.32);
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; height: auto; display: block; }
figure { margin: 0; }
figcaption {
  margin-top: 0.6rem;
  font-family: 'Inter', sans-serif;
  font-variant-caps: all-small-caps;
  font-feature-settings: "smcp" 1, "c2sc" 1;
  letter-spacing: 0.18em;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
}
@media (max-width: 720px) {
  html { scroll-padding-top: 80px; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

/* ================================================================
   MOBILE HAMBURGER + OVERLAY MENU
   ================================================================ */
.wp-block-navigation__responsive-container-open {
  margin-left: auto;
  padding: 0.5rem;
}
.wp-block-navigation__responsive-container-open svg { display: none !important; }
.wp-block-navigation__responsive-container-open::before {
  content: '';
  display: block;
  width: 28px;
  height: 18px;
  background-image:
    linear-gradient(currentColor, currentColor),
    linear-gradient(currentColor, currentColor),
    linear-gradient(currentColor, currentColor);
  background-size: 100% 2px;
  background-position: top, center, bottom;
  background-repeat: no-repeat;
  color: var(--wp--preset--color--text);
}

.wp-block-navigation__responsive-container.is-menu-open {
  background: var(--wp--preset--color--background) !important;
  padding: 5rem 2rem 2rem !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  display: flex !important;
  flex-direction: column !important;
}
.wp-block-navigation__responsive-container.is-menu-open ul,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
  flex-direction: column !important;
  list-style: none !important;
  padding-left: 0 !important;
  width: 100% !important;
  gap: 1.25rem !important;
  align-items: flex-start !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 2rem;
  letter-spacing: 0;
  color: var(--wp--preset--color--text);
  padding: 0.25rem 0;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--primary);
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
  position: absolute !important;
  top: 1.5rem !important;
  right: 1.5rem !important;
  width: 44px !important;
  height: 44px !important;
  padding: 8px !important;
  color: var(--wp--preset--color--text) !important;
  background: transparent !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
  width: 28px !important;
  height: 28px !important;
}

/* ================================================================
   STICKY HEADER
   ================================================================ */

/* Border and shadow */
body.sb-sticky-header .wp-site-blocks > header,
body.sb-sticky-header .sb-masthead-wrap {
  border-bottom: 1px solid var(--sb-rule) !important;
  box-shadow: none;
  transition: box-shadow 0.3s ease;
}

/* Compact top padding — overrides the block editor's L (3rem) preset
   so the logo sits close to the top of the header bar */
body.sb-sticky-header .wp-site-blocks > header > *,
body.sb-sticky-header .sb-masthead-wrap > * {
  padding-top: 0.6rem !important;
}

/* Subtle shadow when scrolled */
body.sb-sticky-header .wp-site-blocks > header.is-shrunk,
body.sb-sticky-header .sb-masthead-wrap.is-shrunk {
  box-shadow: 0 2px 12px rgba(30, 26, 20, 0.08);
}

/* Kill every source of gap between the fixed header and the first content section:
   1. blockGap margin WordPress injects on <main> (wp-site-blocks > * + *)
   2. blockGap margin on the first block inside post-content */
.wp-site-blocks > main,
.wp-site-blocks > .sb-main {
  margin-block-start: 0 !important;
  margin-top: 0 !important;
}
.sb-main > .wp-block-post-content > *:first-child,
.wp-block-post-content > *:first-child {
  margin-top: 0 !important;
  margin-block-start: 0 !important;
}

/* ================================================================
   BLOCK STYLE VARIATIONS
   ================================================================ */
.is-style-kicker {
  font-family: 'Inter', sans-serif;
  font-variant-caps: all-small-caps;
  font-feature-settings: "smcp" 1, "c2sc" 1;
  letter-spacing: 0.18em;
  color: var(--wp--preset--color--muted);
}
.is-style-lead {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  line-height: 1.45;
}
.is-style-byline {
  font-family: 'Inter', sans-serif;
  font-variant-caps: all-small-caps;
  font-feature-settings: "smcp" 1, "c2sc" 1;
  letter-spacing: 0.18em;
  color: var(--wp--preset--color--muted);
}
.wp-block-heading.is-style-italic { font-style: italic; }
.wp-block-heading.is-style-display {
  font-style: italic;
  color: var(--wp--preset--color--primary);
}
/* Global button size — applied to every button on the site */
.wp-element-button,
.wp-block-button__link {
  font-size: 0.8rem !important;
  padding-top: 0.65rem !important;
  padding-right: 1.6rem !important;
  padding-bottom: 0.65rem !important;
  padding-left: 1.6rem !important;
}

.wp-block-button.is-style-outline > .wp-block-button__link {
  background: transparent;
  color: var(--wp--preset--color--text);
  border: 1px solid var(--wp--preset--color--text);
}
.wp-block-button.is-style-outline > .wp-block-button__link:hover {
  background: var(--wp--preset--color--text);
  color: var(--wp--preset--color--white);
}
.wp-block-button.is-style-ghost > .wp-block-button__link {
  background: transparent;
  color: var(--wp--preset--color--primary);
  padding-left: 0;
  padding-right: 0;
}

/* ================================================================
   DECORATIVE / KICKER TEXT
   ================================================================ */
.sb-kicker,
.sb-issue-badge {
  font-family: 'Inter', sans-serif;
  font-variant-caps: all-small-caps;
  font-feature-settings: "smcp" 1, "c2sc" 1;
  letter-spacing: 0.18em;
  color: var(--wp--preset--color--muted);
  margin-bottom: 0.75rem !important;
}
.sb-kicker--center { text-align: center; }

/* ================================================================
   HERO COVER (background image with text overlay)
   ================================================================ */
.sb-hero-cover {
  display: flex;
  align-items: center;
  justify-content: center;
}
.sb-hero-cover .wp-block-cover__inner-container {
  max-width: 1100px;
  width: 100%;
  padding: 0 1.5rem;
  text-align: center;
}
.sb-hero-cover .sb-hero-title,
.sb-hero-cover .sb-hero-title em {
  color: #fff;
  font-size: clamp(3.25rem, 2rem + 7.5vw, 6.5rem);
  line-height: 1.05;
  margin-bottom: 1.25rem;
}
.sb-hero-cover .sb-hero-badge {
  color: #FAF4EC;
  margin-bottom: 1.5rem;
}
.sb-hero-cover .sb-hero-sub {
  color: #fff;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.625rem);
}

/* ================================================================
   ISSUE HERO (plain section header used on inner pages)
   ================================================================ */
.sb-issue-hero {
  text-align: center;
  padding: clamp(3rem, 8vw, 7rem) 1.5rem;
}

/* ================================================================
   EDITORIAL TWO-COLUMN BODY
   ================================================================ */
.sb-lead-body {
  column-count: 2;
  column-gap: 2.5rem;
}
.sb-lead-body > * { break-inside: avoid-column; }
@media (max-width: 900px) {
  .sb-lead-body { column-count: 1; }
}

.sb-byline {
  text-align: right;
  margin-top: var(--wp--preset--spacing--l);
}

/* ================================================================
   DIVIDER SECTION
   ================================================================ */
.sb-divider {
  text-align: center;
  padding: 1.25rem 1rem !important;
}
.sb-divider-marks {
  letter-spacing: 0.5em;
  font-size: 0.85rem;
  color: var(--wp--preset--color--primary);
  margin-bottom: 0.5rem !important;
}
.sb-divider h3.wp-block-heading {
  margin: 0.25rem 0 0 !important;
}
.sb-divider + .wp-block-group {
  padding-top: 1rem !important;
}

/* ================================================================
   PRODUCTS CATALOG GRID
   ================================================================ */
.sb-catalog {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: clamp(2rem, 4vw, 4rem);
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}
@media (max-width: 900px) and (min-width: 641px) {
  .sb-catalog { grid-template-columns: repeat(2, 1fr); }
}
.sb-c-item { display: block !important; }
.sb-c-item .wp-block-image,
.sb-c-item figure.wp-block-image {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 4 / 5 !important;
  margin: 0 0 1.25rem 0 !important;
  overflow: hidden !important;
  background: rgba(0,0,0,0.04);
}
.sb-c-item .wp-block-image img,
.sb-c-item figure.wp-block-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  aspect-ratio: auto !important;
  margin: 0 !important;
}
.sb-c-item h3,
.sb-c-item h3.wp-block-heading {
  margin: 0 0 0.5rem 0 !important;
  font-size: clamp(2rem, 1.5rem + 1.5vw, 2.75rem);
  line-height: 1.15;
}
.sb-c-item p {
  margin: 0 !important;
  font-size: 1.05rem;
  line-height: 1.55;
}
@media (max-width: 640px) {
  .sb-catalog { grid-template-columns: 1fr; gap: 3rem; }
  /* Locations index: stack to 1 column on small screens */
  .sb-index { grid-template-columns: 1fr !important; }
}

/* ================================================================
   FEATURE IMAGE + QUOTE
   ================================================================ */
.sb-pull-quote-section,
.sb-feature-quote {
  text-align: center;
  padding: clamp(3rem, 6vw, 5rem) 1.5rem;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.sb-pull-quote {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2.25rem);
  line-height: 1.4;
  margin: 0 auto 1rem;
  max-width: 800px;
}
.sb-quote-mark {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 5rem;
  line-height: 0.6;
  color: var(--wp--preset--color--primary);
  margin: 0 0 0.5rem;
}
.sb-pull-quote-cite {
  font-family: 'Inter', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.85rem;
  color: var(--wp--preset--color--muted);
}

/* ================================================================
   LOCATIONS INDEX GRID (Zwei Filialen)
   ================================================================ */
.sb-index {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: stretch;
  gap: clamp(2rem, 4vw, 3rem);
  max-width: 900px;
  margin: 3rem auto 0;
  padding: 0 1.5rem;
}
.sb-idx-row {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 2.5rem 2rem !important;
  border: 1px solid var(--sb-rule);
  background: rgba(255,255,255,0.35);
  gap: 0.6rem;
  box-sizing: border-box;
}
.sb-idx-row > * {
  margin: 0 !important;
  width: 100%;
  text-align: center !important;
}
.sb-idx-num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 2.75rem !important;
  color: var(--wp--preset--color--primary);
  line-height: 1;
}
.sb-idx-row h4.wp-block-heading {
  font-size: 2.25rem !important;
  line-height: 1.1 !important;
  margin-bottom: 0.5rem !important;
}
.sb-idx-addr {
  font-size: 1.05rem !important;
  line-height: 1.55 !important;
}
.sb-idx-hours {
  font-size: 0.95rem !important;
  line-height: 1.55 !important;
  color: var(--wp--preset--color--muted);
  margin-top: 0.25rem !important;
}
.sb-idx-link { margin-top: 0.75rem !important; }
.sb-idx-link a {
  font-family: 'Inter', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.85rem;
  color: var(--wp--preset--color--primary);
  text-decoration: none;
  border-bottom: 1px solid var(--wp--preset--color--primary);
  padding-bottom: 2px;
}
.sb-idx-link a:hover {
  color: var(--wp--preset--color--text);
  border-color: var(--wp--preset--color--text);
}
@media (max-width: 640px) {
  .sb-index { grid-template-columns: 1fr; max-width: 480px; }
}

/* ================================================================
   CLOSING CTA SECTION
   ================================================================ */
.sb-closing {
  text-align: center;
  padding: clamp(3rem, 6vw, 5rem) 1.5rem 0 !important;
  margin-bottom: 0 !important;
}

/* Kill every source of space between last section and footer line */
.wp-site-blocks > footer,
.wp-site-blocks > .wp-block-template-part:last-child {
  margin-block-start: 0 !important;
  margin-top: 0 !important;
}
.sb-main,
.wp-block-post-content {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* ================================================================
   MILESTONES TIMELINE
   ================================================================ */
.sb-milestones { max-width: 1100px; margin: 0 auto; }
.sb-milestone-row.wp-block-columns {
  align-items: flex-start;
  padding: 2rem 0;
  margin: 0;
  gap: 2rem;
}
.sb-ms-year {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: clamp(2.75rem, 2rem + 2.4vw, 4.5rem) !important;
  color: var(--wp--preset--color--primary);
  line-height: 1;
  margin: 0;
}
.sb-ms-kicker {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.5rem, 1.25rem + 1vw, 2rem);
  margin-bottom: 0.75rem;
}
.sb-ms-body p { font-size: 1.05rem; line-height: 1.6; }
.sb-ms-divider {
  border: 0 !important;
  border-top: 2px solid var(--wp--preset--color--text) !important;
  width: 80px !important;
  max-width: 80px !important;
  margin: 1.5rem 0 !important;
  background: transparent !important;
  height: 0 !important;
}
@media (max-width: 900px) {
  .sb-milestone-row.wp-block-columns { gap: 1.25rem; padding: 1.5rem 0; }
  .sb-milestone-row.wp-block-columns > .wp-block-column:first-child { flex-basis: 110px !important; }
}
@media (max-width: 640px) {
  .sb-milestone-row.wp-block-columns {
    flex-direction: column !important;
    gap: 0.4rem;
    padding: 1.25rem 0;
  }
  .sb-milestone-row.wp-block-columns > .wp-block-column,
  .sb-milestone-row.wp-block-columns.is-stacked-on-mobile > .wp-block-column {
    flex-basis: auto !important;
    width: 100% !important;
    min-width: 0;
    margin: 0;
    padding: 0;
  }
}

/* ================================================================
   TEAM INDEX
   ================================================================ */
.sb-team-index {
  max-width: 1100px;
  margin: 3rem auto 0;
  padding: 0 1.5rem;
}
.sb-t-row.wp-block-columns {
  align-items: center;
  padding: 1.5rem 0;
  border-top: 1px solid var(--sb-rule);
  margin: 0;
  gap: 2rem;
}
.sb-t-row.wp-block-columns:last-child { border-bottom: 1px solid var(--sb-rule); }
.sb-t-row .sb-t-num-col { display: none; }
.sb-t-row .sb-t-text-col { flex-grow: 1 !important; }
.sb-t-row .sb-t-img-col {
  flex-basis: 220px !important;
  flex-grow: 0 !important;
}
.sb-t-row .sb-t-text-col h4,
.sb-t-row .sb-t-text-col h4 em {
  font-size: clamp(1.625rem, 1.3rem + 1.2vw, 2.25rem) !important;
  margin-bottom: 0.35rem;
  line-height: 1.2;
}
.sb-t-role {
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  color: var(--wp--preset--color--muted);
  text-transform: uppercase;
  margin: 0;
}
.sb-t-img img {
  border-radius: 0 !important;
  aspect-ratio: 4 / 5 !important;
  object-fit: cover;
  width: 100%;
}
.sb-t-num { display: none; }
@media (max-width: 900px) {
  .sb-t-row .sb-t-img-col { flex-basis: 160px !important; }
}
@media (max-width: 720px) {
  /* 2-column card grid — each card independent height, no overlap */
  .sb-team-index {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    align-items: start; /* prevents empty-photo cards stretching to match taller neighbours */
  }
  .sb-t-row.wp-block-columns {
    display: flex !important;
    flex-direction: column-reverse !important; /* photo on top, name/role below */
    align-items: stretch !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    padding: 0 0 0.5rem !important;
    gap: 0.4rem !important;
    margin: 0 !important;
  }
  /* Force both inner columns to full width so they stack cleanly
     (WordPress only triggers its own stacking at 599px — we need 720px) */
  .sb-t-row .sb-t-img-col,
  .sb-t-row .sb-t-text-col {
    flex-basis: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .sb-t-row .sb-t-img img { aspect-ratio: 1/1 !important; width: 100%; object-fit: cover; }
  .sb-t-row .sb-t-text-col { text-align: left; padding-top: 0.35rem !important; }
  .sb-t-row .sb-t-text-col h4.wp-block-heading { font-size: 1.1rem !important; }
  .sb-t-role { font-size: 0.8rem !important; }
}
@media (max-width: 420px) {
  .sb-team-index { grid-template-columns: 1fr 1fr; gap: 0.75rem; }
  .sb-t-row .sb-t-text-col h4.wp-block-heading { font-size: 0.95rem !important; }
}

/* ================================================================
   IMAGE + TEXT SPREAD (Backstube section)
   ================================================================ */
.sb-spread.wp-block-columns,
.sb-featured-layout.wp-block-columns {
  align-items: flex-start !important;
  max-width: var(--sb-wide);
  margin: 0 auto;
  padding: clamp(3rem, 6vw, 5rem) 1.5rem;
  gap: clamp(2rem, 4vw, 4rem) !important;
}
.sb-spread.wp-block-columns > .wp-block-column,
.sb-featured-layout.wp-block-columns > .wp-block-column {
  align-self: flex-start !important;
}
@media (max-width: 900px) {
  .sb-spread.wp-block-columns,
  .sb-featured-layout.wp-block-columns {
    flex-direction: column !important;
  }
  .sb-spread.wp-block-columns > .wp-block-column,
  .sb-featured-layout.wp-block-columns > .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
  }
}

/* ================================================================
   FOOTER
   ================================================================ */
.sb-footer {
  text-align: left;
  border-top: 1px solid var(--sb-rule);
}
.sb-foot-grid.wp-block-columns {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem 1.5rem 2rem;
  gap: clamp(2rem, 4vw, 4rem);
  flex-wrap: wrap !important;
  justify-content: flex-start;
}
.sb-foot-grid .wp-block-column { text-align: left; }
.sb-foot-grid .sb-kicker { display: block; margin-bottom: 0.75rem; }
.sb-foot-grid h4.wp-block-heading {
  font-size: 1.25rem !important;
  line-height: 1.3 !important;
  margin-top: 1.25rem;
  margin-bottom: 0.35rem;
}
.sb-foot-grid h4.wp-block-heading:first-of-type { margin-top: 0; }
.sb-foot-grid p { margin: 0.25rem 0; line-height: 1.55; }
.sb-foot-rule {
  max-width: 1200px;
  margin-left: auto !important;
  margin-right: auto !important;
}
.sb-foot-copy {
  max-width: 1200px;
  margin: 1.5rem auto 0;
  padding: 0 1.5rem 2rem;
  font-size: 0.9rem;
  color: var(--wp--preset--color--muted);
  text-align: center;
}
@media (max-width: 900px) {
  .sb-foot-grid.wp-block-columns > .wp-block-column {
    flex-basis: calc(50% - 1.25rem) !important;
  }
}
@media (max-width: 640px) {
  .sb-foot-grid.wp-block-columns > .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
  }
}

/* ================================================================
   CONTACT FORM
   ================================================================ */
.sb-contact-form-wrap {
  max-width: 1200px;
  margin: 0 auto !important;
}
.sb-contact-form-wrap form,
.sb-contact-form-wrap .wp-block-schweglerbeck-contact-form {
  width: 100%;
  max-width: 100%;
}

/* ================================================================
   BUTTONS
   ================================================================ */
.wp-block-button .wp-block-button__link {
  background-color: var(--wp--preset--color--primary) !important;
  color: #fff !important;
}
.wp-block-button .wp-block-button__link:hover {
  background-color: #5C2418 !important;
  color: #fff !important;
}

/* ================================================================
   HEADINGS — fluid editorial scale
   ================================================================ */
h1.wp-block-heading,
.wp-block-post-title,
.sb-hero-cover .sb-hero-title {
  font-size: clamp(3.5rem, 2rem + 7vw, 7rem) !important;
  font-weight: 600 !important;
  line-height: 1.05 !important;
  letter-spacing: -0.015em;
}
h2.wp-block-heading {
  font-size: clamp(2.75rem, 1.8rem + 4vw, 5rem) !important;
  font-weight: 600 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.01em;
}
h3.wp-block-heading {
  font-size: clamp(2rem, 1.5rem + 2vw, 3.25rem) !important;
  font-weight: 600 !important;
  line-height: 1.15 !important;
}
h4.wp-block-heading {
  font-size: clamp(1.625rem, 1.3rem + 1.2vw, 2.25rem) !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
}

/* Exceptions — keep these smaller than the global scale */
.sb-foot-grid h4.wp-block-heading {
  font-size: 1.25rem !important;
}
.sb-t-row .sb-t-text-col h4.wp-block-heading {
  font-size: clamp(1.75rem, 1.4rem + 1.2vw, 2.5rem) !important;
}
.sb-ms-year.wp-block-heading {
  font-size: clamp(2.75rem, 2rem + 2.4vw, 4.5rem) !important;
}
.sb-idx-row h4.wp-block-heading {
  font-size: 2.25rem !important;
}

/* Brand-red italic accent inside headings */
.wp-block-heading em {
  color: var(--wp--preset--color--primary);
  font-style: italic;
}

/* ================================================================
   SECTION RHYTHM
   ================================================================ */
.sb-issue-hero h1.wp-block-heading,
.sb-issue-hero h2.wp-block-heading,
.sb-catalog-section h2.wp-block-heading,
.sb-locations-section h2.wp-block-heading,
.sb-closing h2.wp-block-heading {
  margin-bottom: 1.5rem !important;
}

/* ================================================================
   MOBILE TYPOGRAPHY — larger text for readability on small screens
   ================================================================ */
@media (max-width: 720px) {
  /* General paragraph text — was ~17px, now 18px */
  p {
    font-size: 1.125rem;
    line-height: 1.65;
  }

  /* Kicker labels (small-caps) — was ~14px, now 15px */
  .sb-kicker,
  .is-style-kicker {
    font-size: 0.9rem !important;
    letter-spacing: 0.14em !important;
  }

  /* Hero subtitle */
  .sb-hero-sub { font-size: 1.25rem !important; line-height: 1.5 !important; }

  /* Pull quote */
  .sb-pull-quote { font-size: 1.5rem !important; line-height: 1.45 !important; }

  /* Catalog item description */
  .sb-c-item p { font-size: 1.0625rem !important; }

  /* Location / contact card text */
  .sb-idx-addr  { font-size: 1.0625rem !important; line-height: 1.6 !important; }
  .sb-idx-hours { font-size: 1rem !important;      line-height: 1.6 !important; }

  /* Milestone body */
  .sb-ms-body p { font-size: 1.0625rem !important; line-height: 1.65 !important; }

  /* Footer columns */
  .sb-foot-grid p { font-size: 1rem !important; line-height: 1.6 !important; }

  /* Contact form — labels, inputs, textareas
     16px minimum prevents iOS Safari from auto-zooming on focus */
  .sb-contact-form-wrap label,
  .sb-contact-form-wrap input,
  .sb-contact-form-wrap textarea,
  .sb-contact-form-wrap select,
  .sb-contact-form-wrap p,
  input, textarea, select { font-size: 1rem !important; }
  label { font-size: 1.0625rem !important; }

  /* Navigation overlay items — was 2rem, keep but ensure minimum */
  .wp-block-navigation a {
    font-size: 1.0625rem !important;
  }
}

/* ================================================================
   GLOBAL MOBILE PADDING
   ================================================================ */
@media (max-width: 720px) {
  .sb-issue-hero,
  .sb-closing,
  .sb-divider,
  .sb-pull-quote-section,
  .sb-feature-quote,
  .sb-catalog-section,
  .sb-locations-section {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }
  .sb-lead-body,
  .sb-byline,
  .sb-foot-grid.wp-block-columns,
  .sb-foot-copy,
  .sb-catalog,
  .sb-team-index,
  .sb-milestones {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }
}

/* ================================================================
   BACK-TO-TOP BUTTON
   ================================================================ */
.sb-to-top {
  position: fixed;
  right: clamp(1rem, 2vw, 2rem);
  bottom: clamp(1rem, 2vw, 2rem);
  z-index: 9999;
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  background: var(--wp--preset--color--primary);
  color: #fff;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(30,26,20,0.18);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity 0.35s ease, transform 0.35s ease, background-color 0.25s ease;
}
.sb-to-top:hover { background: #5C2418; transform: translateY(-2px); }
.sb-to-top.is-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.sb-to-top svg { display: block; }

/* ================================================================
   REVEAL ON SCROLL
   ================================================================ */
.sb-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}
.sb-reveal.is-in-view { opacity: 1; transform: none; }
.sb-issue-hero > .sb-reveal:nth-child(2) { transition-delay: 0.08s; }
.sb-issue-hero > .sb-reveal:nth-child(3) { transition-delay: 0.16s; }
.sb-hero-cover .wp-block-cover__inner-container > .sb-reveal:nth-child(2) { transition-delay: 0.1s; }
.sb-hero-cover .wp-block-cover__inner-container > .sb-reveal:nth-child(3) { transition-delay: 0.2s; }
.sb-catalog .sb-c-item.sb-reveal:nth-child(2) { transition-delay: 0.08s; }
.sb-catalog .sb-c-item.sb-reveal:nth-child(3) { transition-delay: 0.16s; }
.sb-catalog .sb-c-item.sb-reveal:nth-child(4) { transition-delay: 0.08s; }
.sb-catalog .sb-c-item.sb-reveal:nth-child(5) { transition-delay: 0.16s; }
.sb-catalog .sb-c-item.sb-reveal:nth-child(6) { transition-delay: 0.24s; }

/* ================================================================
   ACCESSIBILITY
   ================================================================ */
:focus-visible {
  outline: 2px solid var(--wp--preset--color--primary);
  outline-offset: 2px;
}
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 999;
  padding: 0.75rem 1rem;
  background: var(--wp--preset--color--text);
  color: var(--wp--preset--color--white);
  text-decoration: none;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* Utility: force a heading onto one line (add class "sb-nowrap" in editor) */
.sb-nowrap { white-space: nowrap; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .sb-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .sb-to-top { transition: opacity 0.2s ease; }
  .sb-to-top:hover { transform: none; }
}
