/* ============================================================================
   OHLALA V4 — "La Bocca Boutique"
   Cream-based premium dessert boutique. Color is an ACCENT, never a block.
   Everything scoped under .oh4 so it never leaks onto v1 / v2 / v3.
   ============================================================================ */

.oh4 {
	/* Base — cream dominant */
	--c-cream:    #FBF6EC;
	--c-cream-2:  #F4ECD9;
	--c-ink:      #2A2018;
	--c-ink-soft: #6B5D4F;
	--c-line:     #E7DcC6;

	/* Fruit accents — used small */
	--a-strawberry: #FF4D6D;
	--a-mango:      #FFB23E;
	--a-kiwi:       #7DBA3C;
	--a-berry:      #C04CFC;
	--a-citrus:     #FF8A3D;
	--a-blue:       #1FA6DF;
	--oh4-head-h:   110px;

	--f-display: 'Fraunces', Georgia, serif;
	--f-body:    'Inter', system-ui, sans-serif;
	--f-accent:  'Satisfy', cursive;

	background: var(--c-cream);
	color: var(--c-ink);
	font-family: var(--f-body);
	font-size: 1.08rem;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}
.oh4 *, .oh4 *::before, .oh4 *::after { box-sizing: border-box; }
.oh4 img { max-width: 100%; display: block; }
.oh4 a { text-decoration: none; color: inherit; }
.oh4-body { margin: 0; background: var(--c-cream); }

/* ── Shared bits ─────────────────────────────────────────────────────────── */
.oh4-wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.oh4-section { padding: clamp(70px, 11vw, 120px) 0; position: relative; overflow: hidden; }
.oh4-section--tight { padding: clamp(50px, 8vw, 90px) 0; }

.oh4-eyebrow {
	font-family: var(--f-body);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .18em;
	font-size: .78rem;
	color: var(--a-strawberry);
	margin: 0 0 14px;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.oh4-eyebrow::before {
	content: '';
	width: 26px; height: 3px; border-radius: 3px;
	background: currentColor;
}
.oh4-script {
	font-family: var(--f-accent);
	color: var(--a-mango);
	font-weight: 400;
}

.oh4-h1, .oh4-h2, .oh4-h3 {
	font-family: var(--f-display);
	font-weight: 900;
	line-height: 1.02;
	letter-spacing: -.01em;
	margin: 0;
	color: var(--c-ink);
	font-optical-sizing: auto;
}
.oh4-h1 { font-size: clamp(2.7rem, 6vw, 4.6rem); }
.oh4-h2 { font-size: clamp(2.1rem, 4.4vw, 3.4rem); }
.oh4-h3 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); font-weight: 700; }
.oh4-lead { color: var(--c-ink-soft); font-size: 1.15rem; max-width: 46ch; }

