@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@400;600;700&display=swap');

/* Global Preloader */
.preloader{position:fixed;inset:0;z-index:9999;background:#faf8f5;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center;width:200px}
.preloader-logo{width:120px;height:auto;margin-bottom:28px;animation:preloaderPulse 2s ease-in-out infinite}
@keyframes preloaderPulse{0%,100%{transform:scale(1);filter:drop-shadow(0 0 0 rgba(198,168,124,0))}50%{transform:scale(1.04);filter:drop-shadow(0 0 18px rgba(198,168,124,.35))}}
.preloader-bar-wrap{width:100%;height:2px;background:rgba(0,0,0,.06);border-radius:2px;overflow:hidden}
.preloader-bar{width:0%;height:100%;background:linear-gradient(90deg,#C6A87C,#D4BF9A,#C6A87C);background-size:200% 100%;border-radius:2px;transition:width .3s ease;animation:preloaderShimmer 1.5s ease infinite}
@keyframes preloaderShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.preloader-pct{font-family:'Inter',sans-serif;font-size:11px;font-weight:500;color:rgba(0,0,0,.35);margin-top:10px;letter-spacing:.5px}

:root {
    --color-cream: #FAF6F0;
    --color-cream-light: #FFFFFF;
    --color-black: #1A1A1A;
    --color-gold: #C6A87C;
    --color-gold-dark: #A58B65;
    --color-nude: #F2D5D0;
    --color-navy: #2C3545;
    --color-gray: #E0E0E0;
    --color-text: #333;
    --color-text-light: #777;
    --color-error: #e74c3c;
    --font-heading: 'Playfair Display', serif;
    --font-body: 'Inter', sans-serif;
    --radius-sm: 8px;
    --radius-md: 16px;
    --radius-lg: 24px
}

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

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

.container {
    max-width: 480px;
    margin: 0 auto;
    background-color: var(--color-cream-light);
    min-height: 100vh;
    box-shadow: 0 0 40px rgba(0, 0, 0, .05);
    overflow-x: hidden;
    position: relative
}

header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(0, 0, 0, .05);
    position: sticky;
    top: 0;
    background: var(--color-cream-light);
    z-index: 100
}

.header-logo {
    text-align: center
}

.header-logo h1 {
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 2px;
    color: var(--color-black);
    text-transform: uppercase
}

.header-logo span {
    display: block;
    font-size: 10px;
    color: var(--color-gold);
    font-weight: 500
}

.menu-btn,
.cart-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    color: var(--color-black)
}

.menu-btn i,
.cart-btn i {
    font-size: 22px
}

/* Drawer */
.menu-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .4);
    z-index: 998;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s
}

.menu-overlay.open {
    opacity: 1;
    pointer-events: auto
}

.menu-drawer {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    height: 100%;
    background: var(--color-cream-light);
    z-index: 999;
    transform: translateX(-100%);
    transition: transform .3s;
    overflow-y: auto;
    box-shadow: 4px 0 20px rgba(0, 0, 0, .1)
}

.menu-drawer.open {
    transform: translateX(0)
}

.menu-drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid var(--color-gray)
}

.menu-drawer-brand {
    font-family: var(--font-heading);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 2px
}

.menu-close-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: var(--color-black)
}

.menu-close-btn i {
    font-size: 20px
}

.menu-nav,
.menu-legal-nav {
    list-style: none;
    padding: 12px 0
}

.menu-nav li a,
.menu-legal-nav li a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    text-decoration: none;
    color: var(--color-text);
    font-size: 14px;
    font-weight: 500;
    transition: background .2s
}

.menu-nav li a:hover,
.menu-legal-nav li a:hover {
    background: var(--color-cream)
}

.menu-nav li a i,
.menu-legal-nav li a i {
    font-size: 18px;
    color: var(--color-gold)
}

.menu-divider {
    height: 1px;
    background: var(--color-gray);
    margin: 0 20px
}

