/*
Theme Name: Jono Shaffer
Theme URI: https://sbweddingguy.com/
Description: Custom FSE block theme for Jono Shaffer, Wedding Officiant – Santa Barbara, CA. Refined luxury aesthetic, fully editable in the Gutenberg block editor.
Version: 2.0.0
Author: Custom
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jono-schaffer
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
Tags: full-site-editing, block-patterns, custom-colors, custom-fonts, wedding
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

/* ── Variables ─────────────────────────────── */
:root {
  --cream:      #faf7f2;
  --parchment:  #f0ead8;
  --gold:       #b8935a;
  --gold-light: #d4a96a;
  --gold-pale:  #e8d5b0;
  --dark:       #1a1512;
  --text:       #3a3028;
  --text-light: #7a6e60;
  --white:      #ffffff;
  --ink:        #100d0a;
  --serif:      'Cormorant Garamond', Georgia, serif;
  --sans:       'Jost', sans-serif;
}

/* ── Base ──────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  background: var(--cream);
  color: var(--text);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--serif);
  font-weight: 300;
  line-height: 1.15;
}

h4 { font-size: 1.35rem; font-weight: 400; }

a { color: var(--gold); }

/* ── Header / Nav ──────────────────────────── */
.jono-site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(250,247,242,0.97);
  box-shadow: 0 2px 30px rgba(0,0,0,0.06);
  padding: 0 5% !important;
  height: 80px;
}
.jono-nav-inner {
  height: 80px;
  padding: 0 !important;
}
/* Site title as logo */
.jono-site-header .wp-block-site-title a,
.jono-nav-logo a {
  font-family: var(--serif) !important;
  font-size: 1.35rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  color: var(--dark) !important;
  text-decoration: none !important;
}
/* Nav links */
.jono-nav-links .wp-block-navigation__container,
.jono-nav-links ul { gap: 2.5rem !important; }
.jono-nav-links a {
  font-family: var(--sans) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--text-light) !important;
  text-decoration: none !important;
  transition: color 0.2s;
}
.jono-nav-links a:hover,
.jono-nav-links .current-menu-item a { color: var(--gold) !important; }
/* CTA button */
.jono-nav-cta-wrap { margin-left: 1rem; }
.jono-nav-cta .wp-block-button__link {
  font-family: var(--sans) !important;
  font-size: 0.73rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  background: transparent !important;
  color: var(--gold) !important;
  border: 1px solid var(--gold) !important;
  border-radius: 0 !important;
  padding: 0.55rem 1.4rem !important;
  transition: all 0.3s !important;
}
.jono-nav-cta .wp-block-button__link:hover {
  background: var(--gold) !important;
  color: var(--white) !important;
}
/* Push page content below fixed header */
.jono-page-main,
.jono-hero { margin-top: 0; }
.jono-page-top { padding-top: calc(80px + 4rem) !important; }

/* ── Sections ──────────────────────────────── */
.jono-section {
  padding: 6rem 7% !important;
  background: var(--cream);
}
.jono-section-alt {
  padding: 6rem 7% !important;
  background: var(--parchment);
}
.jono-section-dark {
  padding: 6rem 7% !important;
  background: var(--dark);
  color: var(--white);
}

/* ── Two-col layout ────────────────────────── */
.jono-two-col.wp-block-columns {
  align-items: start !important;
  gap: 5rem !important;
}
@media (max-width: 781px) {
  .jono-two-col.wp-block-columns { flex-direction: column !important; gap: 3rem !important; }
  .jono-two-col .wp-block-column { flex-basis: 100% !important; }
  .jono-feature-card { margin-bottom: 1.5rem; }
  .jono-reviews-grid { flex-direction: column !important; }
}

