/* [next]/internal/font/google/inter_62349e8a.module.css [app-client] (css) */
@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/5476f68d60460930-s.0wxq9webf.ew4.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/5476f68d60460930-s.0wxq9webf.ew4.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/5476f68d60460930-s.0wxq9webf.ew4.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/5476f68d60460930-s.0wxq9webf.ew4.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Inter Fallback;
  src: local(Arial);
  ascent-override: 90.44%;
  descent-override: 22.52%;
  line-gap-override: 0.0%;
  size-adjust: 107.12%;
}

.inter_62349e8a-module__KMPqta__className {
  font-family: Inter, Inter Fallback;
  font-style: normal;
}

.inter_62349e8a-module__KMPqta__variable {
  --font-inter: "Inter", "Inter Fallback";
}

/* [next]/internal/font/google/playfair_display_1f93bd76.module.css [app-client] (css) */
@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/65c558afe41e89d6-s.113htgw8u-emy.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/14e23f9b59180572-s.08.c8psu~gif9.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/b49b0d9b851e4899-s.0yfy_qj1.2qn0.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/2a65768255d6b625-s.p.14by5b4al-y~f.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/65c558afe41e89d6-s.113htgw8u-emy.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/14e23f9b59180572-s.08.c8psu~gif9.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/b49b0d9b851e4899-s.0yfy_qj1.2qn0.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/2a65768255d6b625-s.p.14by5b4al-y~f.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/65c558afe41e89d6-s.113htgw8u-emy.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/14e23f9b59180572-s.08.c8psu~gif9.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/b49b0d9b851e4899-s.0yfy_qj1.2qn0.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Playfair Display;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/2a65768255d6b625-s.p.14by5b4al-y~f.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Playfair Display Fallback;
  src: local(Times New Roman);
  ascent-override: 97.25%;
  descent-override: 22.56%;
  line-gap-override: 0.0%;
  size-adjust: 111.26%;
}

.playfair_display_1f93bd76-module__UxgEwG__className {
  font-family: Playfair Display, Playfair Display Fallback;
  font-style: normal;
}

.playfair_display_1f93bd76-module__UxgEwG__variable {
  --font-playfair: "Playfair Display", "Playfair Display Fallback";
}

/* [project]/src/app/globals.css [app-client] (css) */
:root {
  --bg-primary: #efe6dc;
  --bg-secondary: #fff;
  --bg-tertiary: #e2d8cd;
  --text-primary: #1d140f;
  --text-secondary: #1d140fa6;
  --accent: #7a0000;
  --accent-hover: #9a2020;
  --accent-gold: #7a0000;
  --accent-gold-hover: #9a2020;
  --accent-bronze: #6b1515;
  --border-light: #3c291d1f;
  --border-focus: #7a000080;
  --space-sm: .5rem;
  --space-md: 1rem;
  --space-lg: 2rem;
  --space-xl: 4rem;
  --font-serif: var(--font-playfair), "Playfair Display", serif;
  --font-sans: var(--font-inter), "Inter", sans-serif;
  --transition-smooth: all .4s cubic-bezier(.16, 1, .3, 1);
  --transition-fast: all .2s ease;
  --page-top-offset: 10.25rem;
  --auth-on-panel: #1d140f;
  --auth-on-panel-muted: #1d140fb8;
  --auth-on-panel-subtle: #1d140f8c;
  --auth-link: var(--accent-gold);
  --auth-link-hover: var(--accent-gold-hover);
  --auth-success: #1b5e20;
  --auth-success-bg: #1b5e201a;
  --auth-danger: #8b1538;
  --auth-danger-bg: #8b15381a;
  --cookie-banner-height: 80px;
}

@media (max-width: 768px) {
  :root {
    --page-top-offset: 11.25rem;
  }
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  --lightningcss-light: initial;
  --lightningcss-dark: ;
  color-scheme: light;
}

html, body {
  scroll-behavior: smooth;
  max-width: 100vw;
  overflow-x: hidden;
}

body {
  color: var(--text-primary);
  background: var(--bg-primary);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

a {
  color: inherit;
  transition: var(--transition-fast);
  text-decoration: none;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  letter-spacing: -.01em;
  font-weight: 400;
  line-height: 1.15;
}

.btn-primary {
  background-color: var(--accent);
  color: #fff;
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 1.8px;
  cursor: pointer;
  border: none;
  border-radius: 2px;
  padding: .9rem 2.4rem;
  font-size: .8rem;
  font-weight: 600;
  transition: background-color .2s, box-shadow .2s;
  display: inline-block;
  position: relative;
  overflow: hidden;
}

.btn-primary:hover {
  background-color: #5c0000;
  box-shadow: 0 4px 20px #5c00004d;
}

.btn-secondary {
  color: inherit;
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 1.8px;
  border: 1px solid color-mix(in srgb, currentColor 30%, transparent);
  background-color: #0000;
  background: color-mix(in srgb, currentColor 4%, transparent);
  cursor: pointer;
  border-radius: 2px;
  padding: .9rem 2.4rem;
  font-size: .8rem;
  font-weight: 600;
  transition: border-color .2s, background .2s;
  display: inline-block;
}

.btn-secondary:hover {
  border-color: color-mix(in srgb, currentColor 60%, transparent);
  background: color-mix(in srgb, currentColor 10%, transparent);
}

.glass-panel {
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--border-light);
  background: #ffffff08;
  border-radius: 4px;
}

.container {
  width: 100%;
  max-width: 1280px;
  padding: 0 var(--space-lg);
  margin: 0 auto;
}

@media (max-width: 640px) {
  .section {
    padding: 2.35rem 0;
  }

  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .section-header {
    margin-bottom: 1.35rem;
  }

  .section-header h2 {
    font-size: clamp(1.65rem, 6.5vw, 2.4rem);
  }

  .grid {
    gap: 1.2rem;
  }

  .product-info {
    padding: 1.1rem 1.15rem 1.35rem;
  }

  .section-header-split {
    text-align: center;
    justify-items: center;
    gap: .85rem;
  }

  .section-header-split > div {
    text-align: center;
  }

  .collections-footer {
    gap: .85rem;
    margin-top: 1.35rem;
    padding: 1rem;
  }

  .collections-note {
    text-align: center;
    font-size: .86rem;
  }

  .services-content {
    padding: 1.5rem 1.05rem 1.65rem;
  }

  .services-spotlight h2 {
    margin-bottom: 1rem;
  }

  .services-spotlight p {
    margin-bottom: 1.25rem;
    font-size: .98rem;
    line-height: 1.62;
  }

  .service-pill-row {
    justify-content: center;
    gap: .5rem;
    margin-bottom: 1.25rem;
  }

  .service-pill {
    padding: .55rem .75rem;
    font-size: .72rem;
  }

  .services-stats {
    gap: .55rem;
    margin-bottom: 1.25rem;
  }

  .services-stats div {
    padding: .75rem .65rem;
  }

  .services-stats strong {
    font-size: 1.35rem;
  }

  .services-stats span {
    font-size: .82rem;
  }
}

.navbar {
  z-index: 170;
  -webkit-backdrop-filter: blur(14px);
  background: #efe6dcf7;
  border-bottom: 1px solid #3c291d1f;
  width: 100%;
  position: fixed;
  top: 0;
}

.navbar, .nav-content, .nav-links, .nav-item-mega {
  overflow: visible;
}