/* wavy accent underline under a word/heading */
.oh4-uline { position: relative; display: inline-block; white-space: nowrap; }
.oh4-uline::after {
	content: '';
	position: absolute;
	left: 0; right: 0; bottom: -.32em;
	height: .35em;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M2 11 C 45 2 70 14 105 8 S 165 3 198 9' fill='none' stroke='%23FF4D6D' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center / 100% 100%;
}
.oh4-uline--mango::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M2 11 C 45 2 70 14 105 8 S 165 3 198 9' fill='none' stroke='%23FFB23E' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E"); }
.oh4-uline--kiwi::after  { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M2 11 C 45 2 70 14 105 8 S 165 3 198 9' fill='none' stroke='%237DBA3C' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E"); }

/* Buttons */
.oh4-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 9px;
	font-family: var(--f-body); font-weight: 600; font-size: 1rem;
	padding: 14px 28px; border-radius: 999px; cursor: pointer;
	border: 2px solid transparent; transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.oh4-btn--fill { background: var(--a-strawberry); color: #fff; box-shadow: 0 8px 20px rgba(255,77,109,.28); }
.oh4-btn--fill:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(255,77,109,.36); }
.oh4-btn--mango { background: var(--a-mango); color: var(--c-ink); box-shadow: 0 8px 20px rgba(255,178,62,.3); }
.oh4-btn--mango:hover { transform: translateY(-2px); }
.oh4-btn--green { background: var(--a-kiwi); color: #fff; box-shadow: 0 8px 20px rgba(125,186,60,.3); }
.oh4-btn--green:hover { transform: translateY(-2px); }
.oh4-btn--outline { background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.oh4-btn--outline:hover { background: var(--c-ink); color: var(--c-cream); transform: translateY(-2px); }

/* Soft blurred color glow behind floating products */
.oh4-glow { position: absolute; border-radius: 50%; filter: blur(54px); opacity: .5; z-index: 0; pointer-events: none; }
.oh4-glow--strawberry { background: var(--a-strawberry); }
.oh4-glow--mango      { background: var(--a-mango); }
.oh4-glow--kiwi       { background: var(--a-kiwi); }
.oh4-glow--citrus     { background: var(--a-citrus); }

/* Decorative confetti dots + blobs */
.oh4-dot { position: absolute; border-radius: 50%; z-index: 1; pointer-events: none; }
.oh4-ring { position: absolute; border-radius: 50%; border: 3px dotted; z-index: 1; pointer-events: none; opacity: .5; }

/* Gentle float on hero products */
.oh4-float { animation: oh4-float 4s ease-in-out infinite; }
.oh4-float--slow { animation-duration: 5.5s; }
.oh4-float--delay { animation-delay: .8s; }
@keyframes oh4-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@media (prefers-reduced-motion: reduce) {
	.oh4-float, .oh4-float--slow, .oh4-float--delay { animation: none; }
}

/* Scroll-reveal slide-up (classes added by js/oh4-nav.js) */
.oh4-anim .oh4-reveal { opacity: 0; transform: translateY(40px); transition: opacity .65s ease, transform .65s cubic-bezier(.2,.7,.2,1); }
.oh4-anim .oh4-reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
	.oh4-anim .oh4-reveal { opacity: 1; transform: none; transition: none; }
}

/* ── Header (sticky slim) ────────────────────────────────────────────────── */
/* Header OVERLAYS the hero (no cream bar, no reserved space) until scrolled. */
.oh4-header {
	position: absolute;
	top: 0; left: 0; right: 0;
	z-index: 70;
	background: transparent;
	box-shadow: none;
	transition: background .25s ease, box-shadow .25s ease;
}
.oh4-header.is-scrolled {
	position: fixed;
	background: var(--c-cream);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.oh4-header-inner { display: flex; align-items: center; justify-content: space-between; min-height: var(--oh4-head-h); }
.oh4-logo { flex: 0 0 auto; }
.oh4-logo img { height: calc(var(--oh4-head-h) - 22px); width: auto; filter: drop-shadow(0 2px 6px rgba(0,0,0,.25)); }
.oh4-nav { display: flex; align-items: center; gap: 30px; }
.oh4-nav-links { display: flex; gap: 26px; list-style: none; margin: 0; padding: 0; }
.oh4-nav-links a { font-weight: 500; color: var(--c-ink); position: relative; padding: 4px 0; }
.oh4-nav-links a::after { content: ''; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px; background: var(--a-strawberry); transition: width .2s ease; }
.oh4-nav-links a:hover::after { width: 100%; }
.oh4-nav .oh4-btn { padding: 11px 22px; }

.oh4-burger {
	display: none;
	width: 46px; height: 46px; border: none; background: none; cursor: pointer;
	flex-direction: column; gap: 5px; align-items: center; justify-content: center;
}
.oh4-burger span { width: 24px; height: 2.5px; border-radius: 2px; background: var(--c-ink); transition: background .2s ease, transform .2s ease, opacity .2s ease; }
/* white hamburger before scroll (soft shadow keeps it visible on light heroes) */
.oh4-header:not(.is-scrolled) .oh4-burger span { background: #fff; box-shadow: 0 0 3px rgba(0,0,0,.4); }
.oh4-header.is-scrolled .oh4-burger span { background: var(--c-ink); box-shadow: none; }

/* mobile nav sheet */
.oh4-mobnav {
	position: fixed; inset: 0; z-index: 100;
	background: var(--c-cream);
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 22px;
	opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease;
}
body.oh4-nav-open { overflow: hidden; }
body.oh4-nav-open .oh4-mobnav { opacity: 1; visibility: visible; }
.oh4-mobnav a { font-family: var(--f-display); font-weight: 700; font-size: 2rem; color: var(--c-ink); }
.oh4-mobnav-close { position: absolute; top: 22px; right: 24px; background: none; border: none; font-size: 2.6rem; line-height: 1; cursor: pointer; color: var(--c-ink); }

/* ── Hero (editorial, asymmetric) ───────────────────────────────────────── */
.oh4-hero { position: relative; padding-top: 0; }
.oh4-hero-grid {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 40px;
	align-items: center;
	min-height: min(82vh, 760px);
}
.oh4-hero-copy { position: relative; z-index: 2; padding-right: clamp(16px, 4vw, 72px); }
.oh4-hero-copy .oh4-h1 { margin: 0 0 20px; }
.oh4-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }

.oh4-hero-stage { position: relative; min-height: 420px; }
.oh4-hero-hero-img {
	position: relative; z-index: 2;
	width: min(420px, 92%); margin: 0 auto;
	filter: drop-shadow(0 30px 40px rgba(42,32,24,.18));
}
.oh4-hero-fruit { position: absolute; z-index: 3; filter: drop-shadow(0 14px 18px rgba(42,32,24,.2)); }
.oh4-hero-fruit--1 { width: 120px; top: 6%; right: 6%; }
.oh4-hero-fruit--2 { width: 104px; bottom: 8%; left: 2%; }
.oh4-hero-fruit--3 { width: 92px;  bottom: 22%; right: 0; }

/* ── Specialty ──────────────────────────────────────────────────────────── */
.oh4-specialty .oh4-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,70px); align-items: center; }
.oh4-specialty-stage { position: relative; min-height: 380px; display: flex; align-items: center; justify-content: center; }
.oh4-specialty-img { position: relative; z-index: 2; width: min(440px, 100%); filter: drop-shadow(0 26px 36px rgba(42,32,24,.2)); }
.oh4-specialty-copy .oh4-h2 { margin: 0 0 16px; }

/* ── Categories ─────────────────────────────────────────────────────────── */
.oh4-cats-head { text-align: center; margin-bottom: clamp(36px, 6vw, 60px); }
.oh4-cats-head .oh4-eyebrow { justify-content: center; }
.oh4-cats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
.oh4-cat {
	position: relative; text-align: center;
	padding: 26px 14px 24px; border-radius: 22px;
	transition: transform .2s ease, background .2s ease;
}
.oh4-cat-glow {
	position: absolute; inset: 18% 24% 30%; border-radius: 50%;
	filter: blur(34px); opacity: 0; transition: opacity .25s ease; z-index: 0;
}
.oh4-cat:hover { transform: translateY(-8px); background: var(--c-cream-2); }
.oh4-cat:hover .oh4-cat-glow { opacity: .55; }
.oh4-cat-img { position: relative; z-index: 1; height: 110px; width: auto; margin: 0 auto 16px; object-fit: contain; transition: transform .2s ease; }
.oh4-cat:hover .oh4-cat-img { transform: scale(1.06); }
.oh4-cat-label { position: relative; z-index: 1; font-family: var(--f-display); font-weight: 700; font-size: 1.15rem; }
.oh4-cat-label::after { content: ''; display: block; width: 26px; height: 3px; border-radius: 3px; background: var(--a-kiwi); margin: 8px auto 0; }

/* ── Fresh & Local row ──────────────────────────────────────────────────── */
.oh4-fresh { background: var(--c-cream-2); }
.oh4-fresh-head { text-align: center; max-width: 640px; margin: 0 auto clamp(34px, 6vw, 56px); }
.oh4-fresh-head .oh4-eyebrow { justify-content: center; color: var(--a-kiwi); }
.oh4-produce { display: flex; flex-wrap: wrap; justify-content: center; align-items: flex-end; gap: clamp(18px, 3.4vw, 46px); }
.oh4-produce-item { text-align: center; }
.oh4-produce-item img { height: clamp(70px, 9vw, 120px); width: auto; margin: 0 auto 12px; object-fit: contain; filter: drop-shadow(0 12px 14px rgba(42,32,24,.14)); transition: transform .2s ease; }
.oh4-produce-item:hover img { transform: translateY(-6px) rotate(-4deg); }
.oh4-produce-label { font-size: .82rem; font-weight: 600; color: var(--c-ink-soft); display: inline-flex; align-items: center; gap: 6px; }
.oh4-produce-label::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--a-strawberry); }