/* ── Typography helpers ────────────────────── */
.jono-eyebrow {
  font-family: var(--sans) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.28em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  margin-bottom: 1.2rem !important;
}
.jono-eyebrow::before {
  content: '';
  display: block;
  width: 32px; height: 1px;
  background: var(--gold);
  flex-shrink: 0;
}
.jono-eyebrow-center { justify-content: center !important; }
.jono-eyebrow-center::before { display: none !important; }
.jono-eyebrow-gold { color: var(--gold-light) !important; }

.jono-display {
  font-family: var(--serif) !important;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem) !important;
  font-weight: 300 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 1rem !important;
}
.jono-display em { color: var(--gold); font-style: italic; }

.jono-divider.wp-block-separator {
  width: 56px !important;
  height: 1px !important;
  background-color: var(--gold) !important;
  border: none !important;
  margin: 2rem 0 !important;
  opacity: 1 !important;
}
.jono-divider-center { margin-left: auto !important; margin-right: auto !important; }

.jono-text-light { color: var(--text-light) !important; line-height: 1.9 !important; }

/* ── Buttons ───────────────────────────────── */
.jono-btn-primary .wp-block-button__link {
  background: var(--gold) !important;
  color: var(--white) !important;
  border: 1px solid var(--gold) !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 1rem 2.5rem !important;
  transition: all 0.3s !important;
}
.jono-btn-primary .wp-block-button__link:hover {
  background: var(--gold-light) !important;
  border-color: var(--gold-light) !important;
  transform: translateY(-2px);
}
.jono-btn-outline-gold .wp-block-button__link {
  background: transparent !important;
  color: var(--gold) !important;
  border: 1px solid var(--gold) !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 1rem 2.5rem !important;
  transition: all 0.3s !important;
}
.jono-btn-outline-gold .wp-block-button__link:hover {
  background: var(--gold) !important;
  color: var(--white) !important;
}
.jono-btn-ghost .wp-block-button__link {
  background: transparent !important;
  color: var(--white) !important;
  border: 1px solid rgba(255,255,255,0.5) !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 1rem 2.5rem !important;
  transition: all 0.3s !important;
}
.jono-btn-ghost .wp-block-button__link:hover { background: rgba(255,255,255,0.12) !important; }

/* ── Hero ──────────────────────────────────── */
.jono-hero.wp-block-cover {
  min-height: 100vh !important;
  align-items: flex-end !important;
  padding: 0 7% 9% !important;
}
.jono-hero .wp-block-cover__inner-container { width: 100%; max-width: 1200px; margin: 0 auto; }
.jono-hero-content { 
  padding: 10px;
  background-color: rgb(0 0 0 / 50%);
}
.jono-hero .wp-block-heading { color: var(--white) !important; }
.jono-hero .wp-block-heading em { color: var(--gold-light); font-style: italic; }
.jono-hero-sub { color: rgba(255,255,255,0.8) !important; max-width: 440px; }
.jono-hero-btns { gap: 1rem !important; }

/* ── Image frame ───────────────────────────── */
.jono-img-frame { position: relative; }
.jono-img-frame::after {
  content: '';
  position: absolute;
  top: 20px; right: -20px; bottom: -20px; left: 20px;
  border: 1px solid var(--gold-pale);
  z-index: -1;
  pointer-events: none;
}
.jono-placeholder {
  background: linear-gradient(135deg, var(--parchment) 0%, var(--gold-pale) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-light);
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.95rem;
  width: 100%;
  min-height: 320px;
  aspect-ratio: 3 / 4;
}
.jono-placeholder-img figure,
.jono-placeholder-img img { width: 100%; aspect-ratio: 3/4; object-fit: cover; }
.jono-gold-tag {
  display: inline-block;
  background: var(--gold);
  color: var(--white) !important;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
  padding: 0.85rem 1.5rem;
  margin-top: 1rem;
}