.menu-lang {
    padding: 16px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.menu-lang>span {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500
}

.menu-lang>span i {
    font-size: 18px;
    color: var(--color-gold)
}

.menu-lang-btns {
    display: flex;
    gap: 8px
}

.lang-btn {
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    color: var(--color-text-light);
    border: 1px solid var(--color-gray);
    transition: all .2s
}

.lang-btn.active {
    background: var(--color-black);
    color: #fff;
    border-color: var(--color-black)
}

.menu-legal-nav li a {
    font-size: 12px;
    color: var(--color-text-light);
    padding: 8px 20px
}

/* Set Switcher */
.set-switcher {
    display: flex;
    gap: 12px;
    padding: 12px 20px;
    background: var(--color-cream);
    border-bottom: 1px solid var(--color-gray)
}

.set-switcher-btn {
    flex: 1;
    padding: 8px 0;
    background: transparent;
    border: 1px solid var(--color-gray);
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-light);
    cursor: pointer;
    transition: all .3s
}

.set-switcher-btn.active.women {
    background: var(--color-nude);
    border-color: var(--color-nude);
    color: var(--color-black)
}

.set-switcher-btn.active.men {
    background: var(--color-navy);
    border-color: var(--color-navy);
    color: #fff
}

/* Hero */
.hero {
    padding: 30px 20px;
    text-align: center
}

.hero h2 {
    font-family: var(--font-heading);
    font-size: 26px;
    line-height: 1.2;
    color: var(--color-black);
    margin-bottom: 12px
}

.hero p.subtitle {
    font-size: 14px;
    color: var(--color-text-light);
    margin-bottom: 24px
}

.hero-video-wrap {
    margin: 0 -20px 24px;
    position: relative;
    background: #000;
    aspect-ratio: 16/9;
    overflow: hidden
}

.hero-video-wrap video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

.video-dots {
    position: absolute;
    bottom: 12px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px
}

.video-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .4);
    cursor: pointer;
    transition: all .3s
}

.video-dot.active {
    background: #fff;
    width: 24px;
    border-radius: 4px
}

.price-block {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--color-cream);
    padding: 16px 24px;
    border-radius: var(--radius-md);
    margin-bottom: 24px
}

.price-block--hero {
    background: linear-gradient(135deg, #faf6f0, #f5ede0);
    border: 2px solid var(--color-gold);
    overflow: hidden
}

.price-old {
    text-align: left
}

.price-old span {
    display: block;
    font-size: 12px;
    color: var(--color-text-light)
}

.price-old s {
    font-size: 22px;
    font-weight: 600;
    color: #c0392b;
    text-decoration-thickness: 2px
}

.price-new {
    text-align: right;
    background: linear-gradient(135deg, var(--color-gold), #D4AF37);
    color: #fff;
    padding: 12px 20px;
    border-radius: var(--radius-sm);
    animation: pricePulse 2s ease-in-out infinite
}

.price-new span {
    display: block;
    font-size: 9px;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 1.5px
}

.price-new strong {
    font-size: 36px;
    line-height: 1;
    text-shadow: 0 2px 4px rgba(0, 0, 0, .15)
}

@keyframes pricePulse {

    0%,
    100% {
        transform: scale(1)
    }

    50% {
        transform: scale(1.03)
    }
}

.badges {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-bottom: 24px;
    font-size: 12px;
    color: var(--color-gold-dark);
    font-weight: 500
}

.badges span {
    display: flex;
    align-items: center;
    gap: 6px
}

.badges i {
    font-size: 14px
}

.btn-primary {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    background: var(--color-black);
    color: #fff;
    border: none;
    padding: 18px 24px;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: transform .2s, background .2s;
    text-decoration: none
}

.btn-primary:active {
    transform: scale(.98)
}

.btn-primary:hover {
    background: #333
}

.btn-primary i {
    font-size: 18px
}

section {
    padding: 40px 20px;
    border-top: 1px solid var(--color-cream)
}

.section-title {
    font-family: var(--font-heading);
    font-size: 24px;
    text-align: center;
    margin-bottom: 24px;
    color: var(--color-black)
}

/* Discovery Set v2 */
.discovery-set {
    padding: 40px 20px;
    border-top: 1px solid var(--color-cream);
    background: #fff
}

.ds-header {
    text-align: center;
    margin-bottom: 20px
}

.ds-title {
    font-family: var(--font-heading);
    font-size: 24px;
    color: var(--color-black);
    margin-bottom: 6px
}

.ds-subtitle {
    font-size: 13px;
    color: var(--color-text-light)
}

.ds-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 24px
}

.ds-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 16px;
    border: 2px solid var(--color-gray);
    border-radius: var(--radius-md);
    background: #fff;
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-light);
    cursor: pointer;
    transition: all .3s;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .04)
}