/* ── Visit Us + Map ─────────────────────────────────────────────────────── */
.oh4-visit .oh4-wrap { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(30px, 5vw, 64px); align-items: center; }
.oh4-visit-info .oh4-h2 { margin: 0 0 28px; }
.oh4-visit-row { margin: 0 0 22px; }
.oh4-visit-row dt { font-weight: 700; text-transform: uppercase; letter-spacing: .12em; font-size: .76rem; color: var(--a-strawberry); margin-bottom: 4px; }
.oh4-visit-row dd { margin: 0; font-size: 1.25rem; font-weight: 500; }
.oh4-visit-row dd a { color: var(--c-ink); }
.oh4-map { border-radius: 22px; overflow: hidden; border: 3px solid var(--a-mango); box-shadow: 0 18px 40px rgba(42,32,24,.12); }
.oh4-map iframe { display: block; width: 100%; height: 380px; border: 0; }

/* ── FAQ ────────────────────────────────────────────────────────────────── */
.oh4-faq-head { text-align: center; margin-bottom: 40px; }
.oh4-faq-head .oh4-eyebrow { justify-content: center; }
.oh4-faq-list { max-width: 760px; margin: 0 auto; }
.oh4-faq-item { border-bottom: 1px solid var(--c-line); }
.oh4-faq-q {
	list-style: none; cursor: pointer;
	display: flex; align-items: center; justify-content: space-between; gap: 18px;
	padding: 22px 4px;
	font-family: var(--f-display); font-weight: 700; font-size: clamp(1.1rem, 2vw, 1.35rem); color: var(--c-ink);
}
.oh4-faq-q::-webkit-details-marker { display: none; }
.oh4-faq-q::marker { content: ''; }
.oh4-faq-icon { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 50%; background: var(--a-strawberry); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; line-height: 1; transition: transform .25s ease; }
.oh4-faq-item[open] .oh4-faq-icon { transform: rotate(45deg); }
.oh4-faq-a { padding: 0 4px 24px; color: var(--c-ink-soft); max-width: 64ch; }

