:root{
    --bg: #fff8fb;
    --bg-soft: #fff2f7;
    --card: rgba(255,255,255,.84);
    --card-strong: rgba(255,255,255,.94);
    --text: #3f2030;
    --muted: #8d6778;
    --border: rgba(142, 24, 50, 0.12);
    --shadow: 0 18px 45px rgba(142, 24, 50, 0.10);
    --shadow-soft: 0 10px 25px rgba(142, 24, 50, 0.08);
    --radius-xl: 28px;
    --radius-lg: 22px;
    --radius-md: 16px;
    --radius-sm: 12px;
    --container: 1280px;
    --gold: #c89c5d;
    --success: #157347;
    --danger: #b42318;
}

*{
    box-sizing: border-box;
}

html{
    scroll-behavior: smooth;
}

body{
    margin: 0;
    font-family: "Inter", "Segoe UI", sans-serif;
    background:
        radial-gradient(circle at top left, rgba(255, 214, 230, 0.7), transparent 28%),
        radial-gradient(circle at bottom right, rgba(255, 206, 223, 0.75), transparent 26%),
        linear-gradient(180deg, #fffafd 0%, #fff4f8 42%, #fff8fb 100%);
    color: var(--text);
    min-height: 100vh;
    overflow-x: hidden;
}

body.is-locked{
    overflow: hidden;
}

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

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

button,
input,
textarea,
select{
    font: inherit;
}

button{
    cursor: pointer;
    border: 0;
    background: none;
}

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

.section{
    position: relative;
    padding: 28px 0;
}

.section-card{
    background: var(--card);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.55);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow);
    padding: 28px;
    position: relative;
    overflow: hidden;
}

.section-head{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px;
}

.section-head-inline{
    align-items: center;
    margin-bottom: 16px;
}

.section-title{
    margin: 0;
    font-size: clamp(1.45rem, 2vw, 2rem);
    line-height: 1.1;
    font-weight: 800;
    color: #581f36;
}

.section-mini-title{
    margin: 0;
    font-size: 1.12rem;
    font-weight: 800;
    color: #66263f;
}

.section-subtitle{
    margin-top: 8px;
    color: var(--muted);
    font-size: .97rem;
    line-height: 1.5;
}

.section-block + .section-block{
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid rgba(142, 24, 50, 0.10);
}

.topbar{
    position: sticky;
    top: 0;
    z-index: 70;
    padding: 14px 0;
    backdrop-filter: blur(16px);
    background: linear-gradient(180deg, rgba(255,248,251,.92), rgba(255,248,251,.70));
    border-bottom: 1px solid rgba(142, 24, 50, 0.08);
}

.topbar-inner{
    position: relative;
}

.topbar-shell{
    display: grid;
    grid-template-columns: minmax(0, 360px) minmax(280px, 1fr) auto;
    align-items: center;
    gap: 18px;
    background: rgba(255,255,255,.74);
    border: 1px solid rgba(255,255,255,.65);
    box-shadow: var(--shadow-soft);
    border-radius: 999px;
    padding: 12px 14px;
}