.ds-tab i {
    font-size: 20px;
    transition: color .3s
}

.ds-tab.active {
    border-color: var(--color-gold);
    background: linear-gradient(135deg, rgba(198, 168, 124, .1), rgba(198, 168, 124, .05));
    color: var(--color-black);
    box-shadow: 0 4px 12px rgba(198, 168, 124, .15)
}

.ds-tab.active i {
    color: var(--color-gold)
}

.ds-tab[data-set="men"].active {
    border-color: var(--color-navy);
    background: linear-gradient(135deg, rgba(44, 53, 69, .08), rgba(44, 53, 69, .03));
    color: var(--color-navy);
    box-shadow: 0 4px 12px rgba(44, 53, 69, .1)
}

/* Panel */
.ds-panel {
    border-radius: 20px;
    padding: 20px;
    animation: dsPanelIn .35s ease
}

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

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

.ds-panel[data-set="women"] {
    background: linear-gradient(180deg, #fdf5f3 0%, #fff 100%);
    border: 1px solid rgba(242, 213, 208, .4)
}

.ds-panel[data-set="men"] {
    background: linear-gradient(180deg, #2C3545 0%, #1e2633 100%);
    border: 1px solid rgba(255, 255, 255, .08);
    color: #e8e8e8
}

/* Carousel (scroll-snap, mobile-first) */
.ds-carousel {
    margin-bottom: 20px;
    position: relative
}

.ds-carousel-track {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 0;
    border-radius: 16px
}

.ds-carousel-track::-webkit-scrollbar {
    display: none
}

.ds-slide {
    flex: 0 0 100%;
    scroll-snap-align: start;
    aspect-ratio: 5/4;
    overflow: hidden;
    border-radius: 16px
}

.ds-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: zoom-in
}

.ds-slide--portrait {
    aspect-ratio: 4/5
}

.ds-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 10px
}

.ds-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-gray);
    transition: all .3s
}

.ds-dot.active {
    width: 20px;
    border-radius: 4px;
    background: var(--color-gold)
}

/* Lightbox */
.lightbox-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1100;
    background: rgba(0, 0, 0, .95);
    align-items: center;
    justify-content: center
}

.lightbox-overlay.active {
    display: flex
}

.lightbox-close {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 1101;
    width: 40px;
    height: 40px;
    border: none;
    background: rgba(255, 255, 255, .15);
    color: #fff;
    border-radius: 50%;
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center
}

.lightbox-body {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    touch-action: pinch-zoom
}

.lightbox-body img {
    max-width: 100%;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 8px
}

/* Text */
.ds-set-title {
    font-family: var(--font-heading);
    font-size: 22px;
    color: var(--color-black);
    margin-bottom: 4px
}

.ds-set-volume {
    font-size: 12px;
    color: var(--color-text-light);
    font-weight: 500;
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 1px
}

.ds-set-desc {
    font-size: 13px;
    color: var(--color-text);
    line-height: 1.5;
    margin-bottom: 14px
}

/* Scent profile */
.ds-scent-profile {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-style: italic;
    color: var(--color-gold-dark);
    margin-bottom: 16px;
    padding: 8px 12px;
    background: rgba(198, 168, 124, .06);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--color-gold)
}

.ds-scent-profile i {
    font-size: 18px;
    color: var(--color-gold)
}

/* Badges */
.ds-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px
}

.ds-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    background: rgba(255, 255, 255, .8);
    color: var(--color-text)
}

.ds-badge i {
    font-size: 14px;
    color: var(--color-gold)
}

.ds-badge--price {
    background: linear-gradient(135deg, var(--color-gold), #D4AF37);
    color: #fff
}

.ds-badge--price i {
    color: #fff
}

/* Inside the Box */
.ds-box {
    background: rgba(255, 255, 255, .7);
    border: 1px solid rgba(0, 0, 0, .04);
    border-radius: var(--radius-md);
    padding: 16px 20px;
    margin-bottom: 20px
}

.ds-box h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--color-black);
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: .5px
}

.ds-box h4 i {
    font-size: 18px;
    color: var(--color-gold)
}

.ds-box ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px
}

