
:root{
  --bg:#eff2ec;
  --bg-deep:#c1cbc3;
  --surface:#f8f6f1;
  --surface-2:#ffffff;
  --surface-dark:#242826;
  --text:#22302a;
  --text-soft:#5e6b65;
  --line:rgba(34,48,42,.11);
  --gold:#9c8158;
  --sage:#bfc9c1;
  --olive:#657468;
  --shadow:rgba(50,50,93,0.18) 0px 30px 45px -26px, rgba(0,0,0,0.10) 0px 18px 36px -18px;
  --shadow-soft:rgba(50,50,93,0.10) 0px 18px 28px -22px, rgba(0,0,0,0.08) 0px 12px 22px -18px;
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.75), rgba(255,255,255,0) 24%),
    linear-gradient(180deg, #d7ded7 0%, #edf1eb 20%, #eff2ec 100%);
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:40;
  background:rgba(248,246,241,.76);
  backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid rgba(34,48,42,.08);
}
.nav-shell{display:flex; align-items:center; justify-content:space-between; gap:24px; padding:14px 0}
.brand{display:flex; align-items:center; gap:14px; min-width:0}
.brand img{width:96px; height:auto}
.brand-mark{display:flex; flex-direction:column; gap:3px}
.brand-mark strong{
  font-family: Georgia, 'Times New Roman', serif;
  font-size:1.16rem; font-weight:600; letter-spacing:.02em;
}
.brand-mark span{
  font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--text-soft)
}
.nav-links{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.nav-links a{
  font-size:.82rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  padding:11px 14px; border-radius:999px; color:#32423a;
}
.nav-links a.active,.nav-links a:hover{background:rgba(34,48,42,.06)}
.nav-cta{padding:11px 16px; border-radius:999px; background:#27342e; color:#fff!important}
.hero{padding:42px 0 28px; position:relative}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:28px; align-items:stretch}
.hero-copy{
  background:linear-gradient(145deg, rgba(36,40,38,.95), rgba(87,100,91,.92));
  color:#fff; border-radius:32px; padding:54px 48px; position:relative; overflow:hidden; box-shadow:var(--shadow)
}
.hero-copy:before{
  content:''; position:absolute; inset:auto -80px -120px auto; width:290px; height:290px; border-radius:50%; border:1px solid rgba(255,255,255,.18)
}
.hero-copy:after{
  content:''; position:absolute; left:-60px; top:-70px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle, rgba(255,255,255,.12), rgba(255,255,255,0) 68%)
}
.eyebrow{font-size:.76rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.72); margin-bottom:18px; text-align:left}
.hero h1{
  margin:0 auto; max-width:12ch; text-align:center; font-family: Georgia, 'Times New Roman', serif; font-size:clamp(2.45rem, 4.9vw, 4rem);
  line-height:1.04; letter-spacing:-.04em; font-weight:500; text-wrap:pretty;
}
.hero-copy p.lead{
  max-width:34ch; text-align:center; font-size:1.12rem; line-height:1.7; color:rgba(255,255,255,.86); margin:20px auto 24px; text-wrap:pretty
}
.hero-badges{display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:0 0 26px}
.hero-badges span{
  font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; padding:10px 14px; border-radius:999px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); color:rgba(255,255,255,.82)
}
.hero-actions{display:flex; justify-content:center; gap:12px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; justify-content:center; padding:14px 18px; min-height:48px;
  border-radius:999px; font-size:.95rem; font-weight:600; letter-spacing:.02em
}
.btn-primary{background:#fff; color:#24302b}
.btn-secondary{border:1px solid rgba(255,255,255,.22); color:#fff; background:rgba(255,255,255,.05)}
.hero-visual{
  display:grid; grid-template-rows:auto 1fr; gap:18px
}
.statement-card{
  background:rgba(255,255,255,.62); border:1px solid rgba(255,255,255,.66); border-radius:28px; padding:18px; box-shadow:var(--shadow-soft)
}
.statement-card .quote{font-family:Georgia, 'Times New Roman', serif; font-size:1.4rem; line-height:1.3; color:#293630; text-align:center; max-width:18ch; margin:0 auto; text-wrap:pretty}
.hero-product{
  background:linear-gradient(180deg, rgba(248,246,241,.95), rgba(255,255,255,.82));
  border:1px solid rgba(34,48,42,.08); border-radius:32px; padding:28px; position:relative; overflow:hidden; box-shadow:var(--shadow)
}
.hero-product .halo{
  position:absolute; right:-40px; top:-40px; width:180px; height:180px; border-radius:50%; background:radial-gradient(circle, rgba(156,129,88,.18), rgba(156,129,88,0) 70%)
}
.hero-product .botanical{
  position:absolute; left:20px; bottom:20px; width:110px; height:180px; opacity:.15; border-left:2px solid var(--olive); border-radius:60px;
}
.hero-logo{width:min(100%, 300px); margin:0 auto 20px}
.hero-product-shot{width:min(100%, 280px); margin:0 auto 18px; filter:drop-shadow(0 26px 28px rgba(36,40,38,.16))}
.hero-product p{margin:0; text-align:center; color:var(--text-soft); line-height:1.65}
.section{padding:30px 0 44px}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.value-card{
  background:rgba(255,255,255,.72); border:1px solid var(--line); border-radius:24px; padding:22px; box-shadow:var(--shadow-soft)
}
.value-card .icon{width:48px; height:48px; border-radius:14px; display:grid; place-items:center; background:rgba(101,116,104,.10); color:var(--olive); font-size:1.25rem; margin-bottom:12px}
.value-card h3{margin:0 0 10px; font-family:Georgia, 'Times New Roman', serif; font-size:1.28rem; font-weight:500; letter-spacing:-.02em}
.value-card p{margin:0; color:var(--text-soft); line-height:1.72}
.band{
  background:linear-gradient(180deg, rgba(255,255,255,.52), rgba(255,255,255,.36)); border-top:1px solid rgba(255,255,255,.56); border-bottom:1px solid rgba(34,48,42,.06)
}
.section-head{display:flex; align-items:end; justify-content:space-between; gap:24px; margin-bottom:24px}
.section-head h2{
  margin:0; font-family:Georgia, 'Times New Roman', serif; font-size:clamp(2.4rem, 4vw, 3.4rem); line-height:.98; letter-spacing:-.04em; font-weight:500
}
.section-head p{max-width:640px; margin:0; color:var(--text-soft); line-height:1.78}
.collection-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.product-card{
  background:rgba(248,246,241,.96); border:1px solid rgba(34,48,42,.08); border-radius:26px; padding:16px; box-shadow:var(--shadow-soft)
}
.product-card img{width:100%; height:250px; object-fit:contain; background:linear-gradient(180deg, #fff, #f4f2ec); border-radius:18px; padding:10px}
.product-meta{padding:16px 6px 6px}
.product-card h3{margin:0 0 6px; font-family:Georgia, 'Times New Roman', serif; font-size:1.15rem; font-weight:500; letter-spacing:-.01em}
.price{font-size:.92rem; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--gold)}
.product-note{font-size:.9rem; color:var(--text-soft); line-height:1.7; margin-top:8px}
.showcase{
  display:grid; grid-template-columns:.88fr 1.12fr; gap:22px; align-items:stretch
}
.editorial-card{
  background:linear-gradient(180deg, #faf7f2, #f1eee6); border:1px solid rgba(34,48,42,.06); border-radius:28px; padding:30px; box-shadow:var(--shadow)
}
.editorial-card img{width:min(100%, 320px); margin-bottom:18px}
.editorial-card h3{margin:0 0 10px; font-family:Georgia, 'Times New Roman', serif; font-size:2rem; font-weight:500; line-height:1.02}
.editorial-card p{margin:0; color:var(--text-soft); line-height:1.8}
.side-list{display:grid; gap:14px}
.side-item{background:rgba(255,255,255,.76); border:1px solid var(--line); border-radius:20px; padding:18px 20px}
.side-item strong{display:block; font-size:1rem; margin-bottom:8px}
.side-item span{color:var(--text-soft); line-height:1.7}
.alt-section{background:#242826; color:#fff}
.alt-section .section-head p,.alt-section .faq-item p,.alt-section .faq-item .faq-tag,.alt-section .footer-copy{color:rgba(255,255,255,.72)}
.qa-head{margin-bottom:32px}
.faq-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.faq-item{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.10); border-radius:24px; padding:22px}
.faq-tag{font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; margin-bottom:12px}
.faq-item h3{margin:0 0 10px; font-family:Georgia, 'Times New Roman', serif; font-size:1.3rem; font-weight:500}
.faq-item p{margin:0; line-height:1.8}
.contact-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:22px}
.status-banner{margin:0 0 18px; padding:16px 18px; border-radius:18px; border:1px solid rgba(34,48,42,.08); line-height:1.7; box-shadow:var(--shadow-soft)}
.status-success{background:linear-gradient(180deg, rgba(191,201,193,.34), rgba(255,255,255,.72)); color:#22302a}
.status-error{background:linear-gradient(180deg, rgba(214,188,180,.34), rgba(255,255,255,.72)); color:#4d2c24}
.contact-panel,.form-panel{background:rgba(248,246,241,.96); border:1px solid rgba(34,48,42,.08); border-radius:28px; box-shadow:var(--shadow)}
.contact-panel{padding:30px}
.contact-panel img{width:min(100%, 250px); margin:0 auto 22px}
.contact-panel h3{margin:0 0 12px; font-family:Georgia, 'Times New Roman', serif; font-size:2rem; font-weight:500}
.contact-panel p{margin:0 0 14px; color:var(--text-soft); line-height:1.8}
.contact-points{display:grid; gap:12px; margin-top:18px}
.contact-points div{padding:16px 18px; border-radius:18px; background:linear-gradient(180deg, rgba(191,201,193,.26), rgba(255,255,255,.4)); border:1px solid rgba(34,48,42,.06)}
.form-panel{padding:28px}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.field{display:grid; gap:8px}
.field.full{grid-column:1/-1}
label{font-size:.84rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:#415048}
input,textarea{
  width:100%; padding:15px 16px; border-radius:16px; border:1px solid rgba(34,48,42,.14); background:#fff; font:inherit; color:var(--text)
}
textarea{min-height:170px; resize:vertical}
.form-note{font-size:.92rem; color:var(--text-soft); line-height:1.7}
.form-actions{display:flex; justify-content:center; align-items:center; gap:16px; margin-top:18px}
.site-footer{padding:28px 0 48px}
.footer-shell{display:grid; gap:10px}
.footer-wrap{background:rgba(255,255,255,.72); border:1px solid rgba(34,48,42,.08); border-radius:28px; padding:16px 24px 14px; display:grid; grid-template-columns:120px minmax(270px,340px) minmax(280px,1fr); align-items:center; column-gap:0; row-gap:12px; box-shadow:var(--shadow-soft)}
.footer-col{min-height:92px; display:flex; align-items:center; justify-content:center; padding:6px 18px}
.footer-col:not(:last-of-type){border-right:1px solid rgba(34,48,42,.08)}
.footer-brand{display:flex; align-items:center; justify-content:center}
.footer-brand img{width:84px; flex:0 0 auto}
.footer-copy{color:var(--text-soft); line-height:1.5; text-align:center; display:grid; gap:6px}
.footer-tagline,.footer-shay,.micro-disclaimer,.footer-side-title,.footer-side-copy{display:block}
.footer-tagline{max-width:28ch; margin:0 auto; text-wrap:pretty}
.footer-shay{text-align:center; font-size:.96rem}
.footer-shay strong{letter-spacing:.01em}
.footer-side{display:grid; gap:6px; color:var(--text-soft); text-align:center; line-height:1.5}
.footer-side-title{font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:#5d6a61}
.footer-side-copy{max-width:34ch; margin:0 auto; text-wrap:pretty}
.micro{grid-column:1 / -1; padding-top:12px; border-top:1px solid rgba(34,48,42,.08); font-size:.82rem; color:var(--text-soft); line-height:1.55}
.micro-disclaimer{max-width:64ch; margin:0 auto; text-align:center; text-wrap:pretty}
.footer-rights{text-align:center; font-size:.78rem; letter-spacing:.02em; color:var(--text-soft)}
.catalog-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.catalog-card{background:rgba(248,246,241,.96); border:1px solid var(--line); border-radius:24px; padding:16px; box-shadow:var(--shadow-soft)}
.catalog-card img{height:220px; width:100%; object-fit:contain; background:linear-gradient(180deg, #fff, #f4f2ec); border-radius:18px; padding:10px}
.catalog-card h3{margin:14px 0 6px; font-family:Georgia, 'Times New Roman', serif; font-size:1.1rem; font-weight:500}
.mini-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:18px}
.mini-item{background:rgba(255,255,255,.76); border:1px solid var(--line); border-radius:20px; padding:16px}
.mini-item strong{display:block; margin-bottom:6px}
.muted-panel{background:rgba(255,255,255,.62); border:1px solid rgba(34,48,42,.08); border-radius:24px; padding:20px; color:var(--text-soft); line-height:1.8}
@media (max-width:1080px){
  .collection-grid,.catalog-grid,.mini-grid,.faq-grid{grid-template-columns:repeat(2,1fr)}
  .hero-grid,.showcase,.contact-grid{grid-template-columns:1fr}
  .footer-wrap{grid-template-columns:1fr; justify-items:center; text-align:center}
  .footer-col{width:100%; min-height:auto; padding:12px 8px}
  .footer-col:not(:last-of-type){border-right:0; border-bottom:1px solid rgba(34,48,42,.08)}
  .footer-brand{justify-content:center}
}
@media (max-width:760px){
  .nav-shell{flex-direction:column; align-items:flex-start}
  .hero-copy{padding:34px 28px}
  .section-head{flex-direction:column; align-items:flex-start}
  .grid-3,.collection-grid,.catalog-grid,.mini-grid,.faq-grid,.form-grid{grid-template-columns:1fr}
  .footer-wrap{padding:18px 18px}
  .brand img{width:82px}
}


.product-hero{padding:14px 0 8px}
.product-lead{max-width:760px; color:var(--text-soft); line-height:1.8; margin:8px 0 0}
.category-stack{display:grid; gap:30px}
.category-block{background:rgba(255,255,255,.52); border:1px solid rgba(34,48,42,.08); border-radius:30px; padding:24px; box-shadow:var(--shadow-soft)}
.category-head{display:flex; justify-content:space-between; align-items:end; gap:20px; margin-bottom:18px}
.category-head h3{margin:0; font-family:Georgia, 'Times New Roman', serif; font-size:2rem; font-weight:500; letter-spacing:-.03em}
.category-head p{max-width:560px; margin:0; color:var(--text-soft); line-height:1.75}
.category-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.catalog-card{background:rgba(248,246,241,.96); border:1px solid var(--line); border-radius:24px; padding:16px; box-shadow:var(--shadow-soft)}
.catalog-card img{height:220px; width:100%; object-fit:contain; background:linear-gradient(180deg, #fff, #f4f2ec); border-radius:18px; padding:10px}
.catalog-card h4{margin:14px 0 6px; font-family:Georgia, 'Times New Roman', serif; font-size:1.05rem; font-weight:500}
.catalog-card .price{display:block}
@media (max-width:1080px){ .category-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:760px){ .category-head,.category-grid{grid-template-columns:1fr} .category-head{display:block} }
