:root {
  --mg-paper: #f6f0e6;
  --mg-linen: #d8cbb7;
  --mg-sage: #9ba98b;
  --mg-tea: #34463a;
  --mg-amber: #b98245;
  --mg-ink: #28231e;
  --mg-amethyst: #8a6f99;
  --mg-white: #fffdf8;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --radius-full: 999px;
  --shadow-card: 0 12px 32px rgba(40, 35, 30, 0.06);
  --shadow-hover: 0 22px 60px rgba(40, 35, 30, 0.12);
  --font-heading: "Cormorant Garamond", "Noto Serif SC", serif;
  --font-body: Inter, "Noto Sans SC", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--mg-ink); background: var(--mg-paper); font: 16px/1.7 var(--font-body); }
body.mg-menu-open { overflow: hidden; }
img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
.mg-shell { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.mg-skip-link { position: fixed; z-index: 1000; top: 12px; left: 12px; padding: 10px 16px; color: var(--mg-paper); background: var(--mg-tea); transform: translateY(-160%); }
.mg-skip-link:focus { transform: none; }

.mg-site-header { position: sticky; z-index: 80; top: 0; border-bottom: 1px solid rgba(52, 70, 58, 0.12); background: rgba(246, 240, 230, 0.92); backdrop-filter: blur(16px); }
.mg-header-inner { min-height: 76px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--space-5); }
.mg-brand { display: inline-flex; flex-direction: column; width: max-content; font: 500 25px/0.9 var(--font-heading); letter-spacing: 0.02em; }
.mg-brand small { margin-top: 8px; color: var(--mg-amber); font: 600 9px/1 var(--font-body); letter-spacing: 0.26em; text-transform: uppercase; }
.mg-primary-nav ul { display: flex; gap: clamp(20px, 3vw, 42px); margin: 0; padding: 0; list-style: none; }
.mg-primary-nav a, .mg-header-actions a { font-size: 13px; font-weight: 500; }
.mg-primary-nav a:hover, .mg-primary-nav a:focus-visible, .mg-header-actions a:hover { color: var(--mg-amber); }
.mg-header-actions { justify-self: end; }
.mg-header-actions span { min-width: 18px; height: 18px; display: inline-grid; place-items: center; margin-left: 5px; border-radius: 50%; color: var(--mg-paper); background: var(--mg-tea); font-size: 10px; }
.mg-menu-toggle { display: none; border: 0; background: transparent; }

.mg-hero { position: relative; min-height: min(760px, 88svh); display: grid; align-items: end; overflow: hidden; color: var(--mg-white); }
.mg-hero > img, .mg-hero-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.mg-hero > img { object-fit: cover; object-position: center; }
.mg-hero-shade { background: linear-gradient(90deg, rgba(21, 30, 24, 0.72), rgba(21, 30, 24, 0.04) 72%), linear-gradient(0deg, rgba(20, 27, 22, 0.45), transparent 45%); }
.mg-hero-copy { position: relative; z-index: 1; padding-bottom: clamp(64px, 10vw, 116px); }
.mg-hero h1 { max-width: 720px; margin: 0 0 var(--space-5); font: 500 clamp(52px, 7vw, 92px)/0.94 var(--font-heading); letter-spacing: -0.025em; }
.mg-hero p { max-width: 610px; margin: 0 0 var(--space-3); font-size: clamp(16px, 2vw, 20px); }
.mg-hero-cn { opacity: 0.82; }
.mg-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-6); }
.mg-button, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button { min-height: 50px; display: inline-flex; align-items: center; justify-content: center; padding: 13px 26px; border: 1px solid transparent; border-radius: var(--radius-full); font-weight: 600; transition: color 0.28s ease, background 0.28s ease, border-color 0.28s ease, transform 0.28s ease; }
.mg-button:hover, .mg-button:focus-visible, .woocommerce a.button:hover, .woocommerce button.button:hover { transform: translateY(-2px); }
.mg-button--primary, .woocommerce a.button, .woocommerce button.button.alt { color: var(--mg-paper); background: var(--mg-tea); }
.mg-button--primary:hover, .woocommerce a.button:hover, .woocommerce button.button.alt:hover { color: var(--mg-paper); background: var(--mg-amber); }
.mg-button--light { border-color: rgba(255, 255, 255, 0.58); color: var(--mg-white); background: rgba(255, 255, 255, 0.08); }
.mg-button--light:hover { color: var(--mg-tea); background: var(--mg-white); }
.mg-button--secondary { border-color: var(--mg-linen); color: var(--mg-tea); }
.mg-button--secondary:hover { background: rgba(216, 203, 183, 0.45); }

.mg-section { padding-block: var(--space-10); }
.mg-section-heading { max-width: 720px; margin-bottom: var(--space-8); }
.mg-section-heading p, .mg-kicker { margin: 0 0 var(--space-3); color: var(--mg-amber); font-size: 12px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; }
.mg-section h2 { margin: 0 0 var(--space-5); font: 500 clamp(42px, 5.5vw, 68px)/1 var(--font-heading); }
.mg-collection-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.mg-collection-card { overflow: hidden; border-radius: var(--radius-lg); background: rgba(255, 253, 248, 0.55); box-shadow: var(--shadow-card); transition: transform 0.35s ease, box-shadow 0.35s ease; }
.mg-collection-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-hover); }
.mg-collection-card img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; }
.mg-collection-card div { padding: var(--space-5); }
.mg-collection-card h3 { margin: 0 0 var(--space-2); font: 500 32px/1.1 var(--font-heading); }
.mg-collection-card p { margin: 0; color: rgba(40, 35, 30, 0.72); font-size: 14px; }