/* ── Feature cards ─────────────────────────── */
.jono-feature-card.wp-block-column {
  border: 1px solid var(--gold-pale);
  padding: 3rem 2rem !important;
  text-align: center;
  transition: border-color 0.3s, transform 0.3s;
}
.jono-feature-card.wp-block-column:hover { border-color: var(--gold); transform: translateY(-4px); }
.jono-feature-icon { font-size: 1.8rem !important; color: var(--gold) !important; margin-bottom: 1rem !important; }
.jono-features.wp-block-columns { gap: 2.5rem !important; }
@media (max-width: 781px) { .jono-features.wp-block-columns { flex-direction: column !important; } }

/* ── Stat bar ──────────────────────────────── */
.jono-stat-bar { padding: 0 !important; }
.jono-stats-cols.wp-block-columns { gap: 0 !important; margin: 0 !important; }
.jono-stat.wp-block-column {
  padding: 3.5rem 1rem !important;
  border-right: 1px solid rgba(255,255,255,0.08);
  text-align: center;
}
.jono-stat.wp-block-column:last-child { border-right: none; }
.jono-stat-num.wp-block-heading {
  font-family: var(--serif) !important;
  font-size: 3.2rem !important;
  font-weight: 300 !important;
  color: var(--gold-light) !important;
  line-height: 1 !important;
  margin-bottom: 0.5rem !important;
}
.jono-stat-label { font-size: 0.7rem !important; letter-spacing: 0.2em !important; text-transform: uppercase !important; color: rgba(255,255,255,0.5) !important; margin: 0 !important; }

/* ── Testimonial strip ─────────────────────── */
.jono-testimonial-strip { padding: 6rem 10% !important; }
.jono-pull-quote {
  border: none !important;
  padding: 0 !important;
  margin: 1.5rem 0 !important;
}
.jono-pull-quote p {
  font-family: var(--serif) !important;
  font-size: clamp(1.4rem, 3vw, 2rem) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  line-height: 1.55 !important;
  color: var(--white) !important;
}
.jono-pull-quote cite {
  font-family: var(--sans) !important;
  font-size: 0.73rem !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  color: var(--gold-light) !important;
  font-style: normal !important;
}

/* ── About stats ───────────────────────────── */
.jono-about-stats.wp-block-columns { gap: 2rem !important; margin: 2.5rem 0 !important; }
.jono-about-stat.wp-block-column { text-align: center; }
.jono-about-stat-num.wp-block-heading {
  font-family: var(--serif) !important;
  font-size: 3rem !important;
  font-weight: 300 !important;
  color: var(--gold) !important;
  line-height: 1 !important;
  margin-bottom: 0.3rem !important;
}
.jono-about-stat-label { font-size: 0.7rem !important; letter-spacing: 0.16em !important; text-transform: uppercase !important; color: var(--text-light) !important; margin: 0 !important; }

/* ── Price cards ───────────────────────────── */
.jono-price-card.wp-block-group {
  border-left: 3px solid var(--gold) !important;
  padding: 2.5rem 3rem !important;
  background: var(--white) !important;
  margin-bottom: 2rem;
}
.jono-price-card h3 { font-size: 1.65rem !important; font-weight: 400 !important; margin-bottom: 0.3rem !important; color: var(--dark) !important; }
.jono-price-tag { font-family: var(--serif) !important; font-size: 1.8rem !important; font-style: italic !important; color: var(--gold) !important; margin-bottom: 1.2rem !important; }
.jono-services-list { list-style: none !important; padding: 0 !important; margin: 0.5rem 0 0 !important; }
.jono-services-list li { font-size: 0.88rem !important; color: var(--text-light) !important; padding: 0.45rem 0 0.45rem 1.6rem !important; position: relative; border-bottom: 1px solid var(--parchment); }
.jono-services-list li::before { content: '—'; position: absolute; left: 0; color: var(--gold); }
.jono-note { font-size: 0.8rem !important; color: var(--text-light) !important; font-style: italic !important; margin-top: 1.2rem !important; }

