/* === VYNE+ Configurator 2 styles === */

/* Full-bleed background on the Configurator 2 page — bypass the theme's
   1400px .app cap and paint the warm beige edge-to-edge. */
body.is-configurator-2 {
	background: #f4ede0 !important;
}
body.is-configurator-2 .app {
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	background:
		radial-gradient(ellipse 50% 30% at 100% 100%, rgba(184, 146, 77, 0.10), transparent 70%),
		radial-gradient(ellipse 60% 40% at 0% 10%, rgba(31, 53, 34, 0.06), transparent 70%),
		#f4ede0 !important;
}
body.is-configurator-2 .cfg2 {
	width: 100%;
	min-height: 100vh;
	margin: 0;
	padding: 0;
}
/* Menu bar stays semi-translucent beige so it blends with the page bg. */
body.is-configurator-2 .menu-bar-outer {
	background: rgba(244, 237, 224, 0.92) !important;
}

/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("./0317ab65-e0a2-4487-83d5-31742103d0d6.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("./7a32f9d4-ce08-42e9-a3c9-43447e4a39c8.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("./5c878fd7-8bfc-47ff-a91d-9225faf6009c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("./f58af6f7-4151-4f7d-852c-7edd2cbe0a83.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("./55f20da4-0f31-4beb-b797-2ec55a3ec32a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("./0317ab65-e0a2-4487-83d5-31742103d0d6.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("./7a32f9d4-ce08-42e9-a3c9-43447e4a39c8.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("./5c878fd7-8bfc-47ff-a91d-9225faf6009c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("./f58af6f7-4151-4f7d-852c-7edd2cbe0a83.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("./55f20da4-0f31-4beb-b797-2ec55a3ec32a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("./0317ab65-e0a2-4487-83d5-31742103d0d6.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("./7a32f9d4-ce08-42e9-a3c9-43447e4a39c8.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("./5c878fd7-8bfc-47ff-a91d-9225faf6009c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("./f58af6f7-4151-4f7d-852c-7edd2cbe0a83.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("./55f20da4-0f31-4beb-b797-2ec55a3ec32a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./379f7400-c891-445b-b8b7-9d66b9a4230a.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./83f552a6-36e2-497f-ad54-6aefae5dcc3a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./668956d6-d361-40ac-bed1-4cdfdd1b86ae.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./78999cfb-1a20-491f-b517-eb3df0be14b2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./1b0a5a8e-97c4-4f5e-a883-109b28034983.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./379f7400-c891-445b-b8b7-9d66b9a4230a.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./83f552a6-36e2-497f-ad54-6aefae5dcc3a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./668956d6-d361-40ac-bed1-4cdfdd1b86ae.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./78999cfb-1a20-491f-b517-eb3df0be14b2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./1b0a5a8e-97c4-4f5e-a883-109b28034983.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./379f7400-c891-445b-b8b7-9d66b9a4230a.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./83f552a6-36e2-497f-ad54-6aefae5dcc3a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./668956d6-d361-40ac-bed1-4cdfdd1b86ae.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./78999cfb-1a20-491f-b517-eb3df0be14b2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./1b0a5a8e-97c4-4f5e-a883-109b28034983.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./379f7400-c891-445b-b8b7-9d66b9a4230a.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./83f552a6-36e2-497f-ad54-6aefae5dcc3a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./668956d6-d361-40ac-bed1-4cdfdd1b86ae.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./78999cfb-1a20-491f-b517-eb3df0be14b2.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./1b0a5a8e-97c4-4f5e-a883-109b28034983.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./ffaabfca-62a9-43f8-9b2d-b9d9d7917a1f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./9ef5589c-d0ea-48d9-a01a-a73f5c3596ef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./5e521a84-a85f-45b0-b769-ac7de9250af0.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./4da8cd96-ec58-4ba5-8b5d-6c18806ec482.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./022df7fc-1431-4373-8b45-ad7b3c6ffe51.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./209b26df-c815-4eaa-b28c-c798d72e7d7f.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("./0b64c0d0-ce48-4d4a-a6fc-8bdd358df4cc.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./ffaabfca-62a9-43f8-9b2d-b9d9d7917a1f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./9ef5589c-d0ea-48d9-a01a-a73f5c3596ef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./5e521a84-a85f-45b0-b769-ac7de9250af0.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./4da8cd96-ec58-4ba5-8b5d-6c18806ec482.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./022df7fc-1431-4373-8b45-ad7b3c6ffe51.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./209b26df-c815-4eaa-b28c-c798d72e7d7f.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("./0b64c0d0-ce48-4d4a-a6fc-8bdd358df4cc.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./ffaabfca-62a9-43f8-9b2d-b9d9d7917a1f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./9ef5589c-d0ea-48d9-a01a-a73f5c3596ef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./5e521a84-a85f-45b0-b769-ac7de9250af0.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./4da8cd96-ec58-4ba5-8b5d-6c18806ec482.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./022df7fc-1431-4373-8b45-ad7b3c6ffe51.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./209b26df-c815-4eaa-b28c-c798d72e7d7f.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./0b64c0d0-ce48-4d4a-a6fc-8bdd358df4cc.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./ffaabfca-62a9-43f8-9b2d-b9d9d7917a1f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./9ef5589c-d0ea-48d9-a01a-a73f5c3596ef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./5e521a84-a85f-45b0-b769-ac7de9250af0.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./4da8cd96-ec58-4ba5-8b5d-6c18806ec482.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./022df7fc-1431-4373-8b45-ad7b3c6ffe51.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./209b26df-c815-4eaa-b28c-c798d72e7d7f.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("./0b64c0d0-ce48-4d4a-a6fc-8bdd358df4cc.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./ffaabfca-62a9-43f8-9b2d-b9d9d7917a1f.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./9ef5589c-d0ea-48d9-a01a-a73f5c3596ef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./5e521a84-a85f-45b0-b769-ac7de9250af0.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./4da8cd96-ec58-4ba5-8b5d-6c18806ec482.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./022df7fc-1431-4373-8b45-ad7b3c6ffe51.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./209b26df-c815-4eaa-b28c-c798d72e7d7f.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("./0b64c0d0-ce48-4d4a-a6fc-8bdd358df4cc.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Pinyon Script';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./22a049ec-b543-43ad-bded-c3392dae329e.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Pinyon Script';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./8cc6e32a-f15d-482b-819d-a042d466d460.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, 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;
}
/* latin */
@font-face {
  font-family: 'Pinyon Script';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("./ccaec9ac-25a9-43b7-8560-ee98eb2347dd.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* --- scoped layout --- */

  .cfg2{
    --bg: #f4ede0;
    --bg-1: #ebe2d0;
    --bg-2: #e3d8c1;
    --bg-3: #d9ccb1;
    --paper: #faf5e9;
    --line: rgba(38, 30, 16, 0.12);
    --line-strong: rgba(38, 30, 16, 0.28);
    --gold: #b8924d;
    --gold-soft: #c9a661;
    --gold-deep: #8a6f33;
    --gold-bright: #d4ad5a;
    --green: #1f3522;
    --green-soft: #2d4d31;
    --green-mute: rgba(31, 53, 34, 0.7);
    --red: #b53a2a;
    --red-soft: #cf5949;
    --red-deep: #7a2418;
    --ink: #261e10;
    --ink-soft: #4a3f2a;
    --ink-mute: #7a6f5a;
    --serif: 'Cormorant Garamond', serif;
    --sans: 'Inter', sans-serif;
  }
  .cfg2 *{ box-sizing: border-box; margin: 0; padding: 0; }
  .cfg2, .cfg2{ background: var(--bg); color: var(--ink); font-family: var(--sans); font-weight: 300; -webkit-font-smoothing: antialiased; }
  .cfg2{
    background:
      radial-gradient(ellipse 50% 30% at 100% 100%, rgba(184, 146, 77, 0.10), transparent 70%),
      radial-gradient(ellipse 60% 40% at 0% 10%, rgba(31, 53, 34, 0.06), transparent 70%),
      var(--bg);
    min-height: 100vh;
  }
  .cfg2 ::selection{ background: var(--green); color: var(--paper); }

  /* === The pixel grid motif — borrowed straight off the bottle label === */
  .cfg2 .pixel-band{
    height: 16px;
    background-image:
      linear-gradient(90deg, var(--gold) 50%, transparent 50%),
      linear-gradient(0deg, var(--gold) 50%, transparent 50%);
    background-size: 8px 8px, 8px 8px;
    background-position: 0 0, 0 0;
    background-blend-mode: multiply;
    opacity: 0.55;
    mask-image: repeating-linear-gradient(90deg, #000 0 7px, transparent 7px 8px), repeating-linear-gradient(0deg, #000 0 7px, transparent 7px 8px);
    mask-composite: intersect;
    -webkit-mask-image: repeating-linear-gradient(90deg, #000 0 7px, transparent 7px 8px), repeating-linear-gradient(0deg, #000 0 7px, transparent 7px 8px);
    -webkit-mask-composite: source-in;
  }
  .cfg2 .pixel-grid-svg{ display: block; }
  .cfg2 .grid-divider{ width: 100%; height: 12px; background-repeat: repeat-x; background-position: center; background-size: 240px 12px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='12'><g fill='%23b8924d'><rect x='0' y='4' width='4' height='4'/><rect x='8' y='4' width='4' height='4'/><rect x='16' y='4' width='4' height='4'/><rect x='24' y='4' width='4' height='4'/><rect x='32' y='4' width='4' height='4'/><rect x='40' y='4' width='4' height='4'/><rect x='48' y='4' width='4' height='4'/><rect x='56' y='4' width='4' height='4'/><rect x='64' y='4' width='4' height='4'/><rect x='72' y='4' width='4' height='4'/><rect x='80' y='4' width='4' height='4'/><rect x='88' y='4' width='4' height='4'/><rect x='96' y='4' width='4' height='4'/><rect x='104' y='4' width='4' height='4'/><rect x='112' y='4' width='4' height='4'/><rect x='120' y='4' width='4' height='4'/><rect x='128' y='4' width='4' height='4'/><rect x='136' y='4' width='4' height='4'/><rect x='144' y='4' width='4' height='4'/><rect x='152' y='4' width='4' height='4'/><rect x='160' y='4' width='4' height='4'/><rect x='168' y='4' width='4' height='4'/><rect x='176' y='4' width='4' height='4'/><rect x='184' y='4' width='4' height='4'/><rect x='192' y='4' width='4' height='4'/><rect x='200' y='4' width='4' height='4'/><rect x='208' y='4' width='4' height='4'/><rect x='216' y='4' width='4' height='4'/><rect x='224' y='4' width='4' height='4'/><rect x='232' y='4' width='4' height='4'/></g></svg>"); }
  .cfg2 .grid-frame{
    position: absolute; inset: 0; pointer-events: none;
    --gf-color: var(--gold);
    background-image:
      url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='12'><g fill='%23b8924d'><rect x='0' y='0' width='3' height='3'/><rect x='6' y='0' width='3' height='3'/><rect x='12' y='0' width='3' height='3'/><rect x='18' y='0' width='3' height='3'/><rect x='24' y='0' width='3' height='3'/><rect x='30' y='0' width='3' height='3'/><rect x='36' y='0' width='3' height='3'/><rect x='42' y='0' width='3' height='3'/><rect x='48' y='0' width='3' height='3'/><rect x='54' y='0' width='3' height='3'/><rect x='60' y='0' width='3' height='3'/><rect x='66' y='0' width='3' height='3'/><rect x='72' y='0' width='3' height='3'/><rect x='0' y='6' width='3' height='3'/><rect x='12' y='6' width='3' height='3'/><rect x='24' y='6' width='3' height='3'/><rect x='36' y='6' width='3' height='3'/><rect x='48' y='6' width='3' height='3'/><rect x='60' y='6' width='3' height='3'/><rect x='72' y='6' width='3' height='3'/></g></svg>");
    background-repeat: repeat-x;
    background-position: top, bottom;
  }

  .cfg2 .topbar{
    display: flex; align-items: center; justify-content: space-between;
    padding: 22px 48px; border-bottom: 1px solid var(--line);
    position: sticky; top: 0; z-index: 50;
    background: rgba(244, 237, 224, 0.88); backdrop-filter: blur(12px);
  }
  .cfg2 .wordmark{ font-family: var(--sans); font-weight: 200; font-size: 22px; letter-spacing: 0.5em; color: var(--green); padding-left: 6px; }
  .cfg2 .wordmark .plus{ color: var(--gold); font-weight: 300; margin-left: -0.2em; }
  .cfg2 .topnav{ display: flex; gap: 32px; font-size: 12px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .topnav a{ color: inherit; text-decoration: none; transition: color 0.2s; cursor: pointer; }
  .cfg2 .topnav a:hover{ color: var(--green); }
  .cfg2 .topbar .right{ display: flex; align-items: center; gap: 24px; }
  .cfg2 .icon-btn{ width: 36px; height: 36px; border: 1px solid var(--line-strong); border-radius: 50%; display: grid; place-items: center; color: var(--ink-soft); background: transparent; cursor: pointer; transition: all 0.2s; }
  .cfg2 .icon-btn:hover{ border-color: var(--green); color: var(--green); }

  /* === Hero === */
  .cfg2 .hero{ padding: 56px 48px 0; text-align: center; position: relative; }
  .cfg2 .hero .eyebrow{ font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--ink-mute); display: inline-flex; align-items: center; gap: 16px; }
  .cfg2 .hero .eyebrow::before, .cfg2 .hero .eyebrow::after{ content: ''; width: 56px; height: 1px; background: var(--gold-deep); }
  .cfg2 .hero h1{
    font-family: var(--serif); font-weight: 300; font-style: italic;
    font-size: 84px; line-height: 1; letter-spacing: -0.01em;
    color: var(--green); margin: 16px 0 16px;
  }
  .cfg2 .hero h1 em{ font-style: normal; color: var(--gold); font-family: var(--sans); font-weight: 200; letter-spacing: 0.04em; font-size: 70px; vertical-align: 6px; }
  .cfg2 .hero .sub{ font-size: 14px; letter-spacing: 0.04em; color: var(--ink-soft); max-width: 600px; margin: 0 auto; line-height: 1.7; }
  .cfg2 .reviews{ display: inline-flex; align-items: center; gap: 10px; margin-top: 22px; font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .reviews .stars{ color: var(--gold); letter-spacing: 2px; font-size: 14px; }
  .cfg2 .hero-grid-band{ margin: 36px auto 0; max-width: 880px; }

  /* === Stepper === */
  .cfg2 .stepper{ display: flex; align-items: center; justify-content: center; gap: 0; padding: 36px 48px 16px; max-width: 1100px; margin: 0 auto; }
  .cfg2 .step-dot{ display: flex; flex-direction: column; align-items: center; gap: 10px; cursor: pointer; flex: 0 0 auto; min-width: 110px; }
  .cfg2 .step-dot .num{
    width: 42px; height: 42px; border-radius: 50%;
    display: grid; place-items: center;
    font-family: var(--serif); font-size: 16px; color: var(--ink-mute);
    transition: all 0.3s; background: var(--paper);
    border: 1px solid var(--line-strong);
  }
  .cfg2 .step-dot.done .num{ border-color: var(--gold); color: var(--gold-deep); }
  .cfg2 .step-dot.active .num{ border-color: var(--green); color: var(--paper); background: var(--green); box-shadow: 0 6px 20px rgba(31, 53, 34, 0.18); }
  .cfg2 .step-dot .lbl{ font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-mute); transition: color 0.2s; }
  .cfg2 .step-dot.active .lbl{ color: var(--green); }
  .cfg2 .step-dot.done .lbl{ color: var(--ink-soft); }
  .cfg2 .step-sep{ flex: 1 1 auto; max-width: 100px; height: 1px; background: var(--line-strong); margin: 0 8px 30px; }
  .cfg2 .step-sep.done{ background: var(--gold); }

  /* === Main layout === */
  .cfg2 .stage{ display: grid; grid-template-columns: 460px 1fr; gap: 0; max-width: 1320px; margin: 24px auto 64px; padding: 0 48px; align-items: start; }

  /* LEFT — bottle showcase */
  .cfg2 .showcase{
    position: sticky; top: 110px;
    background: var(--paper);
    border: 1px solid var(--line-strong);
    padding: 28px;
    display: flex; flex-direction: column;
  }
  .cfg2 .showcase .corner{ display: none; }

  .cfg2 .showcase-head{ display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 14px; margin-bottom: 14px; border-bottom: 1px solid var(--line); }
  .cfg2 .showcase-head .key{ font-size: 9px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .showcase-head .val{ font-size: 11px; letter-spacing: 0.2em; color: var(--green); font-family: var(--serif); font-style: italic; }

  .cfg2 .bottle-img-wrap{ position: relative; flex: 1; min-height: 460px; display: grid; place-items: center; overflow: hidden; }
  .cfg2 .bottle-frame{ position: relative; display: inline-block; line-height: 0; }
  .cfg2 .bottle-img-wrap img{ max-height: 560px; width: auto; max-width: 100%; box-shadow: 0 18px 40px rgba(31, 53, 34, 0.18); transition: filter 0.5s ease; }
  .cfg2 .bottle-frame.base-rose img{ filter: hue-rotate(-28deg) saturate(1.18) brightness(1.02); }
  .cfg2 .bottle-label-overlay{
    position: absolute;
    left: 33%; right: 33%;
    top: 61%; bottom: 24%;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center; color: #2a2521;
    padding: 0.6em 0.4em;
    pointer-events: none;
    opacity: 0; transition: opacity 0.35s ease;
    font-size: 10px; /* set by JS */
    line-height: 1.2;
  }
  .cfg2 .bottle-frame.closeup .bottle-label-overlay{
    left: 13.5%; right: 17%;
    top: 21.5%; bottom: 46.5%;
  }
  .cfg2 .bottle-label-overlay.has-content{ opacity: 1; }
  .cfg2 .bottle-label-overlay .wm{
    font-family: var(--sans); font-weight: 300;
    font-size: 0.9em; letter-spacing: 0.42em;
    color: #3a2f24; line-height: 1;
    padding-left: 0.42em;
  }
  .cfg2 .bottle-label-overlay .rule{
    width: 22%; height: 1px; background: #6e5a3d;
    margin: 0.35em auto 0.25em; opacity: 0.65;
  }
  .cfg2 .bottle-label-overlay .bottle-name{
    font-family: var(--serif); font-style: italic; font-weight: 500;
    font-size: 1.4em; line-height: 1.05; color: #3a2d1a;
    margin: 0 0 0.2em; max-width: 100%;
    word-break: break-word; flex-shrink: 0;
  }
  .cfg2 .bottle-label-overlay .lead{
    font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: 0.7em; line-height: 1.2; color: #5a4a35;
    margin-bottom: 0.15em; flex-shrink: 0;
  }
  .cfg2 .bottle-label-overlay .sound{
    font-family: var(--serif); font-style: italic; font-weight: 400;
    font-size: 1.15em; line-height: 1.1; color: #2a2118;
    word-break: break-word; max-width: 100%; flex-shrink: 0;
  }
  .cfg2 .bottle-label-overlay .duration{
    font-family: var(--serif); font-style: italic;
    font-size: 0.7em; color: #6e5a3d; margin-top: 0.15em; flex-shrink: 0;
  }
  .cfg2 .bottle-label-overlay .sep{
    width: 50%; height: 1px; background: #6e5a3d; opacity: 0.4;
    margin: 0.35em auto 0.25em; flex-shrink: 0;
  }
  .cfg2 .bottle-label-overlay .dedication{
    font-family: 'Pinyon Script', 'Cormorant Garamond', cursive;
    font-size: 1.3em; line-height: 1.1; color: #4a3a26;
    max-width: 100%; flex-shrink: 0;
  }
  .cfg2 .bottle-label-overlay .placeholder{
    color: #a89878; font-style: italic; font-family: var(--serif);
    letter-spacing: 0.08em;
  }
  .cfg2 .live-tag{ position: absolute; top: 8px; right: 8px; display: flex; align-items: center; gap: 8px; font-size: 9px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .live-tag::before{ content: ''; width: 6px; height: 6px; background: var(--red); box-shadow: 0 0 8px var(--red); animation: pulse 1.6s ease-in-out infinite; }
  @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

  .cfg2 .showcase-rule{ height: 1px; background: var(--line); margin: 14px 0; }

  .cfg2 .bottle-specs{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); margin: 0 0 14px; }
  .cfg2 .bottle-specs > div{ background: var(--paper); padding: 12px 6px; text-align: center; }
  .cfg2 .bottle-specs .k{ font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); display: block; margin-bottom: 4px; }
  .cfg2 .bottle-specs .v{ font-family: var(--serif); font-size: 16px; color: var(--green); font-style: italic; }

  .cfg2 .price-row{ display: flex; justify-content: space-between; align-items: baseline; font-size: 13px; color: var(--ink-soft); padding: 6px 0; }
  .cfg2 .price-row.start{ padding-bottom: 12px; }
  .cfg2 .price-row .lbl{ font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .price-row .val{ font-family: var(--serif); font-size: 18px; color: var(--green); font-style: italic; }
  .cfg2 .addons{ padding: 6px 0 4px; }
  .cfg2 .addon-row{ display: flex; justify-content: space-between; font-size: 12px; padding: 5px 0; color: var(--ink-soft); }
  .cfg2 .addon-row .name{ display: flex; align-items: center; gap: 8px; text-transform: lowercase; }
  .cfg2 .addon-row .name::before{ content: '+'; color: var(--gold-deep); }
  .cfg2 .addon-row .price{ color: var(--green); font-family: var(--serif); font-style: italic; }
  .cfg2 .total-row{
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 16px 0 18px; margin-top: 6px;
    border-top: 1px solid var(--gold-deep);
  }
  .cfg2 .total-row .lbl{ font-size: 11px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold-deep); }
  .cfg2 .total-row .val{ font-family: var(--serif); font-size: 38px; color: var(--green); font-style: italic; }
  .cfg2 .total-row .val .currency{ font-size: 18px; color: var(--gold); margin-right: 4px; vertical-align: top; line-height: 1.6; font-style: normal; }

  .cfg2 .cta{ width: 100%; padding: 18px 22px; background: var(--green); color: var(--paper); border: none; font-family: var(--sans); font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase; cursor: pointer; transition: all 0.2s; position: relative; }
  .cfg2 .cta:hover:not(:disabled){ background: var(--green-soft); box-shadow: 0 10px 30px rgba(31, 53, 34, 0.25); }
  .cfg2 .cta:disabled{ background: var(--bg-3); color: var(--ink-mute); cursor: not-allowed; }
  .cfg2 .cta .arrow{ margin-left: 10px; font-family: var(--serif); font-size: 16px; vertical-align: middle; }
  .cfg2 .cta-note{ text-align: center; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); margin-top: 12px; font-style: italic; }

  /* RIGHT — step panel */
  .cfg2 .panel{ padding: 0 0 0 56px; min-height: 720px; }
  .cfg2 .panel-head{ margin-bottom: 32px; padding-bottom: 26px; border-bottom: 1px solid var(--line); }
  .cfg2 .panel-head .kicker{ font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 14px; display: inline-flex; align-items: center; gap: 12px; }
  .cfg2 .panel-head .kicker::after{ content: ''; width: 28px; height: 1px; background: var(--gold-deep); }
  .cfg2 .panel-head h2{ font-family: var(--serif); font-weight: 300; font-style: italic; font-size: 56px; line-height: 1; color: var(--green); margin-bottom: 14px; }
  .cfg2 .panel-head p{ font-size: 14px; line-height: 1.7; color: var(--ink-soft); max-width: 580px; font-weight: 300; }
  .cfg2 .panel-head p em{ color: var(--gold-deep); font-style: italic; font-family: var(--serif); font-size: 16px; }

  .cfg2 .cards{ display: grid; gap: 14px; }
  .cfg2 .cards.cols-2{ grid-template-columns: 1fr 1fr; }
  .cfg2 .card{ background: var(--paper); border: 1px solid var(--line-strong); padding: 24px; cursor: pointer; position: relative; transition: all 0.25s; overflow: hidden; }
  .cfg2 .card:hover{ border-color: var(--gold-deep); transform: translateY(-1px); }
  .cfg2 .card.selected{ border-color: var(--green); background: var(--paper); box-shadow: 0 0 0 1px var(--green), 0 12px 32px rgba(31, 53, 34, 0.12); }
  .cfg2 .card.selected::before{ content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 3px; background: var(--green); }
  .cfg2 .card .head{ display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
  .cfg2 .card .ttl{ font-family: var(--serif); font-size: 26px; color: var(--green); line-height: 1.1; font-style: italic; }
  .cfg2 .card .meta{ font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-mute); margin-top: 6px; }
  .cfg2 .card .desc{ font-size: 13px; color: var(--ink-soft); line-height: 1.6; }
  .cfg2 .card .price-tag{
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--green); color: var(--paper);
    padding: 5px 11px; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 400;
  }
  .cfg2 .card ul{ list-style: none; padding: 0; margin: 4px 0 0; }
  .cfg2 .card ul li{ font-size: 13px; color: var(--ink-soft); line-height: 1.7; padding-left: 14px; position: relative; }
  .cfg2 .card ul li::before{ content: '—'; position: absolute; left: 0; top: 0; color: var(--gold); font-weight: 300; }

  /* SOUND step */
  .cfg2 .sound-cards{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
  .cfg2 .sound-card{ padding: 26px 22px; text-align: left; min-height: 170px; display: flex; flex-direction: column; justify-content: flex-end; }
  .cfg2 .sound-card .ic{ width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--gold-deep); display: grid; place-items: center; color: var(--gold-deep); margin-bottom: auto; transition: all 0.2s; }
  .cfg2 .sound-card.selected .ic{ border-color: var(--green); color: var(--green); background: rgba(31, 53, 34, 0.05); }
  .cfg2 .sound-card .ttl{ font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--green); margin-top: 16px; }
  .cfg2 .sound-card .desc{ font-size: 12px; color: var(--ink-mute); letter-spacing: 0.05em; margin-top: 4px; }

  .cfg2 .sound-detail{ margin-top: 18px; background: var(--paper); border: 1px solid var(--line-strong); border-top: 2px solid var(--gold-deep); padding: 24px 26px; }
  .cfg2 .sound-detail .lbl{ font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 12px; }
  .cfg2 .sound-input{ display: flex; gap: 10px; align-items: center; border-bottom: 1px solid var(--gold-deep); padding-bottom: 10px; }
  .cfg2 .sound-input input{ flex: 1; background: transparent; border: none; outline: none; color: var(--ink); font-family: var(--serif); font-size: 18px; font-style: italic; }
  .cfg2 .sound-input input::placeholder{ color: var(--ink-mute); }
  .cfg2 .sound-input button{ background: transparent; border: 1px solid var(--green); color: var(--green); padding: 7px 18px; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; cursor: pointer; font-family: var(--sans); transition: all 0.2s; }
  .cfg2 .sound-input button:hover{ background: var(--green); color: var(--paper); }

  .cfg2 .loaded-track{ display: flex; align-items: center; gap: 14px; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
  .cfg2 .loaded-track .thumb{ width: 52px; height: 52px; background: var(--green); flex-shrink: 0; display: grid; place-items: center; color: var(--paper); }
  .cfg2 .loaded-track .info{ flex: 1; }
  .cfg2 .loaded-track .t{ font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--green); }
  .cfg2 .loaded-track .a{ font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); margin-top: 2px; }
  .cfg2 .loaded-track .ok{ color: var(--gold-deep); font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; }

  .cfg2 .upload-zone{ border: 1px dashed var(--gold-deep); padding: 32px 14px; text-align: center; background: rgba(184, 146, 77, 0.04); }
  .cfg2 .upload-zone .b{ display: inline-block; padding: 11px 26px; border: 1px solid var(--green); color: var(--green); font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; cursor: pointer; transition: all 0.2s; }
  .cfg2 .upload-zone .b:hover{ background: var(--green); color: var(--paper); }
  .cfg2 .upload-zone .hint{ font-size: 11px; letter-spacing: 0.15em; color: var(--ink-mute); margin-top: 12px; }

  .cfg2 .record-zone{ text-align: center; padding: 24px 14px; }
  .cfg2 .record-btn{ display: inline-flex; align-items: center; gap: 10px; padding: 13px 30px; border-radius: 999px; border: 1px solid var(--red); background: transparent; color: var(--red-deep); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; cursor: pointer; font-family: var(--sans); transition: all 0.2s; }
  .cfg2 .record-btn.on{ background: var(--red); color: var(--paper); }
  .cfg2 .record-btn .dot{ width: 10px; height: 10px; background: var(--red); }
  .cfg2 .record-btn.on .dot{ background: var(--paper); animation: pulse 1s ease-in-out infinite; }

  /* Bottle-style equalizer waveform */
  .cfg2 .waveform{ display: flex; align-items: flex-end; gap: 3px; height: 80px; margin-top: 22px; padding: 0 4px; }
  .cfg2 .waveform .col{ flex: 1; display: flex; flex-direction: column-reverse; gap: 2px; }
  .cfg2 .waveform .col .px{ height: 6px; background: var(--gold); opacity: 0; transition: opacity 0.2s; }
  .cfg2 .waveform .col .px.on{ opacity: 0.85; }

  /* QR notice card (step 1) */
  .cfg2 .qr-notice{
    margin-top: 26px;
    display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: center;
    padding: 22px 26px;
    background: var(--paper);
    border: 1px solid var(--gold-deep);
    border-left: 3px solid var(--gold);
    position: relative;
  }
  .cfg2 .qr-notice .qr-block{
    width: 78px; height: 78px;
    background: #1f3522;
    padding: 7px;
    flex-shrink: 0;
  }
  .cfg2 .qr-notice .qr-pixels{
    width: 100%; height: 100%;
    display: grid; grid-template-columns: repeat(11, 1fr); grid-template-rows: repeat(11, 1fr);
    gap: 0;
  }
  .cfg2 .qr-notice .qr-pixels span{ background: transparent; }
  .cfg2 .qr-notice .qr-pixels span.on{ background: var(--paper); }
  .cfg2 .qr-notice .head{
    font-size: 10px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold-deep);
    margin-bottom: 6px;
  }
  .cfg2 .qr-notice .body{
    font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.5;
    color: var(--green);
  }
  .cfg2 .qr-notice .body b{ font-weight: 500; color: var(--ink); border-bottom: 1px solid var(--gold-deep); padding-bottom: 1px; font-style: normal; font-family: var(--sans); font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; margin: 0 2px; }

  /* Step 2 — delivery card */
  .cfg2 .delivery-card{
    margin-top: 36px;
    position: relative;
    background: linear-gradient(180deg, #1f3522 0%, #16271a 100%);
    color: var(--paper);
    padding: 26px 30px 24px;
    border: 1px solid var(--green);
    overflow: hidden;
  }
  .cfg2 .delivery-card::before{
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--gold) 30%, var(--gold-bright) 50%, var(--gold) 70%, transparent);
  }
  .cfg2 .delivery-card::after{
    content: ""; position: absolute; right: -50px; bottom: -50px; width: 220px; height: 220px;
    border-radius: 50%; background: radial-gradient(circle, rgba(212,170,82,0.18) 0%, transparent 65%);
    pointer-events: none;
  }
  .cfg2 .delivery-grid{ position: relative; display: grid; grid-template-columns: auto 1fr auto; gap: 22px; align-items: center; }
  .cfg2 .delivery-icon{
    width: 64px; height: 68px; border: 1px solid var(--gold);
    display: flex; flex-direction: column; flex-shrink: 0;
    background: rgba(250, 245, 233, 0.04);
  }
  .cfg2 .delivery-icon .di-top{
    background: var(--gold); color: var(--green);
    font-size: 8px; letter-spacing: 0.2em; text-transform: uppercase;
    font-family: var(--sans); font-weight: 600;
    text-align: center; padding: 3px 0 2px;
  }
  .cfg2 .delivery-icon .di-mid{
    flex: 1; display: grid; place-items: center;
    font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: 28px; color: var(--gold-bright); line-height: 1;
  }
  .cfg2 .delivery-icon .di-bot{
    text-align: center; font-size: 7px; letter-spacing: 0.18em; text-transform: uppercase;
    font-family: var(--sans); color: var(--gold); padding-bottom: 3px;
  }
  .cfg2 .delivery-text .eyebrow{
    font-size: 9px; letter-spacing: 0.4em; text-transform: uppercase;
    color: var(--gold-bright); margin-bottom: 6px;
  }
  .cfg2 .delivery-text .date{
    font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: 30px; line-height: 1.05; color: var(--paper);
  }
  .cfg2 .delivery-text .date .placeholder{ color: rgba(250, 245, 233, 0.4); font-size: 22px; }
  .cfg2 .delivery-text .breakdown{
    font-size: 11px; color: rgba(250, 245, 233, 0.65);
    margin-top: 10px; line-height: 1.5; letter-spacing: 0.02em;
  }
  .cfg2 .delivery-text .breakdown b{ color: var(--gold-bright); font-weight: 500; font-style: italic; font-family: var(--serif); font-size: 13px; }
  .cfg2 .delivery-text .breakdown .plus{ color: var(--gold); margin: 0 6px; font-weight: 300; }
  .cfg2 .delivery-aside{
    text-align: right; padding-left: 18px; border-left: 1px solid rgba(212, 170, 82, 0.3);
    align-self: stretch; display: flex; flex-direction: column; justify-content: center; gap: 4px;
  }
  .cfg2 .delivery-aside .ttl{ font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); }
  .cfg2 .delivery-aside .val{ font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--paper); }
  .cfg2 .delivery-aside .sub{ font-size: 10px; color: rgba(250, 245, 233, 0.55); letter-spacing: 0.05em; font-style: italic; font-family: var(--serif); }

  @media (max-width: 720px) {
    .cfg2 .delivery-grid{ grid-template-columns: auto 1fr; }
    .cfg2 .delivery-aside{ grid-column: 1 / -1; padding-left: 0; padding-top: 14px; margin-top: 14px; border-left: none; border-top: 1px solid rgba(212, 170, 82, 0.3); text-align: left; }
  }

  .cfg2 .or-divider{
    display: flex; align-items: center; gap: 18px;
    margin: 30px 0 14px;
  }
  .cfg2 .or-divider .ln{ flex: 1; height: 1px; background: var(--line-strong); }
  .cfg2 .or-divider .word{
    font-family: var(--sans); font-weight: 500;
    font-size: 11px; letter-spacing: 0.5em;
    color: var(--gold-deep); text-transform: uppercase;
    padding: 4px 14px;
    border: 1px solid var(--gold-deep);
    background: var(--paper);
  }

  /* Step 2 redesign: clearer preset vs custom split */
  .cfg2 .duration-section{ margin-top: 8px; }
  .cfg2 .duration-section-label{
    display: flex; align-items: center; gap: 14px;
    font-size: 11px; letter-spacing: 0.35em; text-transform: uppercase;
    color: var(--gold-deep); font-weight: 500;
    margin-bottom: 18px;
  }
  .cfg2 .duration-section-label .lbl-num{
    display: inline-grid; place-items: center;
    width: 26px; height: 26px; border-radius: 50%;
    border: 1px solid var(--gold-deep);
    font-family: var(--serif); font-style: italic; font-size: 14px;
    color: var(--gold-deep); letter-spacing: 0;
  }
  .cfg2 .duration-section-label .lbl-rule{ flex: 1; height: 1px; background: var(--line-strong); }
  .cfg2 .timeline-hint{
    text-align: center; font-family: var(--serif); font-style: italic;
    font-size: 14px; color: var(--ink-mute); margin: 28px 0 6px;
  }
  .cfg2 .timeline-hint::before{ content: '↑ '; font-style: normal; color: var(--gold-deep); }
  /* Pulse animation to draw attention to unselected stops */
  .cfg2 .tl-stop:not(.active) .tl-dot{
    animation: tl-pulse 2.4s ease-in-out infinite;
  }
  @keyframes tl-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(184, 146, 77, 0.0); }
    50% { box-shadow: 0 0 0 8px rgba(184, 146, 77, 0.18); }
  }
  .cfg2 .custom-toggle{
    display: inline-flex; align-items: center; gap: 10px;
    background: transparent; border: 1px solid var(--gold-deep);
    color: var(--gold-deep); padding: 12px 20px; cursor: pointer;
    font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
    font-family: var(--sans); transition: all 0.2s; margin-bottom: 18px;
  }
  .cfg2 .custom-toggle:hover, .cfg2 .custom-toggle.open{ background: var(--green); border-color: var(--green); color: var(--paper); }
  .cfg2 .custom-toggle .ctgl-icon{ font-family: var(--serif); font-size: 18px; line-height: 1; transition: transform 0.25s; }
  .cfg2 .custom-toggle.open .ctgl-icon{ transform: rotate(45deg); }

  /* DURATION — premium / custom */
  .cfg2 .tier-divider{ display: flex; align-items: center; gap: 16px; margin: 30px 0 16px; }
  .cfg2 .tier-divider .line{ flex: 1; height: 1px; background: var(--gold-deep); }
  .cfg2 .tier-divider .lbl{ font-size: 10px; letter-spacing: 0.5em; text-transform: uppercase; color: var(--gold-deep); }

  .cfg2 .card.premium{ background: var(--green); border-color: var(--green); color: var(--paper); }
  .cfg2 .card.premium .ttl{ color: var(--paper); }
  .cfg2 .card.premium .meta{ color: var(--gold-bright); }
  .cfg2 .card.premium .desc, .cfg2 .card.premium ul li{ color: rgba(250, 245, 233, 0.78); }
  .cfg2 .card.premium ul li::before{ background: var(--gold-bright); }
  .cfg2 .card.premium .price-tag{ background: var(--gold); color: var(--green); }
  .cfg2 .card.premium .stamp{ position: absolute; top: 14px; right: 14px; font-size: 9px; letter-spacing: 0.3em; color: var(--gold-bright); border: 1px solid var(--gold-bright); padding: 3px 9px; }

  /* Step 2 timeline */
  .cfg2 .timeline{ padding: 16px 28px 0; }
  .cfg2 .tl-readout{ text-align: center; font-family: var(--serif); font-style: italic; color: var(--gold-deep); margin-bottom: 22px; min-height: 32px; }
  .cfg2 .tl-readout .tl-hrs{ font-size: 28px; color: var(--green); }
  .cfg2 .tl-readout .tl-weeks{ font-size: 20px; color: var(--gold-deep); margin-left: 6px; }
  .cfg2 .tl-readout .tl-pick{ font-size: 16px; color: var(--ink-mute); font-family: var(--serif); font-style: italic; margin-bottom: 6px; }
  .cfg2 .tl-track{ position: relative; height: 3px; background: var(--bg-3); margin: 0 14px; }
  .cfg2 .tl-fill{ position: absolute; top: 0; left: 0; height: 100%; background: var(--gold); transition: width 0.35s ease; }
  .cfg2 .tl-stop{
    position: absolute; top: 50%; transform: translate(-50%, -50%);
    width: 44px; height: 44px; border-radius: 50%;
    background: transparent; border: none; cursor: pointer; padding: 0;
    display: grid; place-items: center;
  }
  /* steady ring to telegraph clickability — only when none are selected yet */
  .cfg2 .timeline.no-selection .tl-stop::before{
    content: ""; position: absolute; inset: 4px; border-radius: 50%;
    border: 1.5px solid rgba(31, 53, 34, 0.22);
    background: rgba(31, 53, 34, 0.04);
    pointer-events: none;
  }
  .cfg2 .tl-stop .tl-dot{
    position: relative;
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--paper);
    border: 2.5px solid var(--gold-deep);
    box-shadow: 0 2px 6px rgba(31, 53, 34, 0.18), inset 0 0 0 2px var(--paper);
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
  }
  /* inner gold pip — the "tap me" affordance */
  .cfg2 .tl-stop .tl-dot::after{
    content: ""; position: absolute; inset: 0; margin: auto;
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--gold-deep);
    transition: all 0.2s ease;
  }
  .cfg2 .tl-stop:hover .tl-dot{
    transform: scale(1.18);
    border-color: var(--green);
    box-shadow: 0 0 0 6px rgba(31, 53, 34, 0.10), 0 4px 12px rgba(31, 53, 34, 0.22);
  }
  .cfg2 .tl-stop:hover .tl-dot::after{ background: var(--green); transform: scale(1.15); }
  .cfg2 .tl-stop:focus-visible{ outline: none; }
  .cfg2 .tl-stop:focus-visible .tl-dot{ box-shadow: 0 0 0 4px rgba(184, 146, 77, 0.4); }
  /* SELECTED — solid green filled disc with a white check */
  .cfg2 .tl-stop.active .tl-dot{
    width: 28px; height: 28px;
    background: var(--green);
    border-color: var(--green);
    border-width: 3px;
    box-shadow:
      0 0 0 5px var(--paper),
      0 0 0 7px var(--green),
      0 0 0 13px rgba(31, 53, 34, 0.14),
      0 6px 16px rgba(31, 53, 34, 0.32);
  }
  .cfg2 .tl-stop.active .tl-dot::after{
    width: 12px; height: 12px;
    background: transparent;
    /* checkmark via two-segment border */
    border: 0;
    background-image:
      linear-gradient(45deg, transparent 38%, var(--paper) 38% 50%, transparent 50%),
      linear-gradient(-45deg, transparent 48%, var(--paper) 48% 60%, transparent 60%);
    background-size: 100% 100%;
    background-repeat: no-repeat;
    transform: translateY(-1px);
  }
  .cfg2 .tl-labels{ position: relative; margin: 22px 14px 0; height: 44px; }
  .cfg2 .tl-lab{ position: absolute; transform: translateX(-50%); text-align: center; cursor: default; }
  .cfg2 .tl-lab-hrs{ font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-soft); transition: color 0.2s; }
  .cfg2 .tl-lab-sub{ font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); margin-top: 4px; }
  .cfg2 .tl-lab.active .tl-lab-hrs{ color: var(--green); }
  .cfg2 .tl-lab.active .tl-lab-sub{ color: var(--gold-deep); }
  .cfg2 .tl-desc{ margin: 18px auto 0; max-width: 540px; text-align: center; font-size: 13px; line-height: 1.7; color: var(--ink-soft); padding: 16px 20px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
  .cfg2 .tl-desc .tl-desc-tag{ display: inline-block; font-family: var(--serif); font-style: italic; color: var(--green); margin-right: 10px; padding-right: 10px; border-right: 1px solid var(--line); }
  .cfg2 .card.premium.selected{ box-shadow: 0 0 0 2px var(--gold), 0 14px 36px rgba(31, 53, 34, 0.3); }
  .cfg2 .card.premium.selected::before{ background: var(--gold); }

  .cfg2 .card.custom{
    background:
      repeating-linear-gradient(0deg, transparent 0 23px, rgba(31, 53, 34, 0.04) 23px 24px),
      repeating-linear-gradient(90deg, transparent 0 23px, rgba(31, 53, 34, 0.04) 23px 24px),
      var(--paper);
    border-style: dashed;
  }
  .cfg2 .custom-input-row{ display: flex; align-items: baseline; gap: 12px; margin: 12px 0 14px; flex-wrap: wrap; }
  .cfg2 .custom-input-row .lab{ font-family: var(--serif); font-size: 15px; color: var(--ink-soft); font-style: italic; }
  .cfg2 .unit-toggle{ display: inline-flex; border: 1px solid var(--line-strong); background: var(--paper); transform: translateY(3px); }
  .cfg2 .unit-toggle button{ background: transparent; border: none; padding: 6px 14px; font-family: var(--sans); font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-mute); cursor: pointer; transition: all 0.15s; }
  .cfg2 .unit-toggle button + button{ border-left: 1px solid var(--line); }
  .cfg2 .unit-toggle button.active{ background: var(--green); color: var(--paper); }
  .cfg2 .unit-toggle button:hover:not(.active){ color: var(--green); }

  .cfg2 .custom-tiers{ margin-top: 6px; padding: 14px 16px 12px; background: rgba(184, 146, 77, 0.06); border: 1px solid rgba(184, 146, 77, 0.4); }
  .cfg2 .custom-tiers .ct-head{ display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; }
  .cfg2 .custom-tiers .ct-head .lbl{ font-size: 9px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold-deep); }
  .cfg2 .custom-tiers .ct-head .now{ font-family: var(--serif); font-style: italic; font-size: 13px; color: var(--green); }
  .cfg2 .custom-tiers .ct-head .now b{ color: var(--gold-deep); font-weight: 500; }
  .cfg2 .ct-grid{ display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px; }
  .cfg2 .ct-cell{ background: var(--paper); border: 1px solid var(--line); padding: 8px 6px; text-align: center; transition: all 0.2s; }
  .cfg2 .ct-cell.active{ background: var(--green); border-color: var(--green); color: var(--paper); transform: translateY(-1px); box-shadow: 0 4px 10px rgba(31, 53, 34, 0.18); }
  .cfg2 .ct-cell .rng{ font-size: 8px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .ct-cell.active .rng{ color: rgba(250, 245, 233, 0.7); }
  .cfg2 .ct-cell .cost{ font-family: var(--serif); font-style: italic; font-size: 15px; color: var(--ink); margin-top: 3px; }
  .cfg2 .ct-cell.active .cost{ color: var(--gold-bright); }
  @media (max-width: 720px) { .cfg2 .ct-grid{ grid-template-columns: repeat(3, 1fr); } }
  .cfg2 .custom-input-row input{ width: 90px; background: transparent; border: none; border-bottom: 1px solid var(--green); color: var(--green); font-family: var(--serif); font-size: 22px; text-align: center; outline: none; padding: 4px 0; font-style: italic; }
  .cfg2 .custom-input-row input::-webkit-outer-spin-button, .cfg2 .custom-input-row input::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; }

  /* BASE swatches */
  .cfg2 .base-card .swatch{ width: 100%; height: 110px; margin-bottom: 16px; position: relative; overflow: hidden; z-index: 1; }
  .cfg2 .base-card .head, .cfg2 .base-card .desc, .cfg2 .base-card .badge{ position: relative; z-index: 1; }
  .cfg2 .base-card .soundbars{ position: absolute; right: 18px; bottom: 18px; width: 88px; height: 36px; display: flex; align-items: flex-end; gap: 2px; pointer-events: none; opacity: 0; transition: opacity 0.5s ease; z-index: 2; }
  .cfg2 .base-card.selected .soundbars{ opacity: 0.75; }
  .cfg2 .base-card .soundbars .bar{ flex: 1; background: var(--green); transform-origin: bottom; animation: sb-pulse 1.2s ease-in-out infinite; min-height: 2px; }
  @keyframes sb-pulse { 0%, 100% { transform: scaleY(0.3); } 50% { transform: scaleY(1); } }
  .cfg2 .base-card .badge{ display: inline-block; font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold-deep); border: 1px solid var(--gold-deep); padding: 3px 9px; margin-top: 10px; }

  /* LABEL step */
  .cfg2 /* premium-label sticker on step 4 thumbs */
  .label-thumb .price-sticker{
    position: absolute; top: -8px; left: -8px;
    background: var(--gold-deep); color: var(--paper);
    font-family: var(--sans); font-size: 10px; font-weight: 600;
    letter-spacing: 0.12em; padding: 6px 10px;
    box-shadow: 0 4px 10px rgba(31, 53, 34, 0.22);
    border: 1px solid var(--paper);
    transform: rotate(-6deg);
    z-index: 3;
    display: flex; align-items: baseline; gap: 3px;
  }
  .cfg2 .label-thumb .price-sticker .plus{ font-size: 9px; opacity: 0.85; }
  .cfg2 .label-thumb .price-sticker .cur{ font-family: var(--serif); font-style: italic; font-size: 11px; }
  .cfg2 .label-thumb .price-sticker.seasonal{ background: var(--red); }
  .cfg2 .label-thumb:hover .price-sticker{ transform: rotate(-3deg) scale(1.06); transition: transform 0.2s; }

  .cfg2 .label-tabs{ display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin-bottom: 22px; flex-wrap: wrap; }
  .cfg2 .label-tab{ padding: 12px 16px; font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-mute); cursor: pointer; border: none; background: none; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all 0.2s; font-family: var(--sans); position: relative; }
  .cfg2 .label-tab:hover{ color: var(--ink-soft); }
  .cfg2 .label-tab.active{ color: var(--green); border-bottom-color: var(--green); }
  .cfg2 .label-tab.seasonal{ color: var(--red); }
  .cfg2 .label-tab.seasonal .pip{ position: absolute; top: 4px; right: 0; font-size: 7px; letter-spacing: 0.15em; background: var(--red); color: var(--paper); padding: 1px 4px; }

  .cfg2 .label-grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
  .cfg2 .label-thumb{ aspect-ratio: 4.2/3; border: 1px solid var(--line-strong); position: relative; cursor: pointer; overflow: hidden; transition: all 0.25s; background: var(--paper); }
  .cfg2 .label-thumb:hover{ border-color: var(--gold-deep); transform: translateY(-2px); }
  .cfg2 .label-thumb.selected{ border-color: var(--green); box-shadow: 0 0 0 2px var(--green), 0 14px 28px rgba(31, 53, 34, 0.15); }
  .cfg2 .label-thumb .label-art{ position: absolute; inset: 0; }
  .cfg2 .label-thumb .label-name{ position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, var(--paper) 30%, transparent); padding: 14px 12px 10px; font-family: var(--serif); font-size: 12px; font-style: italic; color: var(--green); }
  .cfg2 .label-thumb .check{ position: absolute; top: 8px; right: 8px; width: 22px; height: 22px; background: var(--green); color: var(--paper); display: grid; place-items: center; font-size: 11px; opacity: 0; transition: opacity 0.2s; }
  .cfg2 .label-thumb.selected .check{ opacity: 1; }

  .cfg2 .form-fields{ margin-top: 30px; display: grid; gap: 22px; }
  .cfg2 .field label{ display: block; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 10px; }
  .cfg2 .req-pill, .cfg2 .opt-pill{
    display: inline-flex; align-items: center; gap: 4px;
    font-family: var(--sans); font-size: 9px; letter-spacing: 0.18em;
    text-transform: uppercase; padding: 2px 8px; border-radius: 999px;
    line-height: 1.4; margin-left: 8px; vertical-align: middle;
  }
  .cfg2 .req-pill{
    color: var(--green); background: rgba(31, 53, 34, 0.08); border: 1px solid rgba(31, 53, 34, 0.22);
  }
  .cfg2 .req-pill .star{ color: var(--red); font-size: 11px; line-height: 0; transform: translateY(1px); }
  .cfg2 .opt-pill{
    color: var(--ink-mute); background: transparent; border: 1px dashed rgba(120, 100, 70, 0.35);
    font-style: italic; letter-spacing: 0.14em;
  }
  .cfg2 .field-label-row{ display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
  .cfg2 .field-label-row .lbl-main{ display: flex; align-items: center; }
  .cfg2 .field-label-row .lbl-main span.txt{ font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .field-label-row .lbl-count{ font-family: var(--serif); font-style: italic; font-size: 11px; color: var(--ink-mute); letter-spacing: 0; text-transform: none; }
  .cfg2 .field input, .cfg2 .field textarea{ width: 100%; background: var(--paper); border: 1px solid var(--line-strong); padding: 14px 16px; color: var(--ink); font-family: var(--serif); font-size: 17px; font-style: italic; outline: none; transition: border-color 0.2s; resize: none; }
  .cfg2 .field textarea{ font-family: var(--sans); font-size: 14px; font-style: normal; line-height: 1.6; min-height: 88px; }
  .cfg2 .field input:focus, .cfg2 .field textarea:focus{ border-color: var(--green); }
  .cfg2 .field input::placeholder, .cfg2 .field textarea::placeholder{ color: var(--ink-mute); font-style: italic; }

  .cfg2 .base-card .swatch .glyph{ position: absolute; bottom: 12px; right: 14px; font-family: var(--serif); font-style: italic; font-size: 14px; letter-spacing: 0.3em; color: rgba(255,255,255,0.95); }
  .cfg2 .printed-preview{ margin-top: 14px; border: 1px solid var(--gold-deep); background: rgba(184, 146, 77, 0.08); padding: 18px 22px; }
  .cfg2 .printed-preview .head{ font-size: 9px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 8px; }
  .cfg2 .printed-preview .body{ font-family: var(--serif); font-style: italic; font-size: 17px; color: var(--green); line-height: 1.5; }
  .cfg2 .printed-preview .body .var{ color: var(--ink); border-bottom: 1px solid var(--gold-deep); padding: 0 3px; font-style: italic; }

  /* Step nav */
  .cfg2 .panel-nav{ display: flex; justify-content: space-between; align-items: center; margin-top: 38px; padding-top: 26px; border-top: 1px solid var(--line); }
  .cfg2 .nav-btn{ background: transparent; border: 1px solid var(--line-strong); color: var(--ink-soft); padding: 13px 28px; cursor: pointer; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; font-family: var(--sans); transition: all 0.2s; }
  .cfg2 .nav-btn:hover:not(:disabled){ border-color: var(--green); color: var(--green); }
  .cfg2 .nav-btn:disabled{ opacity: 0.4; cursor: not-allowed; }
  .cfg2 .nav-btn.primary{ background: var(--green); color: var(--paper); border-color: var(--green); }
  .cfg2 .nav-btn.primary:hover:not(:disabled){ background: var(--green-soft); border-color: var(--green-soft); }
  .cfg2 .nav-arrow{ font-family: var(--serif); font-size: 16px; margin: 0 8px; vertical-align: middle; }
  .cfg2 .progress-dots{ display: flex; align-items: center; gap: 6px; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .progress-dots .pdot{ width: 6px; height: 6px; border-radius: 50%; background: var(--bg-3); }
  .cfg2 .progress-dots .pdot.done{ background: var(--gold); }
  .cfg2 .progress-dots .pdot.current{ background: var(--green); box-shadow: 0 0 0 3px rgba(31, 53, 34, 0.12); }

  /* Defer overlay */
  .cfg2 .overlay{ position: fixed; inset: 0; background: rgba(38, 30, 16, 0.55); backdrop-filter: blur(8px); display: none; align-items: center; justify-content: center; z-index: 100; padding: 20px; overflow-y: auto; }
  .cfg2 .overlay.open{ display: flex; }
  .cfg2 .overlay-card{ background: var(--paper); border: 1px solid var(--line-strong); border-top: 2px solid var(--green); max-width: 520px; width: 100%; padding: 36px; position: relative; }
  .cfg2 .overlay-card h3{ font-family: var(--serif); font-style: italic; font-weight: 300; font-size: 34px; color: var(--green); margin-bottom: 12px; }
  .cfg2 .overlay-card p{ font-size: 13px; color: var(--ink-soft); line-height: 1.7; margin-bottom: 22px; }
  .cfg2 .overlay-actions{ display: flex; gap: 12px; justify-content: flex-end; }
  .cfg2 .overlay-close{ position: absolute; top: 16px; right: 16px; background: transparent; border: none; color: var(--ink-mute); cursor: pointer; font-size: 22px; }

  /* Preview overlay */
  .cfg2 .preview-card{ background: var(--paper); border: 1px solid var(--line-strong); border-top: 2px solid var(--green); max-width: 1080px; width: 100%; position: relative; margin: auto; }
  .cfg2 .preview-card .preview-head{ padding: 26px 36px 22px; border-bottom: 1px solid var(--line); display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; }
  .cfg2 .preview-card .preview-head .kicker{ font-size: 9px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 8px; }
  .cfg2 .preview-card .preview-head h3{ font-family: var(--serif); font-style: italic; font-weight: 300; font-size: 38px; color: var(--green); margin: 0; line-height: 1; }
  .cfg2 .preview-card .preview-head .bottle-no{ text-align: right; font-size: 9px; letter-spacing: 0.35em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .preview-card .preview-head .bottle-no .v{ display: block; margin-top: 6px; font-family: var(--serif); font-style: italic; font-size: 14px; letter-spacing: 0.2em; color: var(--green); text-transform: none; }
  .cfg2 .preview-body{ display: grid; grid-template-columns: 1fr 1.05fr; gap: 0; }
  .cfg2 .preview-label{ padding: 20px 18px 16px; background: var(--bg-2); border-right: 1px solid var(--line); display: flex; flex-direction: column; align-items: stretch; gap: 10px; min-height: 640px; }
  .cfg2 .pv-slideshow{ position: relative; flex: 1; display: flex; flex-direction: column; align-items: center; gap: 10px; min-height: 0; }
  .cfg2 .pv-stage{ position: relative; flex: 1; width: 100%; display: flex; align-items: center; justify-content: center; overflow: hidden; min-height: 480px; }
  .cfg2 .pv-bottle{ position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.4s ease; pointer-events: none; }
  .cfg2 .pv-bottle.active{ opacity: 1; pointer-events: auto; }
  .cfg2 .pv-bottle .bottle-frame{ position: relative; height: 100%; max-width: 100%; display: inline-block; line-height: 0; }
  .cfg2 .pv-bottle img{ height: 100%; max-height: 100%; width: auto; max-width: 100%; box-shadow: 0 14px 30px rgba(31, 53, 34, 0.18); display: block; transition: filter 0.5s ease; }
  .cfg2 .pv-bottle .bottle-label-overlay{ color: #2a2521; }
  .cfg2 .pv-bottle.full .bottle-label-overlay{ left: 33%; right: 33%; top: 61%; bottom: 24%; }
  .cfg2 .pv-bottle.close .bottle-label-overlay{ left: 13.5%; right: 17%; top: 21.5%; bottom: 46.5%; }

  .cfg2 .pv-nav{ position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(255, 255, 255, 0.6); background: rgba(255, 255, 255, 0.72); backdrop-filter: blur(6px); color: var(--ink); display: grid; place-items: center; cursor: pointer; transition: all 0.2s; font-size: 22px; font-family: var(--serif); z-index: 5; line-height: 1; padding-bottom: 3px; box-shadow: 0 4px 14px rgba(31, 53, 34, 0.18); }
  .cfg2 .pv-nav:hover{ background: var(--paper); color: var(--green); border-color: var(--green); }
  .cfg2 .pv-nav.prev{ left: 22px; }
  .cfg2 .pv-nav.next{ right: 22px; }
  .cfg2 .pv-dots{ display: flex; gap: 8px; align-items: center; justify-content: center; }
  .cfg2 .pv-dot{ width: 8px; height: 8px; border-radius: 50%; border: 1px solid var(--ink-mute); background: transparent; cursor: pointer; padding: 0; transition: all 0.2s; }
  .cfg2 .pv-dot.active{ background: var(--green); border-color: var(--green); transform: scale(1.2); }
  .cfg2 .pv-cap-text{ font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); text-align: center; }

  .cfg2 .preview-label-cap{ text-align: center; padding-top: 6px; border-top: 1px solid var(--line); width: 100%; }
  .cfg2 .preview-label-cap .ttl{ font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--green); }
  .cfg2 .preview-label-cap .sub{ font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); margin-top: 4px; }
  .cfg2 .preview-data{ padding: 28px 36px; display: flex; flex-direction: column; gap: 18px; }
  .cfg2 .pd-row{ display: grid; grid-template-columns: 110px 1fr; gap: 16px; align-items: baseline; padding-bottom: 14px; border-bottom: 1px dashed var(--line); }
  .cfg2 .pd-row:last-of-type{ border-bottom: none; padding-bottom: 0; }
  .cfg2 .pd-row .k{ font-size: 9px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-mute); }
  .cfg2 .pd-row .v{ font-family: var(--serif); font-size: 16px; color: var(--ink); line-height: 1.4; font-style: italic; }
  .cfg2 .pd-row .v .meta{ display: block; font-family: var(--sans); font-style: normal; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); margin-top: 4px; }
  .cfg2 .pd-row .v.empty{ color: var(--ink-mute); font-style: italic; opacity: 0.6; }
  .cfg2 .pd-totals{ margin-top: 6px; padding: 16px 20px; background: rgba(184, 146, 77, 0.08); border: 1px solid var(--gold-deep); display: flex; flex-direction: column; gap: 8px; }
  .cfg2 .pd-totals .ln{ display: flex; justify-content: space-between; align-items: baseline; font-size: 12px; color: var(--ink-soft); letter-spacing: 0.05em; }
  .cfg2 .pd-totals .ln .v{ font-family: var(--serif); font-style: italic; font-size: 14px; color: var(--ink); }
  .cfg2 .pd-totals .ln.tot{ border-top: 1px solid var(--gold-deep); padding-top: 10px; margin-top: 4px; font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--green); }
  .cfg2 .pd-totals .ln.tot .v{ font-family: var(--serif); font-style: italic; font-size: 26px; color: var(--green); }
  .cfg2 .pd-totals .ln.tot .v .currency{ font-size: 16px; color: var(--gold-deep); margin-right: 4px; vertical-align: top; }
  .cfg2 .preview-foot{ padding: 22px 36px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; gap: 12px; }
  .cfg2 .preview-foot .note{ font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); font-style: italic; }
  .cfg2 .preview-foot .actions{ display: flex; gap: 12px; }
  @media (max-width: 820px) {
    .cfg2 .preview-body{ grid-template-columns: 1fr; }
    .cfg2 .preview-label{ border-right: none; border-bottom: 1px solid var(--line); min-height: 320px; }
    .cfg2 .preview-card .preview-head{ flex-direction: column; }
    .cfg2 .preview-foot{ flex-direction: column-reverse; align-items: stretch; }
    .cfg2 .preview-foot .actions{ justify-content: flex-end; }
  }

  @media (max-width: 980px) {
    .cfg2 .stage{ grid-template-columns: 1fr; padding: 0 24px; }
    .cfg2 .panel{ padding-left: 0; margin-top: 32px; }
    .cfg2 .showcase{ position: static; }
    .cfg2 .hero h1{ font-size: 52px; }
    .cfg2 .stepper{ overflow-x: auto; justify-content: flex-start; padding: 24px; }
    .cfg2 .sound-cards, .cfg2 .cards.cols-2{ grid-template-columns: 1fr; }
  }