.ds-box li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--color-text);
    font-weight: 500
}

.ds-box li i {
    font-size: 16px;
    color: #27ae60;
    flex-shrink: 0
}

.ds-cta {
    margin-top: 4px
}

.ds-microcopy {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 11px;
    color: var(--color-text-light);
    margin-top: 12px;
    text-align: center
}

.ds-microcopy i {
    font-size: 14px;
    color: var(--color-gold)
}

/* Men Panel Overrides */
.ds-panel[data-set="men"] .ds-set-title {
    color: #fff
}

.ds-panel[data-set="men"] .ds-set-volume {
    color: rgba(255, 255, 255, .5)
}

.ds-panel[data-set="men"] .ds-set-desc {
    color: rgba(255, 255, 255, .75)
}

.ds-panel[data-set="men"] .ds-scent-profile {
    background: rgba(255, 255, 255, .06);
    border-left-color: var(--color-gold);
    color: var(--color-gold)
}

.ds-panel[data-set="men"] .ds-badge {
    background: rgba(255, 255, 255, .1);
    color: rgba(255, 255, 255, .8)
}

.ds-panel[data-set="men"] .ds-badge i {
    color: var(--color-gold)
}

.ds-panel[data-set="men"] .ds-box {
    background: rgba(255, 255, 255, .06);
    border-color: rgba(255, 255, 255, .08)
}

.ds-panel[data-set="men"] .ds-box h4 {
    color: #fff
}

.ds-panel[data-set="men"] .ds-box li {
    color: rgba(255, 255, 255, .8)
}

.ds-panel[data-set="men"] .ds-cta {
    background: linear-gradient(135deg, var(--color-gold), #D4AF37);
    box-shadow: 0 4px 20px rgba(198, 168, 124, .35)
}

.ds-panel[data-set="men"] .ds-microcopy {
    color: rgba(255, 255, 255, .45)
}

/* Steps */
.steps-container {
    display: flex;
    justify-content: space-between;
    position: relative
}

.steps-container::before {
    content: '';
    position: absolute;
    top: 24px;
    left: 20px;
    right: 20px;
    height: 1px;
    border-top: 1px dashed var(--color-gray);
    z-index: 1
}

.step-item {
    flex: 1;
    text-align: center;
    position: relative;
    z-index: 2
}

.step-icon {
    width: 48px;
    height: 48px;
    background: var(--color-cream-light);
    border: 1px solid var(--color-gray);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
    position: relative
}

.step-icon i {
    font-size: 20px;
    color: var(--color-gold)
}

.step-num {
    position: absolute;
    bottom: -4px;
    right: -4px;
    width: 18px;
    height: 18px;
    background: var(--color-gold);
    color: #fff;
    border-radius: 50%;
    font-size: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold
}

.step-text {
    font-size: 11px;
    color: var(--color-text-light);
    font-weight: 500
}

/* Quiz Overlay */
.quiz-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 900;
    background: var(--color-cream);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch
}

.quiz-overlay.active {
    display: flex;
    flex-direction: column;
    animation: fadeIn .4s
}

.quiz-overlay-inner {
    max-width: 480px;
    width: 100%;
    margin: 0 auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh
}

.quiz-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px
}

.quiz-header h3 {
    font-family: var(--font-heading);
    font-size: 18px
}

.quiz-header-right {
    display: flex;
    align-items: center;
    gap: 12px
}

.quiz-progress {
    font-size: 12px;
    color: var(--color-text-light);
    font-weight: 600
}

.quiz-close-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: var(--color-text-light)
}

.quiz-close-btn i {
    font-size: 22px
}

.quiz-progress-bar {
    height: 4px;
    background: var(--color-gray);
    border-radius: 4px;
    margin-bottom: 24px;
    overflow: hidden
}

.quiz-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-gold), #D4AF37);
    border-radius: 4px;
    transition: width .4s
}

.quiz-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center
}

.quiz-step {
    display: none;
    animation: fadeIn .4s
}

.quiz-step.active {
    display: block
}

.quiz-question {
    background: #fff;
    padding: 24px;
    border-radius: var(--radius-md);
    margin-bottom: 24px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, .04)
}

.quiz-question h4 {
    font-size: 16px;
    margin-bottom: 20px;
    color: var(--color-black);
    display: flex;
    align-items: center;
    gap: 8px
}