/* ── Reviews ───────────────────────────────── */
.jono-reviews-grid.wp-block-columns { gap: 2.5rem !important; align-items: start !important; }
.jono-review-card.wp-block-group {
  background: var(--white) !important;
  padding: 3rem !important;
  position: relative;
  margin-bottom: 0;
}
.jono-review-card::before {
  content: '\201C';
  font-family: var(--serif);
  font-size: 7rem;
  line-height: 0.5;
  color: var(--gold-pale);
  position: absolute;
  top: 2rem; left: 2rem;
  pointer-events: none;
}
.jono-review-stars { color: var(--gold) !important; font-size: 0.82rem !important; letter-spacing: 0.1em !important; margin-bottom: 1.2rem !important; }
.jono-review-text { font-family: var(--serif) !important; font-size: 1.05rem !important; font-style: italic !important; line-height: 1.78 !important; margin-bottom: 1.8rem !important; position: relative; z-index: 1; }
.jono-reviewer.wp-block-group { gap: 1rem !important; padding: 0 !important; }
.jono-reviewer-avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--gold-pale); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 0.85rem; color: var(--gold); flex-shrink: 0; margin: 0 !important; padding: 0 !important; }
.jono-reviewer-name { font-size: 0.78rem !important; letter-spacing: 0.12em !important; text-transform: uppercase !important; font-weight: 400 !important; margin: 0 !important; }

/* ── FAQs (wp:details) ─────────────────────── */
.jono-faq-item.wp-block-details {
  border-top: 1px solid var(--gold-pale);
  padding: 0 !important;
  margin: 0 !important;
}
.jono-faq-item.wp-block-details:last-child { border-bottom: 1px solid var(--gold-pale); }
.jono-faq-item summary {
  font-family: var(--serif) !important;
  font-size: 1.08rem !important;
  font-weight: 400 !important;
  color: var(--dark) !important;
  padding: 1.5rem 0 !important;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  transition: color 0.2s;
}
.jono-faq-item summary:hover { color: var(--gold) !important; }
.jono-faq-item summary::after {
  content: '+';
  color: var(--gold);
  font-size: 1.3rem;
  font-weight: 300;
  flex-shrink: 0;
  transition: transform 0.3s;
}
.jono-faq-item[open] summary::after { transform: rotate(45deg); }
.jono-faq-item p { font-size: 0.92rem !important; color: var(--text-light) !important; line-height: 1.88 !important; padding-bottom: 1.5rem !important; }
.jono-faq-item summary::-webkit-details-marker { display: none; }

/* ── Contact block ─────────────────────────── */
.jono-contact-block.wp-block-group {
  background: var(--dark) !important;
  color: var(--white) !important;
  padding: 7rem 7% !important;
  text-align: center;
}
.jono-contact-heading {
  font-family: var(--serif) !important;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  font-weight: 300 !important;
  color: var(--white) !important;
  margin-bottom: 1rem !important;
}
.jono-contact-heading em { color: var(--gold-light); font-style: italic; }
.jono-contact-intro { color: rgba(255,255,255,0.58) !important; max-width: 520px; margin: 0 auto 2.5rem !important; font-size: 0.95rem !important; line-height: 1.85 !important; }
.jono-contact-items.wp-block-group { gap: 0.5rem 3rem !important; padding: 0 !important; margin-bottom: 1rem; }
.jono-contact-item { color: rgba(255,255,255,0.72) !important; font-size: 0.9rem !important; margin: 0 !important; display: flex; align-items: center; gap: 0.7rem; }
.jono-contact-item a { color: var(--gold-light) !important; text-decoration: none; transition: color 0.2s; }
.jono-contact-item a:hover { color: var(--white) !important; }
.jono-contact-icon { color: var(--gold); }
.jono-dir-btn .wp-block-button__link {
  background: transparent !important;
  color: var(--white) !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  padding: 0.7rem 1.6rem !important;
  transition: all 0.3s !important;
}
.jono-dir-btn .wp-block-button__link:hover { border-color: var(--gold) !important; color: var(--gold) !important; }