/* ── Footer ─────────────────────────────────────────────────────────────── */
.oh4-footer { background: var(--c-cream-2); padding: clamp(56px, 8vw, 84px) 0 40px; }
.oh4-footer-top { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 30px; align-items: flex-start; }
.oh4-footer-brand-name { font-family: var(--f-display); font-weight: 900; font-size: 2rem; }
.oh4-footer-brand img { height: 48px; margin-bottom: 12px; }
.oh4-footer-tag { color: var(--c-ink-soft); margin: 6px 0 0; max-width: 30ch; }
.oh4-footer-col h4 { font-family: var(--f-display); font-size: 1.05rem; margin: 0 0 14px; }
.oh4-footer-col ul { list-style: none; margin: 0; padding: 0; }
.oh4-footer-col li { margin-bottom: 9px; }
.oh4-footer-col a { color: var(--c-ink-soft); transition: color .15s ease; }
.oh4-footer-col a:hover { color: var(--a-strawberry); }
.oh4-socials { display: flex; gap: 12px; margin-top: 6px; }
.oh4-socials a { width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--c-line); display: flex; align-items: center; justify-content: center; color: var(--c-ink); transition: all .18s ease; }
.oh4-socials a:hover { background: var(--a-strawberry); border-color: var(--a-strawberry); color: #fff; transform: translateY(-2px); }
.oh4-socials svg { width: 19px; height: 19px; }
.oh4-footer-rule { height: 3px; border: 0; border-radius: 3px; background: linear-gradient(90deg, var(--a-strawberry), var(--a-mango), var(--a-kiwi)); margin: 36px 0 22px; opacity: .8; }
.oh4-footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 10px; color: var(--c-ink-soft); font-size: .9rem; }

/* ============================================================================
   MENU 4 — boutique menu + ordering engine
   ============================================================================ */
.oh4-menu { padding-bottom: 120px; }
.oh4-menu-head { text-align: center; padding: calc(var(--oh4-head-h) + 26px) 0 18px; }
.oh4-menu-head .oh4-eyebrow { justify-content: center; }

.oh4-tabs-outer { position: sticky; top: var(--oh4-head-h); z-index: 40; background: rgba(251,246,236,.92); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border-bottom: 1px solid var(--c-line); }
.oh4-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 30px; padding: 16px 0; }
.oh4-tab {
	background: none; border: none; cursor: pointer;
	font-family: var(--f-body); font-weight: 600; font-size: 1.02rem;
	color: var(--c-ink-soft); padding: 6px 2px; position: relative;
	text-transform: uppercase; letter-spacing: .05em;
}
.oh4-tab:hover { color: var(--c-ink); }
.oh4-tab.is-active { color: var(--c-ink); }
.oh4-tab.is-active::after { content: ''; position: absolute; left: 0; right: 0; bottom: -17px; height: 3px; border-radius: 3px; background: var(--a-strawberry); }

.oh4-mpanel { max-width: 820px; margin: 0 auto; padding: 30px 28px 0; }
.oh4-mpanel[hidden] { display: none; }
.oh4-msub { font-family: var(--f-display); font-weight: 700; font-size: 1.15rem; color: var(--a-citrus); margin: 26px 0 8px; }