.quiz-question h4 i {
    font-size: 20px;
    color: var(--color-gold)
}

.quiz-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px
}

.quiz-option {
    padding: 16px;
    border: 2px solid var(--color-gray);
    border-radius: var(--radius-md);
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all .2s;
    user-select: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px
}

.quiz-option i {
    font-size: 28px;
    color: var(--color-gold)
}

.quiz-option:hover {
    border-color: var(--color-gold)
}

.quiz-option.selected {
    background: rgba(198, 168, 124, .1);
    border-color: var(--color-gold);
    color: var(--color-gold-dark)
}

.quiz-option.selected i {
    color: var(--color-gold-dark)
}

.quiz-btn-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px
}

.btn-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    border: 1px solid var(--color-gray);
    color: var(--color-text-light);
    padding: 12px 24px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all .2s
}

.btn-back:hover {
    border-color: var(--color-black);
    color: var(--color-black)
}

.btn-back i {
    font-size: 16px
}

.btn-next {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-black);
    color: #fff;
    border: none;
    padding: 14px 36px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s;
    margin-left: auto
}

.btn-next i {
    font-size: 16px
}

.btn-next:disabled {
    background: var(--color-gray);
    cursor: not-allowed
}

.quiz-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 20px 0
}

.quiz-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-gray);
    transition: all .3s
}

.quiz-dot.active {
    background: var(--color-gold);
    width: 24px;
    border-radius: 4px
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px)
    }

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

/* Why */
.benefits-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px
}

.benefit-card {
    background: #fff;
    padding: 16px;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-gray);
    display: flex;
    flex-direction: column;
    gap: 12px
}

.benefit-icon i {
    font-size: 28px;
    color: var(--color-gold)
}

.benefit-text {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.4
}

/* Reviews — Zone A: Main page card+photo carousel */
.reviews-summary {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px
}

.reviews-stars {
    color: var(--color-gold);
    display: flex;
    gap: 2px
}

.reviews-stars i {
    font-size: 16px
}

.reviews-avg {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-black)
}

.reviews-count {
    font-size: 12px;
    color: var(--color-text-light)
}

.reviews-carousel {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 14px;
    padding-bottom: 8px;
    scrollbar-width: none
}

.reviews-carousel::-webkit-scrollbar {
    display: none
}

.review-card {
    min-width: 280px;
    max-width: 300px;
    flex-shrink: 0;
    background: #fff;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-cream);
    box-shadow: 0 4px 16px rgba(0, 0, 0, .04);
    scroll-snap-align: start;
    overflow: hidden
}

.review-card-photo {
    width: 100%;
    aspect-ratio: 3/4;
    overflow: hidden
}

.review-card-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

.review-card-body {
    padding: 16px
}

.review-card-stars {
    color: var(--color-gold);
    display: flex;
    gap: 2px;
    margin-bottom: 8px
}

.review-card-stars i {
    font-size: 13px
}

.review-card-text {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-black);
    line-height: 1.5;
    margin-bottom: 14px
}

.review-card-footer {
    display: flex;
    align-items: center;
    gap: 10px
}

.review-card-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--color-cream);
    flex-shrink: 0
}

.review-card-author {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-black)
}

.review-card-author span {
    font-weight: 400;
    color: var(--color-text-light)
}

/* Reviews — Zone S1: Spinner ticker */
.op-spinner-ticker {
    margin-top: 24px;
    border-top: 1px solid rgba(0, 0, 0, .06);
    padding-top: 16px;
    min-height: 60px;
    position: relative;
    overflow: hidden
}

.op-ticker-item {
    text-align: center;
    animation: tickerFadeIn .6s ease
}

.op-ticker-stars {
    color: var(--color-gold);
    display: flex;
    justify-content: center;
    gap: 2px;
    margin-bottom: 6px
}

.op-ticker-stars i {
    font-size: 11px
}

.op-ticker-text {
    font-size: 12px;
    color: var(--color-text);
    font-style: italic;
    line-height: 1.4;
    margin-bottom: 6px
}

.op-ticker-author {
    font-size: 11px;
    color: var(--color-text-light)
}