.nav-announcement {
  color: #fff;
  background: linear-gradient(90deg, #4a0000 0%, #7a0000 50%, #4a0000 100%);
  border-bottom: 1px solid #7a00004d;
}

.auth-modal {
  z-index: 300;
  padding: max(.75rem, env(safe-area-inset-top, 0px)) max(1rem, env(safe-area-inset-right, 0px))
    max(.75rem, env(safe-area-inset-bottom, 0px)) max(1rem, env(safe-area-inset-left, 0px));
  box-sizing: border-box;
  align-content: center;
  place-items: center;
  display: grid;
  position: fixed;
  inset: 0;
}

.auth-modal-backdrop {
  z-index: 1;
  -webkit-backdrop-filter: blur(10px);
  background: #120a0a59;
  border: 0;
  position: absolute;
  inset: 0;
}

.auth-modal-wrap {
  z-index: 2;
  pointer-events: none;
  width: fit-content;
  max-width: min(500px, 100vw - 1.75rem);
  position: relative;
}

.auth-modal-card {
  pointer-events: auto;
  background: linear-gradient(168deg, #fffefb 0%, #f5ede4 52%, #e8dfd4 100%);
  border: 1px solid #3c291d1a;
  border-radius: 24px;
  flex-direction: column;
  width: 100%;
  max-height: min(98dvh, 100dvh - .5rem);
  padding: 1.15rem .85rem .85rem;
  display: flex;
  overflow: hidden;
  box-shadow: inset 0 4px 2px #ffffffb8, 0 32px 80px #180e0a38;
}

.auth-modal-card > .auth-modal-inner {
  overscroll-behavior: contain;
  flex: auto;
  min-height: 0;
  overflow: hidden;
}

@media (max-height: 520px) {
  .auth-modal-card > .auth-modal-inner {
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    overflow-y: auto;
  }
}

.auth-modal-close {
  z-index: 10;
  pointer-events: auto;
  color: #5d4e44;
  cursor: pointer;
  background: #ffffffe6;
  border: 1px solid #3c291d2e;
  border-radius: 999px;
  place-items: center;
  width: 36px;
  height: 36px;
  font-size: 1.25rem;
  line-height: 1;
  transition: background .15s, box-shadow .15s;
  display: grid;
  position: absolute;
  top: .75rem;
  right: .75rem;
  box-shadow: 0 2px 8px #00000014;
}

.auth-modal-close:hover {
  background: #fff;
  box-shadow: 0 3px 12px #00000024;
}

.auth-modal-inner .auth-panel {
  box-shadow: none;
  text-align: center;
  border: 1px solid #3c291d1a;
  padding: .72rem .8rem .65rem;
}

.auth-modal-inner .auth-panel.auth-form {
  text-align: left;
}

.auth-modal-inner h1 {
  color: var(--auth-on-panel);
  margin-bottom: .3rem;
  font-size: clamp(1.32rem, 3.6vw, 1.72rem);
}

.auth-modal-inner .auth-hero {
  margin-bottom: .55rem;
}

.auth-modal-inner .auth-form {
  text-align: left;
  align-items: stretch;
  gap: .48rem;
}

.auth-modal-inner .auth-footer {
  text-align: center;
  justify-content: center;
}

.auth-modal-inner .auth-kicker {
  letter-spacing: .14em;
  margin-bottom: .35rem;
  padding: .2rem .55rem;
  font-size: .6rem;
}

.auth-modal-inner .auth-footer, .auth-modal-inner .auth-footer a {
  color: var(--auth-on-panel-muted);
}

.auth-modal-inner .auth-footer a.auth-text-link {
  color: var(--auth-link);
  text-underline-offset: 3px;
  border-bottom: none;
  font-weight: 700;
  text-decoration: underline;
}

.auth-modal-inner .auth-footer a.auth-text-link:hover {
  color: var(--auth-link-hover);
}

.auth-modal-inner .auth-field {
  gap: .22rem;
}

.auth-modal-inner .auth-field input {
  border-radius: 11px;
  padding: .52rem .72rem;
  font-size: .86rem;
}

.auth-modal-inner .auth-pw-wrap input {
  padding-right: 2.6rem;
}

.auth-modal-inner .auth-pw-toggle {
  border-radius: 10px;
  width: 2.1rem;
  height: 2.1rem;
  right: .35rem;
}

.auth-verify-resend.btn-primary:disabled, .auth-verify-resend.btn-primary[disabled] {
  opacity: .78;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

.auth-verify-resend.btn-primary:disabled:hover, .auth-verify-resend.btn-primary[disabled]:hover {
  background-color: var(--accent);
  box-shadow: none;
  transform: none;
}

.auth-modal-inner .auth-submit {
  border-radius: 12px;
  margin-top: .1rem;
  padding-top: .68rem;
  padding-bottom: .68rem;
  font-size: .74rem;
}

.auth-modal-inner .auth-field span {
  letter-spacing: .1em;
  font-size: .62rem;
}

.auth-modal-inner .auth-lead {
  max-width: 48ch;
  font-size: .8rem;
  line-height: 1.32;
}

.auth-modal-inner .auth-signup-promo-block {
  border-radius: 11px;
  gap: .3rem;
  padding: .42rem .5rem;
}

.auth-modal-inner .auth-field-label-promo {
  letter-spacing: .1em;
  font-size: .62rem;
}

.auth-modal-inner .auth-signup-promo-row {
  gap: .35rem;
}

.auth-modal-inner .auth-signup-promo-row input {
  border-radius: 10px;
  padding: .48rem .62rem;
  font-size: .8rem;
}

.auth-modal-inner .auth-signup-promo-apply {
  padding: .42rem .65rem;
  font-size: .64rem;
}

.auth-modal-inner .auth-signup-promo-msg {
  margin: 0;
  font-size: .72rem;
}

.auth-modal-inner .auth-marketing-row {
  gap: .4rem !important;
}

.auth-modal-inner .auth-marketing-copy {
  font-size: .7rem !important;
  line-height: 1.28 !important;
}

.auth-modal-inner .auth-register-prompt, .auth-modal-inner .auth-login-prompt {
  gap: .38rem;
  margin-top: .3rem;
}

.auth-modal-inner .auth-register-prompt-hint, .auth-modal-inner .auth-login-prompt-hint {
  font-size: .72rem;
  line-height: 1.3;
}

.auth-modal-inner .auth-register-prompt-cta {
  padding: .42rem .85rem;
  font-size: .68rem;
}

.auth-modal-inner .auth-login-prompt-cta {
  padding: .38rem .78rem;
  font-size: .68rem;
}

.auth-modal-inner .auth-error {
  margin: 0;
  padding: .55rem .7rem;
  font-size: .78rem;
}

.auth-modal-inner label.auth-field[style] span {
  letter-spacing: .02em !important;
  text-transform: none !important;
  font-size: .68rem !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
}

.auth-modal-inner .auth-login-extras {
  gap: .22rem;
  margin-top: -.12rem;
}

.auth-modal-inner .auth-remember-hint {
  margin: -.15rem 0 0;
  font-size: .64rem;
  line-height: 1.28;
}

.auth-modal-inner .auth-inline-link {
  font-size: .72rem;
}

.auth-inline-link.auth-inline-link--forgot-back {
  color: var(--accent);
}

.auth-inline-link.auth-inline-link--forgot-back:hover {
  color: #5c0000;
}

.auth-modal-inner .auth-oauth {
  gap: .5rem;
  margin-top: .65rem;
}

.auth-modal-inner .auth-oauth-divider {
  font-size: .68rem;
}

.auth-modal-inner .auth-oauth-buttons {
  gap: .4rem;
}

.auth-modal-inner .auth-oauth-btn {
  min-width: 6.5rem;
  font-size: .78rem;
}

.auth-modal-inner .cart-promo-msg {
  line-height: 1.28;
  margin-bottom: .35rem !important;
  font-size: .7rem !important;
}

.nav-announcement-inner {
  min-height: 26px;
  padding: .35rem var(--space-lg);
  letter-spacing: .08em;
  text-transform: uppercase;
  justify-content: space-between;
  align-items: center;
  gap: .85rem;
  font-size: .72rem;
  display: flex;
}

.nav-announcement-close {
  color: #fff;
  cursor: pointer;
  background: #0000002e;
  border: 1px solid #ffffff38;
  border-radius: 999px;
  place-items: center;
  width: 28px;
  height: 28px;
  margin-left: auto;
  font-size: 1.1rem;
  line-height: 1;
  transition: transform .15s, background .15s;
  display: grid;
}

.nav-announcement-close:hover {
  background: #00000047;
  transform: translateY(-1px);
}

.nav-announcement-label {
  white-space: nowrap;
  font-weight: 700;
}

.nav-announcement-label:empty {
  display: none;
}

.nav-announcement p {
  opacity: .92;
}

.nav-announcement-items {
  opacity: .92;
  white-space: nowrap;
  scrollbar-width: none;
  flex: 1;
  justify-content: center;
  align-items: center;
  gap: .85rem;
  display: flex;
  overflow: auto;
}

.nav-announcement-items::-webkit-scrollbar {
  display: none;
}

.nav-announcement-items span {
  align-items: center;
  gap: .65rem;
  display: inline-flex;
}

.nav-announcement-items span + span:before {
  content: "·";
  opacity: .7;
}

.cookie-banner {
  z-index: 120;
  padding: 1rem 1rem max(1rem, env(safe-area-inset-bottom, 0px))
    max(1rem, env(safe-area-inset-left, 0px));
  pointer-events: none;
  background: linear-gradient(to top, #1d140f0f 0%, #0000 100%);
  position: fixed;
  bottom: 0;
  left: 0;
  right: auto;
}

.cookie-banner-inner {
  pointer-events: auto;
  background: linear-gradient(168deg, #fffef9 0%, #f3ece4 52%, #ebe3d8 100%);
  border: 1px solid #3c291d24;
  border-radius: 6px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  gap: 1.25rem;
  width: 100%;
  max-width: min(420px, 100vw - 2rem);
  margin: 0;
  padding: 1.1rem 1.35rem;
  display: flex;
  box-shadow: inset 0 2px #ffffffa6, 0 14px 48px #22161024, 0 4px 16px #2216100f;
}

.cookie-banner-title {
  color: var(--text-primary);
  font-family: var(--font-serif);
  letter-spacing: .06em;
  margin-bottom: .35rem;
  font-size: 1.08rem;
  font-weight: 500;
  display: block;
}

.cookie-banner-copy p {
  color: var(--text-secondary);
  max-width: 54ch;
  font-size: .9rem;
  line-height: 1.5;
}

.cookie-banner-link {
  color: var(--accent);
  text-underline-offset: 3px;
  transition: var(--transition-fast);
  font-weight: 500;
  -webkit-text-decoration: underline #7a000059;
  text-decoration: underline #7a000059;
}

.cookie-banner-link:hover {
  color: var(--accent-hover);
  text-decoration-color: #9a20208c;
}

.cookie-banner-actions {
  flex-wrap: wrap;
  flex-shrink: 0;
  justify-content: flex-start;
  align-items: center;
  gap: .55rem;
  display: flex;
}

.cookie-banner .cookie-btn {
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: .65rem 1.15rem;
  font-size: .78rem;
}

.cookie-banner .cookie-btn.btn-secondary {
  background: #ffffff59;
  border-color: #3c291d2e;
}

.cookie-banner .cookie-btn.btn-secondary:hover {
  border-color: var(--accent);
  background: #ffffff8c;
}

.cookie-banner .cookie-btn.btn-primary {
  box-shadow: 0 4px 14px #7a000038;
}

.cookie-banner .cookie-btn.btn-primary:hover {
  box-shadow: 0 8px 22px #7a000047;
}

@media (max-width: 720px) {
  .cookie-banner-inner {
    flex-direction: column;
    align-items: stretch;
    padding: 1rem 1.1rem;
  }

  .cookie-banner-copy p {
    max-width: none;
  }

  .cookie-banner-actions {
    justify-content: stretch;
  }

  .cookie-banner-actions .cookie-btn {
    flex: 1;
    min-width: 0;
  }
}

.nav-content {
  min-height: 88px;
  padding: .9rem var(--space-lg);
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 1.5rem;
  display: grid;
}

.nav-brand-link {
  justify-self: start;
  align-items: center;
  display: flex;
}

.nav-logo {
  object-fit: contain;
  width: auto;
  height: auto;
  max-height: 48px;
}

@media (max-width: 960px) {
  .nav-logo {
    max-height: 42px;
  }
}

@media (max-width: 640px) {
  .nav-logo {
    max-height: 38px;
  }
}

@media (max-width: 420px) {
  .nav-logo {
    max-width: 150px;
    max-height: 34px;
  }
}

.nav-links {
  justify-content: center;
  align-items: center;
  gap: clamp(1rem, 2vw, 2.4rem);
  min-width: 0;
  display: flex;
}

.nav-links > a.nav-mobile-only {
  display: none;
}

@media (min-width: 961px) {
  .nav-links a, .nav-link-btn {
    white-space: nowrap;
  }
}

@media (min-width: 1281px) and (max-width: 1536px) {
  .nav-content {
    gap: 1rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .nav-links {
    gap: clamp(.65rem, 1.35vw, 1.4rem);
  }

  .nav-links a, .nav-link-btn {
    letter-spacing: .1em;
    font-size: .8rem;
  }
}

@media (min-width: 769px) and (max-width: 1280px) {
  .nav-content {
    gap: .55rem .85rem;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .nav-logo {
    max-height: 40px;
  }

  .nav-links {
    flex-wrap: nowrap;
    gap: 0 clamp(.45rem, .9vw, .95rem);
  }

  .nav-links a, .nav-link-btn {
    letter-spacing: .06em;
    font-size: .74rem;
  }

  .nav-actions {
    flex-shrink: 0;
    place-self: center end;
  }

  .nav-item-mega {
    margin-bottom: -.5rem;
    padding-bottom: .5rem;
  }

  .nav-mega {
    width: min(720px, 100vw - 1.25rem);
    max-width: calc(100vw - 1.25rem);
  }

  .nav-mega-inner {
    gap: .85rem;
    padding: 1rem .95rem;
  }

  .nav-mega-col h4 {
    margin-bottom: .55rem;
    font-size: .72rem;
  }

  .nav-mega-col a {
    padding: .42rem .28rem;
    font-size: .82rem;
  }

  .nav-mega-note {
    font-size: .76rem;
    line-height: 1.32;
  }

  .nav-mega-inner.nav-mega-services .nav-mega-col a {
    font-size: .8rem;
  }
}

@media (min-width: 769px) and (max-width: 960px) {
  .nav-mega-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .nav-mega-inner .nav-mega-col:nth-child(3) {
    border-top: 1px solid #3c291d14;
    grid-column: 1 / -1;
    padding-top: .15rem;
  }

  .nav-mega-inner.nav-mega-services {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .nav-mega-inner.nav-mega-services .nav-mega-col:nth-child(3) {
    border-top: 1px solid #3c291d14;
    grid-column: 1 / -1;
    padding-top: .15rem;
  }
}

@media (min-width: 641px) and (max-width: 960px) {
  .nav-announcement-inner {
    flex-wrap: wrap;
    justify-content: center;
    row-gap: .35rem;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .nav-announcement-items {
    white-space: normal;
    flex-wrap: wrap;
    justify-content: center;
    gap: .25rem .65rem;
    overflow: visible;
  }

  .nav-announcement-items span + span:before {
    content: "";
  }

  .nav-announcement-items span:not(:last-child):after {
    content: "·";
    opacity: .7;
    margin-left: .65rem;
  }
}

.nav-links a, .nav-link-btn {
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #201711;
  font-size: .86rem;
  font-weight: 600;
  position: relative;
}

.nav-links a:after, .nav-link-btn:after {
  content: "";
  transform-origin: center;
  background: #201711;
  height: 1px;
  transition: transform .25s;
  position: absolute;
  bottom: -.45rem;
  left: 0;
  right: 0;
  transform: scaleX(0);
}

.nav-links a:hover:after, .nav-link-btn:hover:after, .nav-item-mega.is-open .nav-link-btn:after {
  transform: scaleX(1);
}

.nav-link-btn {
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  font-family: inherit;
}

a.nav-link-btn {
  text-decoration: none;
  display: inline-block;
}

.nav-item-mega {
  align-items: center;
  margin-bottom: -.85rem;
  padding-bottom: .85rem;
  display: flex;
  position: relative;
}

.nav-mega-trigger {
  align-items: center;
  gap: .35rem;
  display: inline-flex;
}

.nav-mega-toggle {
  color: inherit;
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 999px;
  margin: -.35rem -.4rem;
  padding: .35rem .4rem;
  line-height: 1;
}

.nav-mega-toggle:hover {
  background: #2017110f;
}

.nav-mega-toggle:focus-visible {
  outline-offset: 2px;
  outline: 2px solid #7a00008c;
}

.nav-mega {
  top: calc(var(--page-top-offset) - 2.25rem);
  z-index: 180;
  box-sizing: border-box;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  width: min(760px, 100vw - 1.5rem);
  min-width: 0;
  max-width: calc(100vw - 1.5rem);
  padding-top: .4rem;
  transition: opacity .18s, transform .18s, visibility .18s;
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
}

.nav-item-mega.is-open .nav-mega, .nav-item-mega:hover .nav-mega {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%)translateY(0);
}

.nav-mega-inner {
  box-sizing: border-box;
  background: #fcf7f1fa;
  border: 1px solid #3c291d1f;
  border-radius: 6px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
  width: 100%;
  min-width: 0;
  padding: 1.25rem;
  display: grid;
}

.nav-mega-col h4 {
  font-family: var(--font-sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #201711b3;
  margin-bottom: .7rem;
  font-size: .78rem;
  font-weight: 700;
}

.nav-mega-col a {
  letter-spacing: .02em;
  text-transform: none;
  color: #201711;
  border-radius: 3px;
  padding: .5rem .35rem;
  font-size: .9rem;
  font-weight: 600;
  display: block;
}

.nav-mega-col a:hover {
  background: #2017110f;
}

.nav-mega-col a.is-active {
  background: #7a000014;
  border: 1px solid #7a000029;
}

.nav-mega-note {
  color: #20171199;
  margin-top: .6rem;
  font-size: .82rem;
  line-height: 1.35;
}

.nav-mega-inner.nav-mega-services {
  gap: 1rem;
  padding: 1.1rem 1.15rem;
}

.nav-mega-inner.nav-mega-services .nav-mega-col a {
  padding: .35rem;
  font-size: .86rem;
  line-height: 1.32;
}

.nav-actions {
  flex-shrink: 0;
  justify-self: end;
  align-items: center;
  gap: .2rem;
  display: flex;
}

.nav-actions .icon-btn {
  color: #201711;
  border-radius: 999px;
  place-items: center;
  width: 44px;
  height: 44px;
  display: grid;
}

.nav-actions .icon-btn:hover {
  color: #201711;
  background: #2017110f;
}

.nav-prefs-wrap {
  align-items: center;
  margin-right: .1rem;
  display: flex;
}

.nav-prefs-bar {
  align-items: center;
  gap: .3rem;
  display: flex;
}

.nav-prefs-label {
  margin: 0;
}

.nav-prefs-sr {
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  position: absolute;
  overflow: hidden;
}

.nav-prefs-select {
  font-family: var(--font-sans);
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #201711;
  cursor: pointer;
  background: #fffcf7eb;
  border: 1px solid #20171124;
  border-radius: 8px;
  max-width: 4rem;
  padding: .3rem .4rem;
  font-size: .65rem;
  font-weight: 700;
}

.nav-prefs-pill {
  font-family: var(--font-sans);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #201711;
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border: 1px solid #20171129;
  border-radius: 20px;
  padding: .28rem .55rem;
  font-size: .65rem;
  font-weight: 700;
  line-height: 1;
  transition: background .15s, border-color .15s, color .15s;
}

.nav-prefs-pill:hover {
  background: #2017110f;
  border-color: #20171147;
}

.nav-prefs-pill:active {
  background: #2017111a;
}

.nav-prefs-sep {
  background: #20171133;
  border-radius: 1px;
  flex-shrink: 0;
  width: 1px;
  height: .85rem;
  display: inline-block;
}

.nav-links-prefs {
  border-top: 1px solid #20171114;
  flex-direction: column;
  align-items: flex-start;
  gap: .45rem;
  width: 100%;
  margin-top: .75rem;
  padding-top: .85rem;
  display: none;
}

@media (max-width: 1100px) {
  .navbar.is-open .nav-links-prefs {
    text-align: center;
    align-items: center;
  }

  .navbar.is-open .nav-links-prefs .nav-prefs-select {
    max-width: none;
  }

  .navbar.is-open .nav-links-prefs .nav-prefs-pill {
    border-radius: 20px;
    justify-content: center;
    width: 100%;
  }
}

.nav-links-prefs-label {
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #20171173;
  font-size: .68rem;
  font-weight: 700;
}

.nav-icon-link {
  border: 1px solid #20171114;
}

.nav-toggle {
  display: none;
}

@media (max-width: 1100px) {
  .nav-content {
    flex-flow: row;
    justify-content: flex-start;
    align-items: center;
    gap: .35rem;
    min-height: 72px;
    display: flex;
  }

  .nav-brand-link {
    flex: none;
    margin-right: auto;
  }

  .nav-actions {
    justify-self: unset;
    flex: none;
  }

  .nav-toggle {
    flex: none;
    order: unset;
    display: flex;
  }

  .nav-links {
    display: none;
  }

  .nav-mobile-backdrop {
    top: var(--page-top-offset);
    z-index: 101;
    -webkit-backdrop-filter: blur(12px);
    cursor: pointer;
    background: #120a0a80;
    border: 0;
    margin: 0;
    padding: 0;
    animation: .22s navBackdropIn;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
  }

  @keyframes navBackdropIn {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }

  .navbar.is-open .nav-content {
    z-index: 108;
    position: relative;
  }

  .nav-toggle {
    cursor: pointer;
    color: #201711;
    z-index: 110;
    background: none;
    border: none;
    flex-direction: column;
    flex-shrink: 0;
    justify-content: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    padding: 10px;
    position: relative;
  }

  .nav-toggle-bar {
    background: currentColor;
    border-radius: 1px;
    width: 22px;
    height: 2px;
    transition: transform .25s, opacity .25s;
    display: block;
  }

  .navbar.is-open .nav-toggle-bar:first-child {
    transform: translateY(7px)rotate(45deg);
  }

  .navbar.is-open .nav-toggle-bar:nth-child(2) {
    opacity: 0;
  }

  .navbar.is-open .nav-toggle-bar:nth-child(3) {
    transform: translateY(-7px)rotate(-45deg);
  }

  .nav-links {
    width: 100%;
    max-width: none;
    height: 100dvh;
    max-height: none;
    padding: calc(var(--page-top-offset) + 1rem) 1.25rem 2rem;
    -webkit-overflow-scrolling: touch;
    z-index: 106;
    box-shadow: none;
    background: #fffcf7fa;
    border: none;
    border-top: 1px solid #3c291d14;
    border-radius: 0;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: .35rem;
    margin: 0;
    animation: .28s cubic-bezier(.16, 1, .3, 1) navSheetIn;
    display: none;
    position: fixed;
    inset: 0;
    overflow: hidden auto;
    transform: none;
  }

  @keyframes navSheetIn {
    from {
      opacity: 0;
      transform: translateY(12px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  .navbar.is-open .nav-links {
    display: flex;
  }

  .nav-mobile-expanded {
    border-top: 1px solid #3c291d14;
    margin-top: 1rem;
    padding-top: 1rem;
    display: block;
  }

  .nav-mobile-block + .nav-mobile-block {
    margin-top: 1.25rem;
  }

  .nav-mobile-block-title {
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #1d140fa6;
    text-align: left;
    margin: 0 0 .75rem;
    font-size: .9rem;
  }

  .nav-mobile-grid {
    grid-template-columns: 1fr;
    gap: .9rem;
    display: grid;
  }

  .nav-mobile-col h4 {
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #1d140f8c;
    margin: 0 0 .45rem;
    font-size: .72rem;
  }

  .nav-mobile-link {
    text-align: left;
    color: #1d140f;
    background: #ffffff8c;
    border: 1px solid #3c291d14;
    border-radius: 12px;
    padding: .55rem .6rem;
    text-decoration: none;
    display: block;
  }

  .nav-mobile-link:hover {
    background: #7a00000f;
    border-color: #7a000029;
  }

  @media (min-width: 720px) {
    .nav-mobile-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 900px) {
    .nav-mobile-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  .nav-links > a {
    color: #1d140f;
    text-align: center;
    letter-spacing: .1em;
    border-radius: 12px;
    padding: .75rem .5rem;
    font-size: 1.05rem;
    font-weight: 600;
  }

  .nav-links > a.nav-mobile-only {
    display: none;
  }

  .nav-links > a:hover {
    background: #7a00000f;
  }

  .nav-links > a:first-child {
    border-top: 1px solid #3c291d14;
    border-bottom: 1px solid #3c291d14;
    border-radius: 0;
    margin-top: .15rem;
  }

  .nav-links > a:nth-child(2) {
    border-bottom: 1px solid #3c291d14;
    border-radius: 0;
  }

  .nav-links .nav-item-mega {
    border-bottom: 1px solid #3c291d14;
    flex-direction: column;
    align-items: stretch;
    margin-bottom: .35rem;
    padding-bottom: .5rem;
  }

  .nav-links > a:after, .nav-links .nav-link-btn:after {
    display: none;
  }

  .nav-links .nav-link-btn {
    text-align: center;
    border-radius: 12px;
    width: 100%;
    padding: .75rem .5rem;
    font-size: 1.02rem;
  }

  .nav-links .nav-link-btn:hover {
    background: #7a00000f;
  }

  .nav-links .nav-item-mega:not(.is-open) .nav-mega {
    transition: max-height .32s, opacity .2s, visibility .2s;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding-top: 0 !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    overflow: hidden !important;
    transform: none !important;
  }

  .nav-links .nav-item-mega.is-open .nav-mega {
    -webkit-overflow-scrolling: touch;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    max-height: min(62vh, 560px) !important;
    padding-top: .5rem !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    overflow: hidden auto !important;
    transform: none !important;
  }

  .nav-links .nav-mega-inner {
    grid-template-columns: 1fr;
    gap: .85rem;
    padding: .85rem .65rem;
  }

  .nav-links .nav-mega-inner.nav-mega-services {
    grid-template-columns: 1fr;
  }
}

.nav-mobile-expanded {
  display: none;
}

.icon-btn {
  color: var(--text-primary);
  cursor: pointer;
  background: none;
  border: none;
  transition: color .18s, opacity .18s;
}

.icon-btn:hover {
  color: var(--accent);
  opacity: .82;
}

.cart-trigger {
  flex-shrink: 0;
  position: relative;
}

.cart-badge {
  color: #fff9f1;
  background: #201711;
  border-radius: 999px;
  place-items: center;
  min-width: 19px;
  height: 19px;
  padding: 0 .3rem;
  font-size: .68rem;
  font-weight: 700;
  display: grid;
  position: absolute;
  top: 4px;
  right: 2px;
}

.hero {
  background: var(--bg-primary);
  min-height: 100dvh;
  padding-top: 0;
  position: relative;
  overflow: hidden;
}

.hero-shell {
  width: 100%;
  min-height: 100dvh;
  position: relative;
}

.hero-topline {
  z-index: 3;
  background: linear-gradient(90deg, #695548 0%, #b4987f 42%, #6e5a4d 100%);
  height: 14px;
  position: absolute;
  inset: 0 0 auto;
}

.hero-slides {
  min-height: 100dvh;
  position: relative;
  overflow: hidden;
}

.hero-slide {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition: opacity .45s, transform .9s;
  position: absolute;
  inset: 0;
  transform: scale(1.02);
}

.hero-slide.is-active {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
}

.hero-slide-image {
  object-fit: cover;
  filter: saturate(.82) brightness(.8);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.hero-slide-overlay {
  background: linear-gradient(#08080870 0%, #0808088a 42%, #080808a8 100%), linear-gradient(90deg, #00000080 0%, #00000057 38%, #00000080 100%);
  position: absolute;
  inset: 0;
}

.hero-slide-frame {
  transform-origin: center;
  opacity: .8;
  background: #ffffffad;
  width: 1px;
  position: absolute;
  top: 8%;
  bottom: 8%;
  transform: rotate(81deg);
}

.hero-slide-frame-left {
  left: -5%;
}

.hero-slide-frame-right {
  right: -5%;
}

.hero-slide-inner {
  z-index: 1;
  text-align: center;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  max-width: 980px;
  min-height: 100vh;
  margin: 0 auto;
  padding: 8rem 1.5rem 5.5rem;
  display: flex;
  position: relative;
}

.hero-subtitle {
  color: #fff0d2d1;
  text-transform: uppercase;
  letter-spacing: .4em;
  align-items: center;
  gap: .8rem;
  margin-bottom: 1.35rem;
  font-size: .75rem;
  font-weight: 600;
  display: inline-flex;
}

.hero-subtitle:before, .hero-subtitle:after {
  content: "";
  background: #fff0d28c;
  flex-shrink: 0;
  width: 32px;
  height: 1px;
  display: inline-block;
}

.hero-title {
  letter-spacing: -.02em;
  color: #fff8ec;
  text-shadow: 0 8px 28px #00000038;
  flex-direction: column;
  gap: .1rem;
  margin-bottom: 1.5rem;
  font-size: clamp(2.8rem, 7vw, 5.75rem);
  line-height: .92;
  animation: .8s ease-out fadeUp;
  display: flex;
}

.hero-title span {
  font-family: var(--font-sans);
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: clamp(2.7rem, 8.6vw, 6.4rem);
  font-weight: 800;
}

.hero-description {
  color: #fff8ece0;
  max-width: 700px;
  margin-bottom: 2.2rem;
  font-size: clamp(1rem, 1.8vw, 1.18rem);
  line-height: 1.65;
  animation: 1s ease-out fadeUp;
}

.hero-actions {
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  animation: 1.1s ease-out fadeUp;
  display: flex;
}

.hero-secondary-btn {
  color: #fff8ec;
  background: #ffffff0f;
  border-color: #fff8ec61;
}

.hero-secondary-btn:hover {
  color: #fff;
  border-color: #ffffffd9;
}

.hero-secondary-btn.hero-secondary-btn--boutique {
  color: #fff8ec;
  background: linear-gradient(135deg, #5c0000c7 0%, #7a0000e6 48%, #5a0000e0 100%);
  border-color: #ffe8d26b;
  box-shadow: 0 10px 32px #12060659;
}

.hero-secondary-btn.hero-secondary-btn--boutique:hover {
  color: #fff;
  background: linear-gradient(135deg, #6e0000e0 0%, #962020eb 50%, #640000e6 100%);
  border-color: #fff8ecc7;
  box-shadow: 0 12px 36px #1206066b;
}

.hero-secondary-btn.hero-secondary-btn--warm-luxe {
  color: #fffaf3;
  background: linear-gradient(142deg, #2a1814d1 0%, #3e241cdb 42%, #301c16e0 100%);
  border-color: #d4af827a;
  box-shadow: 0 10px 34px #0a040261, inset 0 1px #ffffff12;
}

.hero-secondary-btn.hero-secondary-btn--warm-luxe:hover {
  color: #fff;
  background: linear-gradient(142deg, #341e18e6 0%, #4e2c22eb 45%, #3a201af0 100%);
  border-color: #f5d7b4b8;
  box-shadow: 0 14px 40px #0a040273, inset 0 1px #ffffff1a;
}

.hero-nav {
  z-index: 4;
  color: #fff8ec;
  cursor: pointer;
  width: 74px;
  height: 74px;
  transition: var(--transition-smooth);
  -webkit-backdrop-filter: blur(8px);
  background: #0a0a0a29;
  border: 1px solid #fff3;
  border-radius: 999px;
  place-items: center;
  display: grid;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.hero-nav:hover {
  background: #0a0a0a52;
  border-color: #ffffff80;
}

.hero-nav span {
  margin-top: -.2rem;
  font-size: 3.4rem;
  line-height: 1;
}

.hero-nav-prev {
  left: 2rem;
}

.hero-nav-next {
  right: 2rem;
}

.hero-pagination {
  z-index: 4;
  gap: .75rem;
  display: flex;
  position: absolute;
  bottom: 1.75rem;
  left: 50%;
  transform: translateX(-50%);
}

.hero-dot {
  cursor: pointer;
  opacity: .9;
  background: #ffffff9e;
  border: 1px solid #fff8ec7a;
  border-radius: 999px;
  width: 34px;
  height: 4px;
  transition: width .25s, background .25s, transform .2s, opacity .2s;
}

.hero-dot.is-active {
  opacity: 1;
  background: #fff8ec;
  border-color: #fff8eceb;
  width: 58px;
  box-shadow: 0 0 0 2px #0a0a0a33;
}

.hero-dot:hover {
  opacity: 1;
  transform: translateY(-1px);
}

@media (max-width: 1024px) {
  .hero-slide-inner {
    justify-content: center;
    max-width: min(980px, 100%);
    padding: 7rem clamp(1rem, 4vw, 2.75rem);
  }

  .hero-title {
    font-size: clamp(2.1rem, 10vw, 4rem);
  }

  .hero-title span {
    overflow-wrap: anywhere;
    word-break: break-word;
    font-size: clamp(2.15rem, 11vw, 4.35rem);
  }

  .hero-description {
    max-width: min(700px, 100%);
  }

  .hero-nav {
    width: 56px;
    height: 56px;
  }

  .hero-nav-prev {
    left: .65rem;
  }

  .hero-nav-next {
    right: .65rem;
  }

  .hero-dot {
    width: 30px;
    height: 4px;
  }

  .hero-dot.is-active {
    width: 52px;
  }
}

@media (max-width: 640px) {
  .hero-slide-inner {
    padding-left: max(1.15rem, calc(env(safe-area-inset-left, 0px) + 3.35rem));
    padding-right: max(1.15rem, calc(env(safe-area-inset-right, 0px) + 3.35rem));
  }

  .hero-subtitle {
    letter-spacing: .22em;
  }

  .hero-description {
    max-width: 33rem;
  }

  .hero-actions {
    flex-direction: column;
    width: 100%;
  }

  .hero-actions .btn-primary, .hero-actions .btn-secondary {
    width: 100%;
  }

  .hero-slide-frame {
    display: none;
  }

  .hero-nav {
    width: 42px;
    height: 42px;
  }

  .hero-nav-prev {
    left: max(.35rem, env(safe-area-inset-left, 0px));
  }

  .hero-nav-next {
    right: max(.35rem, env(safe-area-inset-right, 0px));
  }

  .hero-nav span {
    font-size: 2.35rem;
  }
}

.section-header {
  text-align: center;
  margin-bottom: clamp(2.5rem, 5vw, 5rem);
}

.section-kicker {
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .22em;
  align-items: center;
  gap: .7rem;
  margin-top: 4rem;
  margin-bottom: 1rem;
  font-size: .72rem;
  font-weight: 700;
  display: inline-flex;
}

.section-kicker:before {
  content: "";
  opacity: .75;
  background: currentColor;
  flex-shrink: 0;
  width: 28px;
  height: 1px;
  display: inline-block;
}

.section-header h2 {
  letter-spacing: -.02em;
  color: #1d140f;
  margin-bottom: .5rem;
  font-size: clamp(2.3rem, 4.2vw, 4rem);
  line-height: 1.05;
}

.section-header p {
  color: #5f5148;
  font-style: normal;
}

.section-header-split {
  text-align: left;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, .7fr);
  align-items: end;
  gap: 2rem;
  display: grid;
}

@media (max-width: 1024px) and (min-width: 769px) {
  .section-header-split {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .section-header-split > div:last-child {
    max-width: 100%;
  }

  .service-media-grid {
    grid-template-columns: 1fr;
  }

  .service-card {
    text-align: center;
    grid-template-columns: 1fr;
  }

  .service-card-image {
    max-width: 220px;
    margin: 0 auto;
  }

  .product-detail {
    grid-template-columns: 1fr;
  }
}

.grid {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  display: grid;
}

.product-card {
  background: linear-gradient(#fffdfb 0%, #f5ede4 100%);
  border: 1px solid #3c291d1a;
  border-radius: 10px;
  transition: transform .3s, box-shadow .3s;
  overflow: hidden;
  box-shadow: 0 2px 8px #5a43340f, inset 0 1px #ffffffb3;
}

.product-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px #5a43341f, inset 0 1px #ffffffb3;
}

.product-card-media {
  background: #1d140f08;
  width: 100%;
  height: min(260px, 46vw);
  display: block;
  position: relative;
  overflow: hidden;
}

.product-card-image {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
  transition: transform .45s;
  display: block;
}

.product-card-media--empty {
  background: linear-gradient(135deg, #2017110f, #baa0892e);
}

.product-collection-badge {
  color: #201711;
  letter-spacing: .16em;
  text-transform: uppercase;
  background: #fff9f1eb;
  border-radius: 3px;
  padding: .3rem .65rem;
  font-size: .65rem;
  font-weight: 700;
  position: absolute;
  top: 1rem;
  left: 1rem;
}

.product-info {
  text-align: left;
  padding: 1.5rem 1.5rem 1.75rem;
}

.product-meta {
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1rem;
  display: flex;
}

.product-meta span {
  color: #5d4e44;
  text-transform: uppercase;
  letter-spacing: .1em;
  background: #2017110f;
  border-radius: 3px;
  padding: .22rem .55rem;
  font-size: .68rem;
  font-weight: 600;
}

.product-info h3 {
  letter-spacing: -.005em;
  color: #1d140f;
  margin-bottom: .45rem;
  font-size: 1.15rem;
  line-height: 1.25;
}

.product-description {
  color: #6a5a50;
  margin-bottom: 1.25rem;
  line-height: 1.65;
}

.product-info .price {
  color: var(--accent);
  font-family: var(--font-sans);
  letter-spacing: .02em;
  margin-bottom: 1.25rem;
  font-size: 1.05rem;
  font-weight: 700;
}

.add-to-cart {
  color: #201711;
  border-color: #20171124;
  width: 100%;
  padding: .8rem;
  font-size: .8rem;
}

.collections-grid {
  align-items: stretch;
}

.collections .grid.collections-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.collections-quick-filters {
  flex-wrap: wrap;
  gap: .7rem;
  margin: 0 0 1.1rem;
  display: flex;
}

.collections-filter-chip {
  color: #2d1e16d6;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
  background: #fffcf7db;
  border: 1px solid #3c291d29;
  border-radius: 999px;
  padding: .48rem .95rem;
  font-size: .72rem;
  font-weight: 700;
}

.collections-filter-chip.is-active {
  color: #fff8ec;
  background: linear-gradient(135deg, #5c0000 0%, #7a0000 100%);
  border-color: #7a0000a6;
}

@media (max-width: 960px) {
  .collections .grid.collections-grid, .home-results-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .collections .grid.collections-grid, .home-results-grid {
    grid-template-columns: 1fr;
  }
}

.grid.collections-grid .product-card, .grid.collections-grid .product-card-boutique {
  width: 100%;
  max-width: min(380px, 94vw);
  margin-inline: auto;
}

@media (min-width: 961px) {
  .collections .grid.collections-grid .product-card, .collections .grid.collections-grid .product-card-boutique {
    max-width: none;
    margin-inline: 0;
  }
}

.collections-footer {
  background: linear-gradient(145deg, #5a0808 0%, var(--accent) 42%, #5c1010 100%);
  border: 1px solid #fff8ef2e;
  border-radius: 6px;
  gap: .9rem;
  margin-top: 2rem;
  padding: 1.35rem 1.45rem;
  display: grid;
  box-shadow: inset 0 1px #ffffff1f, 0 12px 28px #5a000038;
}

.collections-note {
  color: #fff9f1eb;
  margin: 0;
  font-size: .92rem;
  line-height: 1.55;
}

.collections-rewards-head {
  gap: .3rem;
  display: grid;
}

.collections-rewards-kicker {
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #fff1e1c7;
  align-items: center;
  gap: .45rem;
  font-size: .68rem;
  font-weight: 700;
  display: inline-flex;
}

.collections-rewards-kicker:before {
  content: "";
  background: #ffd16e;
  border-radius: 999px;
  width: .55rem;
  height: .55rem;
  box-shadow: 0 0 0 4px #ffd16e26;
}

.collections-rewards-head h3 {
  color: #fff8ec;
  margin: 0;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
}

.collections-rewards-details {
  color: #fff0dedb;
  margin: 0;
  font-size: .84rem;
  line-height: 1.55;
}

.collections-rewards-actions {
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: .2rem;
  display: flex;
}

.collections-footer .btn-primary {
  color: #3f2208;
  background: linear-gradient(135deg, #f8c869 0%, #efb74d 52%, #dfa23e 100%);
  border-color: #ffe7ba94;
  box-shadow: 0 10px 22px #1608023d;
}

.collections-footer .btn-primary:hover {
  color: #2b1504;
  border-color: #fff0d4c7;
}

.collections-footer .btn-secondary {
  color: #fff8ec;
  background: #ffffff0f;
  border-color: #fff8ec8c;
}

.collections-footer .btn-secondary:hover {
  color: #fff;
  background: #ffffff24;
  border-color: #fff8ec;
}

.services-panel {
  color: #fff9f1;
  background: #1d140f;
  border-radius: 14px;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  display: grid;
  overflow: hidden;
  box-shadow: 0 28px 80px #28181029;
}

.services-visual {
  min-height: 620px;
  position: relative;
}

.services-image {
  object-fit: cover;
  filter: saturate(.88) brightness(.88);
  width: 100%;
  height: 100%;
  display: block;
}

.services-content {
  flex-direction: column;
  justify-content: center;
  padding: clamp(2rem, 4vw, 4rem);
  display: flex;
}

.services-spotlight h2 {
  color: #fff7ec;
  margin-bottom: 1.5rem;
  font-size: clamp(2.2rem, 4vw, 4rem);
}

.services-spotlight p {
  color: #fff7ecc7;
  margin-bottom: 2rem;
  font-size: 1.05rem;
  line-height: 1.8;
}

.service-pill-row {
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: 2rem;
  display: flex;
}

.service-pill {
  color: #fff7ec;
  text-transform: uppercase;
  letter-spacing: .1em;
  background: #fff7ec14;
  border: 1px solid #fff7ec1f;
  border-radius: 3px;
  align-items: center;
  padding: .6rem .95rem;
  font-size: .8rem;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s, border-color .2s, color .2s;
  display: inline-flex;
}

.service-pill:hover {
  color: #fff;
  background: #fff7ec29;
  border-color: #fff7ec47;
}

.service-pill:focus-visible {
  outline-offset: 2px;
  outline: 2px solid #fff7ecd9;
}

.services-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
  display: grid;
}

.services-stats div {
  background: #fff7ec0f;
  border: 1px solid #fff7ec14;
  border-radius: 4px;
  padding: 1rem;
}

.services-stats strong {
  color: #fff7ec;
  margin-bottom: .35rem;
  font-size: 1.6rem;
  display: block;
}

.services-stats span {
  color: #fff7ecbd;
  font-size: .9rem;
}

.services-location {
  gap: .2rem;
  margin-top: .4rem;
  display: grid;
}

.services-location p {
  color: #fff7ecd6;
  margin: 0;
  font-size: .86rem;
}

.services-location a {
  color: #ffe2bc;
  width: fit-content;
  font-weight: 700;
  text-decoration: none;
}

.services-location a:hover {
  text-decoration: underline;
}

.services-actions {
  justify-content: flex-start;
}

@media (max-width: 900px) {
  .section-header-split, .services-panel {
    grid-template-columns: 1fr;
  }

  .services-visual {
    min-height: 380px;
  }

  .services-stats {
    grid-template-columns: 1fr;
  }

  .services-actions {
    justify-content: stretch;
  }
}

@media (max-width: 640px) {
  .collections-footer {
    align-items: stretch;
  }

  .collections-rewards-actions {
    flex-direction: column;
  }

  .collections-footer .btn-primary, .collections-footer .btn-secondary, .services-actions .btn-primary, .services-actions .btn-secondary {
    text-align: center;
    width: 100%;
  }
}

.site-footer {
  color: #1d140f;
  border-top: 1px solid var(--border-light);
  background: linear-gradient(#fffdf9 0%, #f5f0eb 100%);
}

.footer-accent-bar {
  background: linear-gradient(90deg, #0000, #7a0000 30%, #b52020 50%, #7a0000 70%, #0000);
  height: 3px;
}

.footer-body {
  padding: clamp(2.5rem, 4.5vw, 4rem) 0 clamp(2rem, 3vw, 2.75rem);
}

.footer-inner-sheet {
  min-width: 0;
}

.footer-grid {
  grid-template-columns: minmax(0, 1.25fr) repeat(3, minmax(0, .85fr));
  align-items: start;
  gap: clamp(1.5rem, 3.2vw, 3rem);
  display: grid;
}

@media (max-width: 1100px) and (min-width: 769px) {
  .footer-grid {
    grid-template-columns: minmax(0, 1.25fr) repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) and (min-width: 769px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
}

.footer-brand-col {
  flex-direction: column;
  gap: 1.1rem;
  display: flex;
}

.footer-logo-link {
  display: inline-block;
}

.footer-logo {
  object-fit: contain;
  opacity: .95;
  width: auto;
  height: auto;
  max-height: 42px;
}

.footer-tagline {
  color: #1d140fb3;
  max-width: 260px;
  font-size: .85rem;
  line-height: 1.75;
}

.footer-location-scope {
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #7a0000d1;
  margin: -.3rem 0 .25rem;
  font-size: .75rem;
  font-weight: 700;
}

@media (max-width: 1100px) {
  .footer-tagline {
    max-width: 42ch;
  }
}

.footer-contact-list {
  flex-direction: column;
  gap: .55rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.footer-contact-list li {
  color: #1d140fb8;
  align-items: center;
  gap: .55rem;
  font-size: .84rem;
  display: flex;
}

.footer-contact-list li svg {
  color: #7a0000;
  flex-shrink: 0;
}

.footer-contact-link {
  color: inherit;
  text-decoration: none;
  transition: color .15s;
}

.footer-contact-link:hover {
  color: #7a0000;
}

.footer-socials {
  flex-wrap: wrap;
  gap: .6rem;
  margin: .25rem 0 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.footer-socials li {
  margin: 0;
  padding: 0;
}

.footer-social-icon {
  color: #1d140fb3;
  background: #ffffffb3;
  border: 1px solid #3c291d1f;
  border-radius: 3px;
  place-items: center;
  width: 34px;
  height: 34px;
  transition: border-color .15s, background .15s, color .15s;
  display: grid;
}

.footer-social-icon:hover {
  color: #7a0000;
  background: #7a000014;
  border-color: #7a000073;
}

.footer-nav-details {
  flex-direction: column;
  gap: .9rem;
  min-width: 0;
  display: flex;
}

.footer-nav-summary {
  cursor: default;
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer-nav-summary::-webkit-details-marker {
  display: none;
}

.footer-nav-summary::marker {
  content: "";
}

.footer-nav-summary-label {
  font-family: var(--font-sans);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #1d140fb3;
  font-size: .72rem;
  font-weight: 700;
}

.footer-nav-chevron {
  display: none;
}

.footer-nav-list {
  flex-direction: column;
  gap: .6rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.footer-nav-link {
  color: #1d140fb8;
  font-size: .875rem;
  text-decoration: none;
  transition: color .15s, padding-left .15s;
  display: inline-block;
}

.footer-nav-link:hover {
  color: #7a0000;
  padding-left: 4px;
}

.footer-back-top {
  font-family: var(--font-sans);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #7a0000;
  cursor: pointer;
  background: #ffffffbf;
  border: 1px solid #7a000038;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  padding: .45rem .85rem;
  font-size: .72rem;
  font-weight: 600;
  transition: background .15s, border-color .15s, color .15s;
  display: none;
}

.footer-back-top:hover {
  color: #5c0000;
  background: #7a000014;
  border-color: #7a000059;
}

.footer-bottom {
  border-top: 1px solid var(--border-light);
  background: #fff9;
}

.footer-bottom-inner {
  padding: 1.1rem 0;
  padding-right: max(.5rem, calc(env(safe-area-inset-right, 0px) + 4.75rem));
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  display: flex;
}

.footer-bottom-inner-center {
  text-align: center;
  justify-content: center;
}

@media (max-width: 520px) {
  .footer-bottom-inner {
    padding-right: max(.5rem, env(safe-area-inset-right, 0px));
  }
}

.sr-only {
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  position: absolute !important;
  overflow: hidden !important;
}

.footer-copyright {
  color: #1d140f99;
  margin: 0;
  font-size: .78rem;
}

.footer-bottom-right {
  min-width: 0;
}

.footer-payment-badges {
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: 8px;
  max-width: min(100%, 920px);
  padding-bottom: 2px;
  display: flex;
  overflow: auto hidden;
}

@media (max-width: 520px) {
  .footer-payment-badges {
    justify-content: flex-start;
  }
}

.footer-payment-badges::-webkit-scrollbar {
  height: 4px;
}

.footer-payment-badges::-webkit-scrollbar-thumb {
  background: #1d140f33;
  border-radius: 4px;
}

.payment-logo-wrap {
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.payment-logo {
  opacity: .85;
  filter: grayscale(.15) contrast(1.06);
  width: auto;
  max-width: 96px;
  height: 38px;
  max-height: 38px;
  transition: opacity .18s, filter .18s, transform .18s;
}

.payment-logo:hover {
  opacity: 1;
  filter: grayscale(0) contrast(1.08);
  transform: translateY(-1px);
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 768px) {
  .footer-body {
    padding: 1.35rem 0 1.15rem;
  }

  .footer-inner-sheet {
    min-width: 0;
    padding: 0;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: .75rem;
  }

  .footer-brand-col {
    background: #fff5ec12;
    border: 1px solid #fff5ec24;
    border-radius: 14px;
    flex-direction: column;
    grid-column: auto;
    align-items: stretch;
    gap: .85rem;
    padding: 1.2rem 1.15rem;
    box-shadow: inset 0 1px #ffffff0d;
  }

  .site-footer .footer-brand-col .footer-tagline {
    color: #fff5ecc7;
    max-width: none;
    font-size: .84rem;
    line-height: 1.6;
  }

  .site-footer .footer-brand-col .footer-contact-list li {
    color: #fff5ecd9;
  }

  .site-footer .footer-brand-col .footer-contact-link {
    color: #fffaf4f2;
  }

  .site-footer .footer-brand-col .footer-contact-list li svg {
    color: #ffc0c0f2;
  }

  .footer-logo {
    align-self: flex-start;
    max-height: 36px;
  }

  .footer-contact-list {
    flex-direction: column;
    align-items: flex-start;
    gap: .5rem;
  }

  .footer-socials {
    gap: .55rem;
    margin-top: .15rem;
  }

  .footer-nav-details {
    background: #fff5ec12;
    border: 1px solid #fff5ec24;
    border-radius: 14px;
    display: block;
    overflow: hidden;
    box-shadow: inset 0 1px #ffffff0d;
  }

  .footer-nav-summary {
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    justify-content: space-between;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1.05rem;
    display: flex;
  }

  .footer-nav-summary-label {
    letter-spacing: .14em;
    color: #fff5ecf2;
    font-size: .68rem;
  }

  .footer-nav-chevron {
    border-bottom: 2px solid #ffa0a0f2;
    border-right: 2px solid #ffa0a0f2;
    flex-shrink: 0;
    width: .45rem;
    height: .45rem;
    margin-top: -.12rem;
    transition: transform .2s;
    display: block;
    transform: rotate(45deg);
  }

  .footer-nav-details[open] .footer-nav-chevron {
    margin-top: .1rem;
    transform: rotate(225deg);
  }

  .footer-nav-details .footer-nav-list {
    gap: .4rem;
    padding: 0 1.05rem .95rem;
  }

  .footer-nav-link {
    font-size: .84rem;
    line-height: 1.45;
  }

  .footer-nav-link:hover {
    padding-left: 0;
  }

  .site-footer .footer-nav-details .footer-nav-link {
    color: #fff5ece6;
  }

  .site-footer .footer-nav-details .footer-nav-link:hover {
    color: #fff;
  }

  .footer-bottom-inner {
    text-align: center;
    padding: 1.1rem max(1rem, env(safe-area-inset-left, 0px))
      max(5.25rem, calc(env(safe-area-inset-bottom, 0px) + 3.5rem))
      max(1rem, env(safe-area-inset-right, 0px));
    display: block;
  }

  .footer-bottom-inner.footer-bottom-inner-center {
    padding-left: max(1rem, calc(env(safe-area-inset-left, 0px) + 2.75rem));
    padding-right: max(1rem, calc(env(safe-area-inset-right, 0px) + 3.5rem));
  }

  .footer-copyright {
    color: #fff5ec8c;
    max-width: min(100%, 20rem);
    margin: 0 auto;
    line-height: 1.45;
  }

  .footer-back-top {
    display: none;
  }

  .footer-bottom-right {
    width: 100%;
  }

  .footer-payment-badges {
    flex-wrap: wrap;
    justify-content: flex-start;
    max-width: 100%;
    padding-bottom: 0;
    overflow: visible;
  }

  .payment-logo {
    max-width: 88px;
    height: 32px;
    max-height: 32px;
  }

  .nav-announcement-inner {
    padding-left: 1rem;
    padding-right: 1rem;
    font-size: .64rem;
  }

  .nav-announcement p {
    display: none;
  }

  .nav-mobile-backdrop {
    top: var(--page-top-offset);
    z-index: 101;
    -webkit-backdrop-filter: blur(12px);
    cursor: pointer;
    background: #120a0a80;
    border: 0;
    margin: 0;
    padding: 0;
    animation: .22s navBackdropIn;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
  }

  @keyframes navBackdropIn {
    from {
      opacity: 0;
    }

    to {
      opacity: 1;
    }
  }

  .navbar.is-open .nav-content {
    z-index: 108;
    position: relative;
  }

  .nav-toggle {
    cursor: pointer;
    color: #201711;
    z-index: 110;
    background: none;
    border: none;
    flex-direction: column;
    flex-shrink: 0;
    justify-content: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    padding: 10px;
    display: flex;
    position: relative;
  }

  .nav-toggle-bar {
    background: currentColor;
    border-radius: 1px;
    width: 22px;
    height: 2px;
    transition: transform .25s, opacity .25s;
    display: block;
  }

  .navbar.is-open .nav-toggle-bar:first-child {
    transform: translateY(7px)rotate(45deg);
  }

  .navbar.is-open .nav-toggle-bar:nth-child(2) {
    opacity: 0;
  }

  .navbar.is-open .nav-toggle-bar:nth-child(3) {
    transform: translateY(-7px)rotate(-45deg);
  }

  .nav-links {
    width: 100%;
    max-width: none;
    height: 100dvh;
    max-height: none;
    padding: calc(var(--page-top-offset) + 1rem) 1.25rem 2rem;
    -webkit-overflow-scrolling: touch;
    z-index: 106;
    box-shadow: none;
    background: #fffcf7fa;
    border: none;
    border-top: 1px solid #3c291d14;
    border-radius: 0;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: .35rem;
    margin: 0;
    animation: .28s cubic-bezier(.16, 1, .3, 1) navSheetIn768;
    display: none;
    position: fixed;
    inset: 0;
    overflow: hidden auto;
    transform: none;
  }

  @keyframes navSheetIn768 {
    from {
      opacity: 0;
      transform: translateY(12px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  .navbar.is-open .nav-links {
    display: flex;
  }

  .nav-links > a {
    color: #1d140f;
    text-align: center;
    letter-spacing: .1em;
    border-radius: 12px;
    padding: .75rem .5rem;
    font-size: 1.05rem;
    font-weight: 600;
  }

  .nav-links > a.nav-mobile-only {
    display: none;
  }

  .nav-links > a:hover {
    background: #7a00000f;
  }

  .nav-links > a:first-child {
    border-top: 1px solid #3c291d14;
    border-bottom: 1px solid #3c291d14;
    border-radius: 0;
    margin-top: .15rem;
  }

  .nav-links > a:nth-child(2) {
    border-bottom: 1px solid #3c291d14;
    border-radius: 0;
  }

  .nav-links .nav-item-mega {
    border-bottom: 1px solid #3c291d14;
    flex-direction: column;
    align-items: stretch;
    margin-bottom: .35rem;
    padding-bottom: .5rem;
  }

  .nav-links > a:after, .nav-links .nav-link-btn:after {
    display: none;
  }

  .nav-links .nav-link-btn {
    text-align: center;
    border-radius: 12px;
    width: 100%;
    padding: .75rem .5rem;
    font-size: 1.02rem;
  }

  .nav-links .nav-link-btn:hover {
    background: #7a00000f;
  }

  .nav-links .nav-item-mega:not(.is-open) .nav-mega {
    transition: max-height .32s, opacity .2s, visibility .2s;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding-top: 0 !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    overflow: hidden !important;
    transform: none !important;
  }

  .nav-links .nav-item-mega.is-open .nav-mega {
    -webkit-overflow-scrolling: touch;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    max-height: min(62vh, 560px) !important;
    padding-top: .5rem !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    overflow: hidden auto !important;
    transform: none !important;
  }

  .nav-links .nav-mega-inner {
    grid-template-columns: 1fr;
    gap: .85rem;
    padding: .85rem .65rem;
  }

  .nav-links .nav-mega-inner.nav-mega-services {
    grid-template-columns: 1fr;
  }

  .nav-content {
    flex-flow: row;
    justify-content: flex-start;
    align-items: center;
    gap: .35rem;
    min-height: 72px;
    padding-top: .75rem;
    padding-bottom: .75rem;
    display: flex;
  }

  .nav-brand-link {
    flex-shrink: 0;
    margin-right: auto;
  }

  .nav-logo {
    max-height: 40px;
  }

  .nav-actions {
    flex-shrink: 0;
    gap: .15rem;
    margin-left: 0;
  }

  .nav-actions .nav-icon-link {
    display: none;
  }

  .nav-actions .nav-icon-link.nav-icon-mobile-visible {
    display: grid;
  }

  .nav-prefs-wrap {
    display: none;
  }

  .navbar.is-open .nav-links-prefs {
    display: flex;
  }

  .footer-grid {
    grid-template-columns: 1fr;
  }

  .trust-badges-inner {
    background: #fffffff5;
  }

  .footer-bottom-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .footer-payment-badges {
    justify-content: flex-start;
    max-width: 100%;
  }
}

.cart-overlay {
  z-index: 200;
  background: #00000080;
  animation: .2s fadeIn;
  position: fixed;
  inset: 0;
}

.search-overlay {
  z-index: 240;
  background: #0000006b;
  position: fixed;
  inset: 0;
}

.search-drawer {
  top: calc(var(--page-top-offset) - 2.5rem);
  z-index: 250;
  background: #fffcf7fa;
  border: 1px solid #3c291d1f;
  border-radius: 8px;
  width: min(980px, 100vw - 2rem);
  max-height: min(78vh, 720px);
  padding: 1.25rem 1.25rem 1.4rem;
  position: fixed;
  left: 50%;
  overflow: auto;
  transform: translateX(-50%);
  box-shadow: 0 32px 88px #100a0842;
}

.search-head {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1rem;
  display: flex;
}

.search-head h3 {
  color: #1d140f;
  margin: 0;
  font-size: 1.35rem;
}

.search-head p {
  color: #1d140fa6;
  margin: .25rem 0 0;
  font-size: .92rem;
}

.search-close {
  color: #1d140f;
  cursor: pointer;
  background: #fffdfa;
  border: 1px solid #3c291d1f;
  border-radius: 12px;
  width: 40px;
  height: 40px;
  font-size: 1.35rem;
  line-height: 1;
}

.search-bar {
  grid-template-columns: 1fr auto;
  gap: .75rem;
  margin-bottom: 1.1rem;
  display: grid;
}

.search-bar input {
  color: #1d140f;
  width: 100%;
  font-family: var(--font-sans);
  background: #fffdfb;
  border: 1px solid #3c291d24;
  border-radius: 14px;
  padding: .95rem 1.05rem;
}

.search-submit {
  border-radius: 14px;
  padding: .95rem 1.25rem;
  font-size: .82rem;
}

.search-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
  display: grid;
}

.search-col h4 {
  font-family: var(--font-sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #201711b3;
  margin-bottom: .7rem;
  font-size: .78rem;
  font-weight: 700;
}

.search-col a {
  color: #201711;
  border-radius: 12px;
  padding: .5rem .35rem;
  font-size: .9rem;
  font-weight: 600;
  display: block;
}

.search-col a:hover {
  background: #2017110f;
}

.search-note {
  color: #20171199;
  margin-top: .6rem;
  font-size: .84rem;
  line-height: 1.35;
}

.search-chips {
  flex-wrap: wrap;
  gap: .5rem;
  display: flex;
}

.search-chip {
  color: #5a0a0a;
  background: #7a000014;
  border: 1px solid #7a000024;
  border-radius: 999px;
  align-items: center;
  padding: .45rem .7rem;
  font-size: .85rem;
  font-weight: 650;
  display: inline-flex;
}

.search-chip:hover {
  background: #7a00001f;
}

@media (max-width: 860px) {
  .search-grid, .search-bar {
    grid-template-columns: 1fr;
  }
}

.cart-slide {
  background: var(--bg-secondary);
  border-left: 1px solid var(--border-light);
  z-index: 201;
  flex-direction: column;
  width: 100%;
  max-width: 420px;
  height: 100dvh;
  animation: .3s slideInRight;
  display: flex;
  position: fixed;
  top: 0;
  right: 0;
  overflow: hidden;
}

.cart-header {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-light);
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.cart-header h2 {
  margin: 0;
  font-size: 1.25rem;
}

.cart-close {
  color: var(--text-primary);
  cursor: pointer;
  background: none;
  border: none;
  padding: 0 .25rem;
  font-size: 1.75rem;
  line-height: 1;
}

.cart-close:hover {
  color: var(--accent-gold);
}

.cart-shipping-banner {
  padding: .6rem var(--space-lg);
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border-light);
}

.cart-shipping-progress {
  background: #ffffff14;
  border-radius: 999px;
  height: 6px;
  margin-top: .7rem;
  overflow: hidden;
}

.cart-shipping-progress-bar {
  border-radius: inherit;
  background: linear-gradient(90deg, #8b6d57 0%, #d8c0a5 100%);
  height: 100%;
  display: block;
}

.cart-shipping-info {
  color: var(--text-secondary);
  margin: 0;
  font-size: .85rem;
}

.cart-shipping-eligible {
  color: var(--accent);
  margin: 0;
  font-size: .9rem;
  font-weight: 500;
}

.cart-body {
  padding: var(--space-md);
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

.cart-empty {
  color: var(--text-secondary);
  text-align: center;
  padding: var(--space-xl);
}

.cart-empty-state {
  flex-direction: column;
  align-items: center;
  gap: .85rem;
  padding: 2rem 1rem;
  display: flex;
}

.cart-empty-note {
  color: var(--text-secondary);
  text-align: center;
  max-width: 22rem;
}

.cart-empty-cta {
  text-align: center;
  min-width: 220px;
}

.cart-list {
  list-style: none;
}

.cart-item {
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--border-light);
  display: flex;
}

.cart-item-image {
  background: linear-gradient(135deg, var(--bg-tertiary), var(--border-light));
  border-radius: 6px;
  place-items: center;
  width: 80px;
  min-width: 80px;
  height: 80px;
  padding: .4rem;
  display: grid;
}

.cart-item-image span {
  text-transform: uppercase;
  letter-spacing: .12em;
  text-align: center;
  color: var(--text-secondary);
  font-size: .66rem;
}

.cart-item-details {
  flex: 1;
  min-width: 0;
}

.cart-item-name {
  margin-bottom: .25rem;
  font-weight: 500;
  display: block;
}

.cart-item-name:hover {
  color: var(--accent-gold);
}

.cart-item-price {
  color: var(--accent-gold);
  margin-bottom: .5rem;
  font-size: .9rem;
}

.cart-item-meta {
  color: var(--text-secondary);
  margin-bottom: .35rem;
  font-size: .76rem;
}

.cart-item-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  display: flex;
}

.cart-item-actions button:not(.cart-item-remove) {
  border: 1px solid var(--border-light);
  background: var(--bg-tertiary);
  width: 28px;
  height: 28px;
  color: var(--text-primary);
  cursor: pointer;
  border-radius: 4px;
  font-size: 1rem;
  line-height: 1;
}

.cart-item-actions button:not(.cart-item-remove):hover {
  border-color: var(--accent-gold);
  color: var(--accent-gold);
}

.cart-item-actions span {
  text-align: center;
  min-width: 1.5rem;
  font-size: .9rem;
}

.cart-item-unit-price {
  color: var(--text-secondary);
  font-size: .8rem;
}

.cart-item-remove {
  color: var(--text-secondary);
  cursor: pointer;
  background: none;
  border: none;
  border-radius: 6px;
  align-items: center;
  margin-left: auto;
  padding: 4px;
  transition: color .15s, background .15s;
  display: flex;
}

.cart-item-remove:hover {
  color: #c0392b;
  background: #c0392b14;
}

.cart-promo-details {
  border-top: 1px solid var(--border-light);
  padding-top: .5rem;
}

.cart-promo-summary {
  cursor: pointer;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-secondary);
  -webkit-user-select: none;
  user-select: none;
  align-items: center;
  gap: .4rem;
  padding: .4rem 0;
  font-size: .8rem;
  font-weight: 600;
  list-style: none;
  display: flex;
}

.cart-promo-summary::-webkit-details-marker {
  display: none;
}

.cart-promo-summary:before {
  content: "+";
  font-size: 1rem;
  transition: transform .15s;
}

.cart-promo-details[open] .cart-promo-summary:before {
  content: "−";
}

.cart-promo-details .cart-promo {
  margin-top: .5rem;
  margin-bottom: 0;
}

.cart-footer {
  padding: var(--space-md) var(--space-lg) var(--space-lg);
  border-top: 1px solid var(--border-light);
  flex-direction: column;
  flex-shrink: 0;
  gap: .65rem;
  display: flex;
}

.cart-summary-lines {
  gap: .5rem;
  margin-bottom: .9rem;
  display: grid;
}

.cart-summary-lines div {
  color: var(--text-secondary);
  justify-content: space-between;
  gap: 1rem;
  font-size: .88rem;
  display: flex;
}

.cart-total {
  margin-bottom: var(--space-md);
  font-size: 1rem;
}

.cart-total-wrap {
  background: var(--bg-tertiary);
  border: 1px solid var(--border-light);
  border-radius: 10px;
  margin-bottom: .2rem;
  padding: .65rem .75rem;
}

.cart-promo {
  margin-bottom: 1rem;
  padding: .85rem 1rem;
}

.cart-promo-label span {
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-secondary);
  margin-bottom: .35rem;
  font-size: .78rem;
  display: block;
}

.cart-promo-row {
  flex-wrap: wrap;
  gap: .5rem;
  display: flex;
}

.cart-promo-row input {
  border: 1px solid var(--border-light);
  background: var(--bg-tertiary);
  min-width: 0;
  color: var(--text-primary);
  border-radius: 8px;
  flex: 140px;
  padding: .55rem .75rem;
}

.cart-promo-apply {
  padding: .55rem 1rem;
  font-size: .82rem;
}

.cart-promo-active {
  color: var(--accent-gold);
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  margin-top: .65rem;
  font-size: .88rem;
  display: flex;
}

.cart-promo-clear {
  color: var(--text-secondary);
  cursor: pointer;
  background: none;
  border: none;
  font-size: .82rem;
  text-decoration: underline;
}

.cart-promo-msg {
  color: var(--text-secondary);
  margin-top: .5rem;
  font-size: .82rem;
}

.cart-upsell-hint {
  color: var(--text-secondary);
  margin-bottom: .85rem;
  font-size: .85rem;
}

.cart-upsell-hint a {
  color: var(--accent-gold);
}

.cart-actions {
  grid-template-columns: 1fr;
  gap: .55rem;
  margin-bottom: .65rem;
  display: grid;
}

.cart-upsell-block {
  border-top: 1px solid var(--border-light);
  margin-top: 1.25rem;
  padding-top: 1rem;
}

.cart-upsell-title {
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-secondary);
  margin: 0 0 .65rem;
  font-size: .82rem;
}

.cart-upsell-list {
  gap: .5rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.cart-upsell-card {
  border: 1px solid var(--border-light);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border-radius: 10px;
  justify-content: space-between;
  align-items: baseline;
  gap: .75rem;
  padding: .65rem .75rem;
  font-size: .88rem;
  text-decoration: none;
  transition: border-color .15s, background .15s;
  display: flex;
}

.cart-upsell-card:hover {
  border-color: var(--accent-gold-muted, #baa08973);
  background: var(--bg-secondary);
}

.cart-upsell-card-name {
  font-weight: 500;
}

.cart-upsell-card-price {
  color: var(--accent-gold);
  white-space: nowrap;
  font-weight: 600;
}

.product-whatsapp-cta {
  text-align: center;
  box-sizing: border-box;
  width: 100%;
  max-width: 320px;
  text-decoration: none;
}

.auth-chrome {
  box-sizing: border-box;
  flex-direction: column;
  height: 100dvh;
  min-height: 100dvh;
  max-height: 100dvh;
  display: flex;
  overflow: hidden;
}

.auth-chrome > .nav-announcement {
  flex-shrink: 0;
}

.auth-chrome-body {
  min-height: 0;
  padding-top: max(.75rem, env(safe-area-inset-top, 0px));
  padding-bottom: max(.75rem, env(safe-area-inset-bottom, 0px));
  padding-left: max(1rem, env(safe-area-inset-left, 0px));
  padding-right: max(1rem, env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  flex-direction: column;
  flex: 1;
  justify-content: center;
  align-items: stretch;
  display: flex;
}

.auth-chrome .auth-page {
  flex-direction: column;
  flex: 1;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 0;
  max-height: 100%;
  padding-top: 0;
  padding-bottom: 0;
  display: flex;
  overflow: hidden;
}

.auth-chrome .auth-page.section {
  padding-top: 0;
  padding-bottom: 0;
}

.auth-chrome .auth-page.page-content {
  padding-top: 0;
}

.auth-chrome .auth-shell {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  flex: 0 auto;
  max-width: 440px;
  min-height: 0;
  max-height: min(88dvh, 100dvh - 5.5rem);
  padding-block: .35rem;
  overflow: hidden auto;
}

.auth-chrome .auth-hero {
  margin-bottom: 1.35rem;
}

.auth-page {
  min-height: min(88vh, 820px);
  padding-bottom: var(--space-xl);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.auth-page:before {
  content: "";
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(90% 60% at 50% -30%, #7a000038, #0000 55%), radial-gradient(circle at 100% 60%, #baa08924, #0000 45%), radial-gradient(circle at 0 80%, #fffcf70f, #0000 50%);
  position: absolute;
  inset: 0;
}

.auth-page .auth-shell {
  z-index: 1;
  width: 100%;
  max-width: 420px;
  margin: 0 auto;
  position: relative;
}

main.auth-page.auth-page--standalone {
  min-height: calc(100svh - var(--page-top-offset) - 9rem);
  min-height: calc(100dvh - var(--page-top-offset) - 9rem);
  justify-content: flex-start;
  padding-bottom: clamp(2.75rem, 7vw, 5rem);
}

main.auth-page.auth-page--standalone .auth-shell {
  max-width: min(100%, 460px);
}

main.auth-page.auth-page--standalone.auth-page--register .auth-shell {
  max-width: min(100%, 520px);
}

main.auth-page.auth-page--standalone .auth-hero {
  margin-bottom: 1.65rem;
}

main.auth-page.auth-page--standalone .auth-panel, main.auth-page.auth-page--standalone .auth-oauth {
  width: 100%;
}

main.auth-page.auth-page--standalone .auth-panel {
  border-radius: 24px;
  padding: 2.35rem 2.25rem 2.15rem;
}

main.auth-page.auth-page--standalone.auth-page--register .auth-oauth {
  margin-bottom: 1.25rem;
}

main.auth-page.auth-page--standalone.auth-page--login .auth-oauth {
  margin-bottom: 1.15rem;
}

main.auth-page.auth-page--standalone .auth-lead {
  max-width: 38ch;
}

main.auth-page.auth-page--verify .auth-footer {
  text-align: center;
}

.auth-footer.auth-verify-footer-links {
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .35rem .75rem;
  display: flex;
}

.auth-verify-footer-sep {
  opacity: .5;
  -webkit-user-select: none;
  user-select: none;
  font-weight: 600;
}

.auth-modal-inner .auth-footer.auth-verify-footer-links a.auth-inline-link {
  color: var(--auth-link);
  border-bottom: 1px solid #7a000059;
  font-weight: 600;
  text-decoration: none;
}

.auth-modal-inner .auth-footer.auth-verify-footer-links a.auth-inline-link:hover {
  color: var(--auth-link-hover);
  border-bottom-color: #9a20208c;
}

@media (prefers-reduced-motion: no-preference) {
  main.auth-page.auth-page--standalone .auth-panel {
    animation: .48s cubic-bezier(.22, 1, .36, 1) both auth-standalone-panel-in;
  }
}

@keyframes auth-standalone-panel-in {
  from {
    opacity: 0;
    transform: translateY(14px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.auth-page .auth-hero {
  text-align: center;
  margin-bottom: 1.85rem;
}

.auth-page .auth-hero h1 {
  letter-spacing: -.02em;
  color: var(--auth-on-panel);
  margin-bottom: .65rem;
  font-size: clamp(1.9rem, 4.5vw, 2.45rem);
}

.auth-kicker {
  font-family: var(--font-sans);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #5a0808;
  background: #fff5eef2;
  border: 1px solid #7a000033;
  border-radius: 999px;
  margin-bottom: .65rem;
  padding: .28rem .75rem;
  font-size: .68rem;
  font-weight: 700;
  display: inline-block;
}

.auth-lead {
  max-width: 34ch;
  color: var(--text-secondary);
  margin: 0 auto;
  font-size: .98rem;
  line-height: 1.55;
}

.auth-panel {
  background: linear-gradient(168deg, #fffef9 0%, #f3ece4 55%, #ebe3d8 100%);
  border: 1px solid #3c291d1c;
  border-radius: 22px;
  padding: 2.15rem 2.1rem 1.9rem;
  box-shadow: inset 0 4px 2px #ffffffa6, 0 28px 72px #22161024, inset 0 2px #ffffff80;
}

.auth-form {
  flex-direction: column;
  gap: 1.2rem;
  display: flex;
}

.auth-field {
  flex-direction: column;
  gap: .5rem;
  display: flex;
}

.auth-field span {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: #4f433c;
  text-align: left;
  align-self: flex-start;
  font-size: .78rem;
  font-weight: 600;
}

.auth-field input {
  color: #1d140f;
  width: 100%;
  font-family: var(--font-sans);
  background: #fffdfb;
  border: 1px solid #3c291d24;
  border-radius: 14px;
  padding: .95rem 1.05rem;
  font-size: .97rem;
  transition: border-color .18s, box-shadow .18s;
}

.auth-pw-wrap {
  align-items: center;
  display: flex;
  position: relative;
}

.auth-pw-wrap > input {
  padding-right: 3.1rem;
}

.auth-pw-toggle {
  color: #1d140fbf;
  cursor: pointer;
  background: #fffdfbeb;
  border: 1px solid #3c291d24;
  border-radius: 12px;
  place-items: center;
  width: 38px;
  height: 38px;
  transition: background .15s, border-color .15s, color .15s;
  display: grid;
  position: absolute;
  top: 50%;
  right: .65rem;
  transform: translateY(-50%);
}

.auth-pw-toggle:hover {
  color: #1d140feb;
  border-color: #3c291d38;
}

.auth-pw-toggle:focus-visible {
  border-color: #7a000080;
  outline: none;
  box-shadow: 0 0 0 4px #7a000017;
}

.auth-field input::placeholder {
  color: #4d403773;
}

.auth-field input:hover {
  border-color: #3c291d38;
}

.auth-field input:focus {
  border-color: #7a000080;
  outline: none;
  box-shadow: 0 0 0 4px #7a000017;
}

.auth-field .auth-pw-strength-label, .auth-modal-inner .auth-field .auth-pw-strength-label {
  text-transform: none;
  letter-spacing: .02em;
  color: #4f433cd9;
  font-size: .78rem;
  font-weight: 500;
}

.auth-pw-match {
  align-items: center;
  gap: .35rem;
  margin: 0;
  font-size: .78rem;
  font-weight: 500;
  line-height: 1.35;
  display: flex;
}

.auth-pw-match--ok {
  color: #1f6b3a;
}

.auth-pw-match--err {
  color: #7a1515;
}

.auth-pw-strength {
  align-items: center;
  gap: .5rem;
  margin-top: .15rem;
  display: flex;
}

.auth-pw-strength-bars {
  flex-shrink: 0;
  gap: 3px;
  display: flex;
}

.auth-pw-strength-seg {
  background: #3c291d1f;
  border-radius: 2px;
  width: 22px;
  height: 4px;
}

.auth-pw-strength[data-level="1"] .auth-pw-strength-seg:nth-child(-n+1), .auth-pw-strength[data-level="2"] .auth-pw-strength-seg:nth-child(-n+2), .auth-pw-strength[data-level="3"] .auth-pw-strength-seg:nth-child(-n+3), .auth-pw-strength[data-level="4"] .auth-pw-strength-seg:nth-child(-n+4) {
  background: linear-gradient(90deg, #8a3030, #b54545);
}

.auth-pw-strength[data-level="3"] .auth-pw-strength-seg:nth-child(-n+3) {
  background: linear-gradient(90deg, #6a5a2a, #9a8230);
}

.auth-pw-strength[data-level="4"] .auth-pw-strength-seg:nth-child(-n+4) {
  background: linear-gradient(90deg, #1f6b3a, #2d8f4f);
}

.auth-pw-wrap {
  width: 100%;
  position: relative;
}

.auth-pw-wrap input {
  box-sizing: border-box;
  width: 100%;
  padding-right: 2.75rem;
}

.auth-pw-toggle {
  color: #2d241eb8;
  cursor: pointer;
  background: #7a000012;
  border: 0;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 2.35rem;
  height: 2.35rem;
  margin: 0;
  padding: 0;
  transition: background .15s, color .15s;
  display: inline-flex;
  position: absolute;
  top: 50%;
  right: .45rem;
  transform: translateY(-50%);
}

.auth-pw-toggle:hover {
  color: #5c0000;
  background: #7a000024;
}

.auth-pw-toggle:focus-visible {
  outline-offset: 2px;
  outline: 2px solid #7a000073;
}

.auth-error {
  color: #7a1515;
  background: #b4282817;
  border: 1px solid #a028282e;
  border-radius: 12px;
  margin: -.25rem 0 0;
  padding: .75rem .9rem;
  font-size: .88rem;
  line-height: 1.4;
}

.auth-submit {
  letter-spacing: .1em;
  border-radius: 14px;
  width: 100%;
  margin-top: .35rem;
  padding-top: 1.05rem;
  padding-bottom: 1.05rem;
  font-size: .82rem;
}

.auth-register-prompt {
  text-align: center;
  flex-direction: column;
  align-items: center;
  gap: .65rem;
  margin-top: .5rem;
  display: flex;
}

.auth-register-prompt-hint {
  color: var(--auth-on-panel-muted);
  max-width: 28rem;
  margin: 0;
  font-size: .84rem;
  line-height: 1.5;
}

.auth-register-prompt-hint strong {
  color: var(--auth-link);
  font-weight: 700;
}

.auth-register-prompt-cta {
  font-family: var(--font-sans);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fffefb;
  background: linear-gradient(165deg, #6a0000 0%, #7a0000 48%, #5c0000 100%);
  border: 1px solid #5a000073;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  gap: .4rem;
  padding: .55rem 1.1rem;
  font-size: .82rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform .15s, box-shadow .15s, filter .15s;
  display: inline-flex;
  box-shadow: inset 0 1px #fff3, 0 10px 28px #7a000038;
}

.auth-register-prompt-cta:hover {
  color: #fffefb;
  filter: brightness(1.06);
  transform: translateY(-1px);
  box-shadow: inset 0 1px #ffffff38, 0 14px 34px #7a000047;
}

.auth-register-prompt-cta--emphasis {
  letter-spacing: .14em;
  border-width: 2px;
  padding: .62rem 1.25rem;
  font-size: .84rem;
  box-shadow: inset 0 2px #ffffff40, 0 12px 36px #7a000059;
}

.auth-register-prompt-arrow {
  font-size: 1.05em;
  font-weight: 800;
  line-height: 1;
}

.auth-login-prompt {
  text-align: center;
  flex-direction: column;
  align-items: center;
  gap: .55rem;
  margin-top: .5rem;
  display: flex;
}

.auth-login-prompt-hint {
  color: var(--auth-on-panel-muted);
  max-width: 26rem;
  margin: 0;
  font-size: .84rem;
  line-height: 1.45;
}

.auth-login-prompt-cta {
  font-family: var(--font-sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--auth-link);
  background: none;
  border: 1px solid #7a000059;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  gap: .35rem;
  padding: .5rem 1rem;
  font-size: .78rem;
  font-weight: 700;
  text-decoration: none;
  transition: color .15s, border-color .15s, background .15s;
  display: inline-flex;
}

.auth-login-prompt-cta:hover {
  color: var(--auth-link-hover);
  border-color: var(--auth-link-hover);
  background: #7a00000f;
}

.auth-field-label-promo {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--auth-on-panel-muted);
  text-align: left;
  align-self: flex-start;
  margin: 0;
  font-size: .78rem;
  font-weight: 600;
}

.auth-signup-promo-block {
  background: #ffffff8c;
  border: 1px solid #3c291d1f;
  border-radius: 14px;
  flex-direction: column;
  gap: .5rem;
  padding: .75rem .85rem;
  display: flex;
}

.auth-signup-promo-row {
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  display: flex;
}

.auth-signup-promo-row input {
  min-width: 0;
  color: var(--auth-on-panel);
  font-family: var(--font-sans);
  background: #fffdfb;
  border: 1px solid #3c291d24;
  border-radius: 12px;
  flex: 140px;
  padding: .72rem .85rem;
  font-size: .92rem;
}

.auth-signup-promo-apply {
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--auth-on-panel);
  cursor: pointer;
  background: #ffffffe6;
  border: 1px solid #3c291d33;
  border-radius: 12px;
  padding: .65rem 1rem;
  font-size: .75rem;
  font-weight: 700;
  transition: border-color .15s, background .15s;
}

.auth-signup-promo-apply:hover:not(:disabled) {
  border-color: var(--auth-link);
  color: var(--auth-link);
}

.auth-signup-promo-apply:disabled {
  opacity: .55;
  cursor: not-allowed;
}

.auth-signup-promo-msg {
  margin: 0;
  font-size: .82rem;
  line-height: 1.4;
}

.auth-signup-promo-msg.is-ok {
  color: var(--auth-success);
}

.auth-signup-promo-msg.is-err {
  color: var(--auth-danger);
}

.auth-inline-link {
  color: var(--auth-link);
  text-underline-offset: 3px;
  align-self: flex-start;
  font-size: .82rem;
  font-weight: 600;
  text-decoration: underline;
}

.auth-inline-link:hover {
  color: var(--auth-link-hover);
}

.auth-login-extras {
  flex-direction: column;
  gap: .35rem;
  margin-top: -.25rem;
  display: flex;
}

.auth-marketing-copy {
  color: var(--auth-on-panel-muted);
  letter-spacing: .02em;
  text-transform: none;
  font-size: .88rem;
  font-weight: 500;
  line-height: 1.5;
}

.auth-marketing-copy strong {
  color: var(--auth-on-panel);
  font-weight: 700;
}

.auth-remember-hint {
  color: var(--auth-on-panel-subtle);
  margin: -.35rem 0 0;
  font-size: .78rem;
  line-height: 1.4;
}

.auth-oauth {
  flex-direction: column;
  gap: .75rem;
  margin-top: 1rem;
  display: flex;
}

.auth-oauth-divider {
  text-align: center;
  color: var(--auth-on-panel-subtle);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: 0;
  font-size: .78rem;
}

.auth-oauth-buttons {
  flex-wrap: wrap;
  justify-content: center;
  gap: .5rem;
  display: flex;
}

.auth-oauth-btn {
  flex: auto;
  min-width: 8rem;
  font-size: .88rem;
}

.auth-page .auth-footer {
  text-align: center;
  color: #6b5e54;
  margin: .35rem 0 0;
  font-size: .9rem;
  line-height: 1.5;
}

.auth-page .auth-footer a {
  color: #7a0000;
  border-bottom: 1px solid #7a000059;
  font-weight: 600;
  text-decoration: none;
  transition: color .15s, border-color .15s;
}

.auth-page .auth-footer a:hover {
  color: #9a2020;
  border-bottom-color: #9a20208c;
}

.auth-page .auth-footer-muted {
  color: #6b5e54;
  text-align: center;
  font-size: .82rem;
  line-height: 1.45;
}

.cart-checkout {
  text-align: center;
  width: 100%;
}

.cart-continue-link {
  text-align: center;
  color: var(--text-secondary);
  margin-top: .9rem;
  font-size: .88rem;
  display: block;
}

.cart-continue-link:hover {
  color: var(--text-primary);
}

@keyframes slideInRight {
  from {
    transform: translateX(100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.shell-error-page {
  z-index: 400;
  box-sizing: border-box;
  justify-content: center;
  align-items: center;
  padding: clamp(1rem, 4vw, 2.5rem);
  display: flex;
  position: fixed;
  inset: 0;
}

.shell-error-page__backdrop {
  background: radial-gradient(85% 55% at 50% -25%, #7a000038, #0000 58%), linear-gradient(168deg, #120c0b 0%, #231612 38%, #1a100e 100%);
  position: absolute;
  inset: 0;
}

.shell-error-page__panel {
  z-index: 1;
  text-align: center;
  background: linear-gradient(#fffdf9fa 0%, #f8f0e8f7 100%);
  border: 1px solid #3c291d1a;
  border-radius: 26px;
  width: 100%;
  max-width: 28rem;
  padding: clamp(1.85rem, 4.5vw, 2.65rem);
  position: relative;
  box-shadow: 0 32px 90px #0000006b, inset 0 1px #ffffffd1;
}

.shell-error-page__code {
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #730101;
  margin: 0 0 .85rem;
  font-size: .72rem;
  font-weight: 700;
}

.shell-error-page__title {
  font-family: var(--font-serif);
  letter-spacing: -.02em;
  color: #1d140f;
  margin: 0 0 .7rem;
  font-size: clamp(1.55rem, 4.2vw, 2.05rem);
  font-weight: 600;
  line-height: 1.12;
}

.shell-error-page__lead {
  color: #1d140fbd;
  margin: 0 0 1.55rem;
  font-size: 1.02rem;
  line-height: 1.65;
}

.shell-error-page__actions {
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .75rem;
  display: flex;
}

.shell-error-page__actions .btn-primary, .shell-error-page__actions .btn-secondary {
  min-width: 9.5rem;
}

.whatsapp-bubble {
  --support-bubble-size: 50px;
  bottom: max(.55rem, env(safe-area-inset-bottom, 0px));
  right: max(.55rem, env(safe-area-inset-right, 0px));
  width: var(--support-bubble-size);
  height: var(--support-bubble-size);
  color: #fff;
  white-space: nowrap;
  z-index: 125;
  background: linear-gradient(135deg, #1a0a0a 0%, #5a0000 100%);
  border: 1px solid #ffffff1f;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  gap: 0;
  padding: 0;
  text-decoration: none;
  transition: transform .18s, box-shadow .18s;
  display: inline-flex;
  position: fixed;
  overflow: hidden;
  box-shadow: 0 10px 28px #22161038;
}

.whatsapp-bubble:hover, .whatsapp-bubble:focus-visible {
  width: max-content;
  max-width: min(280px, 100vw - 1.25rem);
  min-height: var(--support-bubble-size);
  height: var(--support-bubble-size);
  color: #fff;
  border-radius: 999px;
  justify-content: flex-start;
  gap: .45rem;
  padding: 0 .65rem 0 .5rem;
  transform: translateY(-1px);
  box-shadow: 0 14px 34px #22161047;
}

.whatsapp-bubble svg {
  flex-shrink: 0;
}

.whatsapp-bubble-label {
  letter-spacing: .06em;
  text-transform: uppercase;
  opacity: 0;
  text-overflow: ellipsis;
  pointer-events: none;
  max-width: 0;
  font-size: .72rem;
  font-weight: 700;
  line-height: 1.15;
  transition: opacity .18s 80ms;
  overflow: hidden;
}

.whatsapp-bubble:hover .whatsapp-bubble-label, .whatsapp-bubble:focus-visible .whatsapp-bubble-label {
  opacity: 1;
  max-width: none;
}

@media (max-width: 640px) {
  .whatsapp-bubble--cookie-offset {
    bottom: 5.5rem;
  }
}

.boutique-layout {
  gap: var(--space-xl);
  grid-template-columns: 240px 1fr;
  align-items: start;
  display: grid;
}

.boutique-layout--below-presentation {
  border-top: 1px solid #3c291d1a;
  margin-top: clamp(2.5rem, 5vw, 4.25rem);
  padding-top: clamp(1.25rem, 3vw, 2rem);
}

.boutique-catalog-all-head {
  grid-column: 1 / -1;
  margin-bottom: .25rem;
}

.boutique-catalog-all-title {
  font-family: var(--font-serif);
  color: #1d140f;
  letter-spacing: -.02em;
  margin: 0 0 .35rem;
  font-size: clamp(1.35rem, 2.8vw, 1.75rem);
  font-weight: 600;
}

.boutique-catalog-all-lead {
  color: #1d140fad;
  max-width: 52ch;
  margin: 0;
  font-size: .95rem;
  line-height: 1.55;
}

.boutique-filters {
  padding: var(--space-lg);
  position: sticky;
  top: 100px;
}

.boutique-filters h3 {
  margin-bottom: var(--space-md);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 1rem;
}

.boutique-filters label {
  margin-bottom: var(--space-md);
  display: block;
}

.boutique-filters label span {
  color: var(--text-secondary);
  margin-bottom: .25rem;
  font-size: .85rem;
  display: block;
}

.boutique-filters select, .boutique-filters input {
  background: var(--bg-tertiary);
  border: 1px solid var(--border-light);
  width: 100%;
  color: var(--text-primary);
  font-family: var(--font-sans);
  border-radius: 6px;
  padding: .5rem .75rem;
}

.boutique-filters > .btn-secondary {
  margin-inline: auto;
  width: fit-content;
  margin-top: .35rem;
  display: block;
}

.boutique-empty {
  color: var(--text-secondary);
  text-align: center;
  padding: var(--space-xl);
}

.boutique-empty--filters {
  align-items: center;
  gap: var(--space-md);
  flex-direction: column;
  display: flex;
}

.boutique-empty--filters .btn-secondary {
  margin-inline: unset;
}

.boutique-layout .grid.collections-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}

.boutique-layout .grid.collections-grid .product-card, .boutique-layout .grid.collections-grid .product-card-boutique {
  max-width: none;
  margin-inline: 0;
}

@media (max-width: 768px) {
  .boutique-layout {
    grid-template-columns: 1fr;
  }

  .boutique-filters {
    position: static;
  }
}

.breadcrumb {
  color: var(--text-secondary);
  margin-bottom: var(--space-lg);
  font-size: .9rem;
}

.breadcrumb a:hover {
  color: var(--accent-gold);
}

.breadcrumb span {
  margin: 0 .35rem;
}

.product-detail {
  gap: var(--space-xl);
  grid-template-columns: minmax(280px, min(480px, 44vw)) minmax(0, 1fr);
  align-items: start;
  display: grid;
}

.product-detail-info {
  min-width: 0;
}

.product-detail-info h1 {
  margin-bottom: .5rem;
  font-size: 2rem;
}

.product-detail-badges {
  flex-wrap: wrap;
  gap: .45rem;
  margin-bottom: .75rem;
  display: flex;
}

.product-badge {
  font-size: .72rem;
  font-family: var(--font-sans);
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid var(--border-light);
  color: var(--text-secondary);
  background: var(--bg-tertiary);
  border-radius: 999px;
  padding: .28rem .65rem;
  font-weight: 600;
  display: inline-block;
}

.product-badge--accent {
  color: #fff9f1;
  background: var(--accent);
  border-color: #0000;
}

.product-detail-collection {
  color: var(--accent-gold);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: .5rem;
  font-size: .85rem;
}

.product-detail-price {
  color: var(--accent-gold);
  margin-bottom: var(--space-md);
  font-size: 1.5rem;
  font-weight: 500;
}

.product-detail-desc {
  color: var(--text-secondary);
  margin-bottom: var(--space-lg);
  line-height: 1.6;
}

.product-detail-specs {
  margin-bottom: var(--space-lg);
  grid-template-columns: auto 1fr;
  gap: .25rem 1.5rem;
  font-size: .9rem;
  display: grid;
}

.product-detail-specs dt {
  color: var(--text-secondary);
}

.product-detail-cta {
  width: 100%;
  max-width: min(100%, 560px);
}

.product-detail-cta-row {
  flex-direction: column;
  align-items: stretch;
  gap: 1rem;
  margin-top: .25rem;
  display: flex;
}

.product-qty-row {
  align-items: center;
  gap: .85rem;
  margin-bottom: .75rem;
  display: flex;
}

.product-qty-label {
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #9a7e72;
  font-size: .62rem;
  font-weight: 700;
}

.product-qty-stepper {
  background: #fffdf9f2;
  border: .5px solid #d4c4b0e6;
  border-radius: 3px;
  align-items: center;
  display: flex;
  overflow: hidden;
}

.product-qty-btn {
  color: #3a2820;
  cursor: pointer;
  background: none;
  border: none;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1;
  transition: background .12s;
  display: flex;
}

.product-qty-btn:hover:not(:disabled) {
  background: #d4c4b04d;
}

.product-qty-btn:disabled {
  opacity: .35;
  cursor: default;
}

.product-qty-value {
  text-align: center;
  color: #1e1210;
  -webkit-user-select: none;
  user-select: none;
  border-left: .5px solid #d4c4b0b3;
  border-right: .5px solid #d4c4b0b3;
  width: 32px;
  font-size: .88rem;
  font-weight: 600;
  line-height: 32px;
}

.product-variants {
  margin-top: 0;
}

.product-detail-secondary-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
  max-width: 100%;
  display: flex;
}

.product-detail-icon-action {
  padding: .85rem 1.25rem;
  font-size: .82rem;
}

.product-detail-copy-hint {
  color: var(--accent-gold);
  font-size: .82rem;
}

.product-detail-faq {
  margin-top: var(--space-xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-light);
}

.product-detail-faq h2 {
  margin-bottom: var(--space-md);
  font-size: 1.35rem;
}

.product-faq-list {
  gap: .65rem;
  max-width: 720px;
  display: grid;
}

.product-faq-item {
  padding: 0;
  overflow: hidden;
}

.product-faq-item summary {
  cursor: pointer;
  font-family: var(--font-sans);
  color: var(--text-primary);
  padding: 1rem 1.15rem;
  font-size: .95rem;
  font-weight: 600;
  list-style: none;
}

.product-faq-item summary::-webkit-details-marker {
  display: none;
}

.product-faq-item summary:after {
  content: "+";
  float: right;
  color: var(--text-secondary);
  font-weight: 500;
}

.product-faq-item[open] summary:after {
  content: "–";
}

.product-faq-item p {
  color: var(--text-secondary);
  border-top: 1px solid var(--border-light);
  margin: 0;
  padding: .85rem 1.15rem 1rem;
  font-size: .92rem;
  line-height: 1.55;
}

@media (max-width: 768px) {
  .product-detail {
    grid-template-columns: 1fr;
  }
}

.services-category {
  margin: 0 auto var(--space-lg);
  max-width: 980px;
  padding: 1.25rem;
}

.services-category-header {
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  display: flex;
}

.services-category-header h2 {
  margin: 0;
  font-size: 1.3rem;
}

.services-category-pill {
  border: 1px solid var(--border-light);
  color: #7a0000;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: #ffffff8c;
  border-radius: 999px;
  align-items: center;
  padding: .35rem .75rem;
  font-size: .78rem;
  font-weight: 700;
  display: inline-flex;
}

.services-table-wrap {
  border: 1px solid var(--border-light);
  background: #ffffff8c;
  border-radius: 14px;
  width: 100%;
  overflow: auto;
}

.services-table {
  border-collapse: collapse;
  width: 100%;
  min-width: 720px;
}

.services-table th {
  text-align: left;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #1d140fb3;
  background: #7a000014;
  padding: .9rem 1rem;
  font-size: .72rem;
}

.services-table td {
  color: #1d140fc7;
  border-top: 1px solid #3c291d14;
  padding: .85rem 1rem;
  font-weight: 600;
}

.services-table tr:hover td {
  background: #ffffffa6;
}

.services-table-link {
  color: #7a0000;
  font-weight: 800;
}

.services-table-link:hover {
  text-decoration: underline;
}

.services-chip-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
  display: grid;
}

.service-chip {
  color: #1d140f;
  background: #ffffff9e;
  border: 1px solid #3c291d1a;
  border-radius: 16px;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  padding: .95rem 1rem;
  transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
  display: flex;
}

.service-chip:hover {
  background: #ffffffc7;
  border-color: #7a00002e;
  transform: translateY(-2px);
  box-shadow: 0 18px 40px #5a43341f;
}

.service-chip-name {
  color: #7a0000;
  font-weight: 800;
}

.service-chip-arrow {
  color: #7a0000;
  background: #7a000014;
  border: 1px solid #7a00001f;
  border-radius: 12px;
  place-items: center;
  width: 34px;
  height: 34px;
  font-weight: 900;
  display: grid;
}

.service-detail-card {
  max-width: 980px;
  margin: 0 auto;
  padding: 1.25rem;
}

.service-detail-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  display: grid;
}

.service-detail-item {
  background: #fffcf7d1;
  border: 1px solid #3c291d14;
  border-radius: 16px;
  padding: 1rem 1.1rem;
}

.service-detail-item span {
  color: #7a6a5f;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: .35rem;
  font-size: .78rem;
  display: block;
}

.service-detail-item strong {
  color: #1d140f;
  font-size: 1.2rem;
  display: block;
}

.service-detail-actions {
  flex-wrap: wrap;
  justify-content: center;
  gap: .85rem;
  margin-top: 1.2rem;
  display: flex;
}

.service-option-panel {
  max-width: 980px;
  margin: 1rem auto 0;
  padding: 1.25rem;
}

.service-option-header {
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: .9rem;
  display: flex;
}

.service-option-header h3 {
  margin: 0;
  font-size: 1.1rem;
}

.service-option-header.service-option-header-stack {
  flex-direction: column;
  align-items: flex-start;
}

.service-option-header.service-option-header-addons {
  margin-top: 1.35rem;
}

.service-option-sub {
  color: #1d140f9e;
  max-width: 42rem;
  margin: .35rem 0 0;
  font-size: .88rem;
  font-weight: 500;
  line-height: 1.35;
}

.service-option-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
  display: grid;
}

.service-option-tile {
  text-align: left;
  cursor: pointer;
  background: #ffffff9e;
  border: 1px solid #3c291d1a;
  border-radius: 16px;
  padding: .9rem 1rem;
  transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
}

.service-option-tile:hover {
  background: #ffffffc7;
  border-color: #7a00002e;
  transform: translateY(-2px);
  box-shadow: 0 18px 40px #5a43341f;
}

.service-option-tile.is-active {
  border-color: #7a000059;
  box-shadow: 0 20px 50px #7a000014;
}

.service-option-grid-addons .service-option-tile-addon {
  border-style: dashed;
}

.service-option-tile-addon.is-active {
  border-style: solid;
}

.service-option-label {
  color: #7a0000;
  margin-bottom: .25rem;
  font-weight: 900;
  display: block;
}

.service-option-meta {
  color: #1d140fb3;
  font-size: .9rem;
  font-weight: 700;
  display: block;
}

.service-description-block {
  max-width: 980px;
  margin: 0 auto 1.25rem;
  padding: 1.15rem 1.35rem;
}

.service-description-prose {
  color: #1d140fd1;
  white-space: pre-wrap;
  margin: 0 0 .75rem;
  font-size: .98rem;
  line-height: 1.65;
}

.service-protocol-note {
  color: #1d140f8c;
  background: #7a00000d;
  border: 1px solid #7a00001f;
  border-radius: 12px;
  margin: 0;
  padding: .65rem .85rem;
  font-size: .82rem;
  line-height: 1.45;
}

.service-media-panel {
  max-width: 980px;
  margin: 0 auto 1rem;
  padding: 1.25rem;
}

.service-media-grid {
  grid-template-columns: 1.35fr .65fr;
  align-items: start;
  gap: .85rem;
  display: grid;
}

.service-media-hero {
  border: 1px solid #3c291d1a;
  border-radius: 18px;
  overflow: hidden;
}

.service-media-hero img, .service-media-thumbs img {
  max-width: 100%;
  height: auto;
}

.service-media-thumbs {
  gap: .85rem;
  display: grid;
}

.service-video-panel {
  max-width: 980px;
  margin: 0 auto 1rem;
  padding: 1.25rem;
}

.service-video-heading {
  color: #201711;
  margin: 0 0 .75rem;
  font-size: 1rem;
  font-weight: 800;
}

.service-video-wrap {
  aspect-ratio: 16 / 9;
  background: #0f0f0f;
  border: 1px solid #3c291d1a;
  border-radius: 18px;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.service-video-wrap iframe {
  border: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.service-video-fallback {
  margin: 0;
}

.services-list {
  gap: var(--space-lg);
  max-width: 800px;
  margin: 0 auto var(--space-xl);
  flex-direction: column;
  display: flex;
}

.service-card {
  gap: var(--space-lg);
  padding: var(--space-lg);
  grid-template-columns: 200px 1fr;
  align-items: center;
  display: grid;
}

.service-card-image {
  aspect-ratio: 1;
  background: linear-gradient(135deg, var(--bg-tertiary), var(--border-light));
  border-radius: 8px;
}

.service-card-content h2 {
  margin-bottom: .5rem;
  font-size: 1.5rem;
}

.service-card-content p {
  color: var(--text-secondary);
  margin-bottom: .75rem;
}

.service-meta {
  font-size: .9rem;
  color: var(--accent-gold) !important;
  margin-bottom: 1rem !important;
}

.services-cta-note {
  text-align: center;
  color: var(--text-secondary);
  font-size: .9rem;
}

@media (max-width: 768px) {
  .service-card, .services-chip-grid, .service-detail-grid, .service-option-grid, .service-media-grid {
    grid-template-columns: 1fr;
  }
}

.page-content {
  padding-top: calc(var(--page-top-offset) + 1rem + env(safe-area-inset-top, 0px));
}

.page-content h1 {
  margin-bottom: var(--space-lg);
  font-size: 2rem;
}

.checkout-page {
  background: radial-gradient(circle at 0 0, #baa0892e, #0000 28%), linear-gradient(#fffdf9 0%, #f4ece2 100%);
}

.checkout-shell {
  flex-direction: column;
  gap: 2rem;
  display: flex;
}

.checkout-header {
  max-width: 860px;
}

.checkout-kicker {
  color: #8c6f5b;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: .9rem;
  font-size: .8rem;
  font-weight: 700;
  display: inline-block;
}

.checkout-header h1, .checkout-empty-state h1, .checkout-confirmation h1 {
  color: #1d140f;
  margin-bottom: 1rem;
  font-size: clamp(2.3rem, 5vw, 4.25rem);
}

.checkout-header p, .checkout-empty-state p, .checkout-confirmation p {
  color: #64564d;
  max-width: 46rem;
  font-size: 1.05rem;
  line-height: 1.8;
}

.checkout-layout {
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  align-items: start;
  gap: 1.5rem;
  display: grid;
}

.checkout-form-panel, .checkout-form-panel-group {
  flex-direction: column;
  gap: clamp(1.5rem, 3vw, 2.25rem);
  display: flex;
}

.checkout-card {
  background: #fffcf7e6;
  border: 1px solid #3c291d14;
  border-radius: 28px;
  padding: 1.4rem;
  box-shadow: 0 22px 60px #59433514;
}

.checkout-card-head {
  margin-bottom: 1.15rem;
}

.checkout-card-head h2 {
  color: #1d140f;
  margin-bottom: .3rem;
  font-size: 1.45rem;
}

.checkout-card-head p {
  color: #6b5e54;
  font-size: .96rem;
}

.checkout-guest-auth-actions {
  flex-wrap: wrap;
  gap: .75rem;
  display: flex;
}

.checkout-guest-hint {
  color: #5c4a42;
  background: #7a00000d;
  border: 1px solid #7a00001a;
  border-radius: 12px;
  margin-top: .65rem;
  padding: .65rem .75rem;
  font-size: .88rem;
  line-height: 1.45;
}

.checkout-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  display: grid;
}

.checkout-form-grid label {
  flex-direction: column;
  gap: .45rem;
  display: flex;
}

.checkout-form-grid span {
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b6b60;
  font-size: .83rem;
}

.checkout-form-grid input {
  color: #1d140f;
  width: 100%;
  font-family: var(--font-sans);
  background: #fffdfa;
  border: 1px solid #3c291d1f;
  border-radius: 14px;
  padding: .95rem 1rem;
}

.checkout-form-grid input:focus {
  border-color: #7a000073;
  outline: none;
  box-shadow: 0 0 0 4px #7a000014;
}

.checkout-form-grid input:-webkit-autofill {
  -webkit-text-fill-color: #1d140f;
  transition: background-color 99999s ease-out;
  box-shadow: inset 0 0 0 1000px #fffdfa;
}

.checkout-form-grid input:-webkit-autofill:hover {
  -webkit-text-fill-color: #1d140f;
  transition: background-color 99999s ease-out;
  box-shadow: inset 0 0 0 1000px #fffdfa;
}

.checkout-form-grid input:-webkit-autofill:focus {
  -webkit-text-fill-color: #1d140f;
  transition: background-color 99999s ease-out;
  box-shadow: inset 0 0 0 1000px #fffdfa;
}

.checkout-static-field {
  background: #fffdfa;
  border: 1px solid #3c291d14;
  border-radius: 16px;
  padding: 1rem;
}

.checkout-static-field span {
  color: #7b6b60;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: .35rem;
  font-size: .78rem;
  display: block;
}

.checkout-static-field strong {
  color: #1d140f;
  font-size: .96rem;
  line-height: 1.6;
}

.checkout-field-full, .checkout-form-grid-wide .checkout-field-full {
  grid-column: 1 / -1;
}

.checkout-choice-group {
  box-sizing: border-box;
  gap: .9rem;
  width: 100%;
  max-width: 100%;
  margin-top: 1.5rem;
  display: grid;
}

.checkout-choice {
  box-sizing: border-box;
  color: #1d140f;
  cursor: pointer;
  text-align: left;
  background: #fffdfa;
  border: 1px solid #3c291d14;
  border-radius: 18px;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  width: 100%;
  max-width: 100%;
  padding: 1rem 1.35rem 1rem 1.15rem;
  display: flex;
}

.checkout-choice > div:first-of-type {
  flex: 1;
  min-width: 0;
}

.checkout-choice strong {
  margin-bottom: .2rem;
  display: block;
}

.checkout-choice span {
  color: #726359;
  font-size: .9rem;
}

.checkout-choice b {
  white-space: nowrap;
  text-align: right;
  flex-shrink: 0;
  padding-left: .5rem;
}

.checkout-choice.is-selected {
  background: linear-gradient(#fffaf6 0%, #f4e7da 100%);
  border-color: #7a00004d;
  box-shadow: 0 12px 30px #7a000014;
}

.checkout-payment-mock {
  border-top: 1px solid #3c291d14;
  margin-top: 1rem;
  padding-top: 1rem;
}

.checkout-payment-note {
  color: #1d140fbf;
  margin-top: 1rem;
  font-size: .9rem;
  line-height: 1.5;
}

.checkout-submit {
  width: 100%;
}

.checkout-submit:disabled {
  opacity: .7;
  cursor: wait;
}

.checkout-error {
  color: #a32020;
  margin-top: .25rem;
  font-size: .92rem;
}

.checkout-summary-panel {
  position: sticky;
  top: 104px;
}

.checkout-summary-card {
  color: #fff8ef;
  background: #1d140f;
}

.checkout-summary-card .checkout-card-head h2, .checkout-summary-card .checkout-card-head p {
  color: inherit;
}

.checkout-summary-list {
  gap: 1rem;
  margin-bottom: 1.4rem;
  list-style: none;
  display: grid;
}

.checkout-summary-item {
  border-bottom: 1px solid #fff8ef1f;
  grid-template-columns: 64px 1fr auto;
  align-items: start;
  gap: .9rem;
  padding-bottom: 1rem;
  display: grid;
}

.checkout-summary-thumb {
  background: #fff8ef14;
  border-radius: 18px;
  flex-shrink: 0;
  place-items: center;
  width: 64px;
  height: 64px;
  padding: .45rem;
  display: grid;
  position: relative;
  overflow: hidden;
}

.checkout-summary-thumb--photo {
  padding: 0;
}

.checkout-summary-thumb-img {
  object-fit: cover;
}

.checkout-summary-thumb span {
  text-align: center;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff8efb8;
  font-size: .62rem;
}

.checkout-summary-copy {
  flex-direction: column;
  gap: .2rem;
  display: flex;
}

.checkout-summary-copy span {
  color: #fff8efb3;
  font-size: .86rem;
}

.checkout-summary-list-light .checkout-summary-item-light {
  border-bottom-color: #3c291d14;
}

.checkout-summary-thumb-light {
  background: #2017110f;
}

.checkout-summary-thumb-light span {
  color: #6e5e53;
}

.checkout-summary-copy-light strong {
  color: #1d140f;
}

.checkout-summary-copy-light span {
  color: #6c5d53;
}

.checkout-summary-totals {
  gap: .75rem;
  margin-bottom: 1.3rem;
  display: grid;
}

.checkout-summary-totals div {
  color: #fff8efd1;
  justify-content: space-between;
  gap: 1rem;
  display: flex;
}

.checkout-summary-grand-total {
  border-top: 1px solid #fff8ef1f;
  padding-top: .9rem;
  font-size: 1.08rem;
  color: #fff8ef !important;
}

.checkout-assurance {
  gap: .75rem;
  display: grid;
}

.checkout-assurance div {
  background: #fff8ef0f;
  border-radius: 18px;
  padding: .9rem 1rem;
}

.checkout-assurance strong {
  margin-bottom: .2rem;
  display: block;
}

.checkout-assurance span {
  color: #fff8efb3;
  font-size: .9rem;
}

.trust-badges {
  color: #1d140fc7;
  background: #fffdfa8c;
  border-top: 1px solid #3c291d0f;
  border-bottom: 1px solid #3c291d0f;
  padding: .55rem 0;
}

.trust-badges-inner {
  box-shadow: none;
  background: none;
  border: none;
  border-radius: 0;
  padding: .25rem 0;
}

.trust-badges-list {
  text-align: center;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.trust-badge {
  font-family: var(--font-sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #1d140fb3;
  align-items: center;
  gap: .45rem;
  font-size: .72rem;
  font-weight: 500;
  line-height: 1.35;
  display: inline-flex;
}

.trust-badge-icon {
  color: #1d140f8c;
  flex-shrink: 0;
  display: block;
}

.trust-badges--compact {
  background: #fffdfab8;
  padding: .45rem 0;
}

.trust-badges--compact .trust-badge {
  font-size: .64rem;
}

@media (max-width: 640px) {
  .trust-badges-list {
    flex-direction: column;
    align-items: center;
    gap: .75rem;
  }
}

.checkout-empty-state, .checkout-confirmation {
  max-width: 900px;
  padding: clamp(2.35rem, 4.5vw, 3.75rem) 0 clamp(3rem, 5vw, 4.25rem);
}

.checkout-confirmation-card {
  margin: clamp(1.6rem, 3.2vw, 2.25rem) 0 clamp(1.35rem, 2.6vw, 1.85rem);
}

.checkout-card + .checkout-card {
  margin-top: 1.15rem;
}

.checkout-confirmation-card {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  display: grid;
}

.checkout-confirmation-card div {
  background: #fffcf7d1;
  border: 1px solid #3c291d14;
  border-radius: 20px;
  padding: 1.1rem 1.2rem;
}

.checkout-confirmation-card span {
  color: #7a6a5f;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: .35rem;
  font-size: .82rem;
  display: block;
}

.checkout-confirmation-card strong {
  color: #1d140f;
  font-size: 1.2rem;
}

.checkout-confirmation-actions {
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: clamp(1rem, 2.4vw, 1.6rem);
  display: flex;
}

@media (max-width: 960px) {
  .checkout-layout, .checkout-confirmation-card {
    grid-template-columns: 1fr;
  }

  .checkout-summary-panel {
    position: static;
  }
}

@media (max-width: 640px) {
  .cart-slide {
    max-width: none;
  }

  .checkout-card {
    padding: 1rem;
  }

  .checkout-form-grid {
    grid-template-columns: 1fr;
  }

  .checkout-choice {
    flex-direction: column;
    align-items: flex-start;
  }

  .checkout-confirmation-actions .btn-primary, .checkout-confirmation-actions .btn-secondary {
    text-align: center;
    width: 100%;
  }

  .footer-body {
    padding: 1.25rem 0 1rem;
  }

  .footer-brand-col {
    padding: 1.05rem 1rem;
  }

  .footer-nav-summary {
    padding: .75rem .95rem;
  }

  .footer-nav-details .footer-nav-list {
    flex-direction: column;
    gap: .35rem;
    padding: 0 .95rem .85rem;
    display: flex;
  }

  .footer-nav-link {
    font-size: .8rem;
  }

  .footer-bottom-inner.footer-bottom-inner-center {
    padding-left: max(.85rem, calc(env(safe-area-inset-left, 0px) + 2.5rem));
    padding-right: max(.85rem, calc(env(safe-area-inset-right, 0px) + 3.25rem));
    padding-bottom: max(4.75rem, calc(env(safe-area-inset-bottom, 0px) + 3.25rem));
  }

  .footer-bottom-inner {
    padding-top: .85rem;
  }
}

.page-content h2 {
  margin-top: var(--space-lg);
  margin-bottom: .5rem;
  font-size: 1.25rem;
}

.page-content p {
  color: var(--text-secondary);
  max-width: 65ch;
  margin-bottom: 1rem;
}

.prose-content {
  max-width: 720px;
}

.prose-content ul, .prose-content ol {
  color: var(--text-secondary);
  margin-bottom: 1rem;
  padding-left: 1.5rem;
}

.prose-content li {
  margin-bottom: .35rem;
}

.prose-content a:not(.btn-primary) {
  color: var(--accent);
  text-decoration: underline;
}

.prose-content a:hover {
  color: var(--accent-hover);
}

.faq-list {
  max-width: 720px;
}

.faq-item {
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--border-light);
}

.faq-item:last-child {
  border-bottom: none;
}

.faq-question {
  font-family: var(--font-serif);
  color: var(--text-primary);
  margin-bottom: .5rem;
  font-size: 1.1rem;
  font-weight: 600;
}

.faq-answer {
  color: var(--text-secondary);
  margin-left: 0;
  line-height: 1.6;
}

.contact-block {
  margin-bottom: var(--space-lg);
}

.contact-block h2 {
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-secondary);
  margin-bottom: .25rem;
  font-size: .9rem;
}

.contact-block a:not(.btn-primary):not(.btn-secondary):not(.contact-aside-pill) {
  color: var(--accent);
  text-decoration: underline;
}

.contact-aside-pill {
  color: var(--text-primary);
  background: #fffdf9fa;
  border: 1px solid #3c291d1a;
  border-radius: 999px;
  align-items: center;
  gap: .55rem;
  max-width: 100%;
  padding: .55rem 1rem;
  font-size: .94rem;
  font-weight: 600;
  line-height: 1.3;
  text-decoration: none;
  transition: border-color .15s, box-shadow .15s;
  display: inline-flex;
}

.contact-aside-pill:hover {
  color: var(--text-primary);
  border-color: #7a000038;
  box-shadow: 0 2px 12px #7a00000f;
}

.contact-aside-pill-icon {
  color: var(--accent);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.contact-block--whatsapp {
  margin-top: .35rem;
}

.contact-aside-whatsapp {
  text-align: center;
  box-sizing: border-box;
  justify-content: center;
  width: 100%;
  display: inline-flex;
}

.contact-social-list {
  margin: .5rem 0 0;
  padding-left: 1.25rem;
  line-height: 1.7;
}

.contact-payment-section {
  border-top: 1px solid var(--border-light);
  margin-top: 3rem;
  padding-top: 2rem;
}

.contact-payment-title {
  color: var(--text-secondary);
  margin-bottom: 1rem;
  font-size: 1rem;
}

.payment-logos {
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  display: flex;
}

.payment-logo-placeholder {
  background: var(--bg-tertiary);
  border: 1px solid var(--border-light);
  color: var(--text-secondary);
  border-radius: 4px;
  padding: .5rem 1rem;
  font-size: .85rem;
}

.payment-note {
  color: var(--text-secondary);
  margin-top: .75rem;
  font-size: .85rem;
}

.footer-rubrics {
  border-bottom: 1px solid var(--border-light);
  background: #ffffff73;
}

.footer-rubrics-inner {
  padding: .55rem var(--space-lg);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #1d140fb8;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .35rem .85rem;
  font-size: .62rem;
  font-weight: 600;
  display: flex;
}

.footer-rubrics-item + .footer-rubrics-item:before {
  content: "·";
  opacity: .55;
  margin-right: .85rem;
}

.auth-top-rubrics {
  background: #fffcf7eb;
  border-bottom: 1px solid #3c291d1a;
}

.auth-top-rubrics-inner {
  padding: .45rem var(--space-lg);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #1d140fa6;
  flex-wrap: wrap;
  justify-content: center;
  gap: .3rem .65rem;
  font-size: .58rem;
  font-weight: 600;
  display: flex;
}

.auth-top-rubrics-item + .auth-top-rubrics-item:before {
  content: "·";
  opacity: .5;
  margin-right: .65rem;
}

.auth-login-footer-row {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  width: 100%;
  margin-top: 1.1rem;
  display: flex;
}

.auth-login-footer-row--tight {
  text-align: center;
  justify-content: center;
  gap: .5rem;
}

.auth-login-footer-row--tight .auth-footer-muted {
  color: var(--auth-on-panel-muted);
  margin: 0;
  font-size: .88rem;
}

.faq-page .container {
  max-width: 62rem;
  margin-top: clamp(1rem, 2.6vw, 1.9rem);
  margin-left: auto;
  margin-right: auto;
}

.faq-page-title {
  text-align: center;
  margin-bottom: 1.5rem;
}

.faq-accordion {
  flex-direction: column;
  gap: .65rem;
  display: flex;
}

.faq-accordion-item {
  padding: 0;
  overflow: hidden;
}

.faq-accordion-trigger {
  cursor: pointer;
  text-align: left;
  width: 100%;
  font-family: var(--font-sans);
  color: var(--text-primary);
  background: none;
  border: 0;
  align-items: flex-start;
  gap: .75rem;
  padding: 1rem 1.15rem;
  font-size: .95rem;
  font-weight: 600;
  line-height: 1.35;
  transition: background .15s;
  display: flex;
}

.faq-accordion-trigger:hover, .faq-accordion-trigger:focus-visible {
  background: #7a00000d;
  outline: none;
}

.faq-accordion-icon {
  width: 1.5rem;
  color: var(--accent);
  flex-shrink: 0;
  font-size: 1.15rem;
  font-weight: 500;
  line-height: 1.2;
}

.faq-accordion-panel {
  color: var(--text-secondary);
  padding: 0 1.15rem 1rem 2.75rem;
  font-size: .92rem;
  line-height: 1.55;
}

.faq-accordion-panel:not(.is-open) {
  display: none;
}

.faq-page-cta {
  text-align: center;
  margin-top: 2rem;
}

.container-narrow {
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
}

.home-about-snippet {
  background: radial-gradient(circle at 80%, #7a00000a, #0000 50%), linear-gradient(#fff 0%, #f8f0e8 100%);
}

.home-about-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  grid-template-areas: "copy media";
  align-items: center;
  gap: clamp(1.25rem, 2.6vw, 2.25rem);
  display: grid;
}

@media (max-width: 900px) {
  .home-about-grid {
    text-align: center;
    grid-template-columns: 1fr;
    grid-template-areas: "copy"
                         "media";
    justify-items: center;
  }

  .home-about-copy {
    width: 100%;
    max-width: 44rem;
  }

  .home-about-snippet .home-about-cta {
    justify-content: center;
    display: flex;
  }

  .home-about-media {
    width: 100%;
    max-width: 44rem;
  }
}

.home-about-copy {
  grid-area: copy;
  align-content: center;
  gap: 1.35rem;
  display: grid;
}

.home-about-head {
  gap: .7rem;
  display: grid;
}

.home-about-body {
  gap: .9rem;
  display: grid;
}

.home-about-media {
  background: linear-gradient(#f8f0e8 0%, #f2e7dd 100%);
  border-radius: 18px;
  grid-area: media;
  height: clamp(280px, 33vw, 410px);
  padding: 0;
  position: relative;
  overflow: hidden;
}

.home-about-image {
  object-fit: cover;
  object-position: center 20%;
  width: 100%;
  height: 100%;
  display: block;
}

@media (max-width: 900px) {
  .home-about-media {
    height: clamp(240px, 56vw, 360px);
  }

  .home-about-image {
    object-position: center 18%;
  }
}

@media (max-width: 640px) {
  .home-about-media {
    height: clamp(220px, 62vw, 300px);
  }

  .home-about-image {
    object-position: center 15%;
  }
}

.home-about-snippet .home-about-cta {
  margin-top: 1.25rem;
}

.home-about-snippet .btn-secondary.home-about-cta-btn {
  color: #fff8ec;
  background: linear-gradient(135deg, #7a0000e6 0%, #962020e6 100%);
  border-color: #7a000073;
  font-weight: 700;
  box-shadow: 0 10px 24px #7a000033;
}

.home-about-snippet .btn-secondary.home-about-cta-btn:hover {
  color: #fff;
  border-color: #7a0000b8;
  box-shadow: 0 14px 28px #7a000042;
}

.home-about-snippet .btn-secondary.home-about-cta-btn:focus-visible {
  outline-offset: 3px;
  outline: 2px solid #7a0000b3;
}

.home-testimonials {
  color: #fff9f1;
  background: #1d140f;
}

.home-testimonials .section-header h2 {
  color: #fff9f1;
}

.home-testimonials .section-header p {
  color: #fff9f1a6;
}

.home-testimonials .section-kicker {
  color: #ffc8a0d9;
}

.testimonial-marquee {
  border-radius: 6px;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, #0000 0%, #000 10% 90%, #0000 100%);
  mask-image: linear-gradient(to right, #0000 0%, #000 10% 90%, #0000 100%);
}

.testimonial-track {
  gap: 1rem;
  width: max-content;
  animation: 42s linear infinite testimonialScroll;
  display: flex;
}

.testimonial-marquee:hover .testimonial-track {
  animation-play-state: paused;
}

@keyframes testimonialScroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .testimonial-track {
    flex-wrap: wrap;
    width: 100%;
    animation: none;
  }
}

.testimonial-card {
  background: #fff9f10d;
  border: 1px solid #fff9f114;
  border-radius: 6px;
  flex-direction: column;
  flex: none;
  width: min(400px, 84vw);
  margin: 0;
  padding: 1.5rem 1.5rem 1.35rem;
  display: flex;
}

.testimonial-card-top {
  align-items: center;
  gap: 1rem;
  margin-bottom: .85rem;
  display: flex;
}

.testimonial-avatar-wrap {
  background: #fffdf9e6;
  border: 2px solid #fffffff2;
  border-radius: 50%;
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  overflow: hidden;
  box-shadow: 0 2px 10px #2216101a, 0 0 0 1px #3c291d14;
}

.testimonial-avatar {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
}

.testimonial-card-meta {
  flex-direction: column;
  flex: 1;
  justify-content: center;
  gap: .2rem;
  min-width: 0;
  display: flex;
}

.testimonial-stars {
  color: #e6a317;
  filter: drop-shadow(0 1px #fff9);
  flex-wrap: wrap;
  gap: .12rem;
  display: flex;
}

.testimonial-star {
  flex-shrink: 0;
}

.testimonial-card p {
  color: #fff9f1d1;
  margin: 0;
  line-height: 1.5;
}

.testimonial-card footer {
  color: #fff9f173;
  margin-top: .85rem;
  font-size: .82rem;
  font-style: normal;
}

.testimonial-result-media {
  border-radius: 12px;
  width: 100%;
  height: 140px;
  margin-top: .9rem;
  position: relative;
  overflow: hidden;
}

.testimonial-card footer strong {
  color: #fff9f1eb;
  font-weight: 700;
  display: block;
}

.testimonial-card footer span {
  margin-top: .15rem;
  display: block;
}

.home-results-gallery {
  background: linear-gradient(#fff8f2 0%, #f6ebe0 100%);
}

.home-results-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  display: grid;
}

.home-result-card {
  padding: .65rem;
}

.home-result-media {
  aspect-ratio: 4 / 5;
  border-radius: 14px;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.home-result-card p {
  color: #1d140fcc;
  margin: .65rem 0 .2rem;
  font-size: .88rem;
}

.home-faq-teaser {
  background: linear-gradient(#f5ede2 0%, #efe6db 100%);
}

.home-testimonials.section {
  padding-bottom: clamp(2rem, 4vw, 3.2rem);
}

.home-faq-teaser.section {
  padding-top: clamp(2.2rem, 4.2vw, 3.4rem);
}

.home-faq-teaser .section-header {
  max-width: 56rem;
  margin-left: auto;
  margin-right: auto;
}

.home-faq-teaser .section-header-split {
  text-align: center;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  gap: .9rem;
}

.home-faq-teaser .section-header h2 {
  max-width: 11ch;
  font-size: clamp(2.7rem, 5.2vw, 4.8rem);
}

.home-faq-teaser .section-header p {
  max-width: 34rem;
  margin: 0 auto;
}

.home-faq-more-wrap {
  text-align: center;
  margin-top: 1.5rem;
}

.home-faq-inner {
  max-width: 56rem;
  margin: 0 auto;
}

.contact-form {
  flex-direction: column;
  gap: 1rem;
  padding: 1.35rem 1.5rem;
  display: flex;
}

.contact-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.25rem;
  width: 100%;
  display: grid;
}

.contact-form-field {
  flex-direction: column;
  gap: .5rem;
  font-size: .88rem;
  display: flex;
}

.contact-form-field--full {
  grid-column: 1 / -1;
}

.contact-form-actions {
  justify-content: flex-start;
  padding-top: .25rem;
  display: flex;
}

.contact-form-actions .btn-primary {
  min-width: min(100%, 14rem);
}

@media (max-width: 520px) {
  .contact-form-grid {
    grid-template-columns: 1fr;
  }

  .contact-form-field--full {
    grid-column: 1;
  }
}

.contact-form-field input, .contact-form-field textarea {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  font-family: var(--font-sans);
  border: 1px solid #3c291d24;
  border-radius: 10px;
  padding: .65rem .85rem;
}

.contact-form-field textarea {
  resize: vertical;
  min-height: 6rem;
}

.contact-form-success {
  color: #1b5e20;
  font-size: .92rem;
}

.contact-form-error {
  color: #8b1538;
  font-size: .9rem;
}

.auth-flow-toast.contact-form-toast {
  z-index: 450;
}

.contact-form-toast {
  z-index: 400;
  left: 50%;
  bottom: max(1.25rem, env(safe-area-inset-bottom, 0px));
  width: min(100vw - 2rem, 420px);
  font-family: var(--font-sans);
  border-radius: 16px;
  align-items: flex-start;
  gap: .75rem;
  padding: 1rem 1rem 1rem 1.1rem;
  font-size: .92rem;
  line-height: 1.45;
  animation: .28s cubic-bezier(.16, 1, .3, 1) contactToastIn;
  display: flex;
  position: fixed;
  transform: translateX(-50%);
  box-shadow: 0 4px 24px #2216102e, 0 0 0 1px #0000000a;
}

@keyframes contactToastIn {
  from {
    opacity: 0;
    transform: translateX(-50%)translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateX(-50%)translateY(0);
  }
}

.contact-form-toast--success {
  color: #1b3d24;
  background: linear-gradient(165deg, #f1f8f4 0%, #e8f5e9 45%, #dff0e3 100%);
  border: 1px solid #1b5e2047;
}

.contact-form-toast--error {
  color: #5c1228;
  background: linear-gradient(165deg, #fff5f7 0%, #fce8ec 45%, #f8dce2 100%);
  border: 1px solid #8b153859;
}

.contact-form-toast-icon {
  border-radius: 999px;
  flex-shrink: 0;
  place-items: center;
  width: 28px;
  height: 28px;
  font-size: .85rem;
  font-weight: 800;
  display: grid;
}

.contact-form-toast--success .contact-form-toast-icon {
  color: #1b5e20;
  background: #1b5e202e;
}

.contact-form-toast--error .contact-form-toast-icon {
  color: #8b1538;
  background: #8b153833;
}

.contact-form-toast-text {
  flex: 1;
  min-width: 0;
  padding-top: .1rem;
}

.contact-form-toast-close {
  width: 32px;
  height: 32px;
  color: inherit;
  opacity: .65;
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 10px;
  flex-shrink: 0;
  margin: -.2rem -.15rem 0 0;
  font-size: 1.35rem;
  line-height: 1;
  transition: opacity .15s, background .15s;
}

.contact-form-toast-close:hover {
  opacity: 1;
  background: #0000000f;
}

.page-hero-shell {
  width: 100%;
  max-width: 1320px;
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 640px) {
  .page-hero-shell {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.page-hero-top {
  flex-direction: column;
  align-items: stretch;
  gap: clamp(.85rem, 2.2vw, 1.35rem);
  display: flex;
}

@media (min-width: 768px) {
  .page-hero-top--split {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.5rem 2.5rem;
  }

  .page-hero-top--split .page-hero-top-main {
    flex: min(0, 44rem);
    min-width: 0;
  }

  .page-hero-top--split .page-hero-top-aside {
    flex: 0 auto;
    align-self: flex-start;
    max-width: min(100%, 26rem);
  }
}

.contact-v2 {
  --contact-v2-ink: #1a100e;
  --contact-v2-ink-soft: #1d140fb8;
  --contact-v2-line: #3c291d1a;
  color: var(--contact-v2-ink);
  background: linear-gradient(#fdf9f4 0%, #f4ebe3 38%, #efe5db 100%);
}

.contact-v2-hero {
  padding-top: calc(env(safe-area-inset-top, 0px) + var(--page-top-offset) + clamp(1.15rem, 4vw, 2.25rem));
  border-bottom: 1px solid var(--contact-v2-line);
  background: radial-gradient(90% 55% at 50% -25%, #7a000012, #0000 52%), linear-gradient(#fffefb 0%, #f8f1e9 100%);
  padding-bottom: clamp(2rem, 4vw, 3.25rem);
  padding-left: 0;
  padding-right: 0;
  position: relative;
}

.contact-v2-hero-content {
  min-width: 0;
}

.contact-v2-kicker.section-kicker {
  margin-bottom: .75rem;
}

.contact-v2-title {
  font-family: var(--font-serif);
  letter-spacing: -.03em;
  color: var(--contact-v2-ink);
  font-size: clamp(2.35rem, 5.8vw, 3.6rem);
  font-weight: 600;
  line-height: 1.02;
}

.contact-v2-title-dot {
  color: #7a0000;
}

.contact-v2-subtitle {
  max-width: 38rem;
  color: var(--contact-v2-ink-soft);
  font-size: clamp(.98rem, 1.35vw, 1.12rem);
}

.contact-v2-badge {
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #2d201ae0;
  text-align: center;
  box-sizing: border-box;
  background: #ffffffc7;
  border: 1px solid #3c291d1f;
  border-radius: 999px;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .55rem;
  padding: .48rem 1rem;
  font-size: .7rem;
  font-weight: 600;
  display: inline-flex;
  box-shadow: 0 4px 18px #2216100f;
}

@media (min-width: 768px) {
  .contact-v2-badge {
    text-align: left;
    justify-content: flex-start;
  }
}

@media (max-width: 767px) {
  .page-hero-top-aside .contact-v2-badge {
    width: 100%;
  }
}

.contact-v2-badge svg {
  color: #7a0000;
  flex-shrink: 0;
}

.contact-v2-channels {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(.75rem, 2vw, 1.1rem);
  width: 100%;
  margin: clamp(1.75rem, 4vw, 2.75rem) 0 0;
  display: grid;
}

@media (max-width: 900px) {
  .contact-v2-channels {
    grid-template-columns: 1fr;
  }
}

.contact-v2-channel {
  color: inherit;
  background: #fffcf7eb;
  border: 1px solid #3c291d1a;
  border-radius: 16px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: .85rem 1rem;
  padding: 1.05rem 1.1rem;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s, border-color .2s, background .2s;
  display: grid;
  box-shadow: 0 10px 32px #2216100f;
}

.contact-v2-channel:hover {
  background: #fffefb;
  border-color: #7a000038;
  transform: translateY(-2px);
  box-shadow: 0 16px 42px #2216101a;
}

.contact-v2-channel--wa .contact-v2-channel-icon {
  color: #1a8f4a;
  background: #25d36624;
}

.contact-v2-channel-icon {
  color: #7a0000;
  background: #7a000017;
  border-radius: 12px;
  flex-shrink: 0;
  place-items: center;
  width: 44px;
  height: 44px;
  display: grid;
}

.contact-v2-channel-text {
  text-align: left;
  flex-direction: column;
  align-items: flex-start;
  gap: .25rem;
  min-width: 0;
  display: flex;
}

.contact-v2-channel-title {
  letter-spacing: .02em;
  color: var(--contact-v2-ink);
  font-size: .95rem;
  font-weight: 700;
  display: block;
}

.contact-v2-channel-sub {
  color: #2d241ea8;
  font-size: .78rem;
  font-weight: 500;
  line-height: 1.4;
  display: block;
}

.contact-v2-channel-arrow {
  color: #7a000080;
  padding: .2rem;
  font-size: 1.1rem;
  line-height: 1;
  transition: transform .2s, color .2s;
}

.contact-v2-channel:hover .contact-v2-channel-arrow {
  color: #7a0000;
  transform: translateX(4px);
}

.contact-v2-body {
  padding: clamp(2.25rem, 5vw, 3.75rem) 0 clamp(2.5rem, 5vw, 4rem);
}

.contact-v2-split {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
  align-items: start;
  gap: clamp(1.75rem, 4vw, 3rem);
  display: grid;
}

@media (max-width: 992px) {
  .contact-v2-split {
    grid-template-columns: 1fr;
  }
}

.contact-v2-form-wrap {
  background: linear-gradient(#fffdf9fa 0%, #f8f0e8f7 100%);
  border: 1px solid #3c291d1a;
  border-radius: 24px;
  padding: clamp(1.35rem, 3vw, 2rem) clamp(1.25rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2.1rem);
  box-shadow: inset 0 4px 2px #ffffffbf, 0 22px 56px #22161014;
}

.contact-v2-form-header {
  margin-bottom: 1.35rem;
}

.contact-v2-form-header .section-kicker {
  margin-bottom: .6rem;
}

.contact-v2-form-header h2 {
  font-family: var(--font-serif);
  letter-spacing: -.02em;
  color: var(--contact-v2-ink);
  margin: 0 0 .55rem;
  font-size: clamp(1.62rem, 3vw, 2.1rem);
  font-weight: 600;
}

.contact-v2-form-header p {
  color: var(--contact-v2-ink-soft);
  max-width: 44rem;
  margin: 0;
  font-size: .94rem;
  line-height: 1.6;
}

.contact-v2 .contact-form.contact-form--v2 {
  gap: 1.25rem;
  padding: 0;
}

.contact-v2 .contact-form--v2 .contact-form-grid {
  gap: 1.1rem 1.35rem;
}

.contact-v2 .contact-form--v2 .contact-form-field span {
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2d241ebf;
  font-size: .68rem;
  font-weight: 700;
}

.contact-v2 .contact-form--v2 .contact-form-field input, .contact-v2 .contact-form--v2 .contact-form-field textarea {
  background: #fffffff0;
  border: 1px solid #3c291d1f;
  border-radius: 14px;
  padding: .78rem 1rem;
  font-size: .95rem;
  transition: border-color .18s, box-shadow .18s;
}

.contact-v2 .contact-form--v2 .contact-form-field input:focus, .contact-v2 .contact-form--v2 .contact-form-field textarea:focus {
  border-color: #7a000073;
  outline: none;
  box-shadow: 0 0 0 4px #7a000014;
}

.contact-v2 .contact-form--v2 .contact-form-actions {
  padding-top: .5rem;
}

.contact-v2 .contact-form--v2 .contact-form-actions .btn-primary {
  border-radius: 999px;
  min-width: min(100%, 16rem);
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.contact-v2-sidebar {
  top: calc(var(--page-top-offset) + 1rem);
  background: #fffcf7eb;
  border: 1px solid #3c291d1a;
  border-radius: 20px;
  padding: 1.35rem 1.25rem 1.45rem;
  position: sticky;
  box-shadow: 0 12px 36px #2216100f;
}

@media (max-width: 992px) {
  .contact-v2-sidebar {
    position: relative;
    top: auto;
  }
}

.contact-v2-avail {
  align-items: flex-start;
  gap: .75rem;
  display: flex;
}

.contact-v2-avail-dot {
  background: #2d8f4e;
  border-radius: 999px;
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  margin-top: .35rem;
  box-shadow: 0 0 0 4px #2d8f4e2e;
}

.contact-v2-avail-text strong {
  margin-bottom: .2rem;
  font-size: .9rem;
  display: block;
}

.contact-v2-avail-text span {
  color: var(--contact-v2-ink-soft);
  font-size: .82rem;
  line-height: 1.45;
}

.contact-v2-divider {
  background: linear-gradient(90deg, #0000, #3c291d1f, #0000);
  height: 1px;
  margin: 1.15rem 0;
}

.contact-v2-direct {
  flex-direction: column;
  gap: .85rem;
  display: flex;
}

.contact-v2-direct-item {
  color: inherit;
  border-radius: 12px;
  align-items: flex-start;
  gap: .75rem;
  margin: 0 -.45rem;
  padding: .55rem .45rem;
  text-decoration: none;
  transition: background .15s;
  display: flex;
}

.contact-v2-direct-item:hover {
  background: #7a00000f;
}

.contact-v2-direct-icon {
  color: #7a0000;
  background: #7a000014;
  border-radius: 10px;
  flex-shrink: 0;
  place-items: center;
  width: 40px;
  height: 40px;
  display: grid;
}

.contact-v2-direct-copy {
  flex-direction: column;
  gap: .2rem;
  min-width: 0;
  display: flex;
}

.contact-v2-direct-copy strong {
  word-break: break-word;
  font-size: .88rem;
}

.contact-v2-direct-copy span {
  color: #2d241e9e;
  font-size: .76rem;
}

.contact-v2-socials-label {
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #2d241e8c;
  margin: 0 0 .65rem;
  font-size: .68rem;
  font-weight: 700;
}

.contact-v2-socials .contact-social-icons {
  gap: .5rem;
}

.contact-v2-map {
  background: linear-gradient(#e8dfd4 0%, #e0d5c8 100%);
  padding: 0 0 clamp(2.5rem, 5vw, 4rem);
}

.contact-v2-map-header {
  text-align: center;
  padding: 0 1.25rem 1.15rem;
}

.contact-v2-map-header h2 {
  font-family: var(--font-serif);
  color: var(--contact-v2-ink);
  margin: 0;
  font-size: clamp(1.42rem, 2.8vw, 1.88rem);
}

.contact-v2-map-frame {
  border: 1px solid #3c291d1f;
  border-radius: 20px;
  max-width: min(1040px, 100% - 2rem);
  margin: 0 auto;
  overflow: hidden;
  box-shadow: 0 18px 48px #2216101f;
}

.contact-v2-map-frame iframe {
  border: 0;
  width: 100%;
  height: min(420px, 55vh);
  display: block;
}

.contact-page-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  align-items: start;
  gap: 1.5rem;
  margin-top: 1.5rem;
  display: grid;
}

@media (max-width: 900px) {
  .contact-page-grid {
    grid-template-columns: 1fr;
  }
}

.contact-page-aside {
  padding: 1.25rem 1.35rem;
}

.contact-social-icons {
  flex-wrap: wrap;
  gap: .45rem;
  margin-top: .35rem;
  display: flex;
}

.contact-map-section {
  margin-top: 2.5rem;
}

.contact-map-title {
  color: var(--text-secondary);
  margin-bottom: .75rem;
  font-size: 1.05rem;
}

.contact-map-frame {
  border: 1px solid var(--border-light);
  border-radius: 16px;
  min-height: 280px;
  overflow: hidden;
}

.contact-map-frame iframe {
  border: 0;
  width: 100%;
  height: 320px;
  display: block;
}

.a-propos-hero {
  border-bottom: 1px solid #3c291d14;
  grid-template-columns: minmax(0, 1fr) minmax(0, min(100%, max(30rem, min(44rem, 42vw))));
  align-items: center;
  gap: clamp(1.35rem, 3.5vw, 2.75rem);
  margin: 0 0 clamp(1.75rem, 4vw, 2.75rem);
  padding-bottom: clamp(1.35rem, 3vw, 2.25rem);
  display: grid;
}

.a-propos-hero-copy {
  min-width: 0;
}

.a-propos-hero-copy .section-kicker {
  margin-bottom: .75rem;
}

.page-content .a-propos-hero-copy h1 {
  letter-spacing: -.03em;
  color: #1d140f;
  margin: 0 0 .85rem;
  font-size: clamp(2.15rem, 4.8vw, 3.35rem);
  line-height: 1.05;
}

.a-propos-hero-lead {
  color: #1d140fbd;
  max-width: 44rem;
  margin: 0 0 1.25rem;
  font-size: clamp(.96rem, 1.2vw, 1.06rem);
  line-height: 1.65;
}

.a-propos-manifesto {
  background: #fffcf7a6;
  border: 1px solid #3c291d14;
  border-radius: 16px;
  margin-bottom: 1.35rem;
  padding: 1rem 1.15rem;
}

.a-propos-manifesto-label {
  letter-spacing: .14em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent) 72%, #4e0f0f 28%);
  margin-bottom: .45rem;
  font-size: .72rem;
  font-weight: 600;
  display: block;
}

.a-propos-manifesto p {
  color: #1d140fc7;
  margin: 0;
  font-size: .95rem;
  line-height: 1.65;
}

.a-propos-signatures {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem 1rem;
  display: grid;
}

@media (max-width: 640px) {
  .a-propos-signatures {
    grid-template-columns: 1fr;
    gap: .75rem;
  }
}

.a-propos-signatures > div {
  background: #fffcf780;
  border: 1px solid #3c291d12;
  border-radius: 12px;
  padding: .75rem .85rem;
}

.a-propos-signatures span {
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #1d140f85;
  margin-bottom: .25rem;
  font-size: .68rem;
  font-weight: 600;
  display: block;
}

.a-propos-signatures strong {
  font-family: var(--font-serif);
  color: #1d140f;
  font-size: clamp(1.15rem, 2.8vw, 1.45rem);
  font-weight: 600;
}

.a-propos-hero-figure {
  min-width: 0;
  margin: 0;
}

.a-propos-hero-image-wrap {
  box-shadow: var(--shadow-soft);
  border-radius: 22px;
  position: relative;
  overflow: hidden;
}

.a-propos-hero-plaque {
  color: #fffaf4f2;
  -webkit-backdrop-filter: blur(10px);
  background: #140c0ab8;
  border-radius: 12px;
  padding: .55rem .75rem;
  font-size: .72rem;
  line-height: 1.4;
  position: absolute;
  bottom: .85rem;
  left: .85rem;
  right: .85rem;
}

@media (max-width: 900px) {
  .a-propos-hero {
    grid-template-columns: 1fr;
  }
}

.a-propos-story-grid {
  grid-template-columns: 1fr minmax(0, 380px);
  align-items: start;
  gap: 2rem;
  margin: 1.5rem 0 2rem;
  display: grid;
}

@media (max-width: 900px) {
  .a-propos-story-grid {
    grid-template-columns: 1fr;
  }
}

.a-propos-story-text {
  padding: clamp(1.2rem, 2.8vw, 1.75rem) clamp(1.35rem, 3.2vw, 2.15rem);
}

.a-propos-story-text p {
  margin: 0;
}

.a-propos-story-text p + p {
  margin-top: 1.05rem;
}

.a-propos-story-note {
  padding: clamp(1.1rem, 2.5vw, 1.5rem) clamp(1.25rem, 3vw, 2rem);
}

.a-propos-story-note p {
  margin: 0;
}

.a-propos-team-image {
  object-fit: cover;
  border-radius: 16px;
  width: 100%;
  height: auto;
}

.a-propos-team-caption {
  color: #1d140f99;
  margin-top: .65rem;
  font-size: .88rem;
  line-height: 1.45;
}

.a-propos-values {
  margin-top: clamp(2.25rem, 4.5vw, 3.75rem);
}

.a-propos-values-intro {
  text-align: center;
  max-width: min(52rem, 100%);
  margin: 0 auto clamp(1.75rem, 3.2vw, 2.75rem);
}

.a-propos-values-intro h2 {
  font-family: var(--font-serif);
  letter-spacing: -.02em;
  color: #1d140f;
  margin: 0 0 .75rem;
  font-size: clamp(1.75rem, 3.2vw, 2.65rem);
  font-weight: 600;
  line-height: 1.1;
}

.a-propos-values-intro p {
  color: #2d241ec2;
  max-width: 42rem;
  margin: 0 auto;
  font-size: clamp(.94rem, 1.15vw, 1.05rem);
  line-height: 1.65;
}

.a-propos-values-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: clamp(1rem, 2.2vw, 1.65rem);
  display: grid;
}

@media (max-width: 1024px) {
  .a-propos-values-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .a-propos-values-grid {
    grid-template-columns: 1fr;
  }
}

.a-propos-value-card {
  text-align: left;
  background: #fffcf7b8;
  border: 1px solid #3c291d14;
  border-radius: 18px;
  flex-direction: column;
  gap: .5rem;
  padding: 1.35rem 1.2rem 1.45rem;
  display: flex;
  box-shadow: 0 10px 28px #2216100d;
}

.a-propos-value-index {
  font-family: var(--font-sans);
  letter-spacing: .2em;
  color: #7a0000e0;
  font-size: .68rem;
  font-weight: 600;
}

.a-propos-value-card h3 {
  font-family: var(--font-serif);
  color: #1d140f;
  margin: 0;
  font-size: clamp(1.08rem, 1.75vw, 1.32rem);
  font-weight: 600;
  line-height: 1.2;
}

.a-propos-value-card p {
  color: #2d241ec7;
  margin: 0;
  font-size: .9rem;
  line-height: 1.62;
}

.a-propos-foundation {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  gap: clamp(1rem, 2vw, 1.5rem);
  margin-top: clamp(2.25rem, 4vw, 3.5rem);
  display: grid;
}

@media (max-width: 900px) {
  .a-propos-foundation {
    grid-template-columns: 1fr;
  }
}

.a-propos-foundation-card {
  background: linear-gradient(#fffcf7eb, #f6ede3f5);
  border: 1px solid #3c291d1a;
  border-radius: 20px;
  padding: clamp(1.35rem, 2.4vw, 1.85rem);
}

.a-propos-foundation-card h2 {
  font-family: var(--font-serif);
  letter-spacing: -.02em;
  color: #1d140f;
  margin: 0 0 .85rem;
  font-size: clamp(1.2rem, 2vw, 1.45rem);
  font-weight: 600;
}

.a-propos-foundation-card p {
  color: #2d241ecc;
  margin: 0;
  font-size: .95rem;
  line-height: 1.68;
}

.a-propos-foundation-card-dark {
  color: #fff8f0eb;
  background: linear-gradient(165deg, #2c1a17 0%, #16100e 100%);
  border-color: #fff5ec1f;
}

.a-propos-foundation-card-dark h2 {
  color: #fff8ec;
}

.a-propos-foundation-card-dark p {
  color: #fff5ecd6;
}

.a-propos-closing {
  text-align: center;
  border-top: 1px solid #3c291d1a;
  margin-top: clamp(2rem, 3.8vw, 3.25rem);
  padding-top: clamp(1.65rem, 3vw, 2.35rem);
}

.a-propos-closing p {
  color: #2d241ec7;
  max-width: 44rem;
  margin: 0 auto;
  font-size: clamp(.95rem, 1.15vw, 1.06rem);
  line-height: 1.68;
}

.service-detail-page .service-detail-container {
  max-width: min(1120px, 100%);
}

.service-upsell-section {
  margin-top: 2rem;
  padding: 1.85rem 2.25rem;
}

.service-upsell-header {
  margin-bottom: 1.25rem;
}

.service-upsell-section .grid.collections-grid {
  justify-content: center;
  justify-items: center;
}

.service-upsell-section .grid.collections-grid .product-card, .service-upsell-section .grid.collections-grid .product-card-boutique {
  width: 100%;
  max-width: 420px;
}

.recherche-query-line {
  color: var(--text-secondary);
  margin: .5rem 0 1.25rem;
  font-size: .95rem;
}

.recherche-results {
  flex-direction: column;
  gap: 1.5rem;
  display: flex;
}

.recherche-block {
  padding: 1.25rem 1.35rem;
}

.recherche-block h2 {
  margin-bottom: .85rem;
  font-size: 1.1rem;
}

.recherche-list {
  flex-direction: column;
  gap: .65rem;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.recherche-list li {
  border-bottom: 1px solid #3c291d14;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: .5rem;
  padding-bottom: .5rem;
  display: flex;
}

.recherche-list li a:first-child {
  color: var(--text-primary);
  font-weight: 600;
  text-decoration: none;
}

.recherche-list li a:first-child:hover {
  color: var(--accent);
}

.btn-small {
  padding: .4rem .75rem;
  font-size: .72rem;
}

.section + .section:not(.home-testimonials):not(.collections):not(.services-spotlight):not(.home-about-snippet):not(.home-faq-teaser):not(.home-contact-block) {
  border-top: 1px solid #3c291d12;
}

.auth-modal-card {
  border-radius: 24px;
}

.auth-modal-inner .auth-field input, .auth-modal-inner .auth-submit, .auth-modal-inner .auth-signup-promo-block {
  border-radius: 12px;
}

.auth-modal-inner .auth-signup-promo-row input {
  border-radius: 10px;
}

.cart-panel {
  border-radius: 0 !important;
}

.nav-announcement {
  border-bottom: 1px solid #7a000038;
}

.page-content > .container > .section-header h1 {
  letter-spacing: -.02em;
  line-height: 1.05;
}

body {
  line-height: 1.65;
}

.prose-content {
  color: var(--text-secondary);
  line-height: 1.75;
}

.trust-badge-item {
  border-radius: 4px;
}

.product-detail-media {
  border-radius: 8px;
  overflow: hidden;
}

.product-detail-gallery-thumb {
  border-radius: 4px;
}

.boutique-layout .product-card, .boutique-layout .product-card-boutique {
  background: #fff;
}

.price {
  font-family: var(--font-sans);
  letter-spacing: .01em;
}

.footer-accent-bar {
  height: 2px;
}

.faq-item {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
}

.faq-question {
  letter-spacing: -.005em;
  line-height: 1.3;
}

.section-header p {
  max-width: 52ch;
  margin: 0 auto;
  font-size: 1.02rem;
  line-height: 1.7;
}

.section-header-split > div:last-child p {
  max-width: none;
  margin: 0;
}

.boutique-layout aside.boutique-filters {
  border-radius: 8px;
}

@media (min-width: 961px) {
  .nav-logo {
    max-height: 46px;
  }
}

@media (max-width: 640px) {
  .section-header {
    margin-bottom: 2rem;
  }

  .section-header h2 {
    letter-spacing: -.015em;
  }

  .hero-subtitle:before, .hero-subtitle:after {
    width: 20px;
  }
}

:root {
  --bg-primary: #eee3d7;
  --bg-secondary: #fffcf7eb;
  --bg-tertiary: #e4d7ca;
  --surface-strong: #fffaf4;
  --surface-muted: #fff8f0c2;
  --surface-dark: #150d0c;
  --surface-dark-soft: #201210;
  --text-primary: #1b120d;
  --text-secondary: #1b120db3;
  --accent: #7a0000;
  --accent-hover: #5f0000;
  --border-light: #3c291d1a;
  --shadow-soft: 0 20px 60px #35221914;
  --shadow-medium: 0 28px 80px #2d1c151f;
  --radius-panel: 18px;
  --radius-card: 14px;
  --radius-tight: 8px;
}

body {
  color: var(--text-primary);
  background: radial-gradient(circle at 0 0, #7a00000f, #0000 26%), radial-gradient(circle at 85% 10%, #baa08924, #0000 22%), linear-gradient(#f6eee6 0%, #eee3d7 46%, #eadfd3 100%);
}

body:before {
  content: "";
  pointer-events: none;
  opacity: .38;
  mix-blend-mode: multiply;
  z-index: -1;
  background: linear-gradient(#ffffff1a, #ffffff1a), repeating-linear-gradient(90deg, #7a000004 0 1px, #0000 1px 120px);
  position: fixed;
  inset: 0;
}

.container {
  max-width: 1320px;
}

.section {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
}

.glass-panel {
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-soft);
  -webkit-backdrop-filter: blur(18px);
  background: linear-gradient(#fffcf7d6, #f5ebe0e6);
  border: 1px solid #3c291d14;
}

.btn-primary, .btn-secondary {
  letter-spacing: .18em;
  border-radius: 999px;
  padding: .95rem 1.55rem;
  font-size: .78rem;
}

.btn-primary {
  background: linear-gradient(135deg, #5c0000 0%, #7a0000 52%, #962020 100%);
  box-shadow: 0 16px 34px #7a00002e;
}

.btn-primary:hover {
  background: linear-gradient(135deg, #4f0000 0%, #700000 55%, #861616 100%);
  transform: translateY(-1px);
  box-shadow: 0 22px 42px #7a000038;
}

.btn-secondary {
  background: #fffdf9b8;
  border-color: #3c291d29;
}

.btn-secondary:hover {
  background: #fffbf6f2;
  border-color: #3c291d47;
  transform: translateY(-1px);
}

.navbar {
  -webkit-backdrop-filter: blur(18px);
  background: #f6eee6e6;
  border-bottom-color: #3c291d14;
  box-shadow: 0 8px 30px #3522190d;
}

.nav-announcement {
  background: linear-gradient(90deg, #290808 0%, #5d0e0e 22%, #7a0000 50%, #5d0e0e 78%, #290808 100%);
  border-bottom-color: #fff1e81f;
}

.nav-content {
  min-height: 5.25rem;
}

.section-kicker {
  color: color-mix(in srgb, var(--accent) 84%, #4e0f0f 16%);
  letter-spacing: .26em;
  gap: .9rem;
  font-size: .7rem;
}

.section-kicker:before {
  opacity: .9;
  background: linear-gradient(90deg, #0000 0%, currentColor 38% 100%);
  width: 42px;
  height: 1px;
}

.section-header {
  margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.section-header h2, .page-content h1, .product-detail-info h1, .services-spotlight h2, .checkout-header h1, .checkout-empty-state h1, .checkout-confirmation h1 {
  letter-spacing: -.03em;
  line-height: .98;
}

.section-header h2 {
  font-size: clamp(2.6rem, 4.8vw, 4.8rem);
}

.section-header p {
  color: #1b120dad;
}

.collections {
  background: radial-gradient(circle at 0 0, #7a00000f, #0000 32%), linear-gradient(#fffcf7e6 0%, #f5ebe0f0 100%);
}

.product-card {
  border-radius: var(--radius-panel);
  box-shadow: var(--shadow-soft);
  background: linear-gradient(#fffdf9f0 0%, #f4eadffa 100%);
  border-color: #3c291d14;
}

.product-card:hover {
  box-shadow: var(--shadow-medium);
  transform: translateY(-3px);
}

.product-card-media {
  background: linear-gradient(#1b120d05, #1b120d1a), #1d140f08;
  height: min(320px, 52vw);
}

.product-card-image {
  transition: transform .6s cubic-bezier(.16, 1, .3, 1);
}

.product-card:hover .product-card-image {
  transform: scale(1.035);
}

.product-collection-badge, .product-meta span, .service-pill, .product-badge {
  border-radius: 999px;
}

.product-collection-badge {
  background: #fffaf4e0;
  padding: .4rem .75rem;
  box-shadow: 0 10px 24px #1b120d14;
}

.product-info {
  padding: 1.55rem 1.55rem 1.7rem;
}

.product-info h3 {
  letter-spacing: -.02em;
  font-size: 1.18rem;
}

.collections-footer {
  border-radius: var(--radius-panel);
  background: radial-gradient(circle at 15% 20%, #ffffff1f, #0000 24%), linear-gradient(135deg, #320606 0%, #5a0909 38%, #7a0000 72%, #450808 100%);
  padding: 1.4rem 1.55rem;
  box-shadow: 0 30px 60px #4c060638;
}

.services-spotlight {
  background: radial-gradient(circle at 82% 28%, #7a000012, #0000 28%), linear-gradient(#f3e9df 0%, #e8ddd0 100%);
}

.services-panel {
  background: linear-gradient(120deg, #110a0afa, #1b0f0eeb), #150d0c;
  border-radius: 30px;
  box-shadow: 0 34px 90px #1f121038;
}

.services-visual:after {
  content: "";
  background: linear-gradient(90deg, #130b0a0a 0%, #130b0a73 100%), linear-gradient(#7a000014, #00000026);
  position: absolute;
  inset: 0;
}

.services-content {
  padding: clamp(2.4rem, 4.5vw, 4.4rem);
}

.services-stats div {
  background: #fff7ec12;
  border-color: #fff7ec1f;
  border-radius: 20px;
}

.home-testimonials {
  background: radial-gradient(circle at 0 0, #7a000038, #0000 20%), radial-gradient(circle at 78% 18%, #fff7ec0f, #0000 18%), linear-gradient(#130c0b 0%, #1a0f0e 50%, #120c0b 100%);
  position: relative;
}

.home-testimonials:before {
  content: "";
  pointer-events: none;
  opacity: .22;
  background: linear-gradient(#ffffff06, #ffffff06), repeating-linear-gradient(90deg, #ffffff08 0 1px, #0000 1px 140px);
  position: absolute;
  inset: 0;
}

.testimonial-card {
  -webkit-backdrop-filter: blur(12px);
  background: linear-gradient(#fff9f114, #fff9f10a);
  border-color: #fff9f11a;
  border-radius: 24px;
}

.testimonial-card p {
  font-size: .98rem;
  line-height: 1.7;
}

.home-contact-block {
  background: radial-gradient(circle at 84% 18%, #7a00000f, #0000 22%), linear-gradient(#f4ebe2 0%, #ecdfd2 100%);
}

.home-contact-cta {
  width: min(1180px, 100%);
  max-width: none;
  box-shadow: var(--shadow-medium);
  background: linear-gradient(135deg, #fffcf7f5 0%, #f4eadff5 100%);
  border: 1px solid #3c291d14;
  border-left: 0;
  border-radius: 28px;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, .75fr);
  gap: 2rem 3rem;
  margin: 0;
  padding: clamp(2.2rem, 4vw, 3.4rem);
  display: grid;
  position: relative;
  overflow: hidden;
}

.home-contact-cta-main {
  gap: 1.5rem;
  min-width: 0;
  display: grid;
}

.home-contact-primary-actions {
  flex-wrap: wrap;
  gap: .85rem;
  display: flex;
}

.home-contact-primary-actions .btn-primary, .home-contact-primary-actions .btn-secondary {
  text-align: center;
  min-width: min(100%, 14.5rem);
}

.home-contact-cta-text h2 {
  letter-spacing: -.02em;
  margin: .35rem 0 .75rem;
  font-size: clamp(1.45rem, 2.6vw, 2rem);
  line-height: 1.12;
}

.home-contact-cta-text p {
  color: #1b120db8;
  max-width: 52ch;
  margin: 0;
  font-size: .98rem;
  line-height: 1.75;
}

.home-contact-side-intro {
  gap: .55rem;
  display: grid;
}

.home-contact-side-kicker {
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #1b120d9e;
  font-size: .72rem;
  font-weight: 700;
}

.home-contact-side-intro p {
  color: #1b120db8;
  margin: 0;
  font-size: .96rem;
  line-height: 1.7;
}

.home-contact-cta-channels {
  flex-direction: column;
  align-self: stretch;
  gap: .85rem;
  display: flex;
}

.home-contact-cta:before {
  content: "";
  background: linear-gradient(#450808 0%, #7a0000 58%, #bd6262 100%);
  border-radius: 999px;
  width: 4px;
  position: absolute;
  top: 1.75rem;
  bottom: 1.75rem;
  left: 0;
}

.home-contact-cta-side {
  align-content: start;
  gap: 1.1rem;
  display: grid;
}

.home-contact-cta-actions {
  grid-area: auto;
  justify-content: flex-start;
  align-items: stretch;
  display: flex;
}

.home-contact-cta-actions .home-contact-whatsapp {
  text-align: center;
  letter-spacing: .12em;
  text-transform: uppercase;
  white-space: normal;
  border-radius: 999px;
  width: 100%;
  padding: .95rem 1.1rem;
  font-size: .78rem;
  font-weight: 800;
  line-height: 1.25;
}

.home-contact-channel {
  color: inherit;
  background: #fff9f1db;
  border: 1px solid #3c291d14;
  border-radius: 999px;
  align-items: center;
  gap: .65rem;
  padding: .7rem .85rem;
  text-decoration: none;
  transition: transform .15s, box-shadow .15s, border-color .15s;
  display: flex;
  box-shadow: 0 10px 26px #2216100f;
}

.home-contact-channel:hover {
  border-color: #7a00002e;
  transform: translateY(-1px);
  box-shadow: 0 14px 34px #2216101a;
}

.home-contact-channel-icon {
  color: #7a0000;
  background: #7a00000d;
  border-radius: 999px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 38px;
  height: 38px;
  display: flex;
}

.home-contact-channel-label {
  letter-spacing: .01em;
  font-size: .92rem;
  font-weight: 600;
}

.home-contact-form {
  box-shadow: none;
  background: none;
  border: 0;
  flex-direction: column;
  gap: .95rem;
  padding: 0;
  display: flex;
}

.home-contact-form .contact-form-grid {
  gap: .95rem;
}

.home-contact-form .contact-form-field {
  gap: .4rem;
}

@media (max-width: 560px) {
  .home-contact-form .contact-form-grid {
    grid-template-columns: 1fr;
  }
}

.contact-form--compact .contact-form-field span {
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #1b120d9e;
  font-size: .7rem;
}

@media (max-width: 900px) {
  .home-contact-cta {
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }

  .home-contact-cta:before {
    width: auto;
    height: 4px;
    inset: 0 1.25rem auto;
  }

  .home-contact-primary-actions {
    flex-direction: column;
    align-items: stretch;
  }
}

.contact-form--compact input, .contact-form--compact textarea {
  background: #fffdf9eb;
  border: 1px solid #3c291d1a;
  border-radius: 18px;
  padding: .9rem 1rem;
  box-shadow: inset 0 1px #ffffffb3;
}

.contact-form--compact textarea {
  min-height: 7rem;
}

.contact-form--compact input::placeholder, .contact-form--compact textarea::placeholder {
  color: #1b120d6b;
}

.contact-form-submit-compact {
  width: fit-content;
  min-width: 15rem;
}

.page-content {
  position: relative;
}

.page-content:before {
  content: "";
  pointer-events: none;
  background: radial-gradient(circle at 14% 24%, #7a000014, #0000 26%), linear-gradient(#ffffff80, #0000 100%);
  height: 18rem;
  position: absolute;
  inset: 0 0 auto;
}

.page-content > .container {
  z-index: 1;
  position: relative;
}

.page-content h1 {
  margin-top: 4rem;
  margin-bottom: 1.25rem;
  font-size: clamp(2.7rem, 5.4vw, 5.3rem);
}

.page-content .services-page-hero h1 {
  margin-bottom: .65rem;
  font-size: clamp(1.95rem, 5.2vw, 3.05rem);
  line-height: 1.08;
}

.page-content h2 {
  letter-spacing: -.02em;
  margin-top: 2.2rem;
  margin-bottom: .8rem;
  font-size: clamp(1.28rem, 2vw, 1.65rem);
}

.page-content p, .prose-content li, .faq-accordion-panel, .product-detail-desc, .contact-block p {
  font-size: .98rem;
  line-height: 1.82;
}

.page-content .container.prose-content, .faq-page .container, .contact-page > .container {
  box-shadow: var(--shadow-soft);
  background: linear-gradient(#fffcf7cc, #f6ede3f0);
  border: 1px solid #3c291d14;
  border-radius: 30px;
  padding: clamp(1.45rem, 3vw, 2.4rem);
}

.page-content .container.prose-content.a-propos-page {
  margin-top: clamp(1rem, 2.6vw, 1.9rem);
}

.faq-page-title {
  margin-bottom: .35rem;
}

.faq-accordion {
  margin-top: 1.6rem;
}

.faq-accordion-item {
  background: #fffcf7c2;
  border: 1px solid #3c291d14;
  border-radius: 18px;
}

.faq-accordion-trigger {
  padding: 1.15rem 1.2rem;
}

.faq-accordion-trigger:hover, .faq-accordion-trigger:focus-visible {
  background: #7a000009;
}

.contact-page-grid {
  gap: 1.8rem;
  margin-top: 2rem;
}

.contact-page-aside, .contact-form {
  border-radius: 24px;
  padding: 1.45rem 1.5rem;
}

.contact-form {
  background: linear-gradient(#fffdf9eb, #f4eadff5);
}

.contact-form-field input, .contact-form-field textarea, .boutique-filters input, .boutique-filters select, .checkout-form-grid input {
  background: #fffdf9f2;
  border-radius: 14px;
}

.contact-map-frame, .a-propos-team-image {
  box-shadow: var(--shadow-soft);
  border-radius: 24px;
}

.a-propos-story-grid {
  align-items: stretch;
  gap: 2.5rem;
}

.a-propos-team-figure {
  box-shadow: var(--shadow-soft);
  background: linear-gradient(#fffcf7e0, #f4eadff5);
  border: 1px solid #3c291d14;
  border-radius: 28px;
  padding: .9rem;
}

.product-detail-page {
  padding-top: calc(var(--page-top-offset) + 1rem + env(safe-area-inset-top, 0px));
}

.breadcrumb {
  text-transform: uppercase;
  letter-spacing: .16em;
  margin-bottom: 1.4rem;
  font-size: .78rem;
}

.product-detail {
  box-shadow: var(--shadow-medium);
  background: linear-gradient(#fffcf7e0, #f4eadffa);
  border: 1px solid #3c291d14;
  border-radius: 32px;
  gap: clamp(1.8rem, 4vw, 4rem);
  padding: clamp(1.4rem, 3vw, 2.2rem);
}

.product-detail-price {
  font-size: 1.8rem;
  font-weight: 700;
}

.product-detail-specs {
  border-top: 1px solid #3c291d14;
  gap: .45rem 1.4rem;
  padding-top: 1.1rem;
}

.product-detail-faq {
  border-top-color: #3c291d14;
  margin-top: 2.4rem;
  padding: 1.6rem 1.4rem 0;
}

.site-footer {
  color: #fff5ece0;
  background: radial-gradient(circle at 0 0, #7a000042, #0000 26%), linear-gradient(#140c0b 0%, #1b100f 100%);
  border-top-color: #fff5ec14;
}

.site-footer .footer-rubrics {
  background: #fff5ec08;
  border-bottom-color: #fff5ec14;
}

.site-footer .footer-rubrics-inner, .site-footer .footer-rubrics-item, .site-footer .footer-copyright, .site-footer .footer-tagline {
  color: #fff5eca3;
}

.site-footer .footer-tagline, .site-footer .footer-contact-link {
  color: #fff5ece0;
}

@media (min-width: 769px) {
  .site-footer .footer-nav-summary-label, .site-footer .footer-nav-link, .site-footer .footer-nav-link:hover {
    color: #fff;
  }
}

.site-footer .footer-social-icon, .site-footer .footer-nav-details, .site-footer .footer-inner-sheet {
  border-color: #fff5ec1a;
}

.site-footer .footer-social-icon {
  color: #fff5ecd1;
  background: #fff5ec0a;
}

.site-footer .footer-social-icon:hover {
  color: #fff;
  background: #fff5ec1f;
}

.site-footer .footer-bottom {
  background: #fff5ec05;
  border-top: 1px solid #fff5ec14;
}

@media (max-width: 960px) {
  .section {
    padding: 3.35rem 0;
  }

  .home-contact-cta {
    grid-template-columns: 1fr;
  }

  .services-panel, .product-detail, .page-content .container.prose-content, .faq-page .container, .contact-page > .container, .home-contact-cta {
    border-radius: 24px;
  }
}

@media (max-width: 640px) {
  .btn-primary, .btn-secondary {
    text-align: center;
    justify-content: center;
    width: 100%;
  }

  .product-card, .contact-page-aside, .contact-form, .faq-accordion-item {
    border-radius: 18px;
  }

  .page-content > .container, .faq-page .container, .contact-page > .container {
    padding: 1rem;
  }

  .home-contact-cta {
    padding: 1.45rem 1rem 1.35rem 1.2rem;
  }

  .home-faq-teaser .section-header h2 {
    max-width: 100%;
  }

  .home-contact-form {
    grid-template-columns: 1fr;
  }

  .home-contact-form .contact-form-field:nth-of-type(4) {
    grid-column: auto;
  }

  .contact-form-submit-compact {
    width: 100%;
    min-width: 0;
  }
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__05va2pw._.css.map*/