.oh4-mcard {
	width: 100%; border: none; background: none; cursor: pointer; text-align: left;
	display: flex; align-items: center; gap: 20px;
	padding: 20px 4px; border-bottom: 1px solid var(--c-line);
	font: inherit; color: inherit;
}
.oh4-mcard-thumb { position: relative; flex: 0 0 84px; width: 84px; height: 84px; }
.oh4-mcard-thumb img { width: 84px; height: 84px; object-fit: contain; position: relative; z-index: 1; }
.oh4-mcard-thumb .oh4-glow { inset: 14%; filter: blur(20px); opacity: 0; transition: opacity .2s ease; }
.oh4-mcard:hover .oh4-mcard-thumb .oh4-glow { opacity: .5; }
.oh4-swatch { flex: 0 0 84px; width: 84px; height: 84px; border-radius: 18px; }
.oh4-swatch--0 { background: var(--a-strawberry); } .oh4-swatch--1 { background: var(--a-mango); }
.oh4-swatch--2 { background: var(--a-kiwi); } .oh4-swatch--3 { background: var(--a-citrus); }
.oh4-mcard-body { flex: 1 1 auto; min-width: 0; }
.oh4-mcard-name { font-family: var(--f-display); font-weight: 700; font-size: 1.3rem; margin: 0 0 4px; }
.oh4-mcard-desc { color: var(--c-ink-soft); font-size: .95rem; margin: 0; }
.oh4-mcard-price { font-weight: 700; font-size: 1.2rem; color: var(--a-strawberry); white-space: nowrap; margin-left: 6px; }
.oh4-mcard-add {
	flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%;
	border: 2px solid var(--a-strawberry); background: transparent; color: var(--a-strawberry);
	font-size: 1.6rem; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center;
	transition: all .15s ease;
}
.oh4-mcard-add:hover { background: var(--a-strawberry); color: #fff; }
.oh4-mcard-add.bump { transform: scale(1.18); }

/* cart fab */
.oh4-fab {
	position: fixed; right: 22px; bottom: 22px; z-index: 60;
	display: flex; align-items: center; gap: 10px;
	background: var(--c-ink); color: var(--c-cream); border: none; cursor: pointer;
	border-radius: 999px; padding: 14px 22px; font-family: var(--f-body); font-weight: 600; font-size: 1rem;
	box-shadow: 0 12px 30px rgba(42,32,24,.3);
}
.oh4-fab-count { background: var(--a-strawberry); color: #fff; border-radius: 999px; min-width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; font-size: .82rem; padding: 0 6px; }

/* overlay shared */
.oh4-overlay { position: fixed; inset: 0; background: rgba(42,32,24,.5); z-index: 80; }
.oh4-modal[hidden], .oh4-drawer[hidden] { display: none; }
body.oh4-modal-open { overflow: hidden; }

/* item modal */
.oh4-modal { position: fixed; inset: 0; z-index: 90; display: flex; align-items: center; justify-content: center; padding: 20px; }
.oh4-modal-card { position: relative; z-index: 91; width: min(460px, 100%); background: var(--c-cream); border-radius: 26px; padding: 30px; text-align: center; max-height: 90vh; overflow-y: auto; box-shadow: 0 30px 70px rgba(42,32,24,.3); }
.oh4-modal-stage { position: relative; height: 210px; display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.oh4-modal-img { position: relative; z-index: 1; max-height: 210px; width: auto; object-fit: contain; }
.oh4-modal-swatch { width: 180px; height: 180px; border-radius: 24px; }
.oh4-modal-name { font-family: var(--f-display); font-weight: 900; font-size: 1.8rem; margin: 0 0 4px; }
.oh4-modal-price { font-weight: 700; font-size: 1.3rem; color: var(--a-strawberry); margin: 0 0 12px; }
.oh4-modal-desc { color: var(--c-ink-soft); margin: 0 0 20px; }
.oh4-close { position: absolute; top: 14px; right: 16px; width: 38px; height: 38px; border-radius: 50%; border: none; background: var(--c-cream-2); color: var(--c-ink); font-size: 1.5rem; line-height: 1; cursor: pointer; }
.oh4-close:hover { background: var(--c-line); }
.oh4-stepper { display: inline-flex; align-items: center; gap: 6px; background: var(--c-cream-2); border-radius: 999px; padding: 5px; margin: 0 auto 18px; }
.oh4-stepper-btn { width: 38px; height: 38px; border-radius: 50%; border: none; cursor: pointer; background: var(--a-strawberry); color: #fff; font-size: 1.3rem; line-height: 1; display: flex; align-items: center; justify-content: center; }
.oh4-stepper-val { min-width: 34px; text-align: center; font-weight: 700; }
.oh4-modal-add { width: 100%; }

/* cart drawer */
.oh4-drawer { position: fixed; inset: 0; z-index: 95; }
.oh4-drawer-panel { position: absolute; top: 0; right: 0; bottom: 0; width: min(420px, 100%); background: var(--c-cream); z-index: 96; display: flex; flex-direction: column; transform: translateX(100%); transition: transform .28s ease; box-shadow: -10px 0 40px rgba(42,32,24,.2); }
.oh4-drawer.is-open .oh4-drawer-panel { transform: translateX(0); }
.oh4-drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 24px 24px 16px; }
.oh4-drawer-head h2 { font-family: var(--f-display); font-weight: 900; font-size: 1.6rem; margin: 0; }
.oh4-drawer-body { flex: 1 1 auto; overflow-y: auto; padding: 6px 22px; }
.oh4-cart-empty { text-align: center; color: var(--c-ink-soft); padding: 50px 10px; }
.oh4-line { display: flex; align-items: center; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--c-line); }
.oh4-line-thumb, .oh4-line-swatch { flex: 0 0 56px; width: 56px; height: 56px; object-fit: contain; border-radius: 12px; }
.oh4-line-info { flex: 1 1 auto; min-width: 0; }
.oh4-line-name { font-weight: 600; margin: 0 0 4px; }
.oh4-line-price { color: var(--a-strawberry); font-weight: 700; margin: 0 0 6px; }
.oh4-line .oh4-stepper { margin: 0; }
.oh4-line .oh4-stepper-btn { width: 30px; height: 30px; font-size: 1.1rem; }
.oh4-line-remove { flex: 0 0 auto; background: none; border: none; cursor: pointer; color: var(--a-strawberry); padding: 6px; }
.oh4-drawer-foot { border-top: 1px solid var(--c-line); padding: 20px 24px 26px; }
.oh4-subtotal { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--f-display); font-weight: 900; font-size: 1.4rem; margin-bottom: 6px; }
.oh4-pickup-note { color: var(--c-ink-soft); font-size: .9rem; margin: 0 0 14px; }
.oh4-checkout-btn { width: 100%; }
.oh4-cart-error { color: var(--a-strawberry); font-size: .9rem; text-align: center; margin: 12px 0 0; }

/* ============================================================================
   LINKS 4 — premium linktree
   ============================================================================ */
.oh4-links { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 70px 22px; position: relative; overflow: hidden; }
.oh4-links-logo { height: 84px; width: auto; margin: 0 auto 14px; }
.oh4-links-brand { font-family: var(--f-display); font-weight: 900; font-size: clamp(2.4rem, 7vw, 3.4rem); margin: 0 0 6px; text-align: center; }
.oh4-links-tag { color: var(--c-ink-soft); margin: 0 0 34px; text-align: center; }
.oh4-links-list { width: 100%; max-width: 440px; display: flex; flex-direction: column; gap: 14px; position: relative; z-index: 2; }
.oh4-link-btn {
	display: flex; align-items: center; justify-content: center; gap: 12px;
	min-height: 60px; padding: 14px 24px; border-radius: 16px;
	background: var(--c-cream); border: 2px solid var(--c-line);
	font-family: var(--f-body); font-weight: 600; font-size: 1.1rem; color: var(--c-ink);
	transition: all .16s ease;
}
.oh4-link-btn:hover { border-color: var(--a-strawberry); background: var(--a-strawberry); color: #fff; transform: translateY(-2px); }
.oh4-link-btn img { width: 26px; height: 26px; object-fit: contain; }
.oh4-link-btn svg { width: 24px; height: 24px; }
.oh4-links-corner { position: absolute; z-index: 1; pointer-events: none; filter: drop-shadow(0 12px 16px rgba(42,32,24,.14)); }

/* ============================================================================
   HOME 4 COLOR — bold full-width color bands (Home 3 style) via .oh4-bands
   Hero stays warm mango with dark ink; the rest become saturated with white.
   ============================================================================ */
/* Color pages: header is fully transparent over the colored hero/banner with
   white nav; reverts to creamy + dark text once scrolled. */
.oh4-bands .oh4-header:not(.is-scrolled) {
	background: transparent;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
}
.oh4-bands .oh4-header:not(.is-scrolled) .oh4-nav-links a { color: #fff; }
.oh4-bands .oh4-header:not(.is-scrolled) .oh4-nav-links a::after { background: #fff; }
.oh4-bands .oh4-header:not(.is-scrolled) .oh4-burger span { background: #fff; }
.oh4-bands .oh4-header:not(.is-scrolled) .oh4-nav .oh4-btn--fill { background: #fff; color: var(--a-strawberry); box-shadow: none; }

/* Hero split: left half pink, right half orange — all text white */
.oh4-bands .oh4-hero { background: linear-gradient(90deg, var(--a-strawberry) 0 50%, var(--a-citrus) 50% 100%); }
.oh4-bands .oh4-hero .oh4-h1,
.oh4-bands .oh4-hero .oh4-lead,
.oh4-bands .oh4-hero .oh4-script,
.oh4-bands .oh4-hero .oh4-eyebrow { color: #fff; }
.oh4-bands .oh4-hero .oh4-eyebrow::before { background: #fff; }
.oh4-bands .oh4-hero .oh4-uline::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M2 11 C 45 2 70 14 105 8 S 165 3 198 9' fill='none' stroke='%23FFFFFF' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E");
}
/* hero buttons: one yellow, one white with pink text */
.oh4-bands .oh4-hero .oh4-btn--fill { background: var(--a-mango); color: var(--c-ink); box-shadow: 0 8px 20px rgba(0,0,0,.16); }
.oh4-bands .oh4-hero .oh4-btn--outline { background: #fff; color: var(--a-strawberry); border-color: #fff; }
.oh4-bands .oh4-hero .oh4-btn--outline:hover { background: var(--a-strawberry); color: #fff; border-color: var(--a-strawberry); }
.oh4-bands .oh4-specialty    { background: var(--a-blue); }
.oh4-bands .oh4-cats-section { background: var(--a-citrus); }
.oh4-bands .oh4-fresh        { background: var(--a-kiwi); }
.oh4-bands .oh4-visit        { background: var(--a-blue); }
.oh4-bands .oh4-faq-section  { background: var(--c-ink); }

/* Footer — dark, slightly blurred photo background, white text */
.oh4-bands .oh4-footer { position: relative; background: var(--c-ink); overflow: hidden; }
.oh4-bands .oh4-footer::before {
	content: '';
	position: absolute; inset: 0;
	background: url("../images/background.webp") center / cover no-repeat;
	filter: brightness(.45);
	z-index: 0;
}
.oh4-bands .oh4-footer > .oh4-wrap { position: relative; z-index: 1; }
.oh4-bands .oh4-footer,
.oh4-bands .oh4-footer .oh4-footer-brand-name,
.oh4-bands .oh4-footer .oh4-footer-tag,
.oh4-bands .oh4-footer .oh4-footer-col h4,
.oh4-bands .oh4-footer .oh4-footer-col li,
.oh4-bands .oh4-footer .oh4-footer-col a,
.oh4-bands .oh4-footer .oh4-footer-bottom span { color: #fff; }
.oh4-bands .oh4-footer .oh4-footer-tag { opacity: .92; }
.oh4-bands .oh4-footer .oh4-socials a { border-color: rgba(255,255,255,.5); color: #fff; }
.oh4-bands .oh4-footer .oh4-socials a:hover { background: var(--a-strawberry); border-color: var(--a-strawberry); }
.oh4-bands .oh4-footer .oh4-footer-col a:hover { color: var(--a-mango); }

.oh4-bands .oh4-section:not(.oh4-hero) :is(.oh4-h1, .oh4-h2, .oh4-h3) { color: #fff; }
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-lead { color: rgba(255,255,255,.92); }
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-eyebrow { color: #fff; }
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-eyebrow::before { background: #fff; }

/* white wavy underline on the colored bands */
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-uline::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M2 11 C 45 2 70 14 105 8 S 165 3 198 9' fill='none' stroke='%23FFFFFF' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* buttons on colored bands → white fill / ink text, white outline */
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-btn--fill,
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-btn--mango {
	background: #fff; color: var(--c-ink); box-shadow: 0 8px 20px rgba(0,0,0,.14);
}
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-btn--outline { border-color: #fff; color: #fff; }
.oh4-bands .oh4-section:not(.oh4-hero) .oh4-btn--outline:hover { background: #fff; color: var(--c-ink); }

/* categories on kiwi */
.oh4-bands .oh4-cats-section .oh4-cat-label { color: #fff; }
.oh4-bands .oh4-cats-section .oh4-cat-label::after { background: #fff; }
.oh4-bands .oh4-cats-section .oh4-cat:hover { background: rgba(255,255,255,.16); }

/* fresh & local on citrus — hide the fruit name labels on the color page */
.oh4-bands .oh4-fresh .oh4-produce-label { display: none; }

/* visit us on berry */
.oh4-bands .oh4-visit .oh4-visit-row dt { color: rgba(255,255,255,.85); }
.oh4-bands .oh4-visit .oh4-visit-row dd,
.oh4-bands .oh4-visit .oh4-visit-row dd a { color: #fff; }
.oh4-bands .oh4-map { border-color: #fff; }

/* faq on ink */
.oh4-bands .oh4-faq-section .oh4-faq-q { color: #fff; }
.oh4-bands .oh4-faq-section .oh4-faq-item { border-color: rgba(255,255,255,.16); }
.oh4-bands .oh4-faq-section .oh4-faq-a { color: rgba(255,255,255,.8); }

/* Menu 4 Color — pink→orange banner under the transparent header, white text */
.oh4-bands .oh4-menu-hero {
	background: linear-gradient(90deg, var(--a-strawberry) 0 50%, var(--a-citrus) 50% 100%);
}
.oh4-bands .oh4-menu-head { padding: calc(var(--oh4-head-h) + 46px) 0 clamp(40px, 6vw, 64px); }
.oh4-bands .oh4-menu-head .oh4-h1,
.oh4-bands .oh4-menu-head .oh4-lead,
.oh4-bands .oh4-menu-head .oh4-eyebrow { color: #fff; }
.oh4-bands .oh4-menu-head .oh4-eyebrow::before { background: #fff; }
.oh4-bands .oh4-menu-head .oh4-uline::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 16' preserveAspectRatio='none'%3E%3Cpath d='M2 11 C 45 2 70 14 105 8 S 165 3 198 9' fill='none' stroke='%23FFFFFF' stroke-width='5' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* ============================================================================
   Responsive
   ============================================================================ */
@media (max-width: 900px) {
	.oh4-hero-grid { grid-template-columns: 1fr; gap: 20px; min-height: 0; padding: 30px 0 10px; }
	.oh4-hero-stage { min-height: 340px; order: -1; }
	.oh4-specialty .oh4-wrap { grid-template-columns: 1fr; }
	.oh4-visit .oh4-wrap { grid-template-columns: 1fr; }
	.oh4-cats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 760px) {
	.oh4 { --oh4-head-h: 84px; }
	.oh4-nav-links, .oh4-nav .oh4-btn { display: none; }
	.oh4-burger { display: flex; }
}
@media (max-width: 560px) {
	.oh4-cats { grid-template-columns: repeat(2, 1fr); }
	.oh4-mcard-thumb, .oh4-swatch { flex-basis: 64px; width: 64px; height: 64px; }
	.oh4-mcard-thumb img { width: 64px; height: 64px; }
	.oh4-mcard-name { font-size: 1.12rem; }
}

/* ============================================================================
   v4 added sections — About / Franchise / Contact, delivery popup triggers,
   and the 4c decorative-dot cleanup.
   ============================================================================ */

/* 4c: remove the stray confetti dots/rings on the colored hero + specialty */
.oh4-bands .oh4-hero-stage .oh4-dot,
.oh4-bands .oh4-hero-stage .oh4-ring,
.oh4-bands .oh4-specialty-stage .oh4-dot,
.oh4-bands .oh4-specialty-stage .oh4-ring { display: none; }

/* helpers */
.oh4-center { text-align: center; }
.oh4-center .oh4-eyebrow { justify-content: center; }
.oh4-narrow { max-width: 760px; margin-left: auto; margin-right: auto; }
.oh4-actions-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* About — story */
.oh4-about .oh4-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,64px); align-items: center; }
.oh4-about-media { position: relative; display: flex; align-items: center; justify-content: center; }
.oh4-about-media img { position: relative; z-index: 1; width: 100%; border-radius: 24px; box-shadow: 0 24px 50px rgba(42,32,24,.18); }
.oh4-about-copy .oh4-h2 { margin: 0 0 16px; }

/* Contact */
.oh4-contact-email { font-size: 1.35rem; font-weight: 700; margin: 0 0 22px; }
.oh4-contact-email a { color: var(--a-strawberry); }

/* 4c band colors for the new sections (white text via the generic bands rules) */
.oh4-bands .oh4-about-section    { background: var(--a-berry); }
.oh4-bands .oh4-franchise-section { background: var(--a-strawberry); }
.oh4-bands .oh4-contact-section  { background: var(--c-ink); }
.oh4-bands .oh4-contact-section,
.oh4-bands .oh4-contact-section .oh4-contact-email a { color: #fff; }

@media (max-width: 900px) {
	.oh4-about .oh4-wrap { grid-template-columns: 1fr; }
	.oh4-about-media { order: -1; }
}

/* Anchor nav: smooth scroll + clear the fixed header */
html { scroll-behavior: smooth; }
.oh4-section[id] { scroll-margin-top: calc(var(--oh4-head-h) + 12px); }

/* ============================================================================
   FAQ page (v4 cream / 4c dark) — uses .lab-faq wrapper (NOT .oh4-section, so
   the bands white-text rules don't fight the cream body).
   ============================================================================ */
.lab-faq { padding: calc(var(--oh4-head-h) + 40px) 0 clamp(60px,9vw,100px); background: var(--c-cream); }
.lab-faq-inner { max-width: 840px; margin: 0 auto; }
.lab-faq-head { text-align: center; margin-bottom: clamp(34px,5vw,52px); }
.oh4-faq-group { font-family: var(--f-display); font-weight: 900; font-size: clamp(1.4rem,2.6vw,1.9rem); color: var(--c-ink); margin: 40px 0 8px; }
.lab-faq .oh4-faq-list { margin-bottom: 8px; }

/* 4c: dark page, white text */
.oh4-bands .lab-faq { background: var(--c-ink); }
.oh4-bands .lab-faq .oh4-h1,
.oh4-bands .lab-faq .oh4-eyebrow,
.oh4-bands .lab-faq .oh4-faq-group,
.oh4-bands .lab-faq .oh4-faq-q { color: #fff; }
.oh4-bands .lab-faq .oh4-eyebrow::before { background: #fff; }
.oh4-bands .lab-faq .oh4-faq-item { border-color: rgba(255,255,255,.16); }
.oh4-bands .lab-faq .oh4-faq-a { color: rgba(255,255,255,.8); }
