@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,500;0,600;1,500&display=swap');

:root{
  --ink:#16140f;
  --paper:#f2ecdf;
  --cream:#fbf7ee;
  --amber:#d79b23;
  --amber-deep:#a96f10;
  --sage:#73765e;
  --rust:#9c4e2a;
  --line:rgba(22,20,15,.18);
  --display:"Playfair Display",Georgia,serif;
  --sans:"DM Sans",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.55}
a{color:inherit}
button,input,select,textarea{font:inherit}
.sr-only,.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link:focus{width:auto;height:auto;clip:auto;margin:0;left:1rem;top:1rem;z-index:1000;background:white;padding:.75rem 1rem}
.site-header{position:fixed;z-index:50;left:0;right:0;top:0;height:96px;display:flex;align-items:center;justify-content:space-between;padding:0 4vw;color:white;transition:.35s ease}
.site-header.scrolled{height:76px;background:rgba(22,20,15,.94);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.12)}
.wordmark{display:flex;align-items:center;gap:12px;text-decoration:none}
.wordmark-mark{width:54px;height:54px;fill:var(--amber);stroke:none}
.mark-line{fill:none;stroke:var(--ink);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.crown{fill:none;stroke:var(--amber);stroke-width:2}
.wordmark-copy strong{display:block;font-family:var(--display);font-size:1.35rem;font-weight:600;line-height:1}
.wordmark-copy small{display:block;margin-top:5px;font-size:.65rem;text-transform:uppercase;letter-spacing:.2em;color:#e9dfc8}
.site-nav{display:flex;align-items:center;gap:2rem;font-size:.84rem;text-transform:uppercase;letter-spacing:.09em}
.site-nav a{text-decoration:none}
.nav-cta{border:1px solid rgba(255,255,255,.65);border-radius:100px;padding:.8rem 1.25rem}
.menu-button{display:none}

.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;background:#2d301f;color:white;padding:150px 5vw 8vh}
.hero-art{position:absolute;inset:0;background:linear-gradient(145deg,#343720 0%,#5b5b35 48%,#b47b21 100%);overflow:hidden}
.hero-art:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,6,.72) 0%,rgba(10,10,6,.25) 48%,rgba(10,10,6,.08) 100%),linear-gradient(0deg,rgba(10,10,6,.5),transparent 55%)}
.sun-disc{position:absolute;width:46vw;height:46vw;border-radius:50%;right:2vw;top:3vh;background:radial-gradient(circle at 45% 40%,#ffe09a 0%,#d79724 38%,rgba(215,151,36,.2) 69%,transparent 70%);opacity:.95}
.mountain{position:absolute;left:-8%;right:-8%;bottom:0;clip-path:polygon(0 72%,16% 54%,28% 68%,45% 34%,58% 59%,72% 38%,100% 70%,100% 100%,0 100%)}
.mountain-back{height:66%;background:#6c6e47;opacity:.8}
.mountain-front{height:48%;background:#262a18;clip-path:polygon(0 72%,18% 48%,34% 70%,50% 45%,67% 63%,82% 43%,100% 67%,100% 100%,0 100%)}
.field-lines{position:absolute;left:-10%;right:-10%;bottom:-18%;height:50%;border-radius:50%;background:repeating-radial-gradient(ellipse at center,transparent 0 22px,rgba(231,184,75,.28) 23px 25px);transform:rotate(-7deg)}
.hero-comb{position:absolute;right:-4vw;bottom:14vh;width:35vw;height:35vw;opacity:.16;background-image:linear-gradient(30deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(150deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(30deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(150deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(60deg,rgba(255,255,255,.7) 25%,transparent 25.5%,transparent 75%,rgba(255,255,255,.7) 75%);background-size:80px 140px;background-position:0 0,0 0,40px 70px,40px 70px,0 0}
.hero-content{position:relative;z-index:2;width:min(1400px,100%)}
.hero-kicker,.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;font-weight:700}
.hero-kicker{color:#f2dca6}
h1,h2,h3,p{margin-top:0}
h1{font-family:var(--display);font-size:clamp(4.5rem,10vw,10rem);line-height:.86;letter-spacing:-.055em;font-weight:500;margin:1.4rem 0 2.2rem}
h1 span{color:var(--amber);font-style:italic}
.hero-lower{display:flex;align-items:center;gap:5rem}
.hero-lower>p{max-width:440px;font-size:1.08rem;color:#eee3cc}
.circle-link{display:flex;align-items:center;justify-content:center;width:132px;height:132px;border:1px solid rgba(255,255,255,.7);border-radius:50%;text-decoration:none;text-align:center;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;position:relative;transition:.3s}
.circle-link svg{position:absolute;width:20px;bottom:24px;fill:none;stroke:currentColor;stroke-width:1.5}
.circle-link:hover{background:var(--amber);border-color:var(--amber);color:var(--ink);transform:rotate(-5deg)}
.scroll-note{position:absolute;right:4vw;bottom:3vh;z-index:2;text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;writing-mode:vertical-rl;display:flex;align-items:center;gap:12px}
.scroll-note span{display:block;width:1px;height:54px;background:white}

.marquee{overflow:hidden;background:var(--amber);border-block:1px solid var(--ink);padding:1rem 0}
.marquee-track{width:max-content;display:flex;gap:2rem;align-items:center;animation:marquee 30s linear infinite;text-transform:uppercase;letter-spacing:.13em;font-weight:700}
.marquee i{font-style:normal}
@keyframes marquee{to{transform:translateX(-50%)}}

.section-dark{background:var(--ink);color:white}
.story{position:relative;padding:10rem 6vw}
.section-number{font-family:var(--display);font-size:1rem;color:var(--amber);border:1px solid currentColor;border-radius:50%;width:42px;height:42px;display:grid;place-items:center}
.story>.section-number{position:absolute;right:6vw;top:7rem}
.story-grid{display:grid;grid-template-columns:1.1fr .8fr .75fr;gap:5vw;align-items:start}
.story-heading h2,.offerings-intro h2,.season-heading h2,.contact-copy h2{font-family:var(--display);font-weight:500;letter-spacing:-.045em;line-height:.98}
.story-heading h2{font-size:clamp(3.4rem,6.2vw,7.2rem)}
.eyebrow{color:var(--amber);margin-bottom:1.4rem}
.image-placeholder{position:relative;display:grid;place-items:center;overflow:hidden;color:rgba(255,255,255,.78);text-align:center}
.image-placeholder span{position:relative;z-index:2;max-width:240px;font-size:.75rem;text-transform:uppercase;letter-spacing:.14em}
.image-bees{height:600px;background:radial-gradient(circle at 65% 28%,rgba(255,213,105,.9) 0 4%,transparent 4.3%),radial-gradient(circle at 35% 50%,#d09820 0 5%,transparent 5.4%),linear-gradient(145deg,#79794a,#32361f 55%,#a06c1f)}
.image-bees:before,.image-apiary:before{content:"";position:absolute;inset:0;background:linear-gradient(30deg,rgba(0,0,0,.38),transparent 55%),repeating-linear-gradient(115deg,transparent 0 32px,rgba(255,255,255,.04) 33px 34px)}
.image-caption{margin-top:1rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.14em;color:#afa997}
.story-copy{padding-top:13rem;color:#c7c0b1}
.story-copy .lead{font-family:var(--display);font-size:1.7rem;line-height:1.35;color:white}
.underlined-link{display:inline-flex;gap:.8rem;margin-top:2rem;padding-bottom:.35rem;border-bottom:1px solid var(--amber);text-decoration:none;color:white}

.offerings{padding:10rem 6vw;background:var(--paper)}
.offerings-intro{display:flex;justify-content:space-between;align-items:end;margin-bottom:5rem}
.offerings-intro h2{font-size:clamp(3.5rem,7vw,7rem);margin:0}
.offering-row{display:grid;grid-template-columns:80px minmax(320px,1fr) minmax(280px,.7fr) 50px;gap:2rem;align-items:center;border-top:1px solid var(--line);padding:2.1rem 0}
.offering-row:last-child{border-bottom:1px solid var(--line)}
.offering-number{font-size:.7rem;color:var(--amber-deep)}
.offering-title{display:flex;align-items:center;gap:1.4rem}
.offering-title h3{font-family:var(--display);font-size:clamp(2rem,3.5vw,4rem);font-weight:500;margin:0}
.offering-icon{font-size:2.2rem;color:var(--amber-deep)}
.offering-row>p{max-width:480px;margin:0;color:#5f5a4f}
.offering-row>a{text-decoration:none;font-size:1.6rem;transition:.2s}
.offering-row>a:hover{transform:translate(4px,-4px)}

.photo-break{position:relative;height:86vh;min-height:680px;background:#30331e;color:white}
.image-apiary{position:absolute;inset:0;background:linear-gradient(160deg,#9d7d32,#45502d 50%,#1d2115)}
.image-apiary span{font-size:.8rem}
.photo-quote{position:absolute;z-index:3;left:6vw;bottom:8vh;max-width:750px}
.photo-quote p{font-family:var(--display);font-size:clamp(2.5rem,5vw,5.6rem);line-height:1.02;margin-bottom:1.5rem}
.photo-quote span{text-transform:uppercase;letter-spacing:.18em;font-size:.68rem;color:#ecd59d}

.season{padding:10rem 6vw;background:var(--amber);overflow:hidden}
.season-heading{display:grid;grid-template-columns:60px 1fr;column-gap:2rem}
.season-heading .eyebrow{color:var(--ink);grid-column:2}
.season-heading h2{font-size:clamp(3.4rem,6.5vw,7rem);grid-column:2}
.season-wheel{position:relative;width:min(760px,80vw);aspect-ratio:1;margin:7rem auto;border:1px solid rgba(22,20,15,.4);border-radius:50%}
.season-wheel:before,.season-wheel:after{content:"";position:absolute;inset:16%;border:1px solid rgba(22,20,15,.25);border-radius:50%}
.season-wheel:after{inset:33%}
.season-center{position:absolute;inset:38%;border-radius:50%;background:var(--ink);color:white;display:grid;place-content:center;text-align:center}
.season-center span,.season-item span{text-transform:uppercase;letter-spacing:.16em;font-size:.6rem}
.season-center strong{font-family:var(--display);font-size:1.7rem;line-height:1.05}
.season-item{position:absolute;width:170px;text-align:center}
.season-item strong{display:block;font-family:var(--display);font-size:1.35rem}
.spring{left:50%;top:-18px;transform:translateX(-50%)}
.summer{right:-72px;top:50%;transform:translateY(-50%) rotate(90deg)}
.harvest{left:50%;bottom:-18px;transform:translateX(-50%)}
.winter{left:-78px;top:50%;transform:translateY(-50%) rotate(-90deg)}
.season-note{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(22,20,15,.45);padding-top:2rem}
.season-note p{max-width:650px}
.button-light{display:inline-flex;padding:1rem 1.4rem;border:1px solid var(--ink);border-radius:100px;text-decoration:none;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem}

.values{display:grid;grid-template-columns:repeat(3,1fr);background:var(--cream)}
.value-card{padding:6rem 4vw;border-right:1px solid var(--line)}
.value-card:last-child{border-right:0}
.value-card>span{color:var(--amber-deep);font-size:.7rem}
.value-card h3{font-family:var(--display);font-size:3rem;font-weight:500;margin:3rem 0 1rem}
.value-card p{color:#625d52;max-width:350px}

.contact{position:relative;display:grid;grid-template-columns:.75fr .85fr 1.2fr;gap:4vw;padding:10rem 6vw;background:#202116;color:white;overflow:hidden}
.contact-art{position:relative;min-height:560px}
.contact-art svg{position:absolute;width:100%;bottom:0;fill:none;stroke:var(--amber);stroke-width:2}
.contact-comb{position:absolute;inset:0;opacity:.12;background-image:linear-gradient(30deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(150deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(30deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff),linear-gradient(150deg,#fff 12%,transparent 12.5%,transparent 87%,#fff 87.5%,#fff);background-size:70px 120px;background-position:0 0,0 0,35px 60px,35px 60px}
.contact-copy h2{font-size:clamp(3rem,5.5vw,6rem)}
.contact-copy>p:last-child{color:#bdb6a8;max-width:430px}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;align-content:start}
.contact-form label{display:grid;gap:.55rem}
.contact-form label span{text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:#d5cbb5}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;background:transparent;color:white;border:0;border-bottom:1px solid #6b685c;border-radius:0;padding:.75rem 0;outline:none}
.contact-form select option{color:var(--ink)}
.contact-form textarea{resize:vertical}
.contact-form .full{grid-column:1/-1}
.contact-form button{grid-column:1/-1;background:var(--amber);border:0;border-radius:100px;padding:1.1rem 1.4rem;display:flex;justify-content:space-between;text-transform:uppercase;letter-spacing:.13em;font-size:.72rem;font-weight:700;cursor:pointer}
.form-note{grid-column:1/-1;font-size:.7rem;color:#8f8a7e}

.site-footer{display:grid;grid-template-columns:1.2fr .7fr .7fr;gap:3rem;padding:4rem 6vw;background:#11120c;color:#d6cfbf;border-top:1px solid #3d3d31}
.footer-brand{display:flex;align-items:center;gap:1rem;font-family:var(--display);font-size:1.5rem}
.footer-brand svg{width:52px;fill:var(--amber)}
.footer-links,.footer-meta{display:grid;gap:.5rem;align-content:start;font-size:.82rem}
.footer-links a{text-decoration:none}
.footer-meta p{margin:0}

.reveal{opacity:0;transform:translateY(35px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:none}

@media(max-width:1000px){
  .site-nav{position:fixed;inset:0;background:var(--ink);display:none;flex-direction:column;justify-content:center;align-items:center;font-size:1.2rem}
  .site-nav.open{display:flex}
  .menu-button{display:block;position:relative;z-index:2;width:48px;height:48px;border:1px solid rgba(255,255,255,.4);border-radius:50%;background:transparent}
  .menu-button span:not(.sr-only){display:block;width:19px;height:1px;background:white;margin:6px auto}
  .hero-lower{gap:2rem}
  .story-grid{grid-template-columns:1fr 1fr}
  .story-copy{padding-top:2rem;grid-column:2}
  .offering-row{grid-template-columns:50px 1fr 40px}
  .offering-row>p{grid-column:2}
  .season-item{width:150px}
  .contact{grid-template-columns:.7fr 1.3fr}
  .contact-copy{grid-column:2}
  .contact-form{grid-column:2}
  .contact-art{grid-row:1/3}
}
@media(max-width:700px){
  .site-header{height:76px;padding:0 1rem}
  .wordmark-mark{width:44px}
  .wordmark-copy strong{font-size:1.1rem}
  .hero{min-height:820px;padding:120px 1.3rem 5rem}
  h1{font-size:clamp(4rem,19vw,6rem)}
  .hero-lower{align-items:flex-start;flex-direction:column}
  .circle-link{width:112px;height:112px}
  .scroll-note{display:none}
  .story,.offerings,.season,.contact{padding:6rem 1.3rem}
  .story>.section-number{display:none}
  .story-grid{display:block}
  .story-heading h2{font-size:3.5rem}
  .image-bees{height:480px;margin-top:3rem}
  .story-copy{padding-top:3rem}
  .offerings-intro{display:block}
  .offerings-intro h2{font-size:3.6rem}
  .offering-row{grid-template-columns:38px 1fr 28px;gap:1rem}
  .offering-title h3{font-size:2.1rem}
  .offering-icon{display:none}
  .offering-row>p{grid-column:2/4}
  .photo-break{height:720px}
  .photo-quote{left:1.3rem;right:1.3rem}
  .season-heading{display:block}
  .season-heading h2{font-size:3.4rem}
  .season-wheel{width:88vw;margin:6rem auto}
  .season-item{width:115px}
  .summer{right:-50px}
  .winter{left:-52px}
  .season-note{display:block}
  .button-light{margin-top:1rem}
  .values{grid-template-columns:1fr}
  .value-card{border-right:0;border-bottom:1px solid var(--line);padding:4rem 1.3rem}
  .contact{display:block}
  .contact-art{min-height:300px;margin-bottom:4rem}
  .contact-copy{margin-bottom:3rem}
  .contact-form{grid-template-columns:1fr}
  .contact-form .full,.contact-form button,.form-note{grid-column:auto}
  .site-footer{grid-template-columns:1fr;padding:3rem 1.3rem}
}


/* v4: final logo, catalog pages, tours, and cart */
.logo-link{display:block;width:min(285px,33vw)}
.brand-logo{display:block;width:100%;height:auto;max-height:78px;object-fit:contain;object-position:left center}
.site-header.scrolled .brand-logo{max-height:60px}
.footer-brand{display:block}
.footer-logo{width:min(360px,100%);height:auto;display:block}
.cart-link span{display:inline-grid;place-items:center;min-width:1.5rem;height:1.5rem;margin-left:.35rem;border-radius:50%;background:var(--amber);color:var(--ink);font-size:.7rem}
.catalog-page{background:var(--paper)}
.catalog-page .site-header{position:relative;background:var(--ink);height:96px}
.catalog-page .site-header.scrolled{height:76px}
.page-hero{padding:8rem 6vw 7rem;background:var(--ink);color:white}
.page-hero h1{font-size:clamp(4rem,9vw,9rem);margin:.7rem 0 2rem}
.page-hero h1 em{color:var(--amber);font-weight:500}
.page-hero>p:last-child{max-width:680px;color:#c7c0b1;font-size:1.1rem}
.category-grid{display:grid;grid-template-columns:repeat(2,1fr);padding:6rem 6vw;gap:1.2rem}
.category-card{min-height:430px;padding:2.5rem;display:flex;flex-direction:column;justify-content:flex-end;text-decoration:none;color:white;position:relative;overflow:hidden}
.category-card:before{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(12,11,8,.8),rgba(12,11,8,.06));transition:.4s}
.category-card>*{position:relative}
.category-card span{position:absolute;top:2rem;left:2rem;font-size:.7rem;letter-spacing:.15em}
.category-card h2{font-family:var(--display);font-size:clamp(2.7rem,5vw,5rem);font-weight:500;margin:0 0 .5rem}
.category-card p{max-width:350px;margin:0}
.category-card:hover:before{background:linear-gradient(0deg,rgba(12,11,8,.72),rgba(215,155,35,.22))}
.category-queens{background:linear-gradient(135deg,#82621d,#2f321d)}
.category-nucs{background:linear-gradient(135deg,#454b28,#b38324)}
.category-honey{background:linear-gradient(135deg,#c98717,#643916)}
.category-goods{background:linear-gradient(135deg,#7d5031,#27261b)}
.category-tours{background:linear-gradient(135deg,#65704b,#c08a25);grid-column:1/-1}
.catalog-note,.category-detail,.tour-safety{margin:0 6vw 7rem;padding:2.3rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;grid-template-columns:.45fr 1.55fr;gap:2rem}
.catalog-note p,.category-detail p,.tour-safety p{max-width:760px;margin:0;color:#625d52}
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;padding:6rem 6vw}
.shop-card{background:var(--cream);border:1px solid var(--line)}
.shop-card-art{height:320px;display:grid;place-items:center;background:linear-gradient(145deg,#373b22,#c28a20);color:#efe1bd;text-transform:uppercase;letter-spacing:.18em;font-size:.68rem;position:relative;overflow:hidden}
.shop-card-art:before{content:"";position:absolute;width:80%;aspect-ratio:1;border-radius:50%;border:1px solid rgba(255,255,255,.28)}
.shop-card-copy{padding:2.2rem}
.shop-card-copy h2{font-family:var(--display);font-size:2.5rem;font-weight:500;line-height:1.08}
.shop-card-copy>p:not(.product-meta){color:#625d52}
.product-meta{text-transform:uppercase;letter-spacing:.15em;font-size:.62rem;color:var(--amber-deep)}
.product-buy{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.product-buy strong{font-family:var(--display);font-size:1.7rem}
.add-cart,.cart-summary button,.checkout-panel button{border:0;border-radius:100px;padding:.9rem 1.2rem;background:var(--ink);color:white;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;cursor:pointer}
.add-cart.added{background:var(--amber);color:var(--ink)}
.category-detail h2,.tour-safety h2{font-family:var(--display);font-size:2rem;font-weight:500}
.category-detail a{grid-column:2;text-decoration:none;font-weight:700}

.tour-feature{display:grid;grid-template-columns:1fr 1fr;gap:5vw;padding:7rem 6vw}
.tour-art{min-height:650px;display:grid;place-items:center;background:linear-gradient(145deg,#31361e,#c59329);color:#f5e3b6;text-transform:uppercase;letter-spacing:.15em;font-size:.7rem;position:relative;overflow:hidden}
.tour-art:after{content:"";position:absolute;inset:12%;border-radius:50%;border:1px solid rgba(255,255,255,.25)}
.tour-copy{align-self:center}
.tour-copy h2{font-family:var(--display);font-size:clamp(3rem,5vw,5.5rem);font-weight:500;line-height:1}
.tour-copy>p{color:#625d52}
.tour-copy li{margin:.7rem 0}

.cart-layout{display:grid;grid-template-columns:1.6fr .7fr;gap:5vw;padding:6rem 6vw}
.cart-items{border-top:1px solid var(--line)}
.cart-row{display:grid;grid-template-columns:1fr auto auto;gap:1.5rem;align-items:center;padding:2rem 0;border-bottom:1px solid var(--line)}
.cart-row h2{font-family:var(--display);font-size:2rem;font-weight:500;margin:0}
.cart-row p{margin:.2rem 0;color:#625d52}
.cart-row>strong{font-family:var(--display);font-size:1.4rem}
.qty-control{display:flex;align-items:center;border:1px solid var(--line);border-radius:100px}
.qty-control button{border:0;background:transparent;padding:.55rem .8rem;cursor:pointer}
.remove-item{grid-column:2/4;justify-self:end;border:0;background:transparent;text-decoration:underline;cursor:pointer;color:#766f62}
.cart-summary{position:sticky;top:110px;align-self:start;padding:2rem;background:var(--cream);border:1px solid var(--line)}
.summary-line{display:flex;justify-content:space-between;padding:1.2rem 0;border-block:1px solid var(--line);font-size:1.2rem}
.cart-summary>p:not(.eyebrow){font-size:.8rem;color:#625d52;margin:1.2rem 0}
.cart-summary button{width:100%;display:flex;justify-content:space-between}
.cart-summary .clear-button{margin-top:.8rem;background:transparent;color:var(--ink);border:1px solid var(--line);display:block}
.cart-empty{padding:4rem 0}
.cart-empty h2{font-family:var(--display);font-size:3rem;font-weight:500}
.checkout-panel{display:grid;grid-template-columns:.8fr 1.2fr;gap:5vw;padding:7rem 6vw;background:var(--ink);color:white}
.checkout-panel h2{font-family:var(--display);font-size:3.5rem;font-weight:500}
.checkout-panel>div>p:last-child{color:#bdb6a8}
.checkout-panel form{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.checkout-panel label{display:grid;gap:.4rem}
.checkout-panel label span{text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:#d5cbb5}
.checkout-panel input,.checkout-panel textarea{background:transparent;color:white;border:0;border-bottom:1px solid #6b685c;padding:.8rem 0}
.checkout-panel .full,.checkout-panel button{grid-column:1/-1}
.checkout-panel button{background:var(--amber);color:var(--ink);display:flex;justify-content:space-between}

@media(max-width:900px){
  .logo-link{width:240px}
  .catalog-page .site-header{padding:0 1.2rem}
  .category-grid,.product-grid{grid-template-columns:1fr}
  .category-tours{grid-column:auto}
  .tour-feature,.cart-layout,.checkout-panel{grid-template-columns:1fr}
  .tour-art{min-height:500px}
  .cart-summary{position:static}
}
@media(max-width:700px){
  .logo-link{width:190px}
  .brand-logo{max-height:58px}
  .page-hero{padding:5rem 1.3rem}
  .category-grid,.product-grid,.tour-feature,.cart-layout,.checkout-panel{padding:4rem 1.3rem}
  .catalog-note,.category-detail,.tour-safety{margin:0 1.3rem 4rem;grid-template-columns:1fr;padding:1.5rem 0}
  .category-detail a{grid-column:auto}
  .category-card{min-height:330px}
  .shop-card-art{height:240px}
  .cart-row{grid-template-columns:1fr auto}
  .cart-row .qty-control{grid-column:1}
  .cart-row>strong{grid-column:2;grid-row:2}
  .remove-item{grid-column:1/-1}
  .checkout-panel form{grid-template-columns:1fr}
  .checkout-panel .full,.checkout-panel button{grid-column:auto}
}


/* v5 navigation, approved logo, video hero, story and contact pages */
.logo-link{width:min(310px,34vw)}
.brand-logo{max-height:84px;object-fit:contain;filter:drop-shadow(0 3px 7px rgba(0,0,0,.35))}
.footer-logo{width:min(420px,100%);filter:drop-shadow(0 3px 7px rgba(0,0,0,.25))}
.hero-video{background:#22261a}
.hero-video-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-video-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,7,.78) 0%,rgba(10,10,7,.34) 48%,rgba(10,10,7,.16) 100%),linear-gradient(0deg,rgba(10,10,7,.52),transparent 58%)}
.hero-video .hero-content,.hero-video .scroll-note{position:relative;z-index:2}
.editorial-story{padding:8rem 6vw}
.editorial-intro{display:grid;grid-template-columns:.55fr 1.45fr;gap:4vw;align-items:start}
.editorial-intro .eyebrow{grid-column:1}
.editorial-intro h2{grid-column:2;font-family:var(--display);font-size:clamp(3.5rem,7vw,7rem);line-height:.98;font-weight:500}
.editorial-intro .lead{grid-column:2;max-width:760px;font-family:var(--display);font-size:1.8rem;line-height:1.35}
.story-photo-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:1.2rem;margin:6rem 0}
.story-photo{display:grid;place-items:center;color:#f1e3bd;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;background:linear-gradient(145deg,#3d4328,#b47d20);position:relative;overflow:hidden}
.story-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.28),transparent)}
.story-photo span{position:relative;z-index:2;max-width:260px;text-align:center}
.story-photo-tall{min-height:680px}
.story-photo-wide{min-height:500px;align-self:end}
.story-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;border-top:1px solid var(--line);padding-top:3rem}
.story-columns h3{font-family:var(--display);font-size:2rem;font-weight:500}
.story-columns p{color:#625d52}
.story-cta{padding:7rem 6vw;background:var(--amber)}
.story-cta h2{font-family:var(--display);font-size:clamp(3.5rem,7vw,7rem);font-weight:500;margin-bottom:1rem}
.story-cta p{max-width:680px}
.contact-page-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:6vw;padding:8rem 6vw}
.contact-page-copy h2{font-family:var(--display);font-size:clamp(3rem,5vw,5rem);font-weight:500}
.contact-page-copy>p{color:#625d52;max-width:520px}
.contact-detail-list{margin-top:3rem;border-top:1px solid var(--line)}
.contact-detail-list>div{padding:1.2rem 0;border-bottom:1px solid var(--line)}
.contact-detail-list span{display:block;text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:var(--amber-deep);margin-bottom:.35rem}
.contact-detail-list p{margin:0}
.contact-form-page{background:var(--cream);color:var(--ink);border:1px solid var(--line);padding:2.5rem;grid-template-columns:1fr 1fr}
.contact-form-page input,.contact-form-page select,.contact-form-page textarea{color:var(--ink);border-bottom-color:#b8ae9a}
.contact-form-page label span{color:#6b6357}
.contact-form-page button{background:var(--ink);color:white}
@media(max-width:900px){
  .editorial-intro,.contact-page-grid{grid-template-columns:1fr}
  .editorial-intro .eyebrow,.editorial-intro h2,.editorial-intro .lead{grid-column:auto}
  .story-photo-grid{grid-template-columns:1fr}
  .story-columns{grid-template-columns:1fr}
}
@media(max-width:700px){
  .logo-link{width:205px}
  .brand-logo{max-height:62px}
  .editorial-story,.story-cta,.contact-page-grid{padding:5rem 1.3rem}
  .story-photo-tall,.story-photo-wide{min-height:420px}
  .contact-form-page{grid-template-columns:1fr;padding:1.5rem}
  .contact-form-page .full,.contact-form-page button,.contact-form-page .form-note{grid-column:auto}
}


/* v6: larger transparent logo, Home link, nav underline, parallax */
.site-header{
  min-height:112px;
  height:112px;
  padding-inline:3vw;
}
.site-header.scrolled{
  min-height:88px;
  height:88px;
}
.logo-link{
  width:min(390px,38vw);
  flex:0 0 auto;
}
.brand-logo{
  width:100%;
  max-height:102px;
  object-fit:contain;
  object-position:left center;
  filter:drop-shadow(0 3px 7px rgba(0,0,0,.35));
}
.site-header.scrolled .brand-logo{
  max-height:78px;
}
.site-nav{
  gap:2.15rem;
  font-size:.93rem;
  font-weight:600;
}
.site-nav > a:not(.nav-cta){
  position:relative;
  padding:.5rem 0;
}
.site-nav > a:not(.nav-cta)::after{
  content:"";
  position:absolute;
  left:0;
  bottom:.18rem;
  width:100%;
  height:2px;
  background:var(--amber);
  transform:scaleX(0);
  transform-origin:right center;
  transition:transform .28s ease;
}
.site-nav > a:not(.nav-cta):hover::after,
.site-nav > a:not(.nav-cta):focus-visible::after{
  transform:scaleX(1);
  transform-origin:left center;
}
.catalog-page .site-header{
  min-height:112px;
  height:112px;
}
.catalog-page .site-header.scrolled{
  min-height:88px;
  height:88px;
}
.footer-logo{
  width:min(420px,100%);
}

/* Parallax media stays clipped by its containing frame. */
.parallax-frame,
.story-image,
.photo-break,
.hero-video{
  overflow:hidden;
}
.parallax-frame{
  transform:translate3d(0,var(--parallax-y,0),0);
  will-change:transform;
}
.parallax-media{
  transform:translate3d(0,var(--parallax-y,0),0) scale(1.08);
  transform-origin:center center;
  will-change:transform;
}
.hero-video-media{
  height:112%;
  top:-6%;
}
@media (prefers-reduced-motion: reduce){
  .parallax-frame,
  .parallax-media{
    transform:none !important;
  }
}
@media(max-width:1100px){
  .logo-link{width:min(320px,34vw)}
  .site-nav{gap:1.35rem;font-size:.84rem}
}
@media(max-width:1000px){
  .site-header,
  .catalog-page .site-header{
    min-height:92px;
    height:92px;
  }
  .logo-link{width:285px}
  .brand-logo{max-height:82px}
  .site-nav{
    font-size:1.25rem;
    gap:1.8rem;
  }
}
@media(max-width:700px){
  .logo-link{width:235px}
  .brand-logo{max-height:72px}
}

/* v7: Cart hover/focus highlight */
.site-nav .nav-cta.cart-link{
  transition:
    background-color .25s ease,
    border-color .25s ease,
    color .25s ease,
    transform .25s ease;
}
.site-nav .nav-cta.cart-link:hover,
.site-nav .nav-cta.cart-link:focus-visible{
  background:var(--amber);
  border-color:var(--amber);
  color:var(--ink);
  transform:translateY(-1px);
}
.site-nav .nav-cta.cart-link:hover [data-cart-count],
.site-nav .nav-cta.cart-link:focus-visible [data-cart-count]{
  background:var(--ink);
  color:var(--amber);
}

/* v8: uniform larger header across all pages */
.site-header,
.site-header.scrolled,
.catalog-page .site-header,
.catalog-page .site-header.scrolled{
  min-height:124px !important;
  height:124px !important;
  padding-inline:3vw !important;
}
.logo-link{ width:min(430px,40vw) !important; }
.brand-logo,
.site-header.scrolled .brand-logo{ max-height:112px !important; }
.site-nav{ font-size:1.02rem !important; gap:2.35rem !important; }
.site-header{
  transition:background-color .35s ease, backdrop-filter .35s ease, border-color .35s ease !important;
}
@media(max-width:1100px){
  .site-header,.site-header.scrolled,.catalog-page .site-header,.catalog-page .site-header.scrolled{
    min-height:112px !important;height:112px !important;
  }
  .logo-link{width:min(360px,38vw) !important;}
  .brand-logo,.site-header.scrolled .brand-logo{max-height:100px !important;}
  .site-nav{font-size:.92rem !important;gap:1.55rem !important;}
}
@media(max-width:1000px){
  .site-header,.site-header.scrolled,.catalog-page .site-header,.catalog-page .site-header.scrolled{
    min-height:102px !important;height:102px !important;
  }
  .logo-link{width:315px !important;}
  .brand-logo,.site-header.scrolled .brand-logo{max-height:92px !important;}
}
@media(max-width:700px){
  .site-header,.site-header.scrolled,.catalog-page .site-header,.catalog-page .site-header.scrolled{
    min-height:94px !important;height:94px !important;
  }
  .logo-link{width:255px !important;}
  .brand-logo,.site-header.scrolled .brand-logo{max-height:84px !important;}
}


/* v9: fixed header on every page and slightly larger navigation */
.site-header,
.site-header.scrolled,
.catalog-page .site-header,
.catalog-page .site-header.scrolled{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:100 !important;
}

/* Interior pages begin below the fixed header. The homepage intentionally
   remains beneath the transparent header for the full-bleed hero treatment. */
.catalog-page{
  padding-top:124px !important;
}

.site-nav{
  font-size:1.10rem !important;
}

@media(max-width:1100px){
  .catalog-page{
    padding-top:112px !important;
  }

  .site-nav{
    font-size:.98rem !important;
  }
}

@media(max-width:1000px){
  .catalog-page{
    padding-top:102px !important;
  }

  .site-nav{
    font-size:1.25rem !important;
  }
}

@media(max-width:700px){
  .catalog-page{
    padding-top:94px !important;
  }
}


/* v10: eliminate the brief white line during header transition */
.site-header,
.site-header.scrolled,
.catalog-page .site-header,
.catalog-page .site-header.scrolled{
  border-bottom-color:transparent !important;
  border-bottom-width:0 !important;
}

/* Keep the transition limited to background effects only. */
.site-header{
  box-shadow:0 0 0 rgba(0,0,0,0) !important;
  transition:
    background-color .35s ease,
    backdrop-filter .35s ease,
    box-shadow .35s ease !important;
}

.site-header.scrolled,
.catalog-page .site-header.scrolled{
  box-shadow:0 8px 24px rgba(0,0,0,.18) !important;
}