/* ── Site footer ───────────────────────────── */
.jono-site-footer.wp-block-group {
  background: var(--ink) !important;
  padding: 1.8rem !important;
}
.jono-footer-text { color: rgba(255,255,255,0.32) !important; font-size: 0.75rem !important; letter-spacing: 0.08em !important; margin: 0 !important; }

/* ── Section header ────────────────────────── */
.jono-section-header { text-align: center; }

/* ── Block editor cleanup ──────────────────── */
.wp-site-blocks { padding-top: 0 !important; }
.is-root-container > * { margin-top: 0 !important; margin-bottom: 0 !important; }

/* ── Additional rules ──────────────────────── */
.jono-review-card-mt { margin-top: 2.5rem !important; }
.jono-reviews-intro  { max-width: 680px; margin: 0 auto 4rem !important; }
.jono-divider-center.wp-block-separator { margin-left: auto !important; margin-right: auto !important; }
.jono-includes-label { font-size: 0.8rem !important; letter-spacing: 0.12em !important; text-transform: uppercase !important; font-weight: 500 !important; margin-bottom: 0.5rem !important; }
.jono-btn-outline-light .wp-block-button__link {
  background: transparent !important;
  color: var(--gold-light) !important;
  border: 1px solid var(--gold-light) !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 1rem 2.5rem !important;
  transition: all 0.3s !important;
}
.jono-btn-outline-light .wp-block-button__link:hover { background: var(--gold) !important; color: var(--white) !important; border-color: var(--gold) !important; }
.jono-eyebrow-light { color: var(--gold-light) !important; }
/* Hero heading override */
.jono-hero-heading { font-family: var(--serif) !important; font-size: clamp(3rem,7vw,5.5rem) !important; font-weight: 300 !important; line-height: 1.05 !important; color: var(--white) !important; }
.jono-hero-heading em { color: var(--gold-light) !important; font-style: italic !important; }
.jono-hero-sub { color: rgba(255,255,255,0.8) !important; max-width: 440px; line-height: 1.82 !important; }
/* Cover block inner container full-width */
.jono-hero .wp-block-cover__inner-container { max-width: 100% !important; padding-left: 7% !important; padding-right: 7% !important; }
/* Nav: hide WordPress admin bar overlap */
.admin-bar .jono-site-header { top: 32px; }

@media (min-width: 769px) {
    .jono-ministry-column {
        margin-top: 107px !important;
    }
}

/* ── Mobile nav fixes ──────────────────────── */

/* 1. Hamburger button: desktop — hide entirely */
.jono-site-header .wp-block-navigation__responsive-container-open {
    display: none !important;
}

/* Hamburger button: mobile only — show, push to far right */
@media (max-width: 781px) {
    .jono-site-header .wp-block-navigation__responsive-container-open {
        display: flex !important;
        margin-left: auto !important;
        align-items: center !important;
    }
    .jono-site-header .wp-block-navigation__responsive-container-open button {
        display: flex !important;
        align-items: center !important;
    }
}

/* Ensure the nav block itself allows the hamburger to sit at the end */
.jono-site-header .wp-block-navigation {
    margin-left: auto !important;
}

/* 2. Mobile overlay menu: full-screen, right-aligned items, no overflow clipping */
.jono-site-header .wp-block-navigation__responsive-container.is-menu-open {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important; /* dynamic viewport height for mobile browsers */
    overflow-y: auto !important;
    overflow-x: hidden !important;
    background: rgba(250, 247, 242, 0.98) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-end !important;
    padding: 5rem 2rem 3rem !important;
    box-sizing: border-box !important;
    z-index: 9999 !important;
}

/* Menu items inside the overlay */
.jono-site-header .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__container {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 2rem !important;
    width: 100% !important;
}

