h1,
h2,
h3,
h4,
h5,
h6,
p,
a {
    font-family: 'Manrope', sans-serif;
}

.mobile-menu {
    padding: 2rem;
}

.dropdown-enter-active,
.dropdown-leave-active {
    transition: opacity 0.1s ease-out, transform 0.1s ease-out;
}
.dropdown-enter-from,
.dropdown-leave-to {
    opacity: 0;
    transform: scale(0.9);
}

.mobile-menu ul {
    width: 100%;
    text-align: center;
}

.mobile-menu li {
    border-bottom: 1px solid #e0e0e0;
    padding-bottom: 1rem;
    padding-top: 1rem;
}

.mobile-dropdown-menu li{
    border-bottom: none;
    border-top: 1px solid #e0e0e0;
}

.mobile-dropdown-menu li:last-child {
    padding-bottom: 0;
}

.mobile-dropdown-menu{
   margin-top: 12px;
}

/* .group:hover h3,
.group:hover p {
    color: #ffffff;
} */

@keyframes scaleUp {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.2);
    }
}

.group-hover\:scale-120:hover {
    animation: scaleUp 0.3s forwards;
}

@keyframes slideDown {
    0% {
        transform: translateY(-20px);
        opacity: 0;
    }

    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

.search-slide-down {
    animation: slideDown 0.3s forwards;
}

/* home page */
.main-slider {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.main-slider .swiper-slide {
    position: relative;
    text-align: center;
}

.main-slider .swiper-slide img {
    width: 100%;
    height: auto;
    max-height: 800px;
    object-fit: cover;
}

@media(min-width:1400px){
    .main-slider .swiper-slide img {
        max-height: inherit;
    }
}

.main-slider .swiper-slide-content {
    position: absolute;
    bottom: 20%;
}

@media (max-width:640px) {
    .main-slider .swiper-slide-content{
        bottom: inherit;
        padding: 10px;
    }
}

.main-slider  .swiper-slide {
    padding: 0;
}

@media(min-width: 1400px) {
    .main-slider .swiper-slide-content {
        position: absolute;
        bottom: 20%;
        left: 10%;
        text-align: left;
    }
}

#product-slider .swiper-button-prev, #product-slider .swiper-button-next{
    color: #fff;
}

.brands-swiper-slider .swiper-button-prev, .brands-swiper-slider .swiper-button-next{
    color: #ff0042;
}

.brands-swiper-slider .swiper-button-next{
    right: 0;
}

.brands-swiper-slider .swiper-button-prev{
    left: 0;
}

.swiper {
    width: 100%;
    height: 100%;
}

.swiper-slide {
    text-align: center;
    font-size: 16px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brands-swiper-slider .swiper-slide img {
    width: auto;
    max-width: 100%;
    max-height: 80px;
    object-fit: contain;
}

.brands-swiper-slider .swiper-slide {
    min-height: 120px;
}

#popular-products .product-card-image,
[data-shopify-products] .shopify-product-image {
    width: 100%;
    display: block;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 0.75rem;
}

@media (min-width: 1024px) {
    .swiper-slide {
        padding: 25px;
    }
}

@media (max-width: 1023px) {

    .swiper-button-prev,
    .swiper-button-next {
        display: none;
    }
}

img.cursor-pointer:hover {
    opacity: 0.8;
}

/* single product tabs */
.tab {
    padding: 0.5rem 1rem;
    color: #010717; 
    border-bottom-width: 2px;
    border-color: transparent;
    font-size: 1rem;
    font-weight: 500; 
    cursor: pointer;
    transition: all 0.3s ease;
}
.tab:hover {
    color: #323232; 
    border-color: #ff0042; 
}
.tab.active {
    color: #ff0042; 
    border-color: #ff0042;
}
.tab-content {
    display: none;
}
.tab-content:not(.hidden) {
    display: block;
}


.custom-checkbox {
    appearance: none;
    background-color: #fff;
    border: 1px solid #d1d5db;
    padding: 0.5rem;
    display: inline-block;
    position: relative;
    cursor: pointer;
    outline: none;
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 0.25rem;
}

.custom-checkbox:checked {
    background-color: #ff0042;
    border-color: #ff0042;
}

/* Product detail page */
.product-details-layout {
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
}

@media (min-width: 1024px) {
    .product-details-layout {
        flex-direction: row;
        align-items: flex-start;
    }
}

.product-details-media {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    width: 100%;
}

@media (min-width: 1024px) {
    .product-details-media {
        flex-direction: row;
        width: 55%;
        position: sticky;
        top: 6rem;
        align-self: flex-start;
    }
}

.product-thumbs {
    display: flex;
    gap: 0.75rem;
}

.product-thumb {
    border-radius: 1rem;
    border: 1px solid #e5e7eb;
    overflow: hidden;
    height: 80px;
    width: 80px;
    padding: 0;
    background: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.product-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-thumb--active {
    border-color: var(--color-primary, #111827);
    box-shadow: 0 0 0 2px rgba(17, 24, 39, 0.12);
}

.product-thumbs--desktop {
    display: none;
}

@media (min-width: 1024px) {
    .product-thumbs--desktop {
        display: flex;
        flex-direction: column;
        overflow-y: auto;
        max-height: 560px;
        padding-right: 0.25rem;
        width: 96px;
        flex-shrink: 0;
    }

    .product-thumbs--mobile {
        display: none;
    }
}

.product-main {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
}

.product-main-image {
    position: relative;
    border-radius: 1.5rem;
    border: 1px solid rgba(229, 231, 235, 0.8);
    background: #fff;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

.product-main-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-info-panel {
    display: flex;
    flex-direction: column;
    gap: 1.75rem;
    width: 100%;
}

@media (min-width: 1024px) {
    .product-info-panel {
        width: 45%;
    }
}

.product-info-header {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.product-info-vendor {
    font-size: 0.75rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #6b7280;
    font-weight: 600;
}

.product-info-title {
    font-size: clamp(2rem, 3vw, 2.75rem);
    font-weight: 600;
    color: #111827;
    line-height: 1.15;
    margin: 0;
}

.product-info-rating {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.875rem;
    color: #4b5563;
}

.product-info-stars {
    display: flex;
    gap: 0.25rem;
    color: #facc15;
}

.product-info-rating-score {
    font-weight: 600;
    color: #374151;
}

.product-info-rating-count {
    color: #9ca3af;
}

.product-price-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    border: 1px solid #e5e7eb;
    background: #fff;
    padding: 1.5rem;
    border-radius: 1.25rem;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

.product-price-row {
    display: flex;
    align-items: flex-end;
    gap: 0.75rem;
}

.product-price-primary {
    font-size: clamp(2.5rem, 3.5vw, 3rem);
    font-weight: 600;
    color: #111827;
    margin: 0;
}

.product-price-secondary {
    font-size: 0.875rem;
    color: #6b7280;
    margin: 0;
}

.product-price-range {
    font-size: 2rem;
    font-weight: 600;
    color: #111827;
    margin: 0;
}

.product-price-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
    background: #fee2e2;
    color: #b91c1c;
    font-size: 0.875rem;
    font-weight: 600;
    width: fit-content;
}

.product-availability {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.product-availability-indicator {
    display: inline-flex;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #dc2626;
}

.product-availability--in .product-availability-indicator {
    background: #10b981;
}

.product-availability--in {
    color: #047857;
}

.product-availability--out {
    color: #b91c1c;
}

.product-variants {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.product-variants-label {
    font-size: 0.75rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #6b7280;
    font-weight: 600;
    margin: 0;
}

.product-variants-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.product-variant-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    background: #fff;
    font-size: 0.875rem;
    color: #374151;
}

.product-highlight-grid {
    display: grid;
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .product-highlight-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.product-highlight-card {
    border: 1px solid #e5e7eb;
    border-radius: 1rem;
    background: #fff;
    padding: 1rem;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
}

.product-highlight-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: #111827;
    margin: 0;
}

.product-highlight-subtitle {
    font-size: 0.75rem;
    color: #6b7280;
    margin: 0.35rem 0 0;
}

.product-purchase-card {
    border: 1px solid #e5e7eb;
    border-radius: 1.25rem;
    background: #fff;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    box-shadow: 0 15px 35px rgba(15, 23, 42, 0.06);
}

.product-quantity-control {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    justify-content: space-between;
}

.product-quantity-label {
    font-size: 0.875rem;
    font-weight: 600;
    color: #374151;
}

.product-quantity-input {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    overflow: hidden;
}

.product-quantity-input button {
    border: none;
    background: transparent;
    font-size: 1.25rem;
    font-weight: 600;
    padding: 0.5rem 1rem;
    color: #374151;
    cursor: pointer;
    transition: background 0.2s ease;
}

.product-quantity-input button:hover {
    background: #f3f4f6;
}

.product-quantity-input input {
    width: 70px;
    text-align: center;
    border: none;
    border-left: 1px solid #e5e7eb;
    border-right: 1px solid #e5e7eb;
    padding: 0.5rem 0.75rem;
    font-size: 1rem;
    color: #111827;
    appearance: textfield;
}

.product-quantity-input input::-webkit-outer-spin-button,
.product-quantity-input input::-webkit-inner-spin-button {
    margin: 0;
    -webkit-appearance: none;
}

.product-add-to-cart {
    border: none;
    width: 100%;
    padding: 0.85rem 1.5rem;
    border-radius: 999px;
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background: var(--color-primary, #111827);
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.product-add-to-cart:hover {
    background: var(--color-secondary, #1f2937);
    transform: translateY(-1px);
    box-shadow: 0 15px 30px rgba(17, 24, 39, 0.15);
}

.product-add-to-cart--disabled {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.product-description {
    font-size: 0.95rem;
    color: #4b5563;
    line-height: 1.7;
}

.product-description h1,
.product-description h2,
.product-description h3,
.product-description h4 {
    color: #111827;
    margin-top: 1.5rem;
}

/* ----------- NEW CSS ---------------- */

:root{ 
    --cart-width: 360px;
    --cart-bg: #ffffff;
    --muted: #8a8a8f;
    --accent-grad: linear-gradient(90deg,#ff8a00,#e52e71);
    --btn-bg: #0b0b0b;
    --radius: 10px;
    --gap: 16px;
}
#site-header { background: rgba(0, 0, 0, 0.75); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid rgba(255, 255, 255, 0.08); transition: background 0.3s ease, box-shadow 0.3s ease; }
#site-header.scrolled { background: rgba(15, 15, 20, 0.95); box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25); }
#site-header a span[data-content="/brand.wordmark"] { letter-spacing: 0.5px; background: linear-gradient(90deg, #fff 0%, #c5c5c5 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
#site-header nav a { color: #f5f5f5; font-size: 0.875rem; letter-spacing: 0.05em; position: relative; transition: color 0.3s ease; }
#site-header nav a::after { content: ""; position: absolute; bottom: -6px; left: 0; width: 0%; height: 2px; background: linear-gradient(90deg, #ff8a00, #e52e71); transition: width 0.3s ease; }
#site-header nav a:hover { color: #ff8a00; }
#site-header nav a:hover::after { width: 100%; }
.cart-wrapper a:hover { transform: scale(1.05); box-shadow: 0 0 16px rgba(229, 46, 113, 0.45); }
.mobile-menu { background: rgba(25, 25, 30, 0.95); backdrop-filter: blur(8px); border-top: 1px solid rgba(255, 255, 255, 0.1); }
#hamburger:hover { background: linear-gradient(145deg, #ff8a00, #e52e71); transform: scale(1.05); transition: all 0.3s ease; }
[data-cart-preview]{ width: var(--cart-width) !important; padding: 22px !important; background: var(--cart-bg) !important; border-radius: var(--radius) 0 0 var(--radius) !important; box-shadow: -26px 12px 60px rgba(7,7,10,0.22) !important; font-family: "Inter", "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial; color: #111; }
[data-cart-preview] { position: fixed; }
[data-cart-preview] > .drawer-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom: 10px; }
[data-cart-preview] h3,
[data-cart-preview] [data-content="/navigation.cartLink.label"]{ font-size: 20px; letter-spacing: 0.06em; font-weight: 700; text-transform: uppercase; margin: 0 0 6px 0; }
[data-cart-preview-list]{ list-style:none; padding:0; margin: 6px 0 18px 0; display:block; gap: var(--gap); }
[data-cart-preview-list] > * { display:flex; gap:12px; align-items:flex-start; padding: 12px 0; border-bottom: 1px solid rgba(15,15,20,0.04); }
[data-cart-preview-list] img,
[data-cart-preview-list] .cart-thumb { width:72px; height:72px; object-fit:cover; border-radius:8px; flex-shrink:0; background:#f6f6f6; box-shadow: 0 6px 20px rgba(0,0,0,0.06) inset; }
[data-cart-preview-list] .cart-info,
[data-cart-preview-list] .info { flex:1 1 auto; min-width:0; }
[data-cart-preview-list] .cart-info h4,
[data-cart-preview-list] .cart-info .title,
[data-cart-preview-list] .title { font-size: 14px; font-weight: 600; margin: 0 0 6px 0; color: #111; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
[data-cart-preview-list] .cart-info p,
[data-cart-preview-list] .meta,
[data-cart-preview-list] .cart-info .meta { margin: 0; font-size: 12px; color: var(--muted); line-height:1.2;}
[data-cart-preview-list] .qty,
[data-cart-preview-list] .quantity,
[data-cart-preview-list] input[type="number"]{ display:inline-flex; gap:6px; align-items:center; margin-top:8px;}
[data-cart-preview-list] input[type="number"]{ width:56px; padding:6px 8px; border:1px solid rgba(15,15,20,0.08); border-radius:6px; background:#fff; font-size:13px;}
[data-cart-preview-list] .price,
[data-cart-preview-list] .cart-price,
[data-cart-preview-list] .amount { font-weight:700; font-size:14px; margin-left:12px; white-space:nowrap; align-self:flex-start; color:#111;}
[data-cart-preview-list] > * { justify-content: space-between; }
[data-cart-preview-summary]{ margin-top: 18px; padding-top: 16px; border-top: 1px solid rgba(15,15,20,0.04);}
[data-cart-preview-summary] .subtotal-row,
[data-cart-preview-summary] .subtotal { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; font-size:14px; color:#111;}
[data-cart-preview-summary] .subtotal-row span.label{ color:var(--muted); font-size:12px; letter-spacing:0.08em; text-transform:uppercase;}
[data-cart-preview-summary] .checkout,
[data-cart-preview-summary] a[href*="checkout"],
[data-cart-preview-summary] .btn-checkout,
[data-cart-preview-summary] a.block { display:block; text-align:center; width:100%; padding:14px 18px; border-radius:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; text-decoration:none; background: var(--btn-bg); color:#fff; box-shadow: 0 10px 30px rgba(11,11,11,0.18); border: none;}
[data-cart-preview-summary] .view-cart,
[data-cart-preview-summary] a.view { display:block; margin-top:10px; text-align:center; padding:10px 12px; border-radius:8px; border:1px solid rgba(15,15,20,0.06); color:#111; text-decoration:none; background: transparent; }
[data-cart-preview] [data-cart-preview-empty]{ font-size:14px; color:var(--muted); padding: 20px 8px; }
[data-cart-preview]::-webkit-scrollbar{ width:10px; }
[data-cart-preview]::-webkit-scrollbar-thumb{ background: rgba(0,0,0,0.06); border-radius: 10px; }

@media (max-width: 1023px){
    :root{ --cart-width: 100vw; }
    [data-cart-preview] { padding:18px; border-radius:0; }
    [data-cart-preview]::after { top:14px; right:14px; }
}

.cart-wrapper:hover [data-cart-preview],
.cart-wrapper:focus-within [data-cart-preview]{ transition: transform 0.28s cubic-bezier(.2,.9,.2,1), opacity 0.2s ease; }
[data-cart-preview] { position: fixed !important; top: 18px !important; right: 18px !important; max-width: 420px !important; width: clamp(300px, 22vw, 380px) !important; box-sizing: border-box !important; padding: 18px !important; border-radius: 12px !important; transform: translateX(110%) !important; overflow: hidden !important; -webkit-overflow-scrolling: touch !important; }
[data-cart-preview]::before { left: 0; width: calc(100% - min(420px, 22vw)); }
[data-cart-preview] > * { max-height: calc(100vh - 60px); overflow-y: auto; -webkit-overflow-scrolling: touch; }
[data-cart-preview-list] > * { display: flex !important; gap: 12px !important; align-items: flex-start !important; justify-content: space-between !important; padding: 12px 0 !important; min-height: 72px; }
[data-cart-preview-list] > * > .cart-left,
[data-cart-preview-list] > * > .left,
[data-cart-preview-list] > * > .cart-info { display:flex; gap:12px; align-items:flex-start; flex: 1 1 auto; min-width: 0; }
[data-cart-preview-list] img,
[data-cart-preview-list] .cart-thumb { width: 72px; height: 72px; flex: 0 0 72px; border-radius: 8px; object-fit: cover; }
[data-cart-preview-list] .title,
[data-cart-preview-list] .cart-info h4,
[data-cart-preview-list] .cart-info .title,
[data-cart-preview-list] .cart-info > p:first-child { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; white-space: normal; word-break: break-word; font-size: 13.5px; line-height: 1.2; margin: 0; color: #111;}
[data-cart-preview-list] .meta,
[data-cart-preview-list] .cart-info .meta,
[data-cart-preview-list] .cart-info p.meta { font-size: 12px; color: #7c7c84; margin-top: 6px;}
[data-cart-preview-list] .price,
[data-cart-preview-list] .cart-price,
[data-cart-preview-list] .amount { flex: 0 0 auto; margin-left: 12px; white-space: nowrap; font-weight: 700; font-size: 14px; color: #111; align-self: center;}
[data-cart-preview-list] .left .price { margin-left: auto;}
[data-cart-preview-list] > * + * { border-top: 1px solid rgba(15,15,20,0.04); }
[data-cart-preview]::after { top: 14px; right: 14px; font-size: 16px; color: #222; background: rgba(255,255,255,0.9); padding: 6px; border-radius: 6px; box-shadow: 0 4px 12px rgba(0,0,0,0.06);}

@media (max-width: 1023px){
    [data-cart-preview] { right: 0 !important; left: 0 !important; width: 100vw !important; max-width: 100vw !important; top: 0 !important; border-radius: 0 !important; }
    [data-cart-preview]::before { width: 0; }
}

[data-cart-preview]::-webkit-scrollbar { width: 10px; height: 10px; }
[data-cart-preview]::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.06); border-radius: 8px; }
.cart-wrapper:hover [data-cart-preview],
.cart-wrapper:focus-within [data-cart-preview]{ transform: translateX(0) !important; opacity: 1 !important; pointer-events: auto !important;}

/* Slider CSS */
:root{
    --hero-height: 88vh;
    --hero-overlay: linear-gradient(180deg, rgba(6,6,8,0.28), rgba(6,6,8,0.46));
    --accent-btn: linear-gradient(90deg,#ff8a00,#e52e71);
    --muted: #c4c4c8;
    --heading-size: clamp(2.25rem, 5vw, 4.5rem);
    --sub-size: clamp(1rem, 2.2vw, 1.375rem);
}
#product-slider { position: relative; overflow: visible; }
.main-slider,
.main-slider .swiper-container,
.main-slider .swiper-wrapper,
.main-slider .swiper-slide { height: var(--hero-height); }
.main-slider .swiper-slide img { width: 100%; height: 100%; object-fit: cover; transform-origin: center center; transition: transform 12s cubic-bezier(.2,.9,.2,1); will-change: transform; backface-visibility: hidden; }
.main-slider .swiper-slide-active img { transform: scale(1.06); }
.main-slider .swiper-slide > .bg-overlay,
.main-slider .swiper-slide > .absolute.bg-black\/40 { position: absolute; inset: 0; background: var(--hero-overlay); pointer-events: none; }
.main-slider .swiper-slide .relative.z-10 { position: relative; z-index: 5; max-width: 1100px; margin: 0 auto; padding: 2.25rem 1.25rem; }
.main-slider .swiper-slide h2,
.main-slider .swiper-slide [data-content="heading"]{ font-family: "Manrope", "Poppins", Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial; font-weight: 800; font-size: var(--heading-size); color: #fff; line-height: 1.02; margin: 0 0 0.6rem 0; letter-spacing: -0.02em; text-wrap: balance; text-shadow: 0 6px 30px rgba(0,0,0,0.45); }
.main-slider .swiper-slide p,
.main-slider .swiper-slide [data-content="body"]{ font-size: var(--sub-size); color: rgba(255,255,255,0.92); max-width: 56ch; margin: 0 auto 1.25rem auto; line-height: 1.35; filter: drop-shadow(0 6px 18px rgba(0,0,0,0.25)); }
.main-slider .swiper-slide a.inline-block { display:inline-block; padding: .9rem 1.6rem; border-radius: 999px; font-weight: 700; letter-spacing: 0.02em; box-shadow: 0 12px 30px rgba(229,46,113,0.16); transition: transform 220ms ease, box-shadow 220ms ease, opacity 220ms ease; background: var(--accent-btn); color: #fff; border: none; text-decoration: none; }
.main-slider .swiper-slide a.inline-block:hover{ transform: translateY(-4px) scale(1.01); box-shadow: 0 18px 40px rgba(229,46,113,0.22); }
.swiper-button-next,
.swiper-button-prev { width: 48px; height: 48px; border-radius: 12px; background: rgba(255,255,255,0.92); color: #111; display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 30px rgba(7,7,10,0.12); transition: transform 180ms ease, opacity 180ms ease; border: 0; }
.swiper-button-next:hover,
.swiper-button-prev:hover{ transform: translateY(-3px); }
.swiper-button-next::after,
.swiper-button-prev::after { font-size: 14px; font-weight: 700; }
.swiper-button-prev { left: 24px; }
.swiper-button-next { right: 24px; top: 50%; transform: translateY(-50%); }
.swiper-pagination { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); display:flex; gap:8px; z-index: 10; }
.swiper-pagination-bullet { width: 14px; height: 4px; border-radius: 999px; opacity: 0.45; background: rgba(255,255,255,0.85); transition: width 220ms ease, opacity 220ms ease, background 220ms ease; }
.swiper-pagination-bullet-active { width: 40px; opacity: 1; background: linear-gradient(90deg,#ff8a00,#e52e71); box-shadow: 0 8px 22px rgba(229,46,113,0.18); }

@media (max-width: 780px) {
    :root { --hero-height: 80vh; }
    #product-slider{min-height: 85vh;}
    .main-slider .swiper-slide .relative.z-10 { padding: 1.25rem; }
    .main-slider .swiper-slide h2 { font-size: clamp(1.5rem,7vw,2.4rem); line-height:1.05; }
    .main-slider .swiper-slide p { font-size: 0.95rem; max-width: 40ch; }
    .swiper-button-next, .swiper-button-prev { width:40px; height:40px; display:none; } /* hide arrows on small screens */
    .swiper-pagination { bottom: 18px; }
}
@media (prefers-reduced-motion: reduce){
    .main-slider .swiper-slide img,
    .main-slider .swiper-slide-active img { transition: none !important; transform: none !important; }
    .swiper-button-next, .swiper-button-prev { transition: none !important; }
}
@media (min-width: 1600px){
    .main-slider .swiper-slide .relative.z-10 { padding-left: 3.5rem; padding-right: 3.5rem; }
    .main-slider .swiper-slide h2 { font-size: 5.5rem; }
}
.main-slider { position: relative; z-index: 1; }
.main-slider .swiper-container,
.main-slider .swiper-wrapper,
.main-slider .swiper-slide { height: min(88vh, 980px); }
.swiper-button-next,
.swiper-button-prev { position: absolute; top: 50%; transform: translateY(-50%); width: 48px; height: 48px; border-radius: 12px; background: rgba(255,255,255,0.96); color: #111; display:flex; align-items:center; justify-content:center; box-shadow: 0 12px 28px rgba(7,7,10,0.12); border: none; z-index: 50; transition: transform .18s ease, box-shadow .18s ease; }
.swiper-button-prev { left: 20px; }
.swiper-button-next { right: 20px; }
.swiper-button-next::after,
.swiper-button-prev::after { font-size: 14px; font-weight: 700; color: #111; opacity: 1; }
.swiper-button-next:hover,
.swiper-button-prev:hover { transform: translateY(-50%) translateY(-4px); box-shadow: 0 18px 40px rgba(7,7,10,0.16); }
.swiper-pagination { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); display: flex; gap: 10px; z-index: 50; }
.swiper-pagination-bullet { width: 14px; height: 4px; background: rgba(255,255,255,0.9); opacity: 0.45; border-radius: 999px; transition: width .22s ease, background .22s ease, opacity .22s ease; }
.swiper-pagination-bullet-active { width: 44px; opacity: 1; background: linear-gradient(90deg,#ff8a00,#e52e71); box-shadow: 0 8px 22px rgba(229,46,113,0.12); }
.swiper-button-next,
.swiper-button-prev,
.swiper-pagination-bullet { backdrop-filter: blur(6px); }
.main-slider .swiper-slide img { transform-origin: center center; transition: transform 10s cubic-bezier(.2,.9,.2,1); will-change: transform; }
.main-slider .swiper-slide-active img { transform: scale(1.06); }
.main-slider .swiper-slide > .absolute.bg-black\/40,
.main-slider .swiper-slide .bg-overlay { pointer-events: none; background: linear-gradient(180deg, rgba(6,6,8,0.28), rgba(6,6,8,0.5)); }

@media (max-width: 780px) {
    .swiper-button-next,
    .swiper-button-prev { display:none; }
    .swiper-pagination { bottom: 18px; }
    .main-slider .swiper-container,
    .main-slider .swiper-wrapper,
    .main-slider .swiper-slide { height: 64vh; }
}
@media (prefers-reduced-motion: reduce) {
    .main-slider .swiper-slide img { transition: none; transform: none; }
}

/* Products Card CSS */
/* ===== Simple Premium Product Grid — drop-in CSS =====
   - Desktop: 4 columns
   - Tablet & Mobile: 2 columns
   - Only zoom-on-hover (no blur, no overlay, no CTA lift)
   - Equal-height tiles and consistent buttons
   ================================================== */

/* Theme vars (tweak colors / sizes here) */
:root{
    --pp-accent-grad: linear-gradient(90deg,#ff8a00 0%, #ff3f79 100%);
    --pp-primary: #ff3f79;
    --pp-text: #0f1724;
    --pp-muted: #7a7a81;
    --image-radius: 12px;
    --tile-min-height: 520px;
    --container-max: 1280px;
    --hover-zoom: 1.08;
}
#popular-products .container { max-width: var(--container-max) !important; margin-left: auto; margin-right: auto; padding-left: 24px !important; padding-right: 24px !important }
#popular-products .flex.flex-wrap > .w-full.sm\:w-1\/2.lg\:w-1\/4 { box-sizing: border-box; padding-left: 12px; padding-right: 12px; margin-bottom: 24px; width: 50% !important; max-width: 50% !important; display: flex; align-items: stretch }
@media (min-width: 1024px) {
    #popular-products .flex.flex-wrap > .w-full.sm\:w-1\/2.lg\:w-1\/4 { width: 25% !important; max-width: 25% !important; }
}
#popular-products .flex.flex-wrap { margin-left: -12px; margin-right: -12px; gap: 0 }
#popular-products article { display: flex !important; flex-direction: column; justify-content: flex-start; align-items: stretch; width: 100%; min-height: var(--tile-min-height); background: transparent !important; padding: 0 !important; border-radius: 0 !important; box-shadow: none !important; transition: transform 220ms cubic-bezier(.2,.9,.2,1), box-shadow 220ms ease; }
#popular-products article > a.block:first-child { position: relative; display: block; overflow: hidden; border-radius: var(--image-radius); margin-bottom: 14px; background: #fff; box-shadow: 0 12px 36px rgba(11,11,11,0.04); }
#popular-products article > a.block:first-child img.shopify-product-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform 700ms cubic-bezier(.2,.9,.2,1); will-change: transform; background: #fafafa; }
#popular-products article > a.block:first-child::before { content: ""; display: block; padding-bottom: 100%; }
#popular-products article a.text-lg { margin: 0 0 8px 0; padding: 0 6px; font-size: 1.02rem; font-weight: 700; color: var(--pp-text); line-height: 1.18; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
#popular-products article p.text-lg { margin: 0 0 10px 0; padding: 0 6px; color: var(--pp-primary); font-weight: 800; font-size: 1.04rem; }
#popular-products article .mt-auto { margin-top: auto; padding: 6px; display: flex; flex-direction: column; gap: 10px; transition: none; }
#popular-products article .mt-auto button[data-cart-action="add"] { width: 100%; border-radius: 999px; padding: 0.72rem 0; font-weight: 800; background: var(--pp-accent-grad); color: #fff; border: 0; box-shadow: 0 16px 36px rgba(255,63,121,0.12); transition: opacity 140ms ease, transform 140ms ease; transform: none !important; }
#popular-products article .mt-auto a.block { width: 100%; border-radius: 999px; padding: 0.64rem 0; text-align: center; display: block; color: var(--pp-primary); border: 1px solid rgba(15,23,36,0.06); background: transparent; font-weight: 700; }
#popular-products .w-full.sm\:w-1\/2.lg\:w-1\/4.px-4.mb-8.flex:hover article,
#popular-products .w-full.sm\:w-1\/2.lg\:w-1\/4.px-4.mb-8.flex:focus-within article { transform: translateY(-6px); box-shadow: 0 22px 50px rgba(11,11,11,0.06); }
#popular-products .w-full.sm\:w-1\/2.lg\:w-1\/4.px-4.mb-8.flex:hover article > a.block:first-child img.shopify-product-image,
#popular-products .w-full.sm\:w-1\/2.lg\:w-1\/4.px-4.mb-8.flex:focus-within article > a.block:first-child img.shopify-product-image { transform: scale(var(--hover-zoom)); }

@media (min-width: 1280px) {
    :root { --tile-min-height: 480px; }
}
@media (min-width: 640px) and (max-width: 1023px) {
    #popular-products .flex.flex-wrap > .w-full.sm\:w-1\/2.lg\:w-1\/4 { width: 50% !important; max-width: 50% !important; }
    :root { --tile-min-height: 540px; }
}
@media (max-width: 639px) {
    #popular-products .flex.flex-wrap > .w-full.sm\:w-1\/2.lg\:w-1\/4 { width: 50% !important; max-width: 50% !important; }
    :root { --tile-min-height: 620px; }
    #popular-products article > a.block:first-child img.shopify-product-image { position: static; height: auto; aspect-ratio: auto; }
    #popular-products article > a.block:first-child::before { display: none; }
}
#popular-products .flex.items-center.justify-between.mb-8 .inline-flex { margin-left: auto; background: var(--pp-accent-grad); color: #fff; padding: 0.5rem 1rem; border-radius: 999px; box-shadow: 0 10px 30px rgba(255,63,121,0.12); border: none; text-decoration: none; transition: transform 180ms ease, box-shadow 180ms ease; }
#popular-products .flex.items-center.justify-between.mb-8 .inline-flex:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(255,63,121,0.16); }
#popular-products h2 { font-weight: 800; font-size: 1.6rem; color: #0b1320; margin-bottom: 18px; }

@media (prefers-reduced-motion: reduce) {
    #popular-products article, #popular-products article img.shopify-product-image { transition: none !important; transform: none !important; }
    #popular-products .w-full.sm\:w-1\/2.lg\:w-1\/4.px-4.mb-8.flex:hover article { transform: none !important; box-shadow: none !important; }
}

@media (max-width: 780px) {
    #popular-products article { min-height: 200px; }
}

/* Footer CSS */
:root{
    --footer-max-width: 1180px;
    --footer-radius: 14px;
    --footer-panel-bg: #ffffff;               /* panel color */
    --footer-outer-bg: linear-gradient(180deg,#fbfbfc,#f6f6f7);
    --footer-text: #0b1320;
    --footer-muted: #6b6b73;
    --footer-accent: #ff3f79;
    --footer-shadow: 0 18px 50px rgba(11,11,12,0.06);
}
footer[data-content-scope="/footer"] { background: var(--footer-outer-bg) !important; border-top: 0 !important; padding: 36px 0 48px 0 !important; color: var(--footer-text); font-family: "Inter", "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial !important; }
footer[data-content-scope="/footer"] .border-t.border-gray-200.bg-gray-100 { background: transparent !important; border-top: none !important; padding: 0 !important; }
footer[data-content-scope="/footer"] .max-w-7xl.mx-auto.px-6 { max-width: var(--footer-max-width) !important; margin-left: auto !important; margin-right: auto !important; padding-left: 20px !important; padding-right: 20px !important; }
footer[data-content-scope="/footer"] .text-center.lg\:text-left { flex: 1 1 55% !important; min-width: 220px; text-align: left !important; }
footer[data-content-scope="/footer"] p.text-sm.text-gray-500 { margin: 0 !important; font-size: 13px !important; color: var(--footer-muted) !important; line-height: 1.45 !important; }
footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] { margin-top: 10px !important; padding: 0 !important; display: flex !important; gap: 16px !important; list-style: none !important; flex-wrap: wrap !important; align-items: center !important; }
footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] li { margin: 0 !important; }
footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] li a { color: var(--footer-muted) !important; text-decoration: none !important; font-size: 13px !important; transition: color .16s ease, transform .14s ease !important; padding: 2px 0 !important; }
footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] li a:hover,
footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] li a:focus { color: var(--footer-accent) !important; transform: translateY(-2px) !important; outline: none !important; }
footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] li + li::before { content: "·"; color: rgba(11,11,12,0.07); margin-right: 10px; margin-left: 6px; font-size: 12px; }
footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] { display: flex !important; align-items: center !important; justify-content: center !important; gap: 12px !important; flex: 0 0 auto !important; min-width: 140px; }
footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] img,
footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] svg { width: 48px !important; height: auto !important; border-radius: 8px !important; padding: 6px !important; background: linear-gradient(180deg, rgba(255,255,255,0.85), rgba(255,255,255,0.6)) !important; box-shadow: 0 8px 24px rgba(11,11,12,0.04) !important; transition: transform .16s ease, opacity .16s ease !important; opacity: 0.95 !important; }
footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] img:hover,
footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] svg:hover { transform: translateY(-3px) scale(1.03) !important; opacity: 1 !important; }

@media (min-width: 1024px) {
    footer[data-content-scope="/footer"] .max-w-7xl.mx-auto.px-6 > .flex { align-items: center !important; }
    footer[data-content-scope="/footer"] .text-center.lg\:text-left { flex: 1 1 65% !important; }
    footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] { justify-content: flex-end !important; }
}
@media (max-width: 767px) {
    footer[data-content-scope="/footer"] .max-w-7xl.mx-auto.px-6 > .flex { flex-direction: column !important; align-items: center !important; text-align: center !important; padding: 20px !important; gap: 10px !important; }
    footer[data-content-scope="/footer"] .text-center.lg\:text-left { text-align: center !important; width: 100%; }
    footer[data-content-scope="/footer"] ul[data-content-repeat="/footer.meta.links"] { justify-content: center !important; gap: 10px !important; }
    footer[data-content-scope="/footer"] [data-content-repeat="/footer.payments"] { justify-content: center !important; }
}

footer[data-content-scope="/footer"] a:focus { outline: none !important; box-shadow: 0 0 0 4px rgba(255,63,121,0.12) !important; border-radius: 8px !important; }
footer[data-content-scope="/footer"] .flex.items-center.gap-3.justify-center.lg\:justify-end { min-width: 0 !important; width: auto !important; }
footer[data-content-scope="/footer"] li { line-height: 1.5 !important; }
footer[data-content-scope="/footer"] a { font-weight: 600 !important; }
footer[data-content-scope="/footer"]::before { content: ""; display: block; height: 1px; width: calc(100% - 40px); margin: 6px auto 18px; background: linear-gradient(90deg, rgba(11,11,12,0.02), rgba(11,11,12,0.04)); border-radius: 1px; pointer-events: none; }
footer[data-content-scope="/footer"], footer[data-content-scope="/footer"] * { box-sizing: border-box !important; -webkit-font-smoothing: antialiased !important; -moz-osx-font-smoothing: grayscale !important; }

/* Cart Page CSS */
:root{
    --cart-max-w: 1180px;
    --card-radius: 12px;
    --panel-shadow: 0 18px 46px rgba(11,11,12,0.06);
    --accent: #ff3f79;
    --muted: #6d6d74;
    --text: #0b1b22;
    --divider: rgba(7,16,26,0.06);
}
#cart-page .container { max-width: var(--cart-max-w); padding-left:28px; padding-right:28px; margin: 0 auto; }
#cart-page h1 { font-size: 2.0rem; font-weight:800; margin-bottom:16px; color:var(--text); }
#cart-page .bg-white.rounded-lg.shadow-md { padding: 18px !important; border-radius: calc(var(--card-radius) + 4px) !important; box-shadow: var(--panel-shadow) !important; }
#cart-page table { width:100%; border-collapse: collapse; table-layout: auto; font-family: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial; }
#cart-page thead th { font-size:0.78rem; color:var(--muted); font-weight:700; text-transform:uppercase; padding:14px 12px; border-bottom:1px solid var(--divider); letter-spacing:.06em; }
#cart-page tbody tr { border-bottom: 1px solid rgba(7,16,26,0.04); transition: background .12s ease; }
#cart-page tbody tr:hover { background: rgba(7,16,26,0.01); }
#cart-page tbody td { padding: 16px 12px; vertical-align: middle; color:var(--text); }
#cart-page td > .flex.items-center { display: flex !important; gap: 16px; align-items: flex-start; }
#cart-page td > .flex.items-center img { width: 92px; height: 92px; object-fit: cover; border-radius: 10px; box-shadow: 0 10px 28px rgba(11,11,12,0.04); flex: 0 0 92px; }
#cart-page td > .flex.items-center > .space-y-1 { display: block; flex: 1 1 auto; min-width: 0; }
#cart-page td > .flex.items-center > .space-y-1 a { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; font-weight: 700; color: var(--text); font-size: 1rem; line-height: 1.16; text-decoration: none; }
#cart-page td > .flex.items-center > .space-y-1 button[data-cart-remove] { margin-top: 6px; display: inline-block; font-size: 0.9rem; color: #d23b52; background: transparent; border: none; padding: 0; font-weight: 700; cursor: pointer; }
#cart-page td > .flex.items-center > .space-y-1 button[data-cart-remove]:hover { text-decoration: underline; }
#cart-page td.text-center { text-align: center; white-space: nowrap; font-weight: 700; }
#cart-page td .inline-flex.items-center.border { display: inline-flex; align-items: center; gap: 10px; padding: 6px 8px; border-radius: 999px; border: 1px solid rgba(7,16,26,0.08); box-shadow: 0 8px 20px rgba(11,11,12,0.03); }
#cart-page td .inline-flex.items-center button { background: transparent; border: none; font-weight: 800; font-size: 18px; color: var(--text); cursor: pointer; padding: 4px 8px; }
#cart-page td .inline-flex.items-center input[type="number"] { width: 56px; border-left: 1px solid rgba(7,16,26,0.04); border-right: 1px solid rgba(7,16,26,0.04); text-align:center; font-weight:700; font-size: 1rem; padding: 6px 4px; background: transparent; }

@media (min-width: 768px) {
    #cart-page td.text-right { text-align: right; }
}

/* Summary card */
[data-cart-summary]{ border-radius: 12px; padding: 18px; box-shadow: var(--panel-shadow); background: #fff; min-width: 260px; align-self: flex-start; }
@media (min-width: 992px) {
    [data-cart-summary]{ position: sticky; top: 90px; }
}
[data-cart-summary] h2 { font-weight:800; margin:0 0 10px 0; color:var(--text); }
[data-cart-summary] .text-sm { color:var(--muted); }
[data-cart-summary] a[data-cart-checkout]{ display:block; width:100%; text-align:center; padding:12px 14px; border-radius:999px; background: linear-gradient(90deg,#ff8a00,#ff3f79); color:#fff; font-weight:800; margin-top:12px; text-decoration:none; box-shadow: 0 18px 44px rgba(255,63,121,0.12); }
[data-cart-summary] a[data-cart-checkout]:hover { transform: translateY(-2px); }
@media (max-width: 767px){
    #cart-page thead { display:none; }
    #cart-page tbody tr { display:block; padding:10px; margin-bottom:12px; border-radius: 10px; box-shadow: 0 12px 30px rgba(11,11,12,0.04); }
    #cart-page tbody td { display:flex; align-items:center; gap:12px; padding:10px; }
    #cart-page td > .flex.items-center img { width:72px; height:72px; flex:0 0 72px; }
    #cart-page td.text-center { justify-content:flex-end; }
    [data-cart-summary] { position: static; margin-top:12px; }
}
#cart-page a:focus, #cart-page button:focus, #cart-page input:focus { outline: none; box-shadow: 0 0 0 4px rgba(255,63,121,0.12); border-radius:8px; }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }



/* Checkout Page CSS */
:root{
    --primary-1: #ff8a00;
    --primary-2: #ff3f79;
    --primary-grad: linear-gradient(90deg,var(--primary-1),var(--primary-2));
    --muted: #70737a;
    --text: #0b1b22;
    --panel-bg: #ffffff;
    --panel-radius: 14px;
    --panel-shadow: 0 22px 60px rgba(11,18,25,0.06);
    --border: rgba(11,18,25,0.06);
    --container-max: 1200px;
}

#checkout-page { background: #fbfbfd; }
#checkout-page .container { max-width: var(--container-max); padding-left:28px; padding-right:28px; margin: 0 auto; }
#checkout-page p.uppercase { letter-spacing: .35em; text-transform: uppercase; color: var(--primary-2); font-weight: 700; font-size: .81rem; margin-bottom: 6px; }
#checkout-page h1 { font-size: 2.25rem; line-height:1.02; color:var(--text); font-weight:800; margin-bottom:6px; }
#checkout-page p.text-gray-500 { color: var(--muted); margin-bottom: 8px; }
[data-checkout-form-wrapper],
aside[data-checkout-summary]{ background: var(--panel-bg); border-radius: var(--panel-radius); border: 1px solid var(--border); box-shadow: var(--panel-shadow); }
[data-checkout-form-wrapper]{ padding: 28px 26px; transition: transform .12s ease; }
[data-checkout-form-wrapper] h2 { font-size: 1.125rem; margin: 0 0 8px 0; color:var(--text); font-weight:700; }
[data-checkout-form-wrapper] p { color:var(--muted); margin:0 0 12px 0; }
[data-checkout-form-wrapper] .grid { gap: 12px; }
[data-checkout-form-wrapper] label span { font-weight:700; color: #222; font-size: .95rem; }
[data-checkout-form-wrapper] input[type="text"],
[data-checkout-form-wrapper] input[type="email"],
[data-checkout-form-wrapper] input[type="tel"],
[data-checkout-form-wrapper] select,
[data-checkout-form-wrapper] textarea { width:100%; background: #fff; border: 1px solid rgba(11,18,25,0.06); padding: 10px 14px; border-radius: 999px; box-shadow: 0 6px 18px rgba(11,18,25,0.03); font-size: .95rem; color: var(--text); transition: box-shadow .14s ease, border-color .14s ease, transform .12s ease; }
[data-checkout-form-wrapper] textarea { border-radius: 12px; padding: 12px 14px; }
[data-checkout-form-wrapper] input:focus,
[data-checkout-form-wrapper] select:focus,
[data-checkout-form-wrapper] textarea:focus { outline: none; border-color: rgba(255,63,121,0.18); box-shadow: 0 6px 30px rgba(255,63,121,0.08); transform: translateY(-1px); }
[data-location-button]{ display:inline-flex; align-items:center; gap:10px; padding:10px 16px; border-radius: 999px; background: transparent; border: 1.5px solid rgba(255,63,121,0.12); color: var(--primary-2); font-weight:700; cursor:pointer; transition: box-shadow .12s ease, transform .12s ease; }
[data-location-button]:hover { box-shadow: 0 14px 30px rgba(255,63,121,0.06); transform: translateY(-2px); }
[data-checkout-payment] label { display:flex; gap:12px; align-items:flex-start; padding:12px 14px; border-radius: 12px; cursor:pointer; }
[data-checkout-payment] label[aria-checked="true"],
[data-checkout-payment] label input:checked + span,
[data-checkout-payment] label:has(input:checked) { box-shadow: 0 10px 30px rgba(7,16,26,0.04); border: 1px solid rgba(11,18,25,0.06); transform: translateY(-2px); }
[data-checkout-form-wrapper] button[type="submit"]{ width:100%; padding: 14px 18px; border-radius: 999px; font-weight:800; font-size: 1rem; color: #fff; background: var(--primary-grad); border: none; box-shadow: 0 18px 44px rgba(255,63,121,0.1); transition: transform .12s ease, box-shadow .12s ease, filter .12s ease; }
[data-checkout-form-wrapper] button[type="submit"]:hover{ transform: translateY(-3px); filter: brightness(1.02); }
[data-checkout-form-wrapper] .text-xs a,
[data-checkout-form-wrapper] .text-xs a:visited { color:var(--primary-2); font-weight:700; text-decoration:underline; }
aside[data-checkout-summary]{ padding: 22px; min-width: 320px; max-width: 420px; }
aside[data-checkout-summary] .flex.items-center { gap: 12px; margin-bottom: 8px; align-items:center; }
aside[data-checkout-summary] h2 { margin:0; font-weight:800; font-size:1.125rem; }
[data-checkout-items] { list-style:none; margin:0; padding:0; max-height: 420px; overflow:auto; }
[data-checkout-items] li { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom: 1px solid rgba(11,18,25,0.04); }
[data-checkout-items] img { width:56px; height:56px; object-fit:cover; border-radius:9px; }
aside dl dt { color: var(--muted); }
aside dl dd { color: var(--text); font-weight:700; margin-left:0; }
aside dl .border-t { border-top: 1px solid rgba(11,18,25,0.06); padding-top:12px; margin-top:8px; }
[data-checkout-summary] .rounded-2xl { border-radius:10px; background: linear-gradient(180deg, rgba(255,63,121,0.04), rgba(255,63,121,0.02)); padding:12px; }
[data-checkout-summary] a { color: var(--primary-2); font-weight:700; }

@media (min-width: 992px){
    aside[data-checkout-summary] { position: sticky; top: 90px; height: fit-content; }
}
@media (max-width: 991px){
    .container > .flex { flex-direction: column; }
    [data-checkout-form-wrapper], aside[data-checkout-summary] { width:100%; }
    [data-checkout-form-wrapper] { padding: 20px; margin-bottom: 18px; }
    aside[data-checkout-summary] { padding: 18px; }
}
#checkout-page a:hover { text-decoration: none; }
#checkout-page input[disabled], #checkout-page button[disabled] { opacity: .6; cursor: not-allowed; }
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition: none !important; animation: none !important; }
}

/* Contact Page CSS */
:root{
    --primary-1: #ff7a17;
    --primary-2: #ff3f79;
    --primary-grad: linear-gradient(90deg,var(--primary-1),var(--primary-2));
    --muted: #6b6f76;
    --text: #0f1720;
    --card-bg: #ffffff;
    --card-radius: 20px;
    --card-shadow: 0 18px 48px rgba(10,18,25,0.06);
    --accent-glow: 0 16px 40px rgba(255,63,121,0.08);
    --container-max: 1200px;
    --gap: 24px;
}
main.container { max-width: var(--container-max); padding-left:28px; padding-right:28px; margin: 0 auto; }
main > .container section > div.bg-white { border-radius: var(--card-radius); background: linear-gradient(180deg, #fff, #fff); box-shadow: var(--card-shadow); padding: 28px; transition: transform .14s ease, box-shadow .14s ease; overflow: hidden; }
[data-content-scope="pages.contact"] p.uppercase,
.text-sm.font-semibold.uppercase { letter-spacing: .34em; color: var(--primary-2); font-weight:800; font-size:.78rem; }
[data-content-scope="pages.contact"] h1 { font-size: 2.4rem; line-height:1.03; margin-top:6px; color:var(--text); font-weight:800; }
[data-content-scope="pages.contact"] p.text-gray-600 { color:var(--muted); font-size:1.05rem; margin-top:6px; }
ul[data-content-repeat="hero.highlights"] { display:grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--gap); margin-top: 8px; }
ul[data-content-repeat="hero.highlights"] li { display:flex; align-items:flex-start; gap:12px; background: linear-gradient(180deg, rgba(255,255,255,0.6), rgba(250,250,250,0.6)); border-radius: 14px; padding:12px 14px; box-shadow: 0 8px 22px rgba(11,18,25,0.04); }
ul[data-content-repeat="hero.highlights"] li span { width:10px; height:10px; flex: 0 0 10px; margin-top:6px; border-radius:50%; box-shadow: 0 6px 20px rgba(11,18,25,0.03); }
div[data-content-repeat="hero.ctas"] { margin-top: 6px; display:flex; gap:12px; flex-wrap:wrap; }
div[data-content-repeat="hero.ctas"] a { display:inline-flex; align-items:center; gap:10px; padding:10px 16px; border-radius:999px; font-weight:800; text-decoration:none; background: var(--primary-grad); color:#fff; box-shadow: var(--accent-glow); transition: transform .12s ease, box-shadow .12s ease; }
div[data-content-repeat="hero.ctas"] a:hover { transform: translateY(-3px); box-shadow: 0 26px 60px rgba(255,63,121,0.12); }
aside#office { border-radius: var(--card-radius); padding:22px; background: linear-gradient(180deg,#fff,#fff); box-shadow: var(--card-shadow); }
aside#office h2 { margin:0 0 8px 0; font-weight:800; color:var(--text); font-size:1.05rem; }
aside#office p, aside#office .text-gray-600 { color:var(--muted); line-height:1.5; }
aside#office .pt-4 { padding-top:16px; border-top: 1px solid rgba(11,18,25,0.04); margin-top:10px; }
aside#office .pt-4 p { margin:0; }
aside#office a { display:inline-flex; gap:10px; align-items:center; padding:10px 14px; border-radius:999px; border:1px solid rgba(255,63,121,0.12); color:var(--primary-2); font-weight:800; text-decoration:none; background: transparent; transition: background .12s ease, transform .12s ease; }
aside#office a:hover { background: linear-gradient(90deg, rgba(255,122,23,0.06), rgba(255,63,121,0.06)); transform: translateY(-3px); }
section[data-content-repeat="channels"] > article,
template[data-content-repeat="channels"] > article,
article[data-content-scope="."] { border-radius: 16px; padding: 18px; background: var(--card-bg); box-shadow: 0 14px 34px rgba(11,18,25,0.04); transition: transform .12s ease, box-shadow .12s ease; margin-top: 10px; }
section[data-content-repeat="channels"] > article:hover,
article[data-content-scope="."]:hover { transform: translateY(-6px); box-shadow: 0 28px 70px rgba(11,18,25,0.06); }
article h3 { margin:0; font-weight:800; color:var(--text); font-size:1.02rem; }
article p { color:var(--muted); margin:6px 0; }
article .text-2xl { color:var(--primary-2); font-weight:900; }
article a { color:var(--primary-2); font-weight:800; text-decoration:none; display:inline-flex; gap:8px; align-items:center; }
article a:hover { text-decoration:underline; transform:translateY(-2px); }

@media (min-width: 1024px){
    .container > section.grid { grid-template-columns: minmax(0,1fr) 360px; gap: 32px; align-items:start; margin-top: 20px; }
}
@media (min-width: 768px){
    section[data-content-repeat="channels"] { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--gap); }
}
@media (max-width: 767px){
    section[data-content-repeat="channels"] { display:block; }
    ul[data-content-repeat="hero.highlights"] { grid-template-columns: 1fr; }
    .container > section.grid { grid-template-columns: 1fr; margin-top: 20px; }
    main h1 { font-size:1.75rem; }
}
@media (prefers-reduced-motion: reduce){
    * { transition: none !important; animation: none !important; }
}
main .rounded-3xl { overflow: visible; }
ul[data-content-repeat="hero.highlights"] li p { margin:0; color:var(--text); font-weight:600; font-size:.97rem; }

/* order page CSS */
:root{
    --primary-1: #ff7a17;
    --primary-2: #ff3f79;
    --primary-grad: linear-gradient(90deg,var(--primary-1),var(--primary-2));
    --muted: #6b6f76;
    --text: #0f1720;
    --card-bg: #ffffff;
    --card-radius: 20px;
    --card-shadow: 0 22px 60px rgba(11,18,25,0.06);
    --panel-shadow: 0 12px 34px rgba(11,18,25,0.05);
    --accent-glow: 0 24px 60px rgba(255,63,121,0.08);
    --container-max: 1200px;
    --gap: 24px;
    --border-line: rgba(11,18,25,0.06);
}

.container { max-width: var(--container-max); margin-left:auto; margin-right:auto; padding-left:28px; padding-right:28px; }
section.bg-gray-50.py-16 { padding-top:3.5rem; padding-bottom:3.5rem; }
section.bg-gray-50 h1.text-4xl { font-size:2.8rem; line-height:1.03; font-weight:800; color:var(--text); margin-bottom:6px; }
section.bg-gray-50 p.text-lg { color:var(--muted); font-size:1.05rem; max-width:72ch; }
.bg-white.rounded-3xl.p-8.shadow-lg.sticky { padding: 20px; border-radius: 18px; box-shadow: var(--card-shadow); border: 1px solid var(--border-line); background: linear-gradient(180deg,#fff,#fff); transition: transform .12s ease, box-shadow .12s ease; }
.bg-white.rounded-3xl.p-8.sticky h2 { font-weight:800; color:var(--text); margin-bottom:8px; }
#order-tracker-form label { display:block; font-weight:700; color:var(--muted); font-size:0.95rem; margin-bottom:4px; }
#order-tracker-form input[type="text"],
#order-tracker-form input[type="email"],
#order-tracker-form input[type="tel"] { width:100%; padding:12px 16px; border-radius:999px; border:1.5px solid rgba(11,18,25,0.08); background: #fff; box-shadow: 0 8px 26px rgba(11,18,25,0.03) inset; transition: box-shadow .12s ease, border-color .12s ease, transform .12s ease; font-size:0.96rem; color:var(--text); }
#order-tracker-form input:focus { outline: none; border-color: rgba(255,63,121,0.7); box-shadow: 0 8px 26px rgba(255,63,121,0.07); transform: translateY(-1px); }
#order-tracker-form button[type="submit"]{ display:inline-block; width:100%; padding:12px 20px; margin-top:6px; border-radius:999px; font-weight:800; letter-spacing:0.02em; background: var(--primary-grad); color:#fff; border: 0; box-shadow: var(--accent-glow); transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease; }
#order-tracker-form button[type="submit"]:hover{ transform: translateY(-3px); box-shadow: 0 36px 88px rgba(255,63,121,0.12); }
#order-tracker-status { margin-top: 20px; padding-top: 8px; border-top: 1px solid var(--border-line); }
#order-tracker-status p.text-sm.font-semibold { color:var(--muted); font-weight:700; font-size:0.88rem; }
#order-tracker-status [data-order-status-message] { background: linear-gradient(180deg, rgba(250,250,251,1), #fff); padding:12px; border-radius:12px; border:1px solid rgba(11,18,25,0.04); box-shadow: var(--panel-shadow); color:var(--muted); }
#order-details { border-radius: 18px; padding:28px; background: linear-gradient(180deg,#fff,#fff); box-shadow: var(--card-shadow); border: 1px solid var(--border-line); }
#order-details .grid { gap:18px; }
#order-details p.text-xs.uppercase { color: #9aa0a6; letter-spacing: .28em; font-weight:700; }
#order-details p.text-lg.font-semibold { font-size:1.05rem; color:var(--text); margin:4px 0; }
#order-details p.text-sm.text-gray-500 { color:var(--muted); margin:0; }
#order-details table { width:100%; border-collapse: collapse; font-size:0.95rem; }
#order-details thead th { text-transform: uppercase; color:#95a0a6; font-size:0.82rem; letter-spacing:0.08em; padding-bottom:10px; text-align:left; }
#order-details tbody tr td { padding:14px 10px; vertical-align: middle; border-bottom: 1px dashed rgba(11,18,25,0.04); color:var(--muted); }
#order-details tbody tr td:first-child { display:flex; gap:12px; align-items:center; }
#order-details tbody img { width:64px; height:64px; object-fit:cover; border-radius:12px; }
#order-details ul { list-style:none; padding:0; margin:0; }
#order-details ul li { background: linear-gradient(180deg,#fff,#fff); padding:12px; border-radius:10px; border:1px solid rgba(11,18,25,0.03); }
.text-right .meta-value { font-weight:800; color:var(--text); }
#order-details.hidden { display:none; }
[data-content-repeat="pages.orders.steps"] article,
[data-content-repeat="pages.orders.steps"] .step-card { background: linear-gradient(180deg,#fff,#fff); border-radius: 14px; padding:16px; box-shadow: 0 12px 36px rgba(11,18,25,0.04); border:1px solid var(--border-line); transition: transform .12s ease, box-shadow .12s ease; }
[data-content-repeat="pages.orders.steps"] article:hover { transform: translateY(-6px); box-shadow: 0 30px 80px rgba(11,18,25,0.06); }
[data-content-repeat="pages.orders.steps"] article h3 { margin:0; color:var(--text); font-weight:700; }
[data-content-repeat="pages.orders.steps"] article p { color:var(--muted); margin-top:6px; }
p.text-sm, .text-sm { font-size:0.95rem; color:var(--muted); margin-top: 7px; }

@media (max-width: 1024px) {
    section.bg-gray-50 .container.grid { grid-template-columns: 1fr; }
    .bg-white.rounded-3xl.p-8.sticky { position: relative; top:auto; left:auto; right:auto; margin-top: 12px; }
    #order-details { padding:18px; }
    #order-details tbody img { width:54px; height:54px; }
}
@media (max-width: 640px) {
    section.bg-gray-50 h1.text-4xl { font-size:1.75rem; }
    #order-tracker-form input { font-size:0.95rem; padding:11px 14px; }
    #order-tracker-form button { padding:11px; font-size:0.95rem; }
    #order-details tbody td { padding:12px 8px; font-size:0.92rem; }
}
@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; animation: none !important; }
}
.divider-hr { height:1px; background:linear-gradient(90deg, rgba(11,18,25,0.03), rgba(11,18,25,0.01)); margin:18px 0; border-radius:2px; }
#order-tracker-form button[disabled] { opacity:0.6; cursor:not-allowed; box-shadow:none; transform:none; }

/* 404 Page CSS */
.page-404 { background: #ffffff; padding: 6rem 1rem; color: #222; font-family: 'Manrope', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial; }
.container-404 { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 520px; gap: 48px; align-items: center; padding: 0 1rem; }
.content-404 { padding: 4rem 0; }
.eyebrow-404 { color: #ff6b8a; font-weight: 700; letter-spacing: 0.35em; text-transform: uppercase; margin: 0 0 0.8rem 0; font-size: 0.85rem; }
.title-404 { color: #ff2f6d; font-size: 2.6rem; line-height: 1.05; margin: 0 0 1rem 0; font-weight: 800; }
.desc-404 { color: #6b7280; font-size: 1.03rem; max-width: 54ch; margin-bottom: 1.6rem; }
.actions-404 { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.btn-primary-404 { display: inline-block; padding: 12px 22px; border-radius: 999px; text-decoration: none; font-weight: 700; color: #fff; background: linear-gradient(90deg,#ff9a1f 0%,#ff2f6d 100%); box-shadow: 0 10px 30px rgba(255,47,109,0.12); transition: transform .12s ease, box-shadow .12s ease; }
.btn-primary-404:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(255,47,109,0.12); }
.btn-ghost-404 { display:inline-block; padding: 10px 18px; border-radius: 999px; text-decoration: none; font-weight: 600; color: #ff2f6d; border: 1.5px solid #ffe8ee; background: #fff; }
.visual-404 { width: 100%; display: flex; justify-content: center; align-items: center; margin: 0; padding: 1.5rem; background: #fff; border-radius: 12px; box-shadow: 0 20px 50px rgba(15,23,42,0.06); }
.visual-404 img { display:block; width:100%; height:auto; max-width: 520px; border-radius: 12px; object-fit: cover; }

@media (max-width: 900px) {
    .container-404 { grid-template-columns: 1fr; gap: 30px; padding: 3rem 1rem; }
    .content-404 { padding: 1rem 0; text-align: center; }
    .title-404 { font-size: 1.9rem; }
    .desc-404 { margin: 0 auto 1.25rem; }
    .actions-404 { justify-content: center; }
    .visual-404 { padding: 1rem; box-shadow: 0 14px 30px rgba(15,23,42,0.06); }
    .visual-404 img { max-width: 420px; }
}
@media (max-width: 420px) {
    .title-404 { font-size: 1.6rem; }
    .eyebrow-404 { font-size: 0.75rem; }
    .btn-primary-404 { padding: 10px 16px; font-size: 0.95rem; }
}

/* ---- JS controlled cart open ---- */
[data-cart-preview].js-open {
  transform: translateX(0) !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transition: transform 0.28s cubic-bezier(.2,.9,.2,1), opacity .18s ease !important;
  visibility: visible !important;
}

/* Close button injected by JS */
[data-cart-preview] .cart-close-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(255,255,255,0.95);
  border: 1px solid rgba(15,15,20,0.06);
  box-shadow: 0 6px 18px rgba(11,11,11,0.06);
  cursor: pointer;
  z-index: 9999;
  transition: transform .12s ease, box-shadow .12s ease;
}
[data-cart-preview] .cart-close-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(11,11,11,0.10);
}
[data-cart-preview] .cart-close-btn svg { width: 18px; height: 18px; color: #222; }
@media (max-width: 1023px) {
  [data-cart-preview] .cart-close-btn { top: 8px; right: 12px; }
}