.brand{
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.brand--sidebar{
    align-items: center;
}

.brand-logo{
    width: 54px;
    height: 54px;
    object-fit: contain;
    border-radius: 16px;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(142,24,50,.12);
    padding: 6px;
    box-shadow: 0 8px 24px rgba(142,24,50,.08);
    flex-shrink: 0;
}

.brand-logo-fallback,
.hero-logo-fallback{
    display: grid;
    place-items: center;
    font-weight: 900;
    color: white;
    background: linear-gradient(135deg, var(--primary), #c94f77);
}

.brand-logo-fallback{
    width: 54px;
    height: 54px;
    border-radius: 16px;
    flex-shrink: 0;
}

.brand-meta{
    min-width: 0;
}

.brand-title{
    font-size: 1rem;
    font-weight: 800;
    color: #5d1f38;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.brand-subtitle{
    margin-top: 4px;
    color: var(--muted);
    font-size: .84rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.topbar-center{
    min-width: 0;
}

.searchbar{
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(255,255,255,.88);
    border: 1px solid rgba(142,24,50,.10);
    border-radius: 999px;
    padding: 8px;
    min-width: 0;
}

.searchbar input{
    flex: 1;
    min-width: 0;
    border: 0;
    outline: none;
    background: transparent;
    color: var(--text);
    padding: 8px 12px;
}

.searchbar input::placeholder{
    color: #aa8091;
}

.top-actions{
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.nav-pill{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    color: #6f2946;
    background: rgba(255,255,255,.85);
    border: 1px solid rgba(142,24,50,.10);
    font-weight: 700;
    transition: .2s ease;
}

.nav-pill:hover{
    transform: translateY(-1px);
    background: rgba(255,255,255,.96);
}

.btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    font-weight: 800;
    transition: .22s ease;
    text-decoration: none;
    border: 1px solid transparent;
}

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

.btn-primary{
    background: linear-gradient(135deg, var(--primary), #cf537b);
    color: #fff;
    box-shadow: 0 14px 28px rgba(142,24,50,.18);
}

.btn-primary:hover{
    box-shadow: 0 18px 30px rgba(142,24,50,.24);
}

.btn-secondary{
    background: rgba(255,255,255,.88);
    color: #692643;
    border-color: rgba(142,24,50,.12);
}

.btn-soft{
    background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,232,240,.95));
    color: #732845;
    border: 1px solid rgba(142,24,50,.10);
}

.btn-small{
    min-height: 38px;
    padding: 0 14px;
    font-size: .92rem;
}

.btn-full,
.cart-footer-form{
    width: 100%;
}

.text-center{
    text-align: center;
}

.icon-btn{
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 999px;
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(142,24,50,.12);
    color: #6a2642;
    box-shadow: var(--shadow-soft);
    font-size: 1.1rem;
}

.badge-count{
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 21px;
    height: 21px;
    padding: 0 6px;
    display: grid;
    place-items: center;
    font-size: .72rem;
    color: #fff;
    background: linear-gradient(135deg, #d62d68, #b21f4d);
    border-radius: 999px;
    font-weight: 900;
    box-shadow: 0 8px 16px rgba(182,31,77,.28);
}

.mobile-only{
    display: none;
}

.desktop-only{
    display: inline-flex;
}

.hero{
    position: relative;
    padding: 28px 0 18px;
}

.hero-premium .container{
    position: relative;
}

.hero-showcase{
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(300px, .85fr);
    gap: 28px;
    align-items: stretch;
    background:
        radial-gradient(circle at 15% 20%, rgba(255,255,255,.75), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,236,244,.70));
    border: 1px solid rgba(255,255,255,.66);
    box-shadow: var(--shadow);
    border-radius: 34px;
    overflow: hidden;
    min-height: 520px;
}

.hero-showcase::before{
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 82% 26%, rgba(255,255,255,.65), transparent 16%),
        radial-gradient(circle at 72% 68%, rgba(255,219,233,.52), transparent 18%),
        radial-gradient(circle at 90% 84%, rgba(255,208,224,.45), transparent 16%);
}

.hero-showcase-copy{
    position: relative;
    z-index: 1;
    padding: 56px 42px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.hero-kicker{
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(142,24,50,.10);
    color: #762844;
    font-size: .86rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.hero-showcase-title{
    margin: 18px 0 14px;
    font-size: clamp(2.3rem, 4.3vw, 4.7rem);
    line-height: .98;
    letter-spacing: -.04em;
    color: #5b1f37;
}

.hero-showcase-text{
    margin: 0;
    max-width: 620px;
    color: #7c5667;
    font-size: 1.03rem;
    line-height: 1.75;
}

.hero-actions{
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 24px;
}

.hero-showcase-visual{
    position: relative;
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 36px;
}

.hero-logo-stage{
    position: relative;
    width: min(100%, 500px);
    aspect-ratio: 1 / 1;
    border-radius: 38px;
    overflow: hidden;
    background:
        radial-gradient(circle at top, rgba(255,255,255,.78), transparent 44%),
        linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,233,242,.80));
    border: 1px solid rgba(255,255,255,.70);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,.8),
        0 20px 45px rgba(142,24,50,.12);
    display: grid;
    place-items: center;
}

