/* Layout & sections */

header.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 20; display: flex; justify-content: center; }
header.site-header .header-inner { width: min(1100px, 94%); margin: var(--space-md) auto; padding: .6rem .9rem; border-radius: 999px; display: flex; justify-content: space-between; align-items: center; background: color-mix(in oklab, var(--color-canvas), white 40%); border: 1px solid rgba(28,28,26,.08); box-shadow: var(--shadow-sm); }
header .brand { font-family: var(--font-display); letter-spacing: .02em; font-size: 1.05rem; }
header nav a { padding: .4rem .6rem; border-radius: 999px; }
header nav a:hover { background: rgba(0,0,0,.06); }

main { overflow: clip; }

.section { padding: clamp(3rem, 8vw, 7rem) 0; position: relative; }
.section-title { font-size: var(--fs-xl); margin-bottom: var(--space-xl); text-align: center; }
.section .subhead { color: rgba(28,28,26,.7); text-align: center; margin-top: -.5rem; margin-bottom: var(--space-2xl); }
.hairline { border-top: 1px solid rgba(28,28,26,.12); }

/* Hero */
.hero { position: relative; min-height: calc(100dvh); display: grid; place-items: center; padding-top: 4.5rem; isolation: isolate; }
.hero__bg { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.2)), radial-gradient(100% 100% at 50% 0%, rgba(199,168,111,.18), transparent 60%), linear-gradient(120deg, #D9D2C5, #EFEAE2); filter: saturate(1.05); transform: translateY(calc(var(--hero-offset, 0) * -0.12)); will-change: transform; }
.hero__grain { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='table' tableValues='0 0.35'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)'/%3E%3C/svg%3E"); opacity: var(--grain-opacity); mix-blend-mode: multiply; }
.hero__content { position: relative; z-index: 2; color: #fff; text-align: center; padding: 1rem; }
.hero h1 { text-shadow: 0 10px 40px rgba(0,0,0,.35); }
.hero .lead { font-size: clamp(1rem, 2vw, 1.25rem); opacity: .95; }
.hero .cta { margin-top: var(--space-xl); display: inline-flex; gap: .75rem; align-items: center; }

/* Marquee */
.marquee { overflow: hidden; border-block: 1px solid rgba(28,28,26,.12); background: color-mix(in oklab, var(--color-canvas), white 30%); }
.marquee__track { display: flex; gap: 2rem; padding: .85rem 0; white-space: nowrap; will-change: transform; }

/* Story strip */
.story { display: grid; grid-template-columns: 1fr; gap: var(--space-xl); align-items: center; }
@media (min-width: 860px) { .story { grid-template-columns: 1.1fr 1fr; } }
.story__media { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); background: #E9E4DA; }
.story__copy { padding-inline: .5rem; }

/* Signature loaves */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-xl); }
.card { background: color-mix(in oklab, var(--color-canvas), white 35%); border: 1px solid rgba(28,28,26,.12); border-radius: calc(var(--radius) + 4px); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .28s ease, box-shadow .28s ease; }
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.card__img { aspect-ratio: 4 / 3; background: #EAE4DA; display: grid; place-items: center; border-bottom: 1px solid rgba(28,28,26,.08); }
.card__body { padding: var(--space-lg); }
.card__title { font-family: var(--font-display); font-size: 1.25rem; margin-bottom: .25rem; }
.card__note { color: rgba(28,28,26,.75); font-size: var(--fs-sm); }

/* Gallery */
.gallery { columns: 1; column-gap: var(--space-lg); }
@media (min-width: 640px) { .gallery { columns: 2; } }
@media (min-width: 1024px) { .gallery { columns: 3; } }
.gallery figure { break-inside: avoid; margin: 0 0 var(--space-lg); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); border: 1px solid rgba(28,28,26,.08); background: #EFEAE2; }
.gallery figcaption { padding: .5rem .75rem; font-size: var(--fs-sm); color: rgba(28,28,26,.7); }

/* Process (horizontal scroller) */
.process { overflow-x: auto; scroll-snap-type: x mandatory; }
.process__track { display: grid; grid-auto-flow: column; grid-auto-columns: 85%; gap: var(--space-xl); padding-bottom: .5rem; }
@media (min-width: 900px) { .process__track { grid-auto-columns: 55%; } }
.process__step { scroll-snap-align: center; background: color-mix(in oklab, var(--color-canvas), white 35%); border: 1px solid rgba(28,28,26,.12); border-radius: var(--radius); padding: var(--space-xl); position: relative; box-shadow: var(--shadow-sm); }
.process__num { position: absolute; top: .9rem; right: 1rem; font-family: var(--font-display); color: rgba(28,28,26,.28); font-size: 2.2rem; }

/* Praise (quotes carousel) */
.quotes { position: relative; display: grid; place-items: center; min-height: 160px; }
.quotes blockquote { max-width: 36ch; text-align: center; font-family: var(--font-display); font-size: clamp(1.2rem, 2vw, 1.6rem); color: rgba(28,28,26,.9); opacity: 0; transform: translateY(12px); transition: opacity .5s ease, transform .5s ease; position: absolute; }
.quotes blockquote.is-active { opacity: 1; transform: none; position: relative; }

/* Find us */
.findus { display: grid; gap: var(--space-xl); grid-template-columns: 1fr; align-items: center; }
@media (min-width: 900px) { .findus { grid-template-columns: 1.2fr 1fr; } }
.map { border-radius: var(--radius); overflow: hidden; background: #EEE6D8; border: 1px solid rgba(28,28,26,.12); box-shadow: var(--shadow-sm); }

/* CTA footer */
.cta-footer { text-align: center; padding: clamp(3rem, 8vw, 6rem) 0; }
.cta-footer .actions { margin-top: var(--space-lg); display: inline-flex; gap: .75rem; }


