:root {
  --bg: #f7f5ef;
  --surface: #ffffff;
  --surface-alt: #f0efe8;
  --text: #18221d;
  --muted: #5f6c64;
  --brand: #204c3c;
  --brand-2: #a67c52;
  --line: #d9ddd7;
  --shadow: 0 12px 40px rgba(20, 36, 28, 0.08);
  --radius: 24px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', sans-serif;
  line-height: 1.6;
}
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }
.container { width: min(1180px, calc(100% - 2rem)); margin: 0 auto; }
.narrow { width: min(860px, 100%); }
.section { padding: 4.5rem 0; }
.alt { background: var(--surface-alt); }
.eyebrow {
  display: inline-block; margin-bottom: .75rem; font-size: .85rem; text-transform: uppercase;
  letter-spacing: .12em; color: var(--brand);
}
h1, h2, h3 { line-height: 1.15; margin: 0 0 1rem; }
h1 { font-size: clamp(2.5rem, 6vw, 4.8rem); font-weight: 800; }
h2 { font-size: clamp(1.8rem, 4vw, 3rem); }
h3 { font-size: 1.35rem; }
p { margin: 0 0 1rem; color: var(--muted); }
.lead { font-size: 1.12rem; max-width: 62ch; }
.site-header {
  position: sticky; top: 0; z-index: 100; background: rgba(247,245,239,.95); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(32,76,60,.08);
}
.header-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height: 84px; }
.brand { display:flex; align-items:center; gap: .9rem; color:var(--text); text-decoration:none; }
.brand-logo { width: 84px; border-radius: 10px; }
.brand-kicker { display:block; color:var(--muted); font-size:.82rem; }
.brand-name { display:block; font-family:'Playfair Display', serif; font-size:1.45rem; font-weight:700; }
.main-nav { display:flex; align-items:center; gap: 1rem; }
.menu { display:flex; list-style:none; padding:0; margin:0; gap: 1.2rem; }
.menu-toggle { display:none; border:1px solid var(--line); background:#fff; border-radius:12px; padding:.65rem .8rem; }
.nav-cta, .button {
  display:inline-flex; align-items:center; justify-content:center; min-height:48px; border-radius:999px; padding: 0 1.2rem;
  font-weight:700; text-decoration:none; border:1px solid transparent;
}
.nav-cta, .button.primary { background: var(--brand); color:#fff; }
.button.secondary { background: transparent; color: var(--brand); border-color: rgba(32,76,60,.18); }
.hero-grid, .video-grid, .brand-band-grid, .footer-grid, .info-grid { display:grid; gap: 1.5rem; }
.hero-grid { grid-template-columns: 1.35fr .85fr; align-items: center; min-height: 72vh; }
.hero-card, .product-card, .info-card, .social-card, .cta-box, .video-shell, .policy-copy, .stat-card {
  background: var(--surface); border:1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
}
.hero-card { padding: 1.2rem; display:grid; gap:1rem; }
.stat-card { padding: 1.1rem; }
.hero-actions { display:flex; flex-wrap:wrap; gap: .85rem; margin: 1.35rem 0; }
.trust-list, .feature-list { padding-left: 1.2rem; color: var(--muted); }
.brand-band { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.brand-band-grid { grid-template-columns: 1.2fr 1fr; align-items:center; }
.chips { display:flex; flex-wrap:wrap; gap:.75rem; }
.chips span, .product-tag {
  display:inline-flex; align-items:center; padding:.45rem .8rem; border-radius:999px; background:rgba(32,76,60,.08); color:var(--brand); font-size:.9rem; font-weight:600;
}
.section-heading { margin-bottom: 1.5rem; max-width: 48rem; }
.product-grid, .social-card-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:1.2rem; }
.product-card, .info-card, .social-card { padding: 1.3rem; }
.price-row { display:flex; align-items:center; justify-content:space-between; gap: .75rem; margin-top: 1.25rem; }
.video-grid { grid-template-columns: 1fr 1.1fr; align-items: center; }
.video-shell { padding: .75rem; }
.video-shell iframe { width:100%; aspect-ratio: 16/9; border:0; border-radius: 18px; }
.info-grid { grid-template-columns: repeat(3, 1fr); }
.social-card { min-height: 140px; display:flex; flex-direction:column; justify-content:space-between; }
.cta-section { padding-top: 0; }
.cta-box { padding: 1.5rem; display:grid; grid-template-columns: 1.2fr .8fr; align-items:center; gap: 1rem; }
.cta-actions { display:flex; flex-wrap:wrap; gap:.75rem; justify-content:flex-end; }
.site-footer { background:#16241d; color:#f7f5ef; }
.site-footer a, .site-footer p { color: rgba(255,255,255,.82); }
.footer-grid { grid-template-columns: 1.4fr .8fr .8fr; padding: 3rem 0; }
.social-links { display:flex; flex-wrap:wrap; gap:.8rem; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); }
.footer-bottom-inner { min-height: 60px; display:flex; align-items:center; justify-content:space-between; gap:1rem; color: rgba(255,255,255,.68); font-size:.95rem; }
.chat-launcher {
  position: fixed; right: 1rem; bottom: 1rem; z-index: 120; border:0; background:var(--brand); color:#fff; border-radius:999px; min-height:52px; padding:0 1rem; box-shadow: var(--shadow);
}
.chat-box {
  position: fixed; right:1rem; bottom:4.8rem; z-index: 130; width:min(360px, calc(100% - 2rem)); background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow: var(--shadow); overflow:hidden;
}
.chat-box-header { display:flex; align-items:center; justify-content:space-between; padding: .9rem 1rem; border-bottom:1px solid var(--line); }
.chat-close { background:none; border:0; font-size:1.4rem; }
.chat-messages { padding: 1rem; max-height: 260px; overflow:auto; }
.chat-form { display:flex; gap:.5rem; padding: 1rem; border-top:1px solid var(--line); }
.chat-form input { flex:1; min-height:44px; border-radius:12px; border:1px solid var(--line); padding:0 .85rem; }
.chat-form button { border:0; background:var(--brand); color:#fff; border-radius:12px; padding:0 .9rem; }
.mobile-panel { padding: 0 1rem 1rem; }
.mobile-menu-list { list-style:none; padding:0; margin:0 0 .75rem; display:grid; gap:.5rem; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.policy-copy { padding: 1.5rem; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.woocommerce div.product,
.woocommerce-cart-form,
.cart-collaterals,
.woocommerce-checkout,
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
  background: var(--surface); border-radius: var(--radius); border:1px solid var(--line); padding: 1rem;
}
.woocommerce-message,
.woocommerce-info,
.woocommerce-error { border-radius: 16px; }
@media (max-width: 980px) {
  .hero-grid, .video-grid, .brand-band-grid, .cta-box, .footer-grid, .info-grid, .product-grid, .social-card-grid { grid-template-columns: 1fr 1fr; }
  .menu { display:none; }
  .menu-toggle { display:block; }
}
@media (max-width: 720px) {
  .hero-grid, .video-grid, .brand-band-grid, .cta-box, .footer-grid, .info-grid, .product-grid, .social-card-grid { grid-template-columns: 1fr; }
  .main-nav { display:none; }
  h1 { font-size: clamp(2.3rem, 12vw, 3.5rem); }
  .header-inner { min-height: 74px; }
}