.mg-custom-story { background: var(--mg-tea); color: var(--mg-paper); }
.mg-split, .mg-feature-row { display: grid; grid-template-columns: 0.9fr 1.1fr; align-items: center; gap: clamp(48px, 8vw, 112px); }
.mg-split-copy > p:not(.mg-kicker), .mg-feature-row > div > p:not(.mg-kicker) { max-width: 590px; color: rgba(246, 240, 230, 0.78); }
.mg-process-list { margin: var(--space-6) 0; padding: 0; list-style: none; border-top: 1px solid rgba(246, 240, 230, 0.2); }
.mg-process-list li { display: flex; gap: var(--space-4); padding: var(--space-4) 0; border-bottom: 1px solid rgba(246, 240, 230, 0.2); }
.mg-process-list span { color: var(--mg-sage); font-size: 12px; }
.mg-text-link { display: inline-block; padding-bottom: 3px; border-bottom: 1px solid currentColor; }
.mg-video-frame { overflow: hidden; border-radius: var(--radius-xl); box-shadow: 0 24px 70px rgba(17, 24, 19, 0.28); }
.mg-video-frame video { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; }
.mg-feature-row > img { width: 100%; max-height: 680px; object-fit: cover; border-radius: var(--radius-xl); }
.mg-feature-row > div > p:not(.mg-kicker) { color: rgba(40, 35, 30, 0.72); }
.mg-feature-row--reverse > img { order: 2; }
.mg-botanical { background: rgba(155, 169, 139, 0.2); }

.mg-content, .mg-commerce { min-height: 60vh; padding-block: var(--space-9); }
.mg-article { max-width: 800px; }
.mg-article h1, .woocommerce-products-header__title, .product_title { font: 500 clamp(44px, 6vw, 72px)/1 var(--font-heading); }
.woocommerce ul.products li.product a img { border-radius: var(--radius-lg); }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font: 500 25px/1.2 var(--font-heading); }
.woocommerce div.product p.price, .woocommerce div.product span.price, .woocommerce ul.products li.product .price { color: var(--mg-amber); }
.woocommerce div.product div.images img { border-radius: var(--radius-lg); }
.woocommerce-message, .woocommerce-info { border-top-color: var(--mg-sage); background: rgba(255, 253, 248, 0.7); }

.mg-site-footer { padding: var(--space-9) 0 var(--space-5); color: var(--mg-paper); background: var(--mg-tea); }
.mg-footer-grid { display: grid; grid-template-columns: 1.6fr 0.7fr 1fr; gap: var(--space-8); }
.mg-brand--footer { color: var(--mg-paper); }
.mg-footer-grid p { max-width: 390px; color: rgba(246, 240, 230, 0.68); }
.mg-footer-grid h2 { margin: 0 0 var(--space-4); color: var(--mg-sage); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; }
.mg-footer-grid ul { margin: 0; padding: 0; list-style: none; }
.mg-footer-grid li { margin-bottom: var(--space-2); }
.mg-footer-bottom { display: flex; justify-content: space-between; gap: var(--space-4); margin-top: var(--space-8); padding-top: var(--space-5); border-top: 1px solid rgba(246, 240, 230, 0.18); color: rgba(246, 240, 230, 0.58); font-size: 12px; }

@media (max-width: 900px) {
  .mg-header-inner { grid-template-columns: 1fr auto; }
  .mg-menu-toggle { width: 44px; height: 44px; display: grid; align-content: center; gap: 7px; justify-self: end; }
  .mg-menu-toggle span:not(.screen-reader-text) { width: 23px; height: 1px; display: block; background: var(--mg-ink); }
  .mg-primary-nav { position: fixed; inset: 76px 0 auto; display: none; padding: 30px 20px 50px; background: var(--mg-paper); box-shadow: var(--shadow-card); }
  .mg-primary-nav.is-open { display: block; }
  .mg-primary-nav ul { flex-direction: column; gap: 0; }
  .mg-primary-nav li { border-bottom: 1px solid rgba(52, 70, 58, 0.14); }
  .mg-primary-nav a { display: block; padding: 17px 0; font: 500 28px/1.2 var(--font-heading); }
  .mg-header-actions { display: none; }
  .mg-collection-grid { grid-template-columns: 1fr; }
  .mg-collection-card { display: grid; grid-template-columns: 0.9fr 1.1fr; }
  .mg-collection-card img { height: 100%; aspect-ratio: 1; }
  .mg-collection-card div { align-self: center; }
  .mg-split, .mg-feature-row { grid-template-columns: 1fr; }
  .mg-feature-row--reverse > img { order: initial; }
  .mg-footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 600px) {
  .mg-shell { width: min(100% - 32px, 1180px); }
  .mg-site-header, .mg-header-inner { min-height: 68px; }
  .mg-primary-nav { inset-block-start: 68px; }
  .mg-hero { min-height: 760px; }
  .mg-hero > img { object-position: 60% center; }
  .mg-hero-shade { background: linear-gradient(0deg, rgba(21, 30, 24, 0.82), rgba(21, 30, 24, 0.05) 78%); }
  .mg-hero h1 { font-size: clamp(48px, 14vw, 62px); }
  .mg-actions { align-items: stretch; flex-direction: column; }
  .mg-button { width: 100%; }
  .mg-section { padding-block: 72px; }
  .mg-section h2 { font-size: 42px; }
  .mg-section-heading { margin-bottom: var(--space-6); }
  .mg-collection-card { display: block; }
  .mg-collection-card img { aspect-ratio: 4 / 5; }
  .mg-footer-grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .mg-footer-bottom { align-items: flex-start; flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