@keyframes tickerFadeIn {
    from {
        opacity: 0;
        transform: translateY(8px)
    }

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

/* Reviews — Zone R1: Mini-card below CTA */
.op-reviews {
    width: 100%;
    margin-top: 24px;
    border-top: 1px solid var(--color-gray);
    padding-top: 20px;
    overflow: hidden;
    position: relative;
    min-height: 80px
}

.op-review-item {
    background: #fff;
    border: 1px solid var(--color-cream);
    border-radius: var(--radius-md);
    padding: 16px;
    animation: reviewSlideIn .5s ease;
    transition: opacity .4s
}

@keyframes reviewSlideIn {
    from {
        opacity: 0;
        transform: translateY(20px)
    }

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

.op-review-stars {
    color: var(--color-gold);
    display: flex;
    gap: 2px;
    margin-bottom: 6px
}

.op-review-stars i {
    font-size: 12px
}

.op-review-text {
    font-size: 12px;
    color: var(--color-text);
    font-style: italic;
    line-height: 1.4;
    margin-bottom: 8px
}

.op-review-author {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--color-text-light)
}

.op-review-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover
}

.op-review-dots {
    display: flex;
    justify-content: center;
    gap: 5px;
    margin-top: 12px
}

.op-review-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-gray);
    transition: all .3s
}

.op-review-dot.active {
    background: var(--color-gold);
    width: 14px;
    border-radius: 3px
}

/* Stats */
.stats-container {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--color-gray);
    padding-bottom: 20px
}

.stat-item {
    text-align: center;
    flex: 1
}

.stat-icon i {
    font-size: 24px;
    color: var(--color-gold)
}

.stat-val {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-black);
    margin-top: 4px
}

.stat-label {
    font-size: 10px;
    color: var(--color-text-light);
    text-transform: lowercase
}

.trust-badges {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.trust-badge {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--color-cream);
    padding: 12px 16px;
    border-radius: var(--radius-sm);
    font-size: 12px;
    font-weight: 500
}

.trust-badge i {
    font-size: 18px;
    color: var(--color-gold)
}

/* Checkout */
.checkout-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 900;
    background: var(--color-cream-light);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch
}

.checkout-overlay.active {
    display: block;
    animation: fadeIn .5s
}

.checkout-overlay-inner {
    max-width: 480px;
    margin: 0 auto;
    padding: 30px 20px
}

.checkout-header {
    text-align: center;
    margin-bottom: 24px
}

.checkout-header h3 {
    font-family: var(--font-heading);
    font-size: 22px;
    color: var(--color-black);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px
}

.checkout-header h3 i {
    font-size: 24px;
    color: var(--color-gold)
}

.checkout-header p {
    font-size: 13px;
    color: var(--color-text-light);
    line-height: 1.5
}

.price-block--checkout {
    background: linear-gradient(135deg, #faf6f0, #f5ede0);
    border: 2px solid var(--color-gold)
}

.form-group {
    margin-bottom: 16px
}

.form-group label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--color-black)
}

.input-icon-wrap {
    position: relative
}

.input-icon-wrap>i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
    color: var(--color-text-light);
    pointer-events: none;
    z-index: 1
}

.input-icon-wrap--textarea>i {
    top: 18px;
    transform: none
}

.input-icon-wrap .form-control {
    padding-left: 42px
}

.form-control {
    width: 100%;
    padding: 14px;
    border: 1px solid var(--color-gray);
    border-radius: var(--radius-sm);
    font-family: var(--font-body);
    font-size: 14px;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    background: #fff
}

.form-control:focus {
    border-color: var(--color-gold);
    box-shadow: 0 0 0 3px rgba(198, 168, 124, .15)
}

.form-control.error {
    border-color: var(--color-error)
}

.form-control.valid {
    border-color: #27ae60
}

.field-error {
    font-size: 11px;
    color: var(--color-error);
    margin-top: 4px;
    min-height: 16px
}

.form-row {
    display: flex;
    gap: 12px
}

.form-row .form-group {
    flex: 1
}

/* City Dropdown */
.city-dropdown {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: #fff;
    border: 1px solid var(--color-gray);
    border-top: none;
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    max-height: 200px;
    overflow-y: auto;
    z-index: 50;
    box-shadow: 0 8px 20px rgba(0, 0, 0, .08)
}

.city-dropdown.open {
    display: block
}