.hero-logo-stage::before,
.hero-logo-stage::after{
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(1px);
}

.hero-logo-stage::before{
    width: 180px;
    height: 180px;
    top: 12%;
    right: 10%;
    background: radial-gradient(circle, rgba(255,255,255,.55), transparent 70%);
}

.hero-logo-stage::after{
    width: 240px;
    height: 240px;
    left: 2%;
    bottom: 0;
    background: radial-gradient(circle, rgba(255,213,227,.52), transparent 70%);
}

.hero-logo-stage img{
    width: 78%;
    height: 78%;
    object-fit: contain;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 18px 35px rgba(142,24,50,.10));
}

.hero-logo-fallback{
    width: 72%;
    height: 72%;
    border-radius: 32px;
    font-size: clamp(4rem, 12vw, 7rem);
}

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

.hero-strip-item{
    background: rgba(255,255,255,.82);
    border: 1px solid rgba(255,255,255,.62);
    box-shadow: var(--shadow-soft);
    border-radius: 24px;
    padding: 18px 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.hero-strip-label{
    color: #9b7182;
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.hero-strip-item strong{
    color: #5d2038;
    line-height: 1.45;
}

.hero-strip-cta{
    justify-content: space-between;
}

.notice{
    margin-bottom: 16px;
    padding: 16px 18px;
    border-radius: 18px;
    font-weight: 700;
    border: 1px solid transparent;
    box-shadow: var(--shadow-soft);
}

.notice.success{
    background: rgba(26, 127, 55, 0.10);
    border-color: rgba(26, 127, 55, 0.14);
    color: var(--success);
}

.notice.error{
    background: rgba(180, 35, 24, 0.08);
    border-color: rgba(180, 35, 24, 0.12);
    color: var(--danger);
}

/* =========================
   CATEGORÍAS EN SLIDER
   ========================= */

.categories-section-card{
    overflow: hidden;
}

.categories-head{
    align-items: center;
    gap: 16px;
}

.categories-tools{
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.categories-arrows{
    display: flex;
    align-items: center;
    gap: 8px;
}

.category-slider-btn{
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
}

.categories-slider-wrap{
    position: relative;
}

.categories-grid.categories-slider{
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 320px);
    gap: 18px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 8px;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
}

.categories-slider::-webkit-scrollbar{
    height: 10px;
}

.categories-slider::-webkit-scrollbar-track{
    background: rgba(142,24,50,.08);
    border-radius: 999px;
}

.categories-slider::-webkit-scrollbar-thumb{
    background: linear-gradient(135deg, rgba(142,24,50,.65), rgba(204,82,121,.70));
    border-radius: 999px;
}

.category-slide{
    scroll-snap-align: start;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    position: relative;
}

.category-card{
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 100%;
    padding: 16px;
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,240,246,.94));
    border: 1px solid rgba(142,24,50,.10);
    box-shadow: var(--shadow-soft);
    transition: .24s ease;
    overflow: hidden;
}

.category-card:hover{
    transform: translateY(-4px);
    box-shadow: 0 18px 38px rgba(142,24,50,.13);
}

.category-card-link{
    display: flex;
    flex-direction: column;
    flex: 1;
    color: inherit;
    text-decoration: none;
}

.category-card-all{
    background:
        linear-gradient(135deg, rgba(142,24,50,.95), rgba(204,81,119,.88));
    color: #fff;
}

.category-card-all .category-desc,
.category-card-all .category-name{
    color: inherit;
}

.category-media{
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    background:
        radial-gradient(circle at top, rgba(255,255,255,.70), transparent 40%),
        linear-gradient(180deg, rgba(255,244,248,.9), rgba(255,232,239,.95));
    aspect-ratio: 4 / 5;
    display: flex;
    align-items: center;
    justify-content: center;
}