/* Individual nav links in mobile overlay */
.jono-site-header .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation-item__content {
    font-family: var(--serif) !important;
    font-size: 1.8rem !important;
    font-weight: 300 !important;
    letter-spacing: 0.04em !important;
    color: var(--dark) !important;
    text-decoration: none !important;
    text-align: right !important;
}

/* Close button: top-right corner */
.jono-site-header .wp-block-navigation__responsive-container-close {
    position: fixed !important;
    top: 1.4rem !important;
    right: 5% !important;
    z-index: 10000 !important;
}

/* 3. Landscape mobile: reduce header height so it doesn't crowd content */
@media (max-height: 500px) and (orientation: landscape) {
    .jono-site-header {
        height: 56px !important;
    }
    .jono-nav-inner {
        height: 56px !important;
    }
    .jono-site-header .wp-block-site-title a,
    .jono-nav-logo a {
        font-size: 1rem !important;
    }
    /* Shrink CTA button in landscape */
    .jono-nav-cta .wp-block-button__link {
        padding: 0.4rem 1rem !important;
        font-size: 0.65rem !important;
    }
    /* Mobile overlay in landscape: scrollable, items smaller */
    .jono-site-header .wp-block-navigation__responsive-container.is-menu-open {
        padding-top: 4rem !important;
        justify-content: flex-start !important;
        padding-top: 3.5rem !important;
    }
    .jono-site-header .wp-block-navigation__responsive-container.is-menu-open
        .wp-block-navigation-item__content {
        font-size: 1.2rem !important;
    }
    .jono-site-header .wp-block-navigation__responsive-container.is-menu-open
        .wp-block-navigation__container {
        gap: 1.2rem !important;
    }
}

/* 4. On small screens, hide the CTA "Get in Touch" button to avoid crowding */
@media (max-width: 781px) {
    .jono-nav-cta {
        display: none !important;
    }
}

/* ── Mobile hero: push text box to bottom so faces are visible ── */
@media (max-width: 781px) {

    /* Give the cover enough top padding to force content to the very bottom */
    .jono-hero.wp-block-cover {
        align-items: flex-end !important;
        padding-top: 55vh !important;   /* pushes inner container below face area */
        padding-bottom: 4% !important;
    }

    /* Make the grey overlay box more compact */
    .jono-hero-content {
        padding: 1.2rem 1rem !important;
    }

    /* Tighten heading so box is shorter */
    .jono-hero-heading {
        font-size: clamp(1.7rem, 7vw, 2.4rem) !important;
        margin-bottom: 0.5rem !important;
    }

    /* Shorter subtext */
    .jono-hero-sub {
        font-size: 0.9rem !important;
        line-height: 1.6 !important;
        margin-bottom: 0.8rem !important;
        max-width: 100% !important;
    }

    /* Eyebrow above heading */
    .jono-hero .jono-eyebrow {
        margin-bottom: 0.6rem !important;
        font-size: 0.65rem !important;
    }

    /* Tighter button row */
    .jono-hero-btns {
        flex-direction: column !important;
        gap: 0.6rem !important;
    }
    .jono-hero-btns .wp-block-button__link {
        width: 100% !important;
        text-align: center !important;
        padding: 0.75rem 1.5rem !important;
    }
}

/* ── Landscape mobile: hide hamburger (full nav is visible) ──── */
@media (max-height: 500px) and (orientation: landscape) {

    /* Hide the hamburger toggle entirely — nav links are already shown */
    .jono-site-header .wp-block-navigation__responsive-container-open {
        display: none !important;
    }

    /* Ensure the nav links container is visible in landscape */
    .jono-site-header .wp-block-navigation__responsive-container {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    /* Hero in landscape: reduce top padding so content isn't too low */
    .jono-hero.wp-block-cover {
        padding-top: 35vh !important;
        padding-bottom: 3% !important;
    }

    .jono-hero-heading {
        font-size: clamp(1.4rem, 5vw, 2rem) !important;
    }
}