.city-dropdown-item {
    padding: 12px 14px 12px 42px;
    font-size: 14px;
    cursor: pointer;
    transition: background .15s
}

.city-dropdown-item:hover,
.city-dropdown-item.highlighted {
    background: var(--color-cream)
}

/* Email suggestions */
.email-suggestions {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--color-gray);
    border-top: none;
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    z-index: 50;
    box-shadow: 0 8px 20px rgba(0, 0, 0, .08)
}

.email-suggestions.open {
    display: block
}

.email-suggestion-item {
    padding: 10px 14px 10px 42px;
    font-size: 13px;
    cursor: pointer;
    transition: background .15s;
    color: var(--color-text)
}

.email-suggestion-item:hover {
    background: var(--color-cream)
}

.email-suggestion-item strong {
    color: var(--color-black)
}

.consents {
    margin-top: 24px;
    margin-bottom: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.checkbox-wrap {
    display: flex;
    align-items: flex-start;
    gap: 10px
}

.checkbox-wrap input[type="checkbox"] {
    margin-top: 2px;
    width: 18px;
    height: 18px;
    accent-color: var(--color-black);
    flex-shrink: 0
}

.checkbox-wrap label {
    font-size: 11px;
    color: var(--color-text-light);
    line-height: 1.4
}

.checkbox-wrap label a {
    color: var(--color-black);
    text-decoration: underline
}

/* Checkbox validation error */
.checkbox-wrap.checkbox-error {
    background: rgba(231, 76, 60, .06);
    border: 1px solid var(--color-error);
    border-radius: var(--radius-sm);
    padding: 8px 10px;
    margin: -8px -10px;
    animation: shakeError .4s ease
}

.checkbox-wrap.checkbox-error label {
    color: var(--color-error)
}

@keyframes shakeError {

    0%,
    100% {
        transform: translateX(0)
    }

    25% {
        transform: translateX(-4px)
    }

    50% {
        transform: translateX(4px)
    }

    75% {
        transform: translateX(-2px)
    }
}

.btn-order {
    margin-top: 8px
}

/* Footer */
.footer-action {
    background: var(--color-cream);
    padding: 30px 20px;
    text-align: center;
    position: relative;
    overflow: hidden
}

.footer-action h3 {
    font-family: var(--font-heading);
    font-size: 24px;
    margin-bottom: 8px
}

.footer-action p {
    font-size: 13px;
    margin-bottom: 20px
}

.footer-bottle {
    position: absolute;
    right: -30px;
    bottom: -20px;
    width: 150px;
    opacity: .5;
    pointer-events: none
}

.legal-links {
    padding: 20px;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    font-size: 10px
}

.legal-links a {
    color: var(--color-text-light);
    text-decoration: none
}

.legal-links a:hover {
    text-decoration: underline
}

/* Cookie */
.cookie-banner {
    position: fixed;
    bottom: -100%;
    left: 0;
    width: 100%;
    background: #fff;
    padding: 20px;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, .1);
    z-index: 1000;
    transition: bottom .4s;
    border-top-left-radius: var(--radius-md);
    border-top-right-radius: var(--radius-md)
}

.cookie-banner.show {
    bottom: 0
}

@media(min-width:480px) {
    .cookie-banner {
        max-width: 480px;
        left: 50%;
        transform: translateX(-50%)
    }
}

.cookie-text {
    font-size: 11px;
    margin-bottom: 16px;
    color: var(--color-text-light)
}

.cookie-buttons {
    display: flex;
    gap: 10px
}

.cookie-btn {
    flex: 1;
    padding: 10px;
    border-radius: var(--radius-sm);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    border: none
}

.cookie-btn.accept {
    background: var(--color-black);
    color: #fff
}

.cookie-btn.reject {
    background: var(--color-gray);
    color: var(--color-black)
}

/* Success */
.success-container {
    text-align: center;
    padding: 60px 20px
}

.success-icon {
    width: 80px;
    height: 80px;
    background: var(--color-gold);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
    margin: 0 auto 24px
}

.success-container h2 {
    font-family: var(--font-heading);
    font-size: 28px;
    margin-bottom: 16px
}

.success-container p {
    color: var(--color-text-light)
}

/* Legal pages */
.legal-page {
    padding: 40px 20px
}