.category-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s ease;
}

.category-card:hover .category-media img{
    transform: scale(1.05);
}

.category-placeholder{
    font-size: clamp(2.6rem, 5vw, 4rem);
    font-weight: 900;
    color: rgba(122,44,74,.54);
}

.category-name{
    font-size: 1.05rem;
    font-weight: 800;
    color: #60223b;
}

.category-desc{
    color: var(--muted);
    line-height: 1.55;
    font-size: .94rem;
}

.category-actions{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 14px;
}

.is-current-category{
    border-color: rgba(142,24,50,.28);
    box-shadow: 0 20px 42px rgba(142,24,50,.16);
}

.is-current-category::after{
    content: "Categoría actual";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--primary), #cc5279);
    color: #fff;
    font-size: .76rem;
    font-weight: 800;
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    box-shadow: 0 10px 20px rgba(142,24,50,.20);
}

.category-card-all .category-actions .btn-secondary{
    background: rgba(255,255,255,.18);
    color: #fff;
    border-color: rgba(255,255,255,.22);
}

.category-card-all .category-actions .btn-primary{
    background: #fff;
    color: #8e1832;
    border-color: transparent;
    box-shadow: none;
}

.brands-grid{
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.brand-card{
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 100%;
    padding: 16px;
    border-radius: 22px;
    background: rgba(255,255,255,.84);
    border: 1px solid rgba(142,24,50,.10);
    box-shadow: var(--shadow-soft);
}

.brand-logo-thumb{
    width: 72px;
    height: 72px;
    object-fit: contain;
    border-radius: 18px;
    background: rgba(255,245,249,.95);
    border: 1px solid rgba(142,24,50,.10);
    padding: 8px;
    flex-shrink: 0;
}

.brand-logo-thumb-fallback{
    display: grid;
    place-items: center;
    font-size: 1.4rem;
    font-weight: 900;
    color: #752847;
}

.brand-name{
    font-weight: 800;
    color: #5e2039;
}

.brand-meta-small{
    margin-top: 6px;
    color: var(--muted);
    font-size: .92rem;
}

.filter-chips{
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.chip,
.selector-chip,
.mini-chip{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    font-weight: 700;
    transition: .2s ease;
}

.chip{
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(142,24,50,.11);
    color: #6d2845;
}

.chip.is-active,
.selector-chip.is-active{
    background: linear-gradient(135deg, var(--primary), #cc5279);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 12px 24px rgba(142,24,50,.18);
}

.products-section-card{
    overflow: hidden;
}

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

.product-card{
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    overflow: hidden;
    border-radius: 28px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,239,245,.96));
    border: 1px solid rgba(142,24,50,.10);
    box-shadow: var(--shadow-soft);
    transition: .24s ease;
}

.product-card:hover{
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(142,24,50,.14);
}

.product-image-wrap{
    position: relative;
    aspect-ratio: 4 / 4.5;
    overflow: hidden;
    cursor: pointer;
    background:
        radial-gradient(circle at top, rgba(255,255,255,.72), transparent 40%),
        linear-gradient(180deg, rgba(255,246,249,.98), rgba(255,232,239,.96));
}

.product-image{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s ease;
}

.product-card:hover .product-image{
    transform: scale(1.05);
}

.product-badges{
    position: absolute;
    top: 14px;
    left: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.badge{
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    color: #fff;
    font-size: .76rem;
    font-weight: 900;
    box-shadow: 0 10px 18px rgba(0,0,0,.12);
}

.badge.sale{
    background: linear-gradient(135deg, #d6306b, #b41f4d);
}

.badge.new{
    background: linear-gradient(135deg, #c79f62, #b88840);
}

.badge.stock-low{
    background: linear-gradient(135deg, #6e7280, #525866);
}

.product-body{
    padding: 18px 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
}

.product-title{
    font-size: 1.06rem;
    font-weight: 800;
    color: #5b2038;
    line-height: 1.35;
    cursor: pointer;
}

.product-meta{
    color: var(--muted);
    line-height: 1.55;
    min-height: 46px;
    font-size: .94rem;
}

.price-row{
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 10px;
}

.price-old{
    color: #a1828f;
    text-decoration: line-through;
    font-weight: 700;
    font-size: .95rem;
}

.price-now{
    color: #5d1f38;
    font-weight: 900;
    font-size: 1.22rem;
}

.variant-preview{
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.mini-chip{
    min-height: 34px;
    padding: 0 12px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(142,24,50,.10);
    color: #6f2a47;
    font-size: .84rem;
}

.product-actions{
    display: flex;
    gap: 10px;
    margin-top: auto;
}

.product-actions .btn{
    flex: 1;
}

.empty-state{
    padding: 34px 22px;
    text-align: center;
    color: var(--muted);
    border-radius: 22px;
    background: rgba(255,255,255,.72);
    border: 1px dashed rgba(142,24,50,.15);
}

.sidebar-overlay,
.cart-overlay,
.modal-overlay{
    position: fixed;
    inset: 0;
    background: rgba(56, 16, 33, 0.32);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: .25s ease;
    z-index: 110;
    backdrop-filter: blur(4px);
}

.sidebar-overlay.is-open,
.cart-overlay.is-open,
.modal-overlay.is-open{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.mobile-sidebar{
    position: fixed;
    top: 0;
    left: 0;
    width: min(88vw, 380px);
    height: 100vh;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,240,246,.96));
    box-shadow: 18px 0 42px rgba(79, 24, 45, 0.18);
    transform: translateX(-102%);
    transition: transform .28s ease;
    z-index: 120;
    display: flex;
    flex-direction: column;
    padding: 18px;
}

.mobile-sidebar.is-open{
    transform: translateX(0);
}

.sidebar-head{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(142,24,50,.10);
}

.sidebar-list{
    display: grid;
    gap: 12px;
    padding-top: 18px;
}

.sidebar-link{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 54px;
    padding: 0 16px;
    border-radius: 18px;
    background: rgba(255,255,255,.88);
    border: 1px solid rgba(142,24,50,.10);
    color: #662740;
    font-weight: 700;
}

.cart-panel{
    position: fixed;
    top: 0;
    right: 0;
    width: min(96vw, 460px);
    height: 100vh;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,240,246,.96));
    box-shadow: -18px 0 42px rgba(79, 24, 45, 0.18);
    transform: translateX(103%);
    transition: transform .28s ease;
    z-index: 120;
    display: flex;
    flex-direction: column;
}

.cart-panel.is-open{
    transform: translateX(0);
}

.cart-head{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 20px 16px;
    border-bottom: 1px solid rgba(142,24,50,.10);
}

.cart-title-inline{
    margin: 0;
}

.cart-items{
    flex: 1;
    overflow: auto;
    padding: 16px 20px;
    display: grid;
    gap: 14px;
}

.cart-item{
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 14px;
    padding: 14px;
    border-radius: 20px;
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(142,24,50,.10);
}

.cart-item img{
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 16px;
}

.cart-item-title{
    font-weight: 800;
    color: #5e2139;
    line-height: 1.35;
}

.cart-item-meta{
    margin-top: 6px;
    color: var(--muted);
    line-height: 1.55;
    font-size: .92rem;
}

.cart-item-price{
    margin-top: 10px;
    color: #5d2038;
    font-weight: 900;
}

.cart-qty-row{
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 12px;
}

.cart-form-inline{
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.cart-form-inline input[type="number"]{
    width: 90px;
    min-height: 38px;
    border-radius: 12px;
    border: 1px solid rgba(142,24,50,.14);
    background: #fff;
    padding: 0 12px;
    outline: none;
}

.cart-footer{
    padding: 18px 20px 24px;
    border-top: 1px solid rgba(142,24,50,.10);
    background: rgba(255,255,255,.78);
}

.cart-summary,
.cart-total{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.cart-summary{
    color: var(--muted);
    margin-bottom: 8px;
}

.cart-total{
    color: #5d2038;
    font-size: 1.12rem;
    font-weight: 900;
}

.cart-footer-actions{
    display: grid;
    gap: 12px;
    margin-top: 16px;
}

.modal{
    position: fixed;
    inset: 0;
    z-index: 130;
    display: grid;
    place-items: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: .25s ease;
}

.modal.is-open{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.modal-card{
    position: relative;
    width: min(1100px, 100%);
    max-height: min(90vh, 920px);
    overflow: auto;
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,241,246,.97));
    border: 1px solid rgba(255,255,255,.75);
    box-shadow: 0 30px 60px rgba(85, 25, 46, 0.22);
    padding: 26px;
}

.modal-close{
    position: absolute;
    top: 18px;
    right: 18px;
    z-index: 5;
}

.modal-grid{
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
    gap: 26px;
}

.modal-gallery-main{
    width: 100%;
    aspect-ratio: 1 / 1.06;
    border-radius: 26px;
    overflow: hidden;
    background:
        radial-gradient(circle at top, rgba(255,255,255,.78), transparent 38%),
        linear-gradient(180deg, rgba(255,247,250,.98), rgba(255,233,240,.96));
    border: 1px solid rgba(142,24,50,.08);
}

.modal-gallery-main img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.modal-thumbs{
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.modal-thumb{
    padding: 0;
    border-radius: 16px;
    overflow: hidden;
    border: 2px solid transparent;
    background: transparent;
    transition: .18s ease;
}

.modal-thumb.is-active{
    border-color: var(--primary);
    box-shadow: 0 10px 20px rgba(142,24,50,.16);
}

.modal-thumb img{
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.eyebrow{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.eyebrow-dark{
    color: #6f2a47;
    background: rgba(255,255,255,.90);
    border: 1px solid rgba(142,24,50,.10);
}

.dot{
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.dot-dark{
    background: var(--primary);
}

.modal-title{
    margin: 14px 0 12px;
    font-size: clamp(1.8rem, 2.6vw, 2.5rem);
    line-height: 1.05;
    color: #5b1f37;
}

.modal-price-row{
    margin-bottom: 10px;
}

.modal-description{
    color: #765566;
    line-height: 1.75;
    margin-bottom: 16px;
}

.selector-group + .selector-group{
    margin-top: 16px;
}

.selector-label,
.qty-label{
    display: block;
    margin-bottom: 10px;
    color: #6f2947;
    font-size: .92rem;
    font-weight: 800;
}

.selector-options{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.selector-chip{
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(142,24,50,.11);
    color: #6d2845;
    min-height: 40px;
}

.selector-chip.is-disabled{
    opacity: .55;
}

.qty-box{
    margin-top: 18px;
}

.qty-box input{
    width: 110px;
    min-height: 46px;
    padding: 0 14px;
    border-radius: 14px;
    border: 1px solid rgba(142,24,50,.14);
    background: #fff;
    color: var(--text);
    outline: none;
}

.modal-form-actions{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 22px;
}

.info-item{
    padding: 18px;
    border-radius: 22px;
    background: rgba(255,255,255,.84);
    border: 1px solid rgba(142,24,50,.10);
    box-shadow: var(--shadow-soft);
}

.info-title{
    color: #61233c;
    font-weight: 800;
    margin-bottom: 8px;
}

.info-text{
    color: var(--muted);
    line-height: 1.7;
}

.contact-layout{
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
    gap: 20px;
}

.contact-grid-card,
.map-card{
    background: var(--card);
    border-radius: 28px;
    border: 1px solid rgba(255,255,255,.64);
    box-shadow: var(--shadow);
    padding: 24px;
}

.contact-head{
    margin-bottom: 18px;
}

.contact-info-item{
    margin-bottom: 14px;
}

.contact-buttons{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.contact-buttons .full{
    width: 100%;
}

.map-frame-wrap{
    overflow: hidden;
    border-radius: 24px;
    min-height: 100%;
    background:
        linear-gradient(180deg, rgba(255,250,252,.98), rgba(255,236,243,.96));
    border: 1px solid rgba(142,24,50,.10);
}

.map-frame{
    width: 100%;
    height: 100%;
    min-height: 480px;
    border: 0;
}

.map-fallback{
    min-height: 480px;
    display: grid;
    place-items: center;
    padding: 24px;
    text-align: center;
    gap: 14px;
    color: var(--muted);
}

.footer{
    padding: 20px 0 34px;
}

.footer-box{
    text-align: center;
    padding: 18px;
    border-radius: 22px;
    color: #7d5969;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(255,255,255,.62);
    box-shadow: var(--shadow-soft);
}

.site-flower{
    position: fixed;
    width: 260px;
    height: 260px;
    z-index: 0;
    pointer-events: none;
    opacity: .14;
    background-image: var(--flowers-url);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    filter: blur(.2px);
}

.site-flower-top{
    top: -28px;
    right: -18px;
    transform: rotate(12deg);
}

.site-flower-bottom{
    left: -28px;
    bottom: -18px;
    transform: rotate(192deg);
}

main,
.topbar,
.footer{
    position: relative;
    z-index: 1;
}

.is-night-category{
    background:
        radial-gradient(circle at top, rgba(45, 55, 88, .45), transparent 25%),
        linear-gradient(180deg, #140f19 0%, #1b1221 45%, #24172b 100%);
    color: #f8f0f5;
}

.is-night-category .section-card,
.is-night-category .contact-grid-card,
.is-night-category .map-card,
.is-night-category .footer-box,
.is-night-category .topbar-shell,
.is-night-category .brand-logo,
.is-night-category .product-card,
.is-night-category .brand-card,
.is-night-category .category-card,
.is-night-category .hero-showcase,
.is-night-category .hero-strip-item{
    background:
        linear-gradient(180deg, rgba(34,24,43,.90), rgba(28,20,36,.92));
    border-color: rgba(255,255,255,.08);
    color: #f5eaf1;
}

.is-night-category .section-title,
.is-night-category .section-mini-title,
.is-night-category .product-title,
.is-night-category .brand-name,
.is-night-category .hero-showcase-title,
.is-night-category .price-now,
.is-night-category .cart-item-title,
.is-night-category .cart-total{
    color: #fff;
}

.is-night-category .section-subtitle,
.is-night-category .product-meta,
.is-night-category .brand-meta-small,
.is-night-category .category-desc,
.is-night-category .info-text,
.is-night-category .footer-box,
.is-night-category .brand-subtitle{
    color: rgba(255,255,255,.72);
}

.night-products-mode{
    position: relative;
    overflow: hidden;
}

.night-products-mode::before{
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle, rgba(255,255,255,.70) 0 1px, transparent 2px) 8% 14% / 180px 180px,
        radial-gradient(circle, rgba(255,255,255,.55) 0 1.2px, transparent 2.2px) 72% 18% / 220px 220px,
        radial-gradient(circle, rgba(255,255,255,.55) 0 1px, transparent 2px) 42% 74% / 200px 200px,
        radial-gradient(circle, rgba(255,255,255,.50) 0 1px, transparent 2px) 90% 60% / 240px 240px;
    opacity: .55;
    animation: twinkleStars 5s ease-in-out infinite alternate;
}

@keyframes twinkleStars{
    0%{ opacity: .35; transform: translateY(0); }
    100%{ opacity: .7; transform: translateY(-2px); }
}

@media (max-width: 1200px){
    .brands-grid{
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

    .hero-showcase{
        grid-template-columns: 1fr;
        min-height: unset;
    }

    .hero-showcase-visual{
        min-height: 360px;
    }

    .contact-layout{
        grid-template-columns: 1fr;
    }
}

@media (max-width: 980px){
    .desktop-only{
        display: none;
    }

    .mobile-only{
        display: inline-flex;
    }

    .topbar-shell{
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px;
        border-radius: 28px;
    }

    .topbar-center{
        grid-column: 1 / -1;
        order: 3;
    }

    .hero-strip{
        grid-template-columns: 1fr;
    }

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

    .modal-card{
        padding: 20px;
    }

    .categories-head{
        align-items: flex-start;
    }

    .categories-tools{
        width: 100%;
        justify-content: flex-start;
    }
}

@media (max-width: 768px){
    .container{
        width: min(100% - 18px, var(--container));
    }

    .section{
        padding: 18px 0;
    }

    .section-card,
    .contact-grid-card,
    .map-card{
        padding: 18px;
        border-radius: 22px;
    }

    .topbar{
        padding: 10px 0;
    }

    .topbar-shell{
        padding: 10px;
    }

    .brand-logo{
        width: 46px;
        height: 46px;
        border-radius: 14px;
    }

    .brand-title{
        font-size: .95rem;
    }

    .brand-subtitle{
        font-size: .78rem;
    }

    .searchbar{
        border-radius: 18px;
        padding: 8px;
    }

    .searchbar input{
        font-size: .95rem;
    }

    .hero{
        padding-top: 16px;
    }

    .hero-showcase{
        border-radius: 24px;
    }

    .hero-showcase-copy{
        padding: 28px 20px 18px;
    }

    .hero-showcase-title{
        font-size: clamp(2rem, 10vw, 3rem);
    }

    .hero-showcase-text{
        font-size: .98rem;
        line-height: 1.68;
    }

    .hero-showcase-visual{
        padding: 18px 20px 24px;
        min-height: 280px;
    }

    .hero-logo-stage{
        border-radius: 26px;
    }

    .hero-actions{
        flex-direction: column;
        align-items: stretch;
    }

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

    .brands-grid,
    .products-grid{
        grid-template-columns: 1fr;
    }

    .filter-chips{
        justify-content: flex-start;
    }

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

    .cart-panel{
        width: 100vw;
    }

    .cart-item{
        grid-template-columns: 80px minmax(0, 1fr);
    }

    .modal{
        padding: 10px;
    }

    .modal-card{
        border-radius: 24px;
        padding: 16px;
        max-height: 94vh;
    }

    .modal-title{
        padding-right: 46px;
    }

    .modal-thumbs{
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .modal-form-actions{
        grid-template-columns: 1fr;
    }

    .map-frame,
    .map-fallback{
        min-height: 320px;
    }

    .site-flower{
        width: 180px;
        height: 180px;
        opacity: .11;
    }

    .categories-grid.categories-slider{
        grid-auto-columns: minmax(240px, 82vw);
        gap: 14px;
    }

    .categories-share-main{
        width: 100%;
    }

    .categories-arrows{
        width: 100%;
        justify-content: flex-end;
    }
}

@media (max-width: 560px){
    .topbar-shell{
        grid-template-columns: 1fr auto;
        align-items: center;
    }

    .brand{
        gap: 10px;
        min-width: 0;
    }

    .brand-meta{
        min-width: 0;
    }

    .top-actions{
        gap: 8px;
        flex-wrap: nowrap;
    }

    .icon-btn{
        width: 42px;
        height: 42px;
    }

    .hero-showcase-copy{
        padding: 24px 16px 16px;
    }

    .hero-strip-item{
        padding: 16px;
        border-radius: 18px;
    }

    .section-head{
        gap: 12px;
        margin-bottom: 18px;
    }

    .section-title{
        font-size: 1.3rem;
    }

    .category-card,
    .product-card,
    .brand-card{
        border-radius: 22px;
    }

    .category-media{
        border-radius: 16px;
    }

    .product-body{
        padding: 16px;
    }

    .chip,
    .selector-chip,
    .mini-chip{
        min-height: 34px;
        padding: 0 12px;
        font-size: .84rem;
    }

    .cart-items{
        padding: 14px;
    }

    .cart-head,
    .cart-footer{
        padding-left: 14px;
        padding-right: 14px;
    }

    .contact-buttons{
        flex-direction: column;
    }

    .contact-buttons .btn{
        width: 100%;
    }

    .category-actions{
        gap: 8px;
    }

    .category-slider-btn{
        width: 40px;
        height: 40px;
        flex-basis: 40px;
    }
}
.filter-chips{
    display: none !important;
}