        :root {
            --bg-top: #f3dce3;
            --bg-mid: #f7eeef;
            --bg-bottom: #f7f1e9;
            --glow-1: rgba(255, 255, 255, .55);
            --glow-2: rgba(247, 242, 217, .7);
            --glow-3: rgba(255, 255, 255, .30);
            --accent-soft: #f7f2d9;
            --accent-strong: #d8ca7a;
            --sage: #b9c7a8;
            --text: #171414;
            --muted: rgba(23, 20, 20, 0.68);
            --line: rgba(23, 20, 20, .08);
            --white: #ffffff;
            --shadow-soft: 0 20px 60px rgba(25, 20, 20, .06);
            --shadow-medium: 0 28px 90px rgba(25, 20, 20, .10);
            --shadow-card: 0 18px 34px rgba(25, 20, 20, .05);
            --container: 1380px;
            --transition: .38s cubic-bezier(.22, 1, .36, 1);
        }

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

        html {
            scroll-behavior: smooth;
        }

        body {
            font-family: "Bebas Neue", sans-serif;
            background:
                radial-gradient(circle at 8% 10%, var(--glow-1), transparent 18%),
                radial-gradient(circle at 92% 14%, var(--glow-2), transparent 20%),
                radial-gradient(circle at 70% 70%, var(--glow-3), transparent 22%),
                linear-gradient(180deg, var(--bg-top) 0%, var(--bg-mid) 40%, var(--bg-bottom) 100%);
            color: var(--text);
            overflow-x: hidden;
            -webkit-font-smoothing: antialiased;
            text-rendering: optimizeLegibility;
        }

        body.menu-open {
            overflow: hidden;
        }

        img {
            display: block;
            max-width: 100%;
        }

        a {
            text-decoration: none;
            color: inherit;
        }

        button,
        input {
            border: none;
            background: none;
            font: inherit;
            color: inherit;
        }

        button {
            cursor: pointer;
        }

        p,
        .body-copy,
        .meta-text {
            font-family: Arial, Helvetica, sans-serif;
        }

        .container {
            width: min(calc(100% - 48px), var(--container));
            margin: 0 auto;
        }

        .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 60px;
            padding: 0 30px;
            border-radius: 999px;
            font-size: .82rem;
            letter-spacing: .18em;
            text-transform: uppercase;
            transition:
                transform var(--transition),
                background var(--transition),
                border-color var(--transition),
                color var(--transition),
                box-shadow var(--transition);
        }

        .btn:hover {
            transform: translateY(-2px);
        }

        .btn-primary {
            background: var(--text);
            color: #fff;
            box-shadow: 0 18px 34px rgba(23, 20, 20, .12);
        }

        .btn-secondary {
            border: 1px solid rgba(23, 20, 20, .10);
            background: rgba(255, 255, 255, .82);
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
        }

        .product-hero {
            position: relative;
            padding: 110px 0 96px;
        }

        .product-layout {
            display: grid;
            grid-template-columns: minmax(0, 0.95fr) minmax(520px, 1.05fr);
            gap: 56px;
            align-items: start;
        }

        .product-copy {
            padding-top: 34px;
        }

        .product-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 14px;
            margin-bottom: 28px;
        }


        .product-story {
            margin: 10px 0 34px;
            padding: 38px;
            border-radius: 38px;
            background:
                linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .72));
            border: 1px solid rgba(255, 255, 255, .65);
            box-shadow:
                0 22px 60px rgba(25, 20, 20, .06),
                inset 0 1px 0 rgba(255, 255, 255, .75);
        }

        .story-intro h2,
        .experience-copy h2 {
            font-size: clamp(2.5rem, 3vw, 4rem);
            line-height: .96;
            letter-spacing: .04em;
            text-transform: uppercase;
            font-weight: 400;
            margin-bottom: 18px;
        }

        .story-intro p,
        .story-card p,
        .story-banner p,
        .experience-copy p,
        .experience-point span {
            font-family: Arial, Helvetica, sans-serif;
            color: rgba(23, 20, 20, .66);
            line-height: 1.9;
            font-size: 1.02rem;
        }

        .story-grid-refined {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 18px;
            margin-top: 30px;
        }

        .story-card {
            padding: 28px;
            border-radius: 28px;
            background:
                linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .78));
            border: 1px solid rgba(23, 20, 20, .05);
            box-shadow: 0 14px 36px rgba(25, 20, 20, .05);
        }

        .story-card-large {
            min-height: 250px;
        }

        .story-card-label {
            display: inline-block;
            margin-bottom: 14px;
            font-size: .68rem;
            letter-spacing: .20em;
            text-transform: uppercase;
            color: rgba(23, 20, 20, .45);
        }

        .story-card h3,
        .story-banner h3 {
            font-size: 2rem;
            line-height: .98;
            letter-spacing: .04em;
            text-transform: uppercase;
            font-weight: 400;
            margin-bottom: 14px;
        }

        .story-banner {
            margin-top: 18px;
            padding: 30px 32px;
            border-radius: 30px;
            background:
                radial-gradient(circle at top right, rgba(247, 242, 217, .9), transparent 26%),
                linear-gradient(180deg, rgba(239, 194, 232, 0.3), rgba(205, 237, 200, 0.3));
            border: 1px solid rgba(255, 177, 226, 0.224);
            box-shadow: 0 16px 40px rgba(25, 20, 20, .05);
        }

        .product-services-shell {
            position: relative;
            margin: 0 0 20px;
            padding: 30px;
            border-radius: 34px;
            background:
                radial-gradient(circle at 92% 8%, rgba(255, 255, 255, .92), transparent 26%),
                linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .84));
            border: 1px solid rgba(255, 255, 255, .82);
            box-shadow:
                0 24px 54px rgba(25, 20, 20, .07),
                inset 0 1px 0 rgba(255, 255, 255, .94);
            overflow: hidden;
        }

        .product-services-shell::before {
            content: "";
            position: absolute;
            inset: 0;
            background: linear-gradient(135deg, rgba(247, 242, 217, .22), rgba(255, 255, 255, 0) 28%);
            pointer-events: none;
        }

        .product-services-shell>* {
            position: relative;
            z-index: 1;
        }

        .product-assurances {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 14px;
            margin: 0;
        }

        .assurance-item {
            display: grid;
            grid-template-columns: 44px 1fr;
            gap: 14px;
            align-items: start;
            padding: 20px 18px;
            border-radius: 24px;
            background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(255, 255, 255, .90));
            border: 1px solid rgba(23, 20, 20, .08);
            box-shadow: 0 10px 24px rgba(25, 20, 20, .05);
            transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
        }

        .assurance-item:hover {
            transform: translateY(-2px);
            border-color: color-mix(in srgb, var(--accent-strong) 28%, rgba(23, 20, 20, .08));
            box-shadow: 0 16px 28px rgba(25, 20, 20, .08);
        }

        .assurance-icon {
            width: 44px;
            height: 44px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            background: color-mix(in srgb, var(--accent-soft) 55%, white);
            border: 1px solid color-mix(in srgb, var(--accent-strong) 18%, transparent);
            color: color-mix(in srgb, var(--text) 85%, var(--accent-strong));
        }

        .assurance-icon svg {
            width: 20px;
            height: 20px;
        }

        .assurance-item h3 {
            margin: 0 0 6px;
            font-size: 1.02rem;
            letter-spacing: .11em;
            text-transform: uppercase;
            line-height: 1.05;
            font-weight: 400;
            color: rgba(23, 20, 20, .9);
        }

        .assurance-item p {
            margin: 0;
            font-family: Arial, Helvetica, sans-serif;
            font-size: .94rem;
            line-height: 1.6;
            color: rgba(23, 20, 20, .68);
        }

        .product-notice {
            margin-top: 0;
            margin-bottom: 14px;
            padding: 24px 28px;
            border: 1px solid rgba(23, 20, 20, .08);
            box-shadow: 0 12px 26px rgba(25, 20, 20, .05);
        }

        .product-notice .story-banner-copy h3 {
            margin-bottom: 10px;
            font-size: 1.95rem;
            letter-spacing: .04em;
        }

        .product-allergenes {
            margin: 0;
            font-family: Arial, Helvetica, sans-serif;
            font-size: .94rem;
            line-height: 1.55;
            color: rgba(23, 20, 20, .74);
            text-transform: none;
            letter-spacing: 0;
        }

        .selector-card {
            border-radius: 34px;
            padding: 32px;
            background:
                linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(255, 255, 255, .66));
            border: 1px solid rgba(255, 255, 255, .58);
            box-shadow:
                0 20px 56px rgba(25, 20, 20, .05),
                inset 0 1px 0 rgba(255, 255, 255, .72);
        }

        .selector-title {
            font-size: 2.35rem;
            letter-spacing: .06em;
            text-transform: uppercase;
        }

        .selector-sub {
            font-size: .74rem;
            letter-spacing: .16em;
            text-transform: uppercase;
            opacity: .52;
            margin-top: 6px;
        }

        .size-box {
            min-height: 80px;
            border-radius: 30px;
            padding: 22px;
            background: rgba(255, 255, 255, .86);
            border: 1px solid rgba(23, 20, 20, .06);
            box-shadow: 0 12px 28px rgba(25, 20, 20, .045);
        }

        .size-name {
            font-size: 2.3rem;
            line-height: 1;
            letter-spacing: .08em;
        }

        .size-price {
            font-size: 1.9rem;
            line-height: 1;
            letter-spacing: .04em;
        }

        .size-copy {
            font-size: .98rem;
            line-height: 1.65;
            color: rgba(23, 20, 20, .62);
        }

        .selector-bottom {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 18px;
            flex-wrap: wrap;
            margin-top: 18px;
        }

        .btn-primary {
            min-width: 260px;
            background: #171414;
            color: #fff;
            box-shadow: 0 18px 34px rgba(23, 20, 20, .14);
        }

        .experience-section {
            display: grid;
            grid-template-columns: minmax(0, 1fr);
            gap: 18px;
            margin-top: 26px;
        }

        .experience-copy,
        .experience-points {
            padding: 30px 32px;
            border-radius: 30px;
            background: rgba(255, 255, 255, .68);
            border: 1px solid rgba(23, 20, 20, .06);
            box-shadow: 0 14px 36px rgba(25, 20, 20, .045);
        }

        .experience-points {
            display: grid;
            gap: 18px;
        }

        .experience-point {
            display: grid;
            grid-template-columns: 42px 1fr;
            gap: 16px;
            align-items: start;
            padding-bottom: 18px;
            border-bottom: 1px solid rgba(23, 20, 20, .07);
        }

        .experience-point:last-child {
            border-bottom: none;
            padding-bottom: 0;
        }

        .experience-point strong {
            font-size: 1rem;
            letter-spacing: .16em;
            text-transform: uppercase;
            color: rgba(23, 20, 20, .48);
            margin-top: 2px;
        }

        .product-gallery {
            position: sticky;
            top: 116px;
        }

        .product-stage {
            position: relative;
            min-height: clamp(675px, 65vh, 720px);
            border-radius: 40px;
            overflow: hidden;
            background:
                radial-gradient(circle at top left, rgba(255, 255, 255, .44), transparent 24%),
                linear-gradient(135deg, rgba(255, 255, 255, .72), rgba(255, 255, 255, .34)),
                linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 38%, white) 0%, color-mix(in srgb, var(--bg-top) 70%, white) 100%);
            box-shadow: var(--shadow-medium);
            border: 1px solid rgba(255, 255, 255, .42);
        }

        .product-stage-topbar {
            position: absolute;
            top: 24px;
            left: 24px;
            right: 24px;
            z-index: 4;
            display: flex;
            justify-content: space-between;
            gap: 16px;
        }

        .stage-chip,
        .product-label {
            display: inline-flex;
            align-items: center;
            border-radius: 999px;
            background: rgba(255, 255, 255, .74);
            border: 1px solid rgba(23, 20, 20, .06);
            text-transform: uppercase;
        }

        .stage-chip {
            min-height: 40px;
            padding: 0 14px;
            font-size: .76rem;
            letter-spacing: .16em;
        }

        .product-visual-wrap {
            position: absolute;
            inset: 0;
            display: grid;
            place-items: center;
        }

        .product-main-visual {
            position: relative;
            width: min(92%, 680px);
            height: min(98%, 760px);
            display: grid;
            place-items: center;
        }

        .halo {
            position: absolute;
            inset: 8% 8%;
            border-radius: 999px;
            background: radial-gradient(circle, rgba(255, 255, 255, .98) 0%, rgba(255, 255, 255, .54) 34%, rgba(255, 255, 255, 0) 72%);
            filter: blur(5px);
        }

        .plate-shadow {
            position: absolute;
            left: 50%;
            bottom: 10%;
            width: 60%;
            height: 8%;
            background: radial-gradient(circle, rgba(39, 24, 12, .18), rgba(39, 24, 12, 0) 72%);
            transform: translateX(-50%);
            filter: blur(12px);
        }

        .product-main-image {
            position: relative;
            z-index: 2;
            width: 100%;
            height: 100%;
            max-width: none;
            max-height: none;
            object-fit: contain;
            object-position: center;
            transform: translateY(-18%) scale(1.22);
            -webkit-transform: translateY(-18%) scale(1.22);
            transform-origin: center;
            filter: drop-shadow(0 28px 38px rgba(0, 0, 0, .12));
            -webkit-filter: drop-shadow(0 28px 38px rgba(0, 0, 0, .12));
            transition: transform .4s ease, opacity .25s ease;
        }

        .floating-note {
            position: absolute;
            z-index: 3;
            border-radius: 20px;
            padding: 16px 18px;
            background: rgba(255, 255, 255, .68);
            backdrop-filter: blur(14px);
            -webkit-backdrop-filter: blur(14px);
            border: 1px solid rgba(255, 255, 255, .46);
            box-shadow: 0 12px 28px rgba(0, 0, 0, .06);
            min-width: 190px;
        }

        .floating-note strong {
            display: block;
            font-size: .88rem;
            letter-spacing: .14em;
            text-transform: uppercase;
            margin-bottom: 6px;
        }

        .floating-note span {
            display: block;
            font-family: Arial, Helvetica, sans-serif;
            font-size: .88rem;
            line-height: 1.45;
            color: var(--muted);
        }

        .note-top {
            top: 96px;
            left: 28px;
        }

        .note-bottom {
            right: 28px;
            bottom: 34px;
        }

        .thumb-rail {
            position: absolute;
            left: 28px;
            bottom: 26px;
            z-index: 4;
            display: flex;
            gap: 12px;
        }

        .thumb-btn {
            width: 76px;
            height: 92px;
            border-radius: 18px;
            overflow: hidden;
            border: 1px solid rgba(255, 255, 255, .36);
            background: rgba(255, 255, 255, .72);
            box-shadow: 0 10px 18px rgba(0, 0, 0, .04);
            transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
        }

        .thumb-btn img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .thumb-btn.is-active,
        .thumb-btn:hover {
            transform: translateY(-2px);
            border-color: var(--accent-strong);
            box-shadow: 0 14px 24px color-mix(in srgb, var(--accent-strong) 25%, transparent);
        }

        .product-copy {
            position: relative;
            padding-top: 24px;
        }

        .product-label {
            min-height: 40px;
            padding: 0 16px;
            margin-bottom: 20px;
            font-size: .8rem;
            letter-spacing: .16em;
        }

        .product-title {
            font-size: clamp(2.8rem, 4.5vw, 4.5rem);
            line-height: .9;
            letter-spacing: .06em;
            text-transform: uppercase;
            font-weight: 300;
            margin-bottom: 18px;
        }

        .product-subcopy {
            max-width: 570px;
            color: var(--muted);
            font-size: 1rem;
            line-height: 1.8;
            margin-bottom: 28px;
        }

        .product-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-bottom: 34px;
        }



        .selector-card {
            border-radius: 34px;
            padding: 30px;
            background:
                radial-gradient(circle at top right, rgba(255, 255, 255, .84), transparent 22%),
                linear-gradient(180deg, rgba(255, 255, 255, .78), rgba(255, 255, 255, .58));
            backdrop-filter: blur(18px);
            -webkit-backdrop-filter: blur(18px);
            border: 1px solid rgba(255, 255, 255, .52);
            box-shadow: var(--shadow-soft);
        }

        .selector-head {
            display: grid;
            grid-template-columns: 1fr auto;
            gap: 18px;
            align-items: end;
            margin-bottom: 22px;
        }

        .selector-title {
            font-size: 2.2rem;
            letter-spacing: .08em;
            text-transform: uppercase;
        }

        .selector-sub {
            font-size: .76rem;
            letter-spacing: .14em;
            text-transform: uppercase;
            opacity: .58;
        }

        .size-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 16px;
            margin-bottom: 22px;
        }

        .size-option {
            position: relative;
        }

        .size-option input {
            position: absolute;
            opacity: 0;
            pointer-events: none;
        }

        .size-box {
            min-height: 80px;
            height: 100%;
            border-radius: 28px;
            padding: 20px 20px 18px;
            background: rgba(255, 255, 255, .78);
            border: 1px solid rgba(23, 20, 20, .07);
            display: grid;
            grid-template-rows: auto 1fr auto;
            gap: 14px;
            transition: transform var(--transition), border-color var(--transition), background var(--transition), box-shadow var(--transition);
            box-shadow: var(--shadow-card);
        }

        .size-box:hover {
            transform: translateY(-3px);
            border-color: rgba(23, 20, 20, .14);
        }

        .size-option input:checked+.size-box {
            background: linear-gradient(180deg,
                    color-mix(in srgb, var(--accent-soft) 65%, white),
                    rgba(255, 255, 255, .96));
            border-color: var(--accent-strong);
            box-shadow: 0 20px 42px color-mix(in srgb, var(--accent-strong) 18%, transparent);
            transform: translateY(-4px);
        }

        .size-top {
            display: flex;
            align-items: start;
            justify-content: space-between;
            gap: 12px;
        }

        .size-name {
            font-size: 2.2rem;
            line-height: 1;
            letter-spacing: .08em;
            text-transform: uppercase;
        }

        .size-badge {
            display: inline-flex;
            align-items: center;
            min-height: 26px;
            padding: 0 10px;
            border-radius: 999px;
            background: rgba(23, 20, 20, .05);
            font-size: .62rem;
            letter-spacing: .14em;
            text-transform: uppercase;
        }

        .size-content {
            display: flex;
            flex-direction: column;
            justify-content: flex-start;
            gap: 10px;
        }

        .size-signatures {
            font-size: 1.55rem;
            line-height: 1.05;
            font-weight: 600;
            letter-spacing: -.02em;
            color: var(--text, #171414);
        }

        .size-copy {
            color: var(--muted);
            font-size: .95rem;
            line-height: 1.55;
            max-width: 24ch;
        }

        .size-price {
            font-size: .95rem;
            line-height: 1;
            letter-spacing: .04em;
            color: rgba(23, 20, 20, .55);
            font-weight: 500;
            align-self: start;
        }

        .size-option input:checked+.size-box .size-signatures {
            color: var(--accent-strong);
        }

        .size-option input:checked+.size-box .size-price {
            color: rgba(23, 20, 20, .68);
        }

        .selector-footer {
            display: grid;
            grid-template-columns: 1fr auto;
            gap: 18px;
            align-items: end;
            margin-top: 6px;
        }

        .selector-left {
            display: grid;
            gap: 18px;
        }

        .quantity-row {
            display: flex;
            align-items: center;
            gap: 14px;
            flex-wrap: wrap;
        }

        .quantity-label {
            font-size: .78rem;
            letter-spacing: .14em;
            text-transform: uppercase;
            opacity: .65;
        }

        .quantity-control {
            display: inline-flex;
            align-items: center;
            border-radius: 999px;
            border: 1px solid rgba(23, 20, 20, .08);
            background: rgba(255, 255, 255, .92);
            overflow: hidden;
            min-height: 54px;
        }

        .quantity-btn {
            width: 54px;
            height: 54px;
            display: grid;
            place-items: center;
            font-size: 1.15rem;
        }

        .quantity-input {
            width: 62px;
            text-align: center;
            font-size: 1rem;
            background: transparent;
            outline: none;
        }

        .summary-inline {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
        }


        .selector-right {
            display: grid;
            gap: 16px;
            min-width: 270px;
        }

        .price-panel {
            border-radius: 28px;
            padding: 20px 22px;
            background: rgba(255, 255, 255, .82);
            border: 1px solid rgba(23, 20, 20, .07);
            box-shadow: var(--shadow-card);
        }

        .price-panel small {
            display: block;
            font-size: .72rem;
            letter-spacing: .14em;
            text-transform: uppercase;
            opacity: .58;
            margin-bottom: 8px;
        }

        .price-value {
            font-size: 2.2rem;
            line-height: 1;
            letter-spacing: .06em;
        }

        .cta-actions {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 12px;
        }

        .cta-actions .btn {
            width: 100%;
        }

        .summary-note {
            display: grid;
            gap: 12px;
            border-radius: 26px;
            padding: 24px;
            background: rgba(255, 255, 255, .58);
            border: 1px solid rgba(23, 20, 20, .06);
            box-shadow: var(--shadow-card);
            margin-top: 20px;
        }

        .summary-row {
            display: flex;
            align-items: start;
            justify-content: space-between;
            gap: 18px;
        }

        .summary-row strong {
            font-size: .82rem;
            letter-spacing: .14em;
            text-transform: uppercase;
        }

        .summary-row span {
            font-family: Arial, Helvetica, sans-serif;
            font-size: .92rem;
            line-height: 1.5;
            color: var(--muted);
            text-align: right;
            max-width: 62%;
        }

        .direction-card {
            position: relative;
            border-radius: 26px;
            overflow: hidden;
            background: #fff;
            aspect-ratio: 1 / 1;
        }

        .direction-card img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform .6s ease;
        }

        .direction-card:hover img {
            transform: scale(1.08);
        }

        .card-overlay {
            position: absolute;
            inset: 0;
            display: flex;
            flex-direction: column;
            justify-content: flex-end;
            padding: 20px;
            background: linear-gradient(to top, rgba(0, 0, 0, .45), transparent 60%);
        }

        .card-overlay span {
            font-size: .7rem;
            letter-spacing: .2em;
            text-transform: uppercase;
            color: rgba(255, 255, 255, .7);
            margin-bottom: 6px;
        }

        .card-overlay p {
            color: #fff;
            font-size: .95rem;
            line-height: 1.6;
        }

        .site-footer {
            padding: 42px 0 30px;
            border-top: 1px solid rgba(23, 20, 20, .06);
            background: var(--sage);
            margin-top: 90px;
        }

        .footer-inner {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 20px;
            flex-wrap: wrap;
        }

        .footer-brand {
            font-size: 1.8rem;
            letter-spacing: .14em;
            text-transform: uppercase;
        }

        .footer-links {
            display: flex;
            gap: 20px;
            flex-wrap: wrap;
            font-size: .9rem;
            letter-spacing: .12em;
            text-transform: uppercase;
            color: rgba(23, 20, 20, .66);
        }

        @media (max-width: 1180px) {

            .product-layout,
            .selector-footer {
                grid-template-columns: 1fr;
            }

            .product-gallery {
                position: relative;
                top: auto;
            }

            .selector-right {
                min-width: 0;
            }
        }

        @media (max-width: 760px) {
            .container {
                width: min(calc(100% - 28px), var(--container));
            }

            .product-hero {
                padding-top: 130px;
                padding-bottom: 80px;
            }

            .product-stage {
                min-height: 560px;
            }

            .product-visual-wrap {
                padding: 0;
            }

            .product-main-visual {
                width: 100%;
                height: 100%;
            }

            .product-main-image {
                width: 100%;
                height: 100%;
                max-width: none;
                max-height: none;
                object-fit: cover;
                object-position: center;
                transform: none;
            }

            .halo,
            .plate-shadow {
                display: none;
            }

            .thumb-rail {
                left: 16px;
                bottom: 16px;
            }

            .thumb-btn {
                width: 64px;
                height: 80px;
            }

            .product-title {
                font-size: 4.3rem;
            }

            .size-grid,
            .cta-actions {
                grid-template-columns: 1fr;
            }

            .selector-card {
                padding: 22px;
            }

            .selector-head,
            .footer-inner,
            .summary-row {
                display: grid;
                gap: 14px;
            }

            .product-services-shell {
                padding: 12px;
                border-radius: 24px;
            }

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

            .assurance-item {
                padding: 18px 16px;
                border-radius: 20px;
            }

            .product-notice {
                padding: 20px 18px;
            }

            .summary-row span {
                max-width: none;
                text-align: left;
            }
        }

        .product-heading {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 24px;
            align-items: start;
            margin-bottom: 24px;
        }

        .flavor-badge-stack {
            display: grid;
            gap: 10px;
            justify-items: end;
        }

        .flavor-badge {
            display: inline-flex;
            align-items: center;
            min-height: 42px;
            padding: 0 16px;
            border-radius: 999px;
            background: rgba(255, 255, 255, .72);
            border: 1px solid rgba(23, 20, 20, .08);
            font-size: .72rem;
            letter-spacing: .16em;
            text-transform: uppercase;
            backdrop-filter: blur(10px);
            -webkit-backdrop-filter: blur(10px);
        }

        .product-story {
            margin: 18px 0 34px;
            padding: 34px;
            border-radius: 34px;
            background:
                radial-gradient(circle at top right, rgba(255, 255, 255, .9), transparent 24%),
                linear-gradient(180deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, .54));
            border: 1px solid rgba(255, 255, 255, .52);
            box-shadow: var(--shadow-soft);
        }

        .story-kicker {
            display: inline-block;
            margin-bottom: 12px;
            font-size: .75rem;
            letter-spacing: .18em;
            text-transform: uppercase;
            color: rgba(23, 20, 20, .55);
        }

        .story-intro h2,
        .experience-copy h2 {
            font-size: clamp(2rem, 3vw, 3.2rem);
            line-height: .95;
            letter-spacing: .05em;
            text-transform: uppercase;
            font-weight: 400;
            margin-bottom: 16px;
        }

        .story-intro p,
        .story-card p,
        .experience-copy p,
        .experience-point span {
            font-family: Arial, Helvetica, sans-serif;
            color: var(--muted);
            line-height: 1.75;
            font-size: 1rem;
        }

        .story-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 18px;
            margin-top: 28px;
        }

        .story-card {
            min-height: 220px;
            padding: 24px;
            border-radius: 26px;
            background: rgba(255, 255, 255, .78);
            border: 1px solid rgba(23, 20, 20, .06);
            box-shadow: var(--shadow-card);
        }

        .story-card-highlight {
            background:
                linear-gradient(180deg,
                    color-mix(in srgb, var(--accent-soft) 55%, white),
                    rgba(255, 255, 255, .92));
            border-color: color-mix(in srgb, var(--accent-strong) 40%, white);
        }

        .story-card-label {
            display: inline-block;
            margin-bottom: 14px;
            font-size: .72rem;
            letter-spacing: .16em;
            text-transform: uppercase;
            opacity: .6;
        }

        .story-card h3 {
            font-size: 1.5rem;
            letter-spacing: .06em;
            text-transform: uppercase;
            margin-bottom: 12px;
            font-weight: 400;
        }

        .selector-bottom {
            display: grid;
            grid-template-columns: minmax(0, 1.15fr) minmax(280px, 340px);
            gap: 18px;
            align-items: stretch;
            margin-top: 18px;
        }

        .selector-summary-card {
            min-height: 150px;
            padding: 18px 20px;
            border-radius: 24px;
            background:
                linear-gradient(180deg, rgba(255, 255, 255, .9), rgba(255, 255, 255, .74));
            border: 1px solid rgba(23, 20, 20, .07);
            box-shadow:
                0 12px 30px rgba(23, 20, 20, .05),
                inset 0 1px 0 rgba(255, 255, 255, .55);
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            gap: 14px;
        }

        .selector-summary-head {
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 16px;
        }

        .summary-label {
            font-size: .68rem;
            line-height: 1;
            letter-spacing: .18em;
            text-transform: uppercase;
            color: rgba(23, 20, 20, .42);
            margin-bottom: 8px;
        }

        .summary-title {
            font-size: 1rem;
            line-height: 1;
            letter-spacing: .08em;
            text-transform: uppercase;
            color: #171414;
        }

        .summary-count {
            display: inline-flex;
            align-items: center;
            min-height: 30px;
            padding: 0 12px;
            border-radius: 999px;
            background: color-mix(in srgb, var(--accent-soft) 58%, white);
            border: 1px solid color-mix(in srgb, var(--accent-strong) 16%, transparent);
            color: var(--accent-strong);
            font-size: .72rem;
            font-weight: 600;
            letter-spacing: .12em;
            text-transform: uppercase;
            white-space: nowrap;
        }

        .selector-bottom {
            display: flex;
            flex-direction: column;
            gap: 18px;
            margin-top: 20px;
            align-items: stretch;
        }

        .selector-summary-card {
            width: 100%;
            padding: 20px;
            border-radius: 26px;
            background: linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(255, 255, 255, .78));
            border: 1px solid rgba(23, 20, 20, .06);
            box-shadow: 0 12px 28px rgba(23, 20, 20, .05);
        }

        .selector-summary-head {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 16px;
            margin-bottom: 14px;
            padding-bottom: 10px;
            border-bottom: 1px solid rgba(23, 20, 20, .05);
        }

        .summary-label {
            font-size: 0.68rem;
            letter-spacing: 0.16em;
            text-transform: uppercase;
            color: rgba(23, 20, 20, .42);
            margin-bottom: 7px;
        }

        .summary-title {
            font-size: 1rem;
            line-height: 1.05;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            color: #171414;
        }

        .summary-count {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-height: 30px;
            padding: 0 12px;
            border-radius: 999px;
            background: color-mix(in srgb, var(--accent-soft) 58%, white);
            border: 1px solid rgba(23, 20, 20, .06);
            color: var(--accent-strong);
            font-size: 0.7rem;
            font-weight: 600;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            white-space: nowrap;
        }

        .selector-summary-content {
            margin-top: 0;
            padding-top: 2px;
            border-top: 1px solid rgba(23, 20, 20, .05);
        }

        .summary-content-layout {
            display: grid;
            grid-template-columns: clamp(152px, 19vw, 208px) minmax(0, 1fr);
            gap: 16px;
            align-items: stretch;
        }

        .summary-box-figure {
            min-height: 156px;
            border-radius: 22px;
            border: 1px solid rgba(23, 20, 20, .09);
            background: linear-gradient(180deg, rgba(255, 255, 255, .95), rgba(255, 255, 255, .84));
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 12px;
            box-shadow:
                0 10px 24px rgba(23, 20, 20, .06),
                inset 0 1px 0 rgba(255, 255, 255, .75);
        }

        .summary-box-image {
            width: 100%;
            max-width: 150px;
            height: auto;
            object-fit: contain;
        }

        .selector-summary-card {
            transition: transform .3s ease, box-shadow .3s ease;
        }

        .selector-summary-card.updated {
            transform: scale(1.01);
            box-shadow: 0 16px 34px rgba(23, 20, 20, .08);
        }

        .summary-items {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            align-content: flex-start;
            padding-top: 2px;
        }

        .summary-item {
            display: inline-flex;
            align-items: center;
            gap: 10px;
            min-height: 50px;
            padding: 4px 14px 4px 7px;
            border-radius: 999px;
            background: rgba(255, 255, 255, .9);
            border: 1px solid rgba(23, 20, 20, .09);
            box-shadow:
                0 4px 10px rgba(23, 20, 20, .04),
                inset 0 1px 0 rgba(255, 255, 255, .8);
            color: rgba(23, 20, 20, .82);
            font-size: 0.84rem;
            line-height: 1;
            font-weight: 500;
            letter-spacing: .01em;
            white-space: nowrap;
        }

        .summary-item-thumb {
            width: 38px;
            height: 38px;
            border-radius: 999px;
            object-fit: contain;
            background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(255, 255, 255, .88));
            border: 1px solid rgba(23, 20, 20, .11);
            flex-shrink: 0;
            padding: 4px;
            box-shadow: 0 2px 8px rgba(23, 20, 20, .08);
        }

        .summary-item-label {
            display: inline-block;
            text-transform: uppercase;
        }

        @media (max-width: 1200px) {
            .summary-content-layout {
                grid-template-columns: 174px minmax(0, 1fr);
            }

            .summary-box-figure {
                min-height: 140px;
            }

            .summary-box-image {
                max-width: 128px;
            }
        }

        .selector-actions {
            display: flex;
            gap: 12px;
            flex-wrap: wrap;
            width: 100%;
        }

        .selector-actions .btn {
            flex: 1 1 260px;
            min-height: 48px;
            border-radius: 999px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            text-align: center;
            padding: 0 22px;
            text-transform: uppercase;
        }

        .selector-main-btn {
            font-size: 0.72rem;
            letter-spacing: 0.14em;
            box-shadow: 0 10px 18px rgba(23, 20, 20, .10);
        }

        .selector-alt-btn {
            font-size: 0.68rem;
            letter-spacing: 0.12em;
            background: rgba(255, 255, 255, .82);
            border: 1px solid rgba(23, 20, 20, .09);
            color: #171414;
            box-shadow: 0 8px 20px rgba(23, 20, 20, .05);
            transition:
                transform var(--transition),
                background var(--transition),
                border-color var(--transition),
                box-shadow var(--transition);
        }

        .selector-alt-btn:hover {
            transform: translateY(-2px);
            background: rgba(255, 255, 255, .9);
            border-color: rgba(23, 20, 20, .16);
            box-shadow: 0 14px 28px rgba(23, 20, 20, .08);
        }

        @media (max-width: 920px) {
            .selector-summary-card {
                padding: 16px;
                border-radius: 22px;
            }

            .selector-summary-head {
                align-items: flex-start;
                flex-wrap: wrap;
                gap: 10px;
            }

            .summary-title {
                font-size: 0.95rem;
            }

            .summary-count {
                font-size: 0.66rem;
                padding: 0 10px;
            }

            .summary-items {
                gap: 8px;
            }

            .summary-content-layout {
                grid-template-columns: 1fr;
                gap: 10px;
            }

            .summary-box-figure {
                width: 132px;
                min-height: 100px;
                border-radius: 18px;
                padding: 10px;
            }

            .summary-item {
                font-size: 0.76rem;
                min-height: 44px;
                padding: 4px 11px 4px 6px;
            }

            .summary-item-thumb {
                width: 32px;
                height: 32px;
                padding: 3px;
            }

            .selector-actions {
                flex-direction: column;
            }

            .selector-actions .btn {
                width: 100%;
                flex: 1 1 auto;
                min-height: 50px;
            }
        }

        .experience-section {
            display: grid;
            grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
            gap: 22px;
            margin-top: 28px;
        }

        .experience-copy,
        .experience-points {
            padding: 30px;
            border-radius: 30px;
            background: rgba(255, 255, 255, .62);
            border: 1px solid rgba(23, 20, 20, .06);
            box-shadow: var(--shadow-card);
        }

        .experience-points {
            display: grid;
            gap: 16px;
        }

        .experience-point {
            display: grid;
            grid-template-columns: auto 1fr;
            gap: 14px;
            align-items: start;
            padding-bottom: 16px;
            border-bottom: 1px solid rgba(23, 20, 20, .07);
        }

        .experience-point:last-child {
            border-bottom: none;
            padding-bottom: 0;
        }

        .experience-point strong {
            font-size: 1.1rem;
            letter-spacing: .14em;
            text-transform: uppercase;
            opacity: .7;
        }

        @media (max-width: 980px) {

            .product-heading,
            .story-grid,
            .experience-section {
                grid-template-columns: 1fr;
            }

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

            .flavor-badge-stack {
                justify-items: start;
            }
        }

        @media (max-width: 760px) {

            .product-story,
            .experience-copy,
            .experience-points {
                padding: 22px;
                border-radius: 24px;
            }

            .story-card {
                min-height: auto;
            }

            .selector-bottom {
                align-items: stretch;
            }

            .selector-bottom .btn {
                width: 100%;
            }
        }

        /*# DECOUVRIR */

        .section-sub {
            font-size: .95rem;
            color: rgba(23, 20, 20, .6);
            margin-top: 10px;
            line-height: 1.6;
        }

        .product-scroller {
            display: flex;
            gap: 20px;
            overflow-x: auto;
            padding: 30px 0 10px;
            scroll-snap-type: x mandatory;
        }

        .product-card {
            min-width: 260px;
            border-radius: 26px;
            overflow: hidden;
            background: rgba(255, 255, 255, .8);
            backdrop-filter: blur(10px);
            box-shadow: 0 18px 40px rgba(0, 0, 0, .06);
            transition: transform .4s ease;
            scroll-snap-align: start;
        }

        .product-card:hover {
            transform: translateY(-6px);
        }

        .product-card img {
            width: 100%;
            height: 200px;
            object-fit: cover;
        }

        .product-card-content {
            padding: 18px;
        }

        .product-card-title {
            font-size: 1.1rem;
            letter-spacing: .08em;
            text-transform: uppercase;
        }

        .product-card-sub {
            font-size: .85rem;
            color: rgba(23, 20, 20, .6);
            margin-top: 6px;
        }

        .related-footer {
            margin-top: 30px;
            text-align: center;
        }

        .site-footer {
            padding: 56px 0 24px;
            border-top: 1px solid rgba(23, 20, 20, .06);
            background:
                linear-gradient(180deg, rgba(255, 255, 255, .14), rgba(255, 255, 255, 0)),
                var(--sage);
        }

        .footer-top {
            display: grid;
            grid-template-columns: minmax(0, 1.1fr) minmax(520px, .9fr);
            gap: 40px;
            padding-bottom: 30px;
            border-bottom: 1px solid rgba(23, 20, 20, .08);
        }

        .footer-columns {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 24px;
        }

        .footer-bottom {
            padding-top: 18px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 16px;
            flex-wrap: wrap;
        }

        @media (max-width: 1080px) {
            .footer-top {
                grid-template-columns: 1fr;
            }

            .footer-columns {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }
        }

        @media (max-width: 760px) {
            .site-footer {
                margin-top: 56px;
                padding: 34px 0 20px;
            }

            .footer-top {
                gap: 22px;
                padding-bottom: 20px;
            }

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

            .footer-col {
                padding-bottom: 12px;
                border-bottom: 1px solid rgba(23, 20, 20, .08);
            }

            .footer-col:last-child {
                padding-bottom: 0;
                border-bottom: 0;
            }

            .footer-col h4 {
                margin-bottom: 8px;
            }

            .footer-col a {
                margin-bottom: 8px;
                font-size: .76rem;
                letter-spacing: .08em;
            }

            .footer-bottom {
                padding-top: 14px;
                gap: 10px;
                font-size: .72rem;
            }
        }