.legal-page h2 {
    font-family: var(--font-heading);
    font-size: 24px;
    margin-bottom: 20px
}

.legal-page-content {
    font-size: 13px;
    color: #555;
    line-height: 1.7
}

.legal-page-content h3 {
    font-size: 16px;
    margin: 20px 0 8px;
    color: var(--color-black)
}

.legal-page-content p {
    margin-bottom: 12px
}

.legal-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 24px;
    color: var(--color-black);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500
}

/* Order Prepare Overlay */
.op-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 950;
    background: var(--color-cream);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch
}

.op-overlay.active {
    display: block;
    animation: fadeIn .5s
}

.op-inner {
    max-width: 480px;
    margin: 0 auto;
    padding: 40px 20px;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    align-items: center
}

.op-spinner-section {
    text-align: center;
    width: 100%;
    padding-top: 40px
}

.op-ring {
    width: 140px;
    height: 140px;
    margin: 0 auto 24px;
    position: relative
}

.op-ring-svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg)
}

.op-ring-bg {
    fill: none;
    stroke: var(--color-gray);
    stroke-width: 6
}

.op-ring-fill {
    fill: none;
    stroke: var(--color-gold);
    stroke-width: 6;
    stroke-linecap: round;
    stroke-dasharray: 326.73;
    stroke-dashoffset: 326.73;
    transition: stroke-dashoffset .8s ease
}

.op-ring-center {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center
}

.op-ring-pct {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-black);
    font-family: var(--font-body)
}

.op-ring-check {
    display: none;
    font-size: 48px;
    color: #27ae60
}

.op-ring-center.done .op-ring-pct {
    display: none
}

.op-ring-center.done .op-ring-check {
    display: block;
    animation: scaleIn .4s ease
}

@keyframes scaleIn {
    from {
        transform: scale(0)
    }

    to {
        transform: scale(1)
    }
}

.op-status-text {
    font-size: 15px;
    font-weight: 500;
    color: var(--color-text);
    margin-bottom: 20px;
    min-height: 24px;
    transition: opacity .3s
}

.op-log {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
    max-width: 300px;
    margin: 0 auto
}

.op-log-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--color-text-light);
    animation: fadeIn .4s
}

.op-log-item.done {
    color: var(--color-text)
}

.op-log-item.done i {
    color: #27ae60
}

.op-log-item i {
    font-size: 16px;
    color: var(--color-gold);
    flex-shrink: 0
}

/* Ready section */
.op-ready-section {
    text-align: center;
    width: 100%;
    animation: fadeIn .5s
}

.op-ready-icon {
    font-size: 56px;
    color: #27ae60;
    margin-bottom: 8px
}

.op-ready-title {
    font-family: var(--font-heading);
    font-size: 24px;
    color: var(--color-black);
    margin-bottom: 20px
}

.op-order-card {
    background: #fff;
    border: 1px solid var(--color-gray);
    border-radius: var(--radius-md);
    padding: 20px;
    margin-bottom: 20px;
    text-align: left
}

.op-order-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
    font-size: 13px;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-cream)
}

.op-order-row:last-child {
    border-bottom: none
}

.op-order-row strong {
    font-weight: 600;
    color: var(--color-black)
}

.op-delivery {
    color: var(--color-gold-dark);
    font-weight: 500;
    gap: 6px;
    justify-content: flex-start
}

.op-delivery i {
    font-size: 16px
}

.op-timer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 20px;
    font-weight: 700;
    color: var(--color-black);
    margin-bottom: 20px
}

.op-timer i {
    font-size: 22px;
    color: var(--color-gold)
}

.op-timer-label {
    font-size: 13px;
    font-weight: 400;
    color: var(--color-text-light)
}

.op-cta {
    animation: ctaPulse 1.5s ease-in-out infinite
}

@keyframes ctaPulse {

    0%,
    100% {
        transform: scale(1);
        box-shadow: 0 4px 16px rgba(0, 0, 0, .1)
    }

    50% {
        transform: scale(1.02);
        box-shadow: 0 6px 24px rgba(198, 168, 124, .3)
    }
}

.op-tab-note {
    font-size: 11px;
    color: var(--color-text-light);
    margin-top: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px
}

.op-timer-note {
    font-size: 11px;
    color: var(--color-text-light);
    margin-top: 4px
}