/* Enhanced Mobile 3D Optimizations */
@media (max-width: 768px) {
    /* Make 3D scene more visible on mobile */
    .hero__scene-pane {
        min-height: 60vh;
        position: relative;
        background: linear-gradient(135deg, #F9F6F2 0%, #F0EBE3 100%);
    }

    .hero__canvas-wrap {
        position: absolute;
        inset: 0;
        opacity: 1 !important;
    }

    #heroCanvas {
        width: 100% !important;
        height: 100% !important;
        display: block;
        touch-action: pan-y;
    }

    /* Enhance gradients for better 3D visibility */
    .hero__scene-gradient {
        width: 25%;
        background: linear-gradient(to right, rgba(249,246,242,0.6), transparent);
    }

    .hero__scene-gradient-bottom {
        height: 20%;
        background: linear-gradient(to top, rgba(249,246,242,0.5), transparent);
    }

    /* Make pincode card more prominent on mobile */
    .hero__pincode {
        position: relative;
        right: auto;
        bottom: auto;
        margin: 24px auto;
        width: calc(100% - 48px);
        max-width: 400px;
        background: rgba(255,255,255,0.75);
        backdrop-filter: blur(32px);
        -webkit-backdrop-filter: blur(32px);
        animation: revealUp 0.7s var(--ease) 1.8s forwards;
    }

    /* Better touch targets */
    .hero__date-btn {
        min-width: calc(33.333% - 7px);
        padding: 14px 16px;
    }

    /* Enhance occasion chips for mobile */
    .occasion-chip {
        padding: 28px 10px 24px;
        transition: all 0.3s var(--ease);
    }

    .occasion-chip:active {
        transform: scale(0.95);
        background: var(--rose-bg);
    }

    /* Better product card scrolling */
    .products__track {
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        padding: 10px 0 30px;
    }

    .p-card {
        scroll-snap-align: center;
        scroll-snap-stop: always;
    }

    /* Enhance same-day visual for mobile */
    .same-day__visual {
        min-height: 400px;
        margin-top: 40px;
    }

    .same-day__card--1,
    .same-day__card--2 {
        width: 48%;
    }

    .same-day__card--floating {
        bottom: 20px;
        right: 50%;
        transform: translateX(50%);
        width: auto;
    }

    /* Mobile-friendly counters */
    .trust-counter__num {
        font-size: 2.5rem;
    }

    /* Testimonial cards stack better */
    .test-card {
        padding: 32px 24px;
    }

    /* Footer adjustments */
    .footer__cta-bar {
        padding: 32px 24px;
        text-align: center;
    }

    .footer__cta-bar h3 {
        font-size: 1.5rem;
    }
}

/* Touch device optimizations */
@media (hover: none) and (pointer: coarse) {
    .p-card:active {
        transform: scale(0.98);
    }

    .occasion-chip:active,
    .cat-card:active,
    .addon-card:active {
        transform: scale(0.97);
    }

    .btn:active {
        transform: scale(0.97);
    }

    /* Remove hover states that don't work on touch */
    .p-card__wish {
        opacity: 1;
        transform: translateY(0);
    }

    .p-card__add-wrap {
        transform: translateY(0);
        background: linear-gradient(to top, rgba(0,0,0,0.7), transparent);
        padding: 20px 14px 14px;
    }
}

/* Landscape mobile optimization */
@media (max-width: 900px) and (orientation: landscape) {
    .hero {
        grid-template-columns: 1fr 1fr;
        min-height: auto;
        padding: calc(var(--header-h) + 16px) 0 40px;
        overflow: visible;
    }

    .hero__scene-pane {
        min-height: 70vh;
    }

    .hero__text-pane {
        padding: 40px 32px;
    }
}

/* Very small screens (< 375px) */
@media (max-width: 374px) {
    :root {
        --section-v: 60px;
    }

    .occasion-chips,
    .cat-grid {
        gap: 10px;
    }

    .p-card {
        width: 240px;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Stems & Tales — Premium CSS (Deduplicated)
   Aesthetic: "Whispered Luxury" — Aesop × Dior × Editorial Floristry
   Fonts: Cormorant Garamond (display) + Outfit (body)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Design Tokens ── */
:root {
    --white: #FFFFFF;
    --ivory: #F9F6F2;
    --cream: #F0EBE3;
    --sand: #E3DCD2;
    --warm-100: #D6CEC3;
    --warm-200: #B8AFA2;
    --warm-300: #9A9184;
    --warm-400: #7C7368;
    --warm-500: #5E554C;
    --warm-600: #3F3832;
    --warm-700: #2A2420;
    --charcoal: #1A1714;

    --rose: #B5715A;
    --rose-light: #D09680;
    --rose-lighter: #E8C4B4;
    --rose-bg: #FBF0EB;
    --rose-dark: #955840;
    --rose-deep: #7A4530;
    --rose-glow: rgba(181, 113, 90, 0.18);

    --wine: #6B2B3A;
    --wine-light: #8B3E50;
    --gold: #C9A96E;
    --gold-light: #E5D4A8;
    --success: #5A9A6E;
    --error: #C04E4E;

    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;

    --container: 1440px;
    --header-h: 76px;
    --promise-h: 40px;
    --section-v: 50px;
    --radius: 12px;
    --radius-lg: 20px;
    --radius-pill: 100px;

    --shadow-xs: 0 1px 3px rgba(26,23,20,0.03);
    --shadow-sm: 0 2px 12px rgba(26,23,20,0.04);
    --shadow-md: 0 10px 40px rgba(26,23,20,0.06);
    --shadow-lg: 0 24px 64px rgba(26,23,20,0.08);
    --shadow-glow: 0 8px 40px rgba(181,113,90,0.15);

    --ease: cubic-bezier(0.22, 1, 0.36, 1);
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Reset ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
body {
    font-family: var(--font-body);
    font-weight: 400;
    color: var(--charcoal);
    background: var(--ivory);
    line-height: 1.65;
    overflow-x: hidden;
    cursor: none;
}
a { text-decoration: none; color: inherit; cursor: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font-family: var(--font-body); cursor: none; outline: none; border: none; }
ul { list-style: none; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 48px; }


/* ═══════════════════════════════════════════════════════════════
   KEYFRAMES
   ═══════════════════════════════════════════════════════════════ */
@keyframes petalSpin {
    0%   { transform: rotate(0deg)   translateX(-20px) scale(0.6); opacity: 0.3; }
    50%  { transform: rotate(180deg) translateX(-20px) scale(1);   opacity: 1; }
    100% { transform: rotate(360deg) translateX(-20px) scale(0.6); opacity: 0.3; }
}
@keyframes loaderFadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes loaderBar    { from { left: -100%; } to { left: 100%; } }
@keyframes revealUp     { from { opacity: 0; transform: translateY(16px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes lineSlide    { to { opacity: 1; transform: translateY(0); } }
@keyframes lineGrow     { to { height: calc(100% - 80px); } }
@keyframes pulse        { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.3; transform: scale(0.7); } }
@keyframes popBadge     { 0% { transform: scale(1); } 50% { transform: scale(1.4); } 100% { transform: scale(1); } }
@keyframes scrollBreath { 0%, 100% { opacity: 1; transform: scaleY(1); } 50% { opacity: 0.3; transform: scaleY(0.5); transform-origin: top; } }
@keyframes marqueePromise { /* used by .promise-bar__inner */ }
@keyframes toastIn  { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
@keyframes toastOut { from { opacity: 1; } to { opacity: 0; transform: translateX(40px); } }
@keyframes fadeIn   { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }


/* ═══════════════════════════════════════════════════════════════
   LOADER
   ═══════════════════════════════════════════════════════════════ */
.loader {
    position: fixed; inset: 0;
    background: var(--charcoal);
    z-index: 10000;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 24px;
    transition: opacity 0.8s ease 0.2s, visibility 0.8s ease 0.2s;
}
.loader.done { opacity: 0; visibility: hidden; pointer-events: none; }
.loader__petals {
    position: relative; width: 48px; height: 48px;
    margin-bottom: 12px;
}
.loader__petals span {
    position: absolute; width: 14px; height: 14px;
    background: var(--rose); border-radius: 50% 50% 50% 0;
    top: 50%; left: 50%;
    transform-origin: 0 0;
    animation: petalSpin 1.6s var(--ease-smooth) infinite;
}
.loader__petals span:nth-child(1) { animation-delay: 0s; }
.loader__petals span:nth-child(2) { animation-delay: 0.15s; }
.loader__petals span:nth-child(3) { animation-delay: 0.3s; }
.loader__petals span:nth-child(4) { animation-delay: 0.45s; }
.loader__petals span:nth-child(5) { animation-delay: 0.6s; }
.loader__name {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 300; color: var(--white);
    letter-spacing: 0.12em;
    opacity: 0; animation: loaderFadeUp 0.8s var(--ease) 0.2s forwards;
}
.loader__line {
    width: 60px; height: 1.5px;
    background: var(--warm-600);
    position: relative; overflow: hidden;
}
.loader__line::after {
    content: ''; position: absolute;
    top: 0; left: -100%;
    width: 100%; height: 100%;
    background: var(--rose);
    animation: loaderBar 1.5s var(--ease-smooth) 0.4s forwards;
}
.loader__sub {
    font-size: 0.65rem; letter-spacing: 0.2em;
    text-transform: uppercase; color: var(--warm-400);
    opacity: 0; animation: loaderFadeUp 0.6s var(--ease) 0.6s forwards;
}


/* ═══════════════════════════════════════════════════════════════
   CUSTOM CURSOR
   ═══════════════════════════════════════════════════════════════ */
.cursor-dot {
    position: fixed; top: 0; left: 0;
    width: 6px; height: 6px;
    background: var(--rose); border-radius: 50%;
    pointer-events: none; z-index: 99999;
    transform: translate(-50%, -50%);
    transition: width 0.2s, height 0.2s, background 0.2s;
}
.cursor-ring {
    position: fixed; top: 0; left: 0;
    width: 44px; height: 44px;
    border: 1px solid rgba(181,113,90,0.35);
    border-radius: 50%; pointer-events: none; z-index: 99998;
    transform: translate(-50%, -50%);
    transition: width 0.4s var(--ease), height 0.4s var(--ease), border-color 0.3s, background 0.3s, opacity 0.3s;
    opacity: 0.6;
}
.cursor-dot.hover { width: 4px; height: 4px; background: var(--white); }
.cursor-ring.hover { width: 72px; height: 72px; background: rgba(181,113,90,0.08); border-color: rgba(181,113,90,0.5); opacity: 1; }
.cursor-ring.clicking { transform: translate(-50%, -50%) scale(0.85); }

.grain {
    position: fixed; inset: 0;
    pointer-events: none; z-index: 9000;
    opacity: 0.022;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-repeat: repeat; background-size: 256px;
}


/* ═══════════════════════════════════════════════════════════════
   PROMISE BAR
   ═══════════════════════════════════════════════════════════════ */
.promise-bar {
    position: fixed; top: 0; left: 0; right: 0;
    height: var(--promise-h);
    background: var(--charcoal);
    z-index: 210; overflow: hidden;
    transition: transform 0.4s var(--ease);
}
.promise-bar.hidden { transform: translateY(-100%); }
.promise-bar__inner {
    max-width: var(--container); margin: 0 auto;
    padding: 0 48px; height: 100%;
    display: flex; align-items: center; justify-content: center;
    animation: marqueePromise 30s linear infinite;
    white-space: nowrap;
}
.promise-bar__item {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.62rem; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--warm-300);
    padding: 0 24px; flex-shrink: 0;
}
.promise-bar__item i { color: var(--rose-light); font-size: 0.7rem; }
.promise-bar__item--cta { color: var(--rose-lighter); }
.promise-bar__item--cta strong { color: var(--white); }
.promise-bar__sep { width: 3px; height: 3px; background: var(--warm-600); border-radius: 50%; flex-shrink: 0; }


/* ═══════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════ */
.site-header {
    position: fixed; top: var(--promise-h); left: 0; right: 0;
    height: var(--header-h);
    z-index: 200;
    background: rgba(249,246,242,0.85);
    backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
    transition: all 0.5s var(--ease);
}
.site-header.scrolled {
    top: 0;
    background: rgba(249,246,242,0.95);
    backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
    box-shadow: 0 1px 0 rgba(26,23,20,0.05);
}
.header__inner {
    max-width: var(--container); margin: 0 auto;
    padding: 0 48px; height: 100%;
    display: flex; align-items: center; justify-content: space-between;
}
.header__logo { display: flex; align-items: center; gap: 14px; z-index: 2; }
.header__logo-icon {
    width: 40px; height: 40px;
    background: linear-gradient(135deg, var(--rose), var(--rose-dark));
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem; color: var(--white);
    box-shadow: 0 2px 8px rgba(181,113,90,0.2);
}
.header__logo-text { display: flex; flex-direction: column; }
.header__logo-name {
    font-family: var(--font-display);
    font-size: 1.35rem; font-weight: 500;
    color: var(--charcoal); line-height: 1.1;
    letter-spacing: 0.02em;
}
.header__logo-tag { font-size: 0.55rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--warm-300); font-weight: 500; }
.header__nav { display: flex; align-items: center; gap: 32px; }
.header__nav-link {
    font-size: 0.8rem; font-weight: 500;
    color: var(--warm-400); letter-spacing: 0.04em;
    position: relative; padding: 4px 0; transition: color 0.3s;
}
.header__nav-link::after {
    content: ''; position: absolute; bottom: 0; left: 0;
    width: 0; height: 1px; background: var(--rose);
    transition: width 0.4s var(--ease);
}
.header__nav-link:hover { color: var(--charcoal); }
.header__nav-link:hover::after { width: 100%; }
.header__actions { display: flex; align-items: center; gap: 6px; }
.header__icon-btn {
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%; background: transparent;
    color: var(--warm-400); font-size: 1.15rem;
    position: relative; transition: all 0.2s;
}
.header__icon-btn:hover { background: rgba(26,23,20,0.04); color: var(--charcoal); }
.cart-badge {
    position: absolute; top: 6px; right: 4px;
    min-width: 17px; height: 17px; padding: 0 4px;
    background: var(--rose); color: var(--white);
    font-size: 0.55rem; font-weight: 700;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    border: 2px solid var(--ivory);
    transition: transform 0.3s var(--ease);
}
.cart-badge.pop { animation: popBadge 0.4s var(--ease); }
.header__cta-btn {
    margin-left: 12px; padding: 11px 28px;
    background: var(--charcoal); color: var(--white);
    font-size: 0.72rem; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    border-radius: var(--radius-pill); transition: all 0.3s;
}
.header__cta-btn:hover { background: var(--rose); box-shadow: var(--shadow-glow); transform: translateY(-1px); }

/* User Menu Dropdown */
.header__user-menu {
    position: relative; margin-left: 12px;
}
.header__cta-btn--user {
    display: flex; align-items: center; gap: 8px;
    cursor: pointer; border: none; font-family: inherit;
}
.header__cta-btn--user i:first-child { font-size: 1.05rem; }
.header__user-arrow {
    font-size: 0.55rem; transition: transform 0.3s;
}
.header__user-menu.open .header__user-arrow {
    transform: rotate(180deg);
}
.header__user-dropdown {
    position: absolute; top: calc(100% + 12px); right: 0;
    min-width: 240px; background: var(--white);
    border-radius: var(--radius-lg); box-shadow: 0 12px 40px rgba(0,0,0,.12);
    border: 1px solid rgba(0,0,0,.06);
    opacity: 0; visibility: hidden;
    transform: translateY(8px);
    transition: all 0.25s cubic-bezier(.4,0,.2,1);
    z-index: 1100; overflow: hidden;
}
.header__user-menu.open .header__user-dropdown {
    opacity: 1; visibility: visible; transform: translateY(0);
}
.header__user-dropdown-header {
    padding: 16px 18px 12px; background: var(--cream);
}
.header__user-dropdown-name {
    font-weight: 600; font-size: 0.88rem; color: var(--charcoal);
}
.header__user-dropdown-email {
    font-size: 0.72rem; color: var(--warm-600); margin-top: 2px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.header__user-dropdown-divider {
    height: 1px; background: rgba(0,0,0,.06); margin: 0;
}
.header__user-dropdown-link {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 18px; font-size: 0.82rem; font-weight: 500;
    color: var(--warm-800); transition: all 0.2s;
    width: 100%; border: none; background: none;
    font-family: inherit; cursor: pointer; text-align: left;
}
.header__user-dropdown-link:hover {
    background: var(--cream); color: var(--rose);
}
.header__user-dropdown-link i {
    font-size: 1rem; width: 18px; text-align: center;
    color: var(--warm-500);
}
.header__user-dropdown-link:hover i { color: var(--rose); }
.header__user-dropdown-link--logout {
    color: #dc3545;
}
.header__user-dropdown-link--logout i { color: #dc3545; }
.header__user-dropdown-link--logout:hover {
    background: #fff5f5; color: #c82333;
}
.header__user-dropdown-link--logout:hover i { color: #c82333; }

/* Burger */
.header__burger {
    display: none; width: 44px; height: 44px;
    background: none; flex-direction: column;
    align-items: center; justify-content: center; gap: 5px;
}
.header__burger span { display: block; width: 22px; height: 1.5px; background: var(--charcoal); transition: all 0.3s; border-radius: 2px; }

/* Search Overlay */
.search-overlay {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--white);
    padding: 28px 48px;
    box-shadow: var(--shadow-lg);
    transform: translateY(-10px); opacity: 0;
    visibility: hidden; pointer-events: none;
    transition: all 0.4s var(--ease);
}
.search-overlay.active { transform: translateY(0); opacity: 1; visibility: visible; pointer-events: all; }
.search-overlay__inner { display: flex; align-items: center; gap: 16px; max-width: 800px; margin: 0 auto; }
.search-overlay__input {
    flex: 1; padding: 14px 0;
    font-size: 1.2rem; background: none;
    border-bottom: 2px solid var(--sand);
    color: var(--charcoal); font-family: var(--font-display);
    transition: border-color 0.3s;
}
.search-overlay__input:focus { border-color: var(--rose); }
.search-overlay__input::placeholder { color: var(--warm-300); }
.search-overlay__close {
    width: 44px; height: 44px;
    background: var(--cream); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; color: var(--warm-400);
    transition: all 0.2s;
}
.search-overlay__close:hover { background: var(--rose); color: var(--white); }
.search-overlay__tags { display: flex; align-items: center; gap: 10px; max-width: 800px; margin: 14px auto 0; font-size: 0.72rem; color: var(--warm-300); }
.search-overlay__tags a { padding: 5px 14px; background: var(--cream); border-radius: var(--radius-pill); color: var(--warm-500); font-weight: 500; transition: all 0.2s; }
.search-overlay__tags a:hover { background: var(--rose); color: var(--white); }


/* ═══════════════════════════════════════════════════════════════
   MOBILE NAV
   ═══════════════════════════════════════════════════════════════ */
/* Mobile Nav — fixed panel, sticky header/footer, scrollable body */
.mobile-nav {
    position: fixed; top: 0; right: 0;
    width: 340px; max-width: 85vw;
    height: 100vh; height: 100dvh;
    background: var(--white);
    z-index: 10001;
    transform: translateX(100%);
    transition: transform 0.5s var(--ease);
    display: flex; flex-direction: column;
    overflow: hidden;
}
.mobile-nav.open { transform: translateX(0); }
.mobile-nav__overlay { position: fixed; inset: 0; background: rgba(26,23,20,0.5); z-index: 10000; opacity: 0; visibility: hidden; transition: all 0.4s; }
.mobile-nav__overlay.open { opacity: 1; visibility: visible; }

/* Sticky header — always visible at top */
.mobile-nav__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 24px 28px 20px; flex-shrink: 0;
    border-bottom: 1px solid var(--cream);
}
.mobile-nav__brand { font-family: var(--font-display); font-size: 1.4rem; font-weight: 500; color: var(--charcoal); }
.mobile-nav__close {
    width: 40px; height: 40px; background: var(--cream); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; color: var(--warm-400); transition: background 0.2s, color 0.2s;
}
.mobile-nav__close:hover { background: var(--warm-100); color: var(--charcoal); }

/* Scrollable body — takes remaining space */
.mobile-nav__body {
    flex: 1 1 auto;
    overflow-y: auto; -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: 8px 28px;
}
.mobile-nav__links { display: flex; flex-direction: column; }
.mobile-nav__links a {
    padding: 16px 0; font-size: 1.1rem; font-weight: 500; color: var(--warm-500);
    border-bottom: 1px solid var(--cream); transition: color 0.2s;
    display: flex; align-items: center; gap: 12px;
}
.mobile-nav__links a i { font-size: 1.1rem; color: var(--warm-300); width: 24px; text-align: center; transition: color 0.2s; }
.mobile-nav__links a:hover { color: var(--rose); }
.mobile-nav__links a:hover i { color: var(--rose); }
.mobile-nav__links a.active { color: var(--rose); font-weight: 600; }
.mobile-nav__links a.active i { color: var(--rose); }

/* Sticky footer — CTA + contact pinned at bottom */
.mobile-nav__footer {
    flex-shrink: 0;
    padding: 20px 28px 28px;
    border-top: 1px solid var(--cream);
    background: var(--white);
}
.mobile-nav__cta { margin-bottom: 16px; }
.mobile-nav__contact { display: flex; flex-direction: column; gap: 12px; }
.mobile-nav__contact a { display: flex; align-items: center; gap: 10px; font-size: 0.85rem; color: var(--warm-400); }
.mobile-nav__contact a i { color: var(--rose); }


/* ═══════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════ */
.hero {
    position: relative;
    min-height: 100vh;
    padding-top: calc(var(--promise-h) + var(--header-h) + 40px);
    display: grid;
    grid-template-columns: 1fr 1fr;
    overflow: hidden;
    background: var(--ivory);
}
.hero__text-pane {
    display: flex; flex-direction: column;
    justify-content: flex-end;
    padding: 0 0 80px 64px;
    position: relative; z-index: 10;
}
.hero__text-pane::before {
    content: ''; position: absolute;
    top: 0; left: 48px;
    width: 1px; height: 0;
    background: linear-gradient(to bottom, transparent, var(--sand), transparent);
    animation: lineGrow 1.2s var(--ease) 1.8s forwards;
}
.hero__eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 9px 20px;
    background: rgba(181,113,90,0.06);
    border: 1px solid rgba(181,113,90,0.12);
    border-radius: var(--radius-pill);
    font-size: 0.62rem; font-weight: 600;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--rose);
    margin-bottom: 16px; margin-left: 16px;
    width: fit-content;
    opacity: 0; transform: translateY(16px);
    animation: revealUp 0.7s var(--ease) 0.6s forwards;
}
.hero__eyebrow-pulse { width: 5px; height: 5px; background: var(--rose); border-radius: 50%; animation: pulse 2.4s ease infinite; }
.hero__heading {
    font-family: var(--font-display);
    font-size: clamp(3.2rem, 5.8vw, 5.6rem);
    font-weight: 400; line-height: 1.0;
    letter-spacing: -0.03em; color: var(--charcoal);
    margin-bottom: 16px; margin-left: 16px;
}
.hero__heading .h-line { display: block; overflow: hidden; padding-bottom: 6px; }
.hero__heading .h-line-inner { display: block; opacity: 0; transform: translateY(110%); animation: lineSlide 0.9s var(--ease-out) forwards; }
.hero__heading .h-line:nth-child(1) .h-line-inner { animation-delay: 0.8s; }
.hero__heading .h-line:nth-child(2) .h-line-inner { animation-delay: 0.95s; }
.hero__heading em { font-style: italic; color: var(--rose); font-weight: 400; }
.hero__sub {
    font-size: 1.05rem; color: var(--warm-400);
    line-height: 1.7; max-width: 440px;
    margin-bottom: 20px; margin-left: 16px;
    opacity: 0; transform: translateY(16px);
    animation: revealUp 0.7s var(--ease) 1.3s forwards;
}
.hero__ctas {
    display: flex; align-items: center; gap: 16px;
    margin-left: 16px;
    opacity: 0; transform: translateY(16px);
    animation: revealUp 0.7s var(--ease) 1.5s forwards;
}

/* Delivery Date Quick Picker */
.hero__date-picker {
    margin-left: 16px; margin-top: 36px;
    opacity: 0; transform: translateY(16px);
    animation: revealUp 0.7s var(--ease) 1.7s forwards;
}
.hero__date-label { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.06em; color: var(--warm-400); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.hero__date-label i { color: var(--rose); }
.hero__date-options { display: flex; gap: 10px; }
.hero__date-btn {
    padding: 12px 20px; background: var(--white);
    border: 1.5px solid var(--sand); border-radius: var(--radius);
    text-align: center; transition: all 0.3s var(--ease);
    min-width: 110px;
}
.hero__date-btn:hover { border-color: var(--rose-lighter); transform: translateY(-2px); }
.hero__date-btn.active { border-color: var(--rose); background: var(--rose-bg); box-shadow: 0 0 0 3px rgba(181,113,90,0.08); }
.hero__date-btn-day { display: block; font-size: 0.82rem; font-weight: 700; color: var(--charcoal); }
.hero__date-btn-sub { display: block; font-size: 0.62rem; color: var(--warm-300); margin-top: 2px; }
.hero__date-hidden { margin-top: 10px; margin-left: 16px; padding: 10px 16px; border: 1.5px solid var(--sand); border-radius: var(--radius); font-size: 0.85rem; color: var(--charcoal); background: var(--white); }

/* Hero Scene */
.hero__scene-pane { position: relative; display: flex; align-items: center; justify-content: center; }
.hero__canvas-wrap { position: absolute; inset: 0; }
#heroCanvas { width: 100% !important; height: 100% !important; display: block; }
.hero__scene-gradient { position: absolute; top: 0; left: 0; bottom: 0; width: 30%; background: linear-gradient(to right, var(--ivory), transparent); z-index: 2; pointer-events: none; }
.hero__scene-gradient-bottom { position: absolute; bottom: 0; left: 0; right: 0; height: 25%; background: linear-gradient(to top, var(--ivory), transparent); z-index: 2; pointer-events: none; }

/* Pincode */
.hero__pincode {
    position: absolute; bottom: 80px; right: 64px;
    z-index: 10;
    background: rgba(255,255,255,0.48);
    backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px);
    border: 1px solid rgba(255,255,255,0.6);
    border-radius: var(--radius-lg);
    padding: 32px 28px; width: 340px;
    box-shadow: 0 24px 64px rgba(26,23,20,0.06), inset 0 1px 0 rgba(255,255,255,0.6);
    opacity: 0; transform: translateY(24px) scale(0.98);
    animation: revealUp 0.7s var(--ease) 1.8s forwards;
}
.hero__pincode-label { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--charcoal); margin-bottom: 4px; }
.hero__pincode-hint { font-size: 0.75rem; color: var(--warm-400); margin-bottom: 18px; }
.hero__pincode-row { display: flex; gap: 8px; }
.hero__pincode-input {
    flex: 1; padding: 13px 16px;
    font-size: 0.9rem; background: var(--white);
    border: 1.5px solid var(--warm-100);
    border-radius: var(--radius); color: var(--charcoal);
    letter-spacing: 0.12em; transition: all 0.2s;
}
.hero__pincode-input:focus { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(181,113,90,0.08); }
.hero__pincode-input::placeholder { color: var(--warm-300); letter-spacing: 0.06em; }
.hero__pincode-btn { padding: 13px 12px; background: var(--rose); color: var(--white); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; border-radius: var(--radius); transition: all 0.2s; white-space: nowrap; }
.hero__pincode-btn:hover { background: var(--rose-dark); }
.hero__pincode-result { margin-top: 12px; font-size: 0.8rem; font-weight: 600; min-height: 22px; transition: all 0.3s; }
.hero__pincode-result.ok  { color: var(--success); }
.hero__pincode-result.ok::before  { content: '✓ '; }
.hero__pincode-result.fail { color: var(--error); }
.hero__pincode-result.fail::before { content: '✗ '; }

/* Pincode saved badge */
.hero__pincode-saved {
    position: absolute; bottom: 80px; right: 64px;
    z-index: 10;
    display: none; align-items: center; gap: 14px;
    background: rgba(255,255,255,0.52);
    backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px);
    border: 1px solid rgba(255,255,255,0.6);
    border-radius: var(--radius-lg);
    padding: 20px 22px;
    box-shadow: 0 24px 64px rgba(26,23,20,0.06), inset 0 1px 0 rgba(255,255,255,0.6);
    min-width: 240px;
}
.hero__pincode-saved-icon {
    width: 42px; height: 42px; border-radius: 50%;
    background: rgba(181,113,90,0.10);
    display: flex; align-items: center; justify-content: center;
    color: var(--rose); font-size: 1.1rem; flex-shrink: 0;
}
.hero__pincode-saved-body { flex: 1; }
.hero__pincode-saved-label { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--success); margin-bottom: 3px; }
.hero__pincode-saved-pin { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--charcoal); letter-spacing: 0.04em; }
.hero__pincode-saved-change {
    font-size: 0.72rem; font-weight: 600; color: var(--rose);
    background: none; border: none; cursor: pointer;
    text-decoration: underline; text-underline-offset: 3px;
    padding: 4px 0; white-space: nowrap;
    transition: color 0.2s;
}
.hero__pincode-saved-change:hover { color: var(--rose-dark); }

/* Scroll Cue */
.hero__scroll-cue {
    position: absolute; bottom: 28px; left: 50%;
    transform: translateX(-50%); z-index: 10;
    display: flex; flex-direction: column; align-items: center; gap: 8px;
    font-size: 0.6rem; font-weight: 600;
    letter-spacing: 0.14em; text-transform: uppercase; color: var(--warm-300);
    opacity: 0; animation: revealUp 0.6s var(--ease) 2.4s forwards;
}
.hero__scroll-bar { width: 1px; height: 36px; background: linear-gradient(to bottom, var(--warm-300), transparent); animation: scrollBreath 2s ease-in-out infinite; }


/* ═══════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════ */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
    border-radius: var(--radius-pill);
    transition: all 0.3s var(--ease);
    position: relative; overflow: hidden;
}
.btn--dark  { padding: 18px 42px; font-size: 0.78rem; background: var(--charcoal); color: var(--white); }
.btn--dark:hover  { background: var(--rose); transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.btn--ghost { padding: 18px 42px; font-size: 0.78rem; background: transparent; color: var(--charcoal); border: 1.5px solid var(--warm-200); }
.btn--ghost:hover { border-color: var(--rose); color: var(--rose); transform: translateY(-2px); }
.btn--rose  { padding: 14px 32px; font-size: 0.75rem; background: var(--rose); color: var(--white); }
.btn--rose:hover  { background: var(--rose-dark); transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.btn--sm    { padding: 10px 22px; font-size: 0.7rem; }
.btn--large { padding: 18px 32px; font-size: 0.85rem; }


/* ═══════════════════════════════════════════════════════════════
   SHARED SECTION STYLES
   ═══════════════════════════════════════════════════════════════ */
.section { padding: var(--section-v) 0; position: relative; overflow-x: hidden; }
.section--ivory  { background: var(--ivory); }
.section--white  { background: var(--white); }
.section--cream  { background: var(--cream); }
.section--dark   { background: var(--charcoal); color: var(--white); }
.section__eyebrow { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--rose); margin-bottom: 14px; }
.section__title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    font-weight: 400; line-height: 1.12;
    letter-spacing: -0.02em; color: var(--charcoal);
}
.section--dark .section__title { color: var(--white); }
.section__title em { font-style: italic; color: var(--rose); font-weight: 400; }
.section__sub { font-size: 1rem; color: var(--warm-400); margin-top: 14px; max-width: 480px; line-height: 1.7; }

/* Reveal Animations */
.rv { opacity: 0; transform: translateY(32px); transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
.rv.vis { opacity: 1; transform: translateY(0); }
.rv-d1 { transition-delay: 0.08s; }
.rv-d2 { transition-delay: 0.16s; }
.rv-d3 { transition-delay: 0.24s; }
.rv-d4 { transition-delay: 0.32s; }
.rv-d5 { transition-delay: 0.40s; }
.rv-d6 { transition-delay: 0.48s; }
.rv-d7 { transition-delay: 0.56s; }
.rv-d8 { transition-delay: 0.64s; }

/* Utility */
.text-success { color: var(--success); }
.text-muted   { color: var(--warm-300); }
.tag { display: inline-block; padding: 4px 10px; background: var(--cream); border-radius: var(--radius); font-size: 0.75rem; margin-right: 6px; }


/* ═══════════════════════════════════════════════════════════════
   OCCASION SHORTCUTS
   ═══════════════════════════════════════════════════════════════ */
.occasion-chips {
    display: grid; grid-template-columns: repeat(6, 1fr);
    gap: 16px; margin-top: 56px;
}
.occasion-chip {
    text-align: center; padding: 32px 12px 28px;
    background: var(--ivory);
    border: 1.5px solid transparent;
    border-radius: var(--radius-lg);
    transition: all 0.4s var(--ease);
    position: relative; overflow: hidden;
}
.occasion-chip::before { content: ''; position: absolute; inset: 0; border-radius: var(--radius-lg); border: 1px solid var(--sand); transition: border-color 0.4s; }
.occasion-chip:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); background: var(--white); }
.occasion-chip:hover::before { border-color: var(--rose-lighter); }
.occasion-chip.active { border-color: var(--rose); background: var(--rose-bg); }
.occasion-chip__icon {
    width: 56px; height: 56px; margin: 0 auto 16px;
    background: var(--white); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--rose);
    transition: all 0.4s var(--ease);
    box-shadow: var(--shadow-sm);
}
.occasion-chip:hover .occasion-chip__icon { background: var(--rose); color: var(--white); transform: scale(1.08); box-shadow: var(--shadow-glow); }
.occasion-chip__emoji {
    font-size: 2.2rem; line-height: 1; margin-bottom: 12px;
    transition: transform 0.4s var(--ease);
}
.occasion-chip:hover .occasion-chip__emoji { transform: scale(1.15); }
.occasion-chip__name { font-family: var(--font-display); font-size: 1.02rem; font-weight: 500; color: var(--charcoal); margin-bottom: 4px; }
.occasion-chip__tag { font-size: 0.62rem; color: var(--warm-300); font-weight: 500; }


/* ═══════════════════════════════════════════════════════════════
   CATEGORY GRID
   ═══════════════════════════════════════════════════════════════ */
.cat-grid {
    display: grid; grid-template-columns: repeat(6, 1fr);
    gap: 16px; margin-top: 56px;
}
.cat-card {
    position: relative; border-radius: var(--radius-lg);
    overflow: hidden; aspect-ratio: 3/4;
    transition: all 0.5s var(--ease);
}
.cat-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.cat-card__img { position: absolute; inset: 0; }
.cat-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease); }
.cat-card:hover .cat-card__img img { transform: scale(1.08); }
.cat-card__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(26,23,20,0.75) 0%, rgba(26,23,20,0.1) 60%, transparent 100%);
    display: flex; flex-direction: column;
    justify-content: flex-end;
    padding: 24px 20px; z-index: 2;
}
.cat-card__overlay--accent { background: linear-gradient(135deg, var(--rose), var(--rose-dark)); justify-content: center; align-items: center; text-align: center; }
.cat-card__icon { font-size: 1.4rem; color: var(--white); margin-bottom: 8px; opacity: 0.8; }
.cat-card__name { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--white); line-height: 1.2; }
.cat-card__count { font-size: 0.65rem; color: rgba(255,255,255,0.6); margin-top: 2px; }
.cat-card__arrow {
    position: absolute; top: 16px; right: 16px;
    width: 36px; height: 36px;
    background: rgba(255,255,255,0.15); backdrop-filter: blur(8px);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--white); font-size: 0.9rem;
    opacity: 0; transform: translateY(6px);
    transition: all 0.3s;
}
.cat-card:hover .cat-card__arrow { opacity: 1; transform: translateY(0); }
.cat-card--accent { aspect-ratio: auto; }
.cat-card--accent .cat-card__name { font-size: 1.3rem; }


/* ═══════════════════════════════════════════════════════════════
   PRODUCTS
   ═══════════════════════════════════════════════════════════════ */
.products__header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 48px; flex-wrap: wrap; gap: 20px; }
.products__filters { display: flex; gap: 8px; flex-wrap: wrap; }
.products__filter {
    padding: 8px 20px; font-size: 0.7rem;
    font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
    background: var(--ivory); border: 1px solid var(--sand);
    border-radius: var(--radius-pill);
    color: var(--warm-400); transition: all 0.3s;
}
.products__filter:hover { border-color: var(--rose-lighter); color: var(--charcoal); }
.products__filter.active { background: var(--charcoal); color: var(--white); border-color: var(--charcoal); }

.products__scroll-wrap { position: relative; overflow: hidden; margin: 0 -48px; padding: 0 48px; max-width: 100vw; }
.products__track {
    display: flex; gap: 20px;
    overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 20px; scrollbar-width: none;
    cursor: grab;
}
.products__track::-webkit-scrollbar { display: none; }
.products__track.grabbing { cursor: grabbing; }
.products__scroll-wrap::before,
.products__scroll-wrap::after { content: ''; position: absolute; top: 0; bottom: 20px; width: 80px; z-index: 3; pointer-events: none; }
.products__scroll-wrap::before { left: 0; background: linear-gradient(to right, var(--white), transparent); }
.products__scroll-wrap::after  { right: 0; background: linear-gradient(to left, var(--white), transparent); }
.products__scroll-btn {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 48px; height: 48px;
    background: var(--white); border: 1px solid var(--sand);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; color: var(--warm-400);
    box-shadow: var(--shadow-md); z-index: 5; transition: all 0.3s;
}
.products__scroll-btn:hover { background: var(--rose); color: var(--white); border-color: var(--rose); }
.products__scroll-btn--prev { left: 16px; }
.products__scroll-btn--next { right: 16px; }

.p-card {
    flex-shrink: 0; width: 250px;
    scroll-snap-align: start;
    background: var(--ivory); border-radius: var(--radius-lg);
    overflow: hidden; transition: all 0.4s var(--ease);
    position: relative; border: 1px solid transparent;
}
.p-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--rose-lighter); }
.p-card__img { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--cream); }
.p-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease); }
.p-card:hover .p-card__img img { transform: scale(1.05); }
.p-card__badge { position: absolute; top: 12px; left: 12px; padding: 4px 10px; background: var(--rose); color: var(--white); font-size: 0.55rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; border-radius: 6px; }
.p-card__delivery-badge { position: absolute; top: 12px; right: 48px; padding: 3px 8px; background: rgba(90,154,110,0.9); color: var(--white); font-size: 0.5rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; border-radius: 5px; display: flex; align-items: center; gap: 4px; backdrop-filter: blur(8px); }
.p-card__wish {
    position: absolute; top: 12px; right: 12px;
    width: 36px; height: 36px;
    background: rgba(255,255,255,0.7); backdrop-filter: blur(12px);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.95rem; color: var(--warm-400);
    opacity: 0; transform: translateY(6px); transition: all 0.3s;
}
.p-card:hover .p-card__wish { opacity: 1; transform: translateY(0); }
.p-card__wish:hover { color: var(--rose); background: var(--white); }
.p-card__wish.liked { opacity: 1; transform: translateY(0); color: var(--rose); }
.p-card__add-wrap { position: absolute; bottom: 0; left: 0; right: 0; padding: 12px; transform: translateY(100%); transition: transform 0.4s var(--ease); }
.p-card:hover .p-card__add-wrap { transform: translateY(0); }
.p-card__add-btn { width: 100%; padding: 11px; background: var(--charcoal); color: var(--white); font-size: 0.62rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; gap: 8px; transition: background 0.2s; }
.p-card__add-btn:hover { background: var(--rose); }
.p-card__body { padding: 16px 16px 18px; }
.p-card__cat { font-size: 0.55rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rose); margin-bottom: 5px; }
.p-card__name { font-family: var(--font-display); font-size: 0.98rem; font-weight: 500; color: var(--charcoal); line-height: 1.3; margin-bottom: 8px; min-height: 2.6em; text-decoration: none; display: block; transition: color 0.2s; }
.p-card__name:hover { color: var(--rose); }
.p-card__rating { display: flex; align-items: center; gap: 5px; font-size: 0.68rem; color: var(--warm-300); margin-bottom: 10px; }
.p-card__rating .stars { color: var(--gold); letter-spacing: 1px; }
.p-card__prices { display: flex; align-items: baseline; gap: 6px; }
.p-card__price { font-size: 1.05rem; font-weight: 700; color: var(--charcoal); }
.p-card__was { font-size: 0.78rem; color: var(--warm-300); text-decoration: line-through; }


/* ═══════════════════════════════════════════════════════════════
   SAME-DAY DELIVERY
   ═══════════════════════════════════════════════════════════════ */
.same-day__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.same-day__desc { font-size: 1rem; color: var(--warm-400); line-height: 1.7; margin: 20px 0 32px; max-width: 440px; }
.same-day__countdown { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 24px 28px; margin-bottom: 28px; display: inline-block; }
.same-day__countdown-label { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rose); margin-bottom: 12px; }
.same-day__countdown-timer { display: flex; align-items: center; gap: 6px; }
.same-day__countdown-unit { text-align: center; }
.same-day__countdown-unit span { display: block; font-family: var(--font-display); font-size: 2.2rem; font-weight: 500; color: var(--charcoal); line-height: 1; }
.same-day__countdown-unit small { font-size: 0.6rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--warm-300); }
.same-day__countdown-sep { font-family: var(--font-display); font-size: 1.8rem; color: var(--warm-200); margin: 0 4px; padding-bottom: 14px; }
.same-day__features { display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; }
.same-day__feature { display: flex; align-items: center; gap: 10px; font-size: 0.88rem; color: var(--warm-500); }
.same-day__feature i { color: var(--success); font-size: 1rem; }
.same-day__visual { position: relative; min-height: 500px; }
.same-day__card { position: absolute; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); transition: transform 0.5s var(--ease); }
.same-day__card img { width: 100%; height: 100%; object-fit: cover; }
.same-day__card--1 { width: 55%; aspect-ratio: 3/4; top: 0; left: 0; }
.same-day__card--2 { width: 50%; aspect-ratio: 3/4; bottom: 0; right: 0; }
.same-day__card:hover { transform: translateY(-4px); }
.same-day__card-badge { position: absolute; bottom: 16px; left: 16px; padding: 8px 14px; background: rgba(26,23,20,0.75); backdrop-filter: blur(12px); color: var(--white); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; border-radius: 8px; display: flex; align-items: center; gap: 6px; }
.same-day__card-badge i { color: var(--gold); }
.same-day__card--floating { position: absolute; bottom: 40%; right: 0; width: auto; aspect-ratio: auto; overflow: visible; box-shadow: none; z-index: 5; }
.same-day__card-glass { background: rgba(255,255,255,0.75); backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.8); border-radius: var(--radius); padding: 18px 24px; display: flex; align-items: center; gap: 14px; box-shadow: var(--shadow-lg); }
.same-day__card-glass-icon { width: 44px; height: 44px; background: var(--rose); border-radius: 10px; display: flex; align-items: center; justify-content: center; color: var(--white); font-size: 1.1rem; }
.same-day__card-glass-text strong { display: block; font-size: 1.1rem; color: var(--charcoal); font-weight: 700; }
.same-day__card-glass-text span { font-size: 0.7rem; color: var(--warm-400); }


/* ═══════════════════════════════════════════════════════════════
   ADD-ON UPSELL
   ═══════════════════════════════════════════════════════════════ */
.addon-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; margin-top: 56px; }
.addon-card { background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-lg); overflow: hidden; text-align: center; transition: all 0.4s var(--ease); position: relative; display: flex; flex-direction: column; }
.addon-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--rose-lighter); }
.addon-card__img { aspect-ratio: 1; overflow: hidden; background: var(--cream); }
.addon-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--ease); }
.addon-card:hover .addon-card__img img { transform: scale(1.06); }
.addon-card__body { padding: 16px 14px; display: flex; flex-direction: column; align-items: center; flex: 1; }
.addon-card__name { font-family: var(--font-display); font-size: 1rem; font-weight: 500; color: var(--charcoal); margin-bottom: 4px; }
.addon-card__price { font-size: 0.78rem; font-weight: 700; color: var(--rose); margin-bottom: 10px; }
.addon-card__qty { margin-top: auto; width: 100%; }
.addon-card__add-btn { width: 100%; padding: 8px 0; background: var(--white); border: 1.5px solid var(--rose); border-radius: var(--radius-md); font-size: 0.85rem; font-weight: 600; color: var(--rose); cursor: pointer; transition: all 0.3s; display: flex; align-items: center; justify-content: center; gap: 6px; }
.addon-card__add-btn:hover { background: var(--rose); color: var(--white); }
.addon-card__controls { display: flex; align-items: center; justify-content: center; gap: 0; border: 1.5px solid var(--rose); border-radius: var(--radius-md); overflow: hidden; }
.addon-card__minus, .addon-card__plus { width: 38px; height: 36px; background: var(--white); border: none; font-size: 1.1rem; color: var(--rose); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
.addon-card__minus:hover, .addon-card__plus:hover { background: var(--rose-lighter, #fff0f3); }
.addon-card__count { flex: 1; text-align: center; font-size: 0.9rem; font-weight: 700; color: var(--charcoal); min-width: 32px; background: var(--rose-lightest, #fff8f9); border-left: 1px solid var(--sand); border-right: 1px solid var(--sand); height: 36px; display: flex; align-items: center; justify-content: center; }


/* ═══════════════════════════════════════════════════════════════
   WHY CHOOSE US
   ═══════════════════════════════════════════════════════════════ */
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; margin-top: 64px; }
/* NOTE: .trust-item is used here (homepage) AND scoped in .order-summary__trust (checkout) */
.trust-item {
    text-align: center; padding: 32px 16px;
    background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius-lg);
    transition: all 0.4s var(--ease);
}
.trust-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--rose-lighter); }
.trust-item__icon { width: 72px; height: 72px; margin: 0 auto 24px; background: linear-gradient(135deg, var(--rose-bg), rgba(181,113,90,0.05)); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--rose); transition: all 0.4s var(--ease); }
.trust-item:hover .trust-item__icon { transform: translateY(-4px) scale(1.05); box-shadow: var(--shadow-glow); background: var(--rose); color: var(--white); }
.trust-item__title { font-family: var(--font-display); font-size: 1.2rem; font-weight: 500; color: var(--charcoal); margin-bottom: 10px; }
.trust-item__text { font-size: 0.88rem; color: var(--warm-400); line-height: 1.6; }
.trust-item__stat { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--cream); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.06em; color: var(--rose); text-transform: uppercase; }

.trust-counters { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; margin-top: 56px; padding: 48px 40px; background: var(--charcoal); border-radius: var(--radius-lg); }
.trust-counter { text-align: center; }
.trust-counter__num { font-family: var(--font-display); font-size: clamp(2rem, 3vw, 3rem); font-weight: 400; color: var(--white); line-height: 1; }
.trust-counter__label { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--warm-500); margin-top: 8px; }

/* Trust Badge (Product Gallery) */
.product-trust-badges { margin-top: 24px; padding: 20px; background: var(--ivory); border-radius: var(--radius-lg); display: flex; flex-direction: column; gap: 12px; }
.trust-badge-item { display: flex; align-items: center; gap: 12px; font-size: 0.85rem; color: var(--warm-500); }
.trust-badge-item i { font-size: 1.1rem; color: var(--rose); }


/* ═══════════════════════════════════════════════════════════════
   OCCASION BANNER
   ═══════════════════════════════════════════════════════════════ */
.occasion {
    position: relative; padding: 140px 0;
    background: linear-gradient(135deg, #1A1714 0%, var(--wine) 40%, var(--rose-deep) 80%, var(--rose-dark) 100%);
    overflow: hidden;
}
.occasion::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 70% 60% at 25% 50%, rgba(255,255,255,0.06), transparent); }
.occasion__deco { position: absolute; border-radius: 50%; border: 1px solid rgba(255,255,255,0.04); }
.occasion__deco:nth-child(1) { width: 500px; height: 500px; top: -200px; right: -100px; }
.occasion__deco:nth-child(2) { width: 300px; height: 300px; bottom: -100px; left: -50px; }
.occasion__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 60px; }
.occasion__eyebrow { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--rose-lighter); margin-bottom: 20px; }
.occasion__title { font-family: var(--font-display); font-size: clamp(2.2rem, 4vw, 3.6rem); font-weight: 400; color: var(--white); line-height: 1.12; letter-spacing: -0.02em; margin-bottom: 20px; }
.occasion__title em { font-style: italic; color: var(--rose-lighter); }
.occasion__desc { font-size: 1rem; color: rgba(255,255,255,0.6); line-height: 1.7; margin-bottom: 24px; max-width: 420px; }
.occasion__price-row { margin-bottom: 32px; display: flex; align-items: baseline; gap: 10px; }
.occasion__price-from { font-size: 0.72rem; color: rgba(255,255,255,0.45); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }
.occasion__price-amount { font-family: var(--font-display); font-size: 2rem; color: var(--white); font-weight: 500; }
.occasion__btn { padding: 18px 44px; background: var(--white); color: var(--wine); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; border-radius: var(--radius-pill); display: inline-flex; align-items: center; gap: 10px; transition: all 0.3s; }
.occasion__btn:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(0,0,0,0.25); }
.occasion__visuals { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; position: relative; }
.occasion__img-card { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 3/4; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); transition: transform 0.5s var(--ease); }
.occasion__img-card img { width: 100%; height: 100%; object-fit: cover; }
.occasion__img-card:nth-child(2) { transform: translateY(32px); }
.occasion__img-card:hover { transform: translateY(-4px); }
.occasion__img-card:nth-child(2):hover { transform: translateY(28px); }


/* ═══════════════════════════════════════════════════════════════
   HOW IT WORKS
   ═══════════════════════════════════════════════════════════════ */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; margin-top: 64px; position: relative; }
.steps::before { content: ''; position: absolute; top: 48px; left: calc(16.67% + 40px); right: calc(16.67% + 40px); height: 1px; background: linear-gradient(to right, transparent, var(--sand), var(--sand), transparent); }
.step { text-align: center; }
.step__num { width: 80px; height: 80px; margin: 0 auto 28px; background: var(--ivory); border: 1.5px solid var(--sand); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.8rem; font-weight: 500; color: var(--rose); position: relative; z-index: 2; transition: all 0.4s var(--ease); }
.step:hover .step__num { background: var(--rose); color: var(--white); border-color: var(--rose); transform: scale(1.06); box-shadow: var(--shadow-glow); }
.step__title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 500; color: var(--charcoal); margin-bottom: 10px; }
.step__text { font-size: 0.88rem; color: var(--warm-400); line-height: 1.65; max-width: 260px; margin: 0 auto; }
.step__icon { margin-top: 20px; font-size: 1.2rem; color: var(--warm-200); transition: color 0.3s; }
.step:hover .step__icon { color: var(--rose); }


/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════════════ */
.test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 56px; }
.test-card { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 40px 32px; transition: all 0.4s var(--ease); position: relative; }
.test-card::before { content: '\201C'; position: absolute; top: 20px; right: 28px; font-family: var(--font-display); font-size: 5rem; font-weight: 400; color: var(--rose-bg); line-height: 1; }
.test-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--rose-lighter); }
.test-card__stars { color: var(--gold); font-size: 0.85rem; letter-spacing: 3px; margin-bottom: 20px; }
.test-card__text { font-size: 0.95rem; color: var(--warm-500); line-height: 1.75; margin-bottom: 28px; font-style: italic; position: relative; z-index: 1; }
.test-card__author { display: flex; align-items: center; gap: 14px; }
.test-card__avatar { width: 44px; height: 44px; background: linear-gradient(135deg, var(--rose-bg), var(--cream)); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.82rem; color: var(--rose); }
.test-card__name { font-weight: 700; font-size: 0.88rem; color: var(--charcoal); }
.test-card__loc { font-size: 0.72rem; color: var(--warm-300); }
.test-card__verified { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--cream); font-size: 0.65rem; font-weight: 600; letter-spacing: 0.06em; color: var(--success); display: flex; align-items: center; gap: 6px; }


/* ═══════════════════════════════════════════════════════════════
   REMINDER SECTION
   ═══════════════════════════════════════════════════════════════ */
.reminder { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.reminder__icon-row { display: flex; gap: 12px; margin-bottom: 28px; }
.reminder__icon { width: 52px; height: 52px; background: var(--rose-bg); border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; color: var(--rose); }
.reminder__title { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 400; color: var(--charcoal); line-height: 1.12; margin-bottom: 16px; }
.reminder__title em { font-style: italic; color: var(--rose); }
.reminder__desc { font-size: 1rem; color: var(--warm-400); line-height: 1.7; max-width: 440px; }
.reminder__form { background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 36px 32px; }
.reminder__field { margin-bottom: 18px; }
.reminder__field label { display: block; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 6px; }
.reminder__field input,
.reminder__field select { width: 100%; padding: 13px 16px; font-size: 0.9rem; background: var(--white); border: 1.5px solid var(--warm-100); border-radius: var(--radius); color: var(--charcoal); transition: border-color 0.2s; }
.reminder__field input:focus,
.reminder__field select:focus { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(181,113,90,0.08); }
.reminder__field input::placeholder { color: var(--warm-300); }
.reminder__btn { width: 100%; padding: 15px; background: var(--rose); color: var(--white); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; gap: 8px; transition: all 0.3s; }
.reminder__btn:hover { background: var(--rose-dark); transform: translateY(-1px); }
.reminder__note { margin-top: 14px; font-size: 0.7rem; color: var(--warm-300); text-align: center; }
.reminder__success { text-align: center; padding: 60px 32px; background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-lg); }
.reminder__success-icon { font-size: 3rem; color: var(--success); margin-bottom: 16px; }
.reminder__success-title { font-family: var(--font-display); font-size: 1.6rem; font-weight: 500; color: var(--charcoal); margin-bottom: 8px; }
.reminder__success-text { font-size: 0.9rem; color: var(--warm-400); }


/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.site-footer { background: var(--charcoal); color: var(--warm-400); }
.footer__top { padding: 80px 0 0; }
.footer__cta-bar { background: linear-gradient(135deg, var(--rose), var(--rose-dark)); border-radius: var(--radius-lg); padding: 48px 56px; display: flex; align-items: center; justify-content: space-between; gap: 32px; margin-bottom: 64px; }
.footer__cta-bar h3 { font-family: var(--font-display); font-size: 1.8rem; font-weight: 400; color: var(--white); }
.footer__cta-bar p { font-size: 0.9rem; color: rgba(255,255,255,0.7); margin-top: 6px; }
.footer__cta-bar .btn--rose { background: var(--white); color: var(--rose-dark); }
.footer__cta-bar .btn--rose:hover { background: var(--charcoal); color: var(--white); }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 56px; }
.footer__brand { font-family: var(--font-display); font-size: 1.5rem; font-weight: 400; color: var(--white); margin-bottom: 16px; letter-spacing: 0.02em; }
.footer__desc { font-size: 0.88rem; color: var(--warm-500); line-height: 1.7; margin-bottom: 28px; max-width: 300px; }
.footer__social { display: flex; gap: 10px; }
.footer__social a { width: 40px; height: 40px; border: 1px solid var(--warm-600); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--warm-400); transition: all 0.3s; }
.footer__social a:hover { background: var(--rose); border-color: var(--rose); color: var(--white); }
.footer__heading { font-family: var(--font-display); font-size: 1.05rem; font-weight: 500; color: var(--white); margin-bottom: 20px; }
.footer__links li { margin-bottom: 10px; }
.footer__links a { font-size: 0.84rem; color: var(--warm-500); transition: color 0.2s; }
.footer__links a:hover { color: var(--rose-light); }
.footer__payment { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 24px 0; border-top: 1px solid rgba(255,255,255,0.05); font-size: 0.72rem; color: var(--warm-600); }
.footer__payment-icons { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.footer__pay-icon { padding: 5px 13px; border-radius: 6px; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.05em; white-space: nowrap; border: 1.5px solid transparent; transition: transform 0.15s ease, box-shadow 0.15s ease; }
.footer__pay-icon:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.3); }
.footer__pay-icon--upi     { background: #4A1D8F; color: #fff; border-color: #6C35C2; }
.footer__pay-icon--visa    { background: #1A1F71; color: #F7B600; border-color: #2B31A8; }
.footer__pay-icon--mc      { background: #EB001B; color: #fff; border-color: #FF5F00; }
.footer__pay-icon--gpay    { background: #fff; color: #1a73e8; border-color: #4285F4; }
.footer__pay-icon--phonepe { background: #5f259f; color: #fff; border-color: #7B3FBE; }
.footer__pay-icon--cod     { background: #1a7f45; color: #fff; border-color: #28A461; }
.footer__credits { border-top: 1px solid rgba(255,255,255,0.05); padding: 16px 0 0; display: flex; justify-content: space-between; align-items: center; font-size: 0.75rem; color: var(--warm-500); flex-wrap: wrap; }
.footer__credits strong { color: var(--warm-400); font-weight: 600; }
.footer__credits a { color: var(--rose-light); font-weight: 600; text-decoration: none; transition: color 0.2s; }
.footer__credits a:hover { color: var(--rose); text-decoration: underline; }
.footer__credits-sep { display: none; }
.footer__bottom { padding: 16px 0 24px; display: flex; justify-content: space-between; align-items: center; font-size: 0.75rem; color: var(--warm-600); }
.footer__bottom a { margin-left: 24px; color: var(--warm-500); transition: color 0.2s; }
.footer__bottom a:hover { color: var(--rose-light); }


/* ═══════════════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════════════ */
.toast-box { position: fixed; top: 96px; right: 28px; z-index: 600; display: flex; flex-direction: column; gap: 10px; }
.toast-item { padding: 14px 24px 14px 18px; background: var(--charcoal); color: var(--white); border-radius: var(--radius); font-size: 0.85rem; font-weight: 500; display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow-lg); animation: toastIn 0.4s var(--ease), toastOut 0.4s var(--ease) 2.4s forwards; border-left: 3px solid var(--rose); }
.toast-item--delivery { background: #e8f5e9; color: #2e7d32; border-left-color: #66bb6a; animation: toastIn 0.4s var(--ease); box-shadow: 0 4px 20px rgba(46,125,50,.15); }
.toast-item--delivery i { color: #43a047; }


/* ═══════════════════════════════════════════════════════════════
   BACK TO TOP
   ═══════════════════════════════════════════════════════════════ */
.back-to-top { position: fixed; bottom: 28px; right: 28px; width: 48px; height: 48px; background: var(--white); border: 1px solid var(--sand); border-radius: 50%; z-index: 500; display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--warm-400); box-shadow: var(--shadow-md); opacity: 0; transform: translateY(20px); transition: all 0.4s var(--ease); pointer-events: none; }
.back-to-top.visible { opacity: 1; transform: translateY(0); pointer-events: all; }
.back-to-top:hover { background: var(--rose); color: var(--white); border-color: var(--rose); transform: translateY(-2px); }


/* ═══════════════════════════════════════════════════════════════
   PRODUCT DETAIL
   ═══════════════════════════════════════════════════════════════ */
.product-detail { padding-top: 32px; }
.product-detail__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }

/* Gallery */
.product-gallery { position: sticky; top: calc(var(--header-h) + 24px); }
.product-gallery__main-img { position: relative; aspect-ratio: 4/5; background: var(--cream); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 16px; }
.product-gallery__main-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--ease); }
.product-gallery__main-img:hover img { transform: scale(1.05); }
.product-badge { position: absolute; padding: 8px 16px; border-radius: var(--radius); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 6px; }
.product-badge--delivery { top: 16px; left: 16px; background: rgba(90, 154, 110, 0.9); color: var(--white); backdrop-filter: blur(8px); }
.product-badge--discount { top: 16px; right: 16px; background: var(--rose); color: var(--white); }
.product-gallery__wishlist { position: absolute; bottom: 16px; right: 16px; width: 48px; height: 48px; background: rgba(255,255,255,0.9); backdrop-filter: blur(12px); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; color: var(--warm-400); transition: all 0.3s; }
.product-gallery__wishlist:hover { background: var(--white); color: var(--rose); transform: scale(1.08); }
.product-gallery__wishlist.liked { color: var(--rose); }
.product-gallery__wishlist.liked i::before { content: "\f415"; }
.product-gallery__thumbs { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: 12px; }
.product-gallery__thumb { aspect-ratio: 1; border-radius: var(--radius); overflow: hidden; background: var(--cream); border: 2px solid transparent; transition: all 0.3s; cursor: pointer; }
.product-gallery__thumb:hover { border-color: var(--rose-lighter); }
.product-gallery__thumb.active { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(181, 113, 90, 0.15); }
.product-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* Product Info */
.product-info__meta { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.product-info__category { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rose); transition: color 0.2s; }
.product-info__category:hover { color: var(--rose-dark); }
.product-info__rating { display: flex; align-items: center; gap: 6px; font-size: 0.85rem; }
.product-info__rating .stars { color: var(--gold); letter-spacing: 2px; }
.rating-value { font-weight: 700; color: var(--charcoal); }
.rating-count { color: var(--warm-400); text-decoration: underline; }
.rating-count:hover { color: var(--rose); }
.product-info__name { font-family: var(--font-display); font-size: clamp(2rem, 3vw, 2.8rem); font-weight: 400; line-height: 1.15; letter-spacing: -0.02em; color: var(--charcoal); margin-bottom: 16px; }
.product-info__short-desc { font-size: 1.05rem; color: var(--warm-400); line-height: 1.7; margin-bottom: 24px; }
.product-info__price { display: flex; align-items: baseline; gap: 12px; margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid var(--sand); }
.price-current { font-family: var(--font-display); font-size: 2.4rem; font-weight: 500; color: var(--charcoal); }
.price-compare { font-size: 1.2rem; color: var(--warm-300); text-decoration: line-through; }
.price-save { padding: 4px 10px; background: rgba(90, 154, 110, 0.1); color: var(--success); font-size: 0.75rem; font-weight: 700; border-radius: var(--radius); }

/* Delivery / Time Selectors */
.delivery-selector { margin-bottom: 24px; }
.delivery-selector__label,
.time-slot-selector__label,
.personalization__label { display: flex; align-items: center; gap: 8px; font-size: 0.85rem; font-weight: 700; color: var(--charcoal); margin-bottom: 12px; }
.delivery-selector__label i,
.time-slot-selector__label i,
.personalization__label i { color: var(--rose); }
.delivery-selector__options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.delivery-date-btn { padding: 14px 12px; background: var(--ivory); border: 2px solid var(--sand); border-radius: var(--radius); text-align: center; transition: all 0.3s var(--ease); cursor: pointer; }
.delivery-date-btn:hover { border-color: var(--rose-lighter); transform: translateY(-2px); }
.delivery-date-btn.active { border-color: var(--rose); background: var(--rose-bg); box-shadow: 0 0 0 3px rgba(181, 113, 90, 0.08); }
.delivery-date-btn__day { display: block; font-size: 0.9rem; font-weight: 700; color: var(--charcoal); margin-bottom: 4px; }
.delivery-date-btn__sub { display: block; font-size: 0.7rem; color: var(--warm-400); }
.delivery-date-custom { margin-top: 12px; width: 100%; padding: 12px 16px; background: var(--white); border: 2px solid var(--sand); border-radius: var(--radius); font-size: 0.9rem; color: var(--charcoal); }
.time-slot-selector { margin-bottom: 24px; }
.time-slot-selector__select { width: 100%; padding: 14px 16px; background: var(--ivory); border: 2px solid var(--sand); border-radius: var(--radius); font-size: 0.9rem; color: var(--charcoal); cursor: pointer; transition: all 0.2s; }
.time-slot-selector__select:hover,
.time-slot-selector__select:focus { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(181, 113, 90, 0.08); }

/* Personalization */
.personalization { margin-bottom: 28px; position: relative; }
.personalization__textarea { width: 100%; min-height: 100px; padding: 14px 16px; background: var(--ivory); border: 2px solid var(--sand); border-radius: var(--radius); font-size: 0.9rem; font-family: var(--font-body); color: var(--charcoal); resize: vertical; transition: all 0.2s; }
.personalization__textarea:focus { border-color: var(--rose); box-shadow: 0 0 0 3px rgba(181, 113, 90, 0.08); background: var(--white); }
.personalization__textarea::placeholder { color: var(--warm-300); font-style: italic; }
.personalization__count { position: absolute; bottom: -20px; right: 0; font-size: 0.7rem; color: var(--warm-300); }

/* Product Actions */
.product-actions { display: grid; grid-template-columns: 1.5fr 1fr; gap: 12px; margin-bottom: 28px; }

/* Quick Info Cards */
.quick-info-cards { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; padding: 20px; background: var(--ivory); border-radius: var(--radius-lg); }
.quick-info-card { display: flex; align-items: center; gap: 12px; font-size: 0.85rem; }
.quick-info-card i { font-size: 1.2rem; color: var(--rose); }
.quick-info-card strong { display: block; color: var(--charcoal); font-weight: 600; }
.quick-info-card span { display: block; font-size: 0.8rem; color: var(--warm-400); }

/* Share */
.product-share { display: flex; align-items: center; gap: 12px; padding-top: 24px; border-top: 1px solid var(--sand); }
.product-share__label { font-size: 0.85rem; font-weight: 600; color: var(--warm-400); }
.product-share__buttons { display: flex; gap: 8px; }
.share-btn { width: 40px; height: 40px; border: 1px solid var(--sand); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--warm-400); transition: all 0.3s; }
.share-btn:hover { background: var(--rose); color: var(--white); border-color: var(--rose); transform: translateY(-2px); }

/* Product Tabs */
.product-tabs { background: var(--white); border-radius: var(--radius-lg); overflow: hidden; }
.product-tabs__nav { display: flex; border-bottom: 1px solid var(--sand); }
.product-tabs__tab { flex: 1; padding: 20px 24px; background: transparent; border-bottom: 3px solid transparent; font-size: 0.9rem; font-weight: 600; color: var(--warm-400); cursor: pointer; transition: all 0.3s; }
.product-tabs__tab:hover { color: var(--charcoal); background: rgba(181, 113, 90, 0.03); }
.product-tabs__tab.active { color: var(--rose); border-bottom-color: var(--rose); background: rgba(181, 113, 90, 0.05); }
.product-tabs__content { padding: 40px 48px; }
.product-tabs__pane { display: none; }
.product-tabs__pane.active { display: block; animation: fadeIn 0.4s var(--ease); }
.product-description { font-size: 1rem; color: var(--warm-500); line-height: 1.8; max-width: 720px; }

/* Detail Rows */
.product-details { max-width: 600px; }
.detail-row { display: flex; padding: 16px 0; border-bottom: 1px solid var(--cream); }
.detail-row:last-child { border-bottom: none; }
.detail-label { width: 180px; font-weight: 600; color: var(--warm-500); font-size: 0.9rem; }
.detail-value { flex: 1; color: var(--charcoal); font-size: 0.9rem; display: flex; align-items: center; gap: 8px; }

/* Delivery Info */
.delivery-info { display: flex; flex-direction: column; gap: 20px; max-width: 640px; }
.delivery-info-card { display: flex; gap: 16px; padding: 24px; background: var(--cream); border-radius: var(--radius-lg); }
.delivery-info-card i { font-size: 1.8rem; color: var(--rose); flex-shrink: 0; }
.delivery-info-card h4 { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--charcoal); margin-bottom: 6px; }
.delivery-info-card p { font-size: 0.9rem; color: var(--warm-500); line-height: 1.6; }

/* Add-ons Grid (Product Page) */
.addons-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; margin-top: 48px; }
.addon-item { background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-lg); overflow: hidden; transition: all 0.4s var(--ease); }
.addon-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--rose-lighter); }
.addon-item__img { aspect-ratio: 1; overflow: hidden; background: var(--cream); }
.addon-item__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--ease); }
.addon-item:hover .addon-item__img img { transform: scale(1.05); }
.addon-item__info { padding: 20px; }
.addon-item__name { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--charcoal); margin-bottom: 6px; }
.addon-item__desc { font-size: 0.85rem; color: var(--warm-400); line-height: 1.5; margin-bottom: 16px; }
.addon-item__footer { display: flex; align-items: center; justify-content: space-between; }
.addon-item__price { font-size: 1rem; font-weight: 700; color: var(--rose); }
.addon-item__add { padding: 8px 18px; background: var(--rose); color: var(--white); font-size: 0.75rem; font-weight: 700; border-radius: var(--radius); display: flex; align-items: center; gap: 6px; transition: all 0.3s; }
.addon-item__add:hover { background: var(--rose-dark); transform: translateY(-1px); }

/* Reviews */
.reviews-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 40px; }
.reviews-summary { margin-top: 16px; }
.reviews-summary__rating { display: flex; align-items: center; gap: 20px; }
.reviews-summary__number { font-family: var(--font-display); font-size: 3.2rem; font-weight: 500; color: var(--charcoal); }
.reviews-summary__stars { color: var(--gold); font-size: 1.2rem; letter-spacing: 2px; margin-bottom: 4px; }
.reviews-summary__count { font-size: 0.85rem; color: var(--warm-400); }
.reviews-list { display: flex; flex-direction: column; gap: 24px; }
.review-card { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 28px; transition: all 0.3s; }
.review-card:hover { box-shadow: var(--shadow-sm); border-color: var(--rose-lighter); }
.review-card__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.review-card__author { display: flex; align-items: center; gap: 14px; }
.review-card__avatar { width: 48px; height: 48px; background: linear-gradient(135deg, var(--rose-bg), var(--cream)); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; color: var(--rose); }
.review-card__name { font-weight: 700; color: var(--charcoal); font-size: 0.95rem; }
.review-card__date { font-size: 0.75rem; color: var(--warm-400); }
.review-card__rating { color: var(--gold); font-size: 1rem; letter-spacing: 2px; }
.review-card__content { font-size: 0.95rem; color: var(--warm-500); line-height: 1.7; margin-bottom: 16px; }
.review-card__images { display: flex; gap: 10px; margin-bottom: 16px; }
.review-card__image { width: 80px; height: 80px; border-radius: var(--radius); object-fit: cover; cursor: pointer; transition: transform 0.3s; }
.review-card__image:hover { transform: scale(1.05); }
.review-card__response { background: rgba(181, 113, 90, 0.05); border-left: 3px solid var(--rose); padding: 16px; border-radius: var(--radius); margin-bottom: 16px; }
.review-card__response strong { display: block; color: var(--rose); font-size: 0.85rem; margin-bottom: 6px; }
.review-card__response p { font-size: 0.9rem; color: var(--warm-500); line-height: 1.6; }
.review-card__actions { display: flex; gap: 12px; }
.review-helpful-btn { padding: 8px 16px; background: transparent; border: 1px solid var(--sand); border-radius: var(--radius); font-size: 0.8rem; color: var(--warm-500); display: flex; align-items: center; gap: 6px; transition: all 0.3s; }
.review-helpful-btn:hover { border-color: var(--rose); color: var(--rose); }
.empty-reviews { text-align: center; padding: 60px 20px; }
.empty-reviews i { font-size: 3rem; color: var(--warm-200); margin-bottom: 16px; }
.empty-reviews p { font-size: 1rem; color: var(--warm-400); }

/* Reviews grid (product detail page) */
.reviews-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 40px;
}
.review-card__meta { display: flex; flex-direction: column; gap: 2px; }
.review-card__stars { color: var(--gold); font-size: 1rem; letter-spacing: 2px; flex-shrink: 0; }
.review-card__title { font-weight: 700; font-size: 1rem; color: var(--charcoal); margin-bottom: 6px; }
.review-card__body { font-size: 0.92rem; color: var(--warm-500); line-height: 1.7; margin-bottom: 12px; }
.review-card__verified { display: inline-flex; align-items: center; gap: 5px; font-size: 0.78rem; color: #16a34a; font-weight: 600; }
.reviews-empty { text-align: center; padding: 60px 20px; color: var(--warm-400); }
.reviews-empty i { font-size: 3rem; color: var(--warm-200); display: block; margin-bottom: 16px; }
.reviews-empty p { font-size: 1rem; }

/* Rating Summary Bar */
.rvw-summary { display: flex; gap: 40px; align-items: center; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 32px 40px; margin-top: 32px; }
.rvw-summary__score { text-align: center; min-width: 120px; }
.rvw-summary__number { font-family: var(--font-display); font-size: 3.6rem; font-weight: 500; color: var(--charcoal); line-height: 1; }
.rvw-summary__stars { color: var(--gold); font-size: 1.1rem; letter-spacing: 2px; margin: 6px 0 4px; }
.rvw-summary__total { font-size: 0.82rem; color: var(--warm-400); }
.rvw-summary__bars { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.rvw-summary__bar-row { display: flex; align-items: center; gap: 10px; }
.rvw-summary__bar-label { font-size: 0.78rem; color: var(--warm-500); min-width: 36px; text-align: right; display: flex; align-items: center; gap: 2px; justify-content: flex-end; }
.rvw-summary__bar-label i { font-size: 0.65rem; color: var(--gold); }
.rvw-summary__bar-track { flex: 1; height: 8px; background: var(--sand); border-radius: 4px; overflow: hidden; }
.rvw-summary__bar-fill { height: 100%; background: var(--gold); border-radius: 4px; transition: width 0.5s ease; }
.rvw-summary__bar-count { font-size: 0.78rem; color: var(--warm-400); min-width: 24px; }

/* Featured Review Card */
.review-card--featured { border-color: var(--gold); background: linear-gradient(135deg, rgba(218, 165, 32, 0.03) 0%, var(--white) 100%); }
.review-card__featured-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 0.72rem; font-weight: 700; color: var(--gold); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 12px; }
.review-card__featured-badge i { font-size: 0.7rem; }
.review-helpful-btn { cursor: pointer; }

/* Review CTA */
.reviews-cta { display: flex; align-items: center; justify-content: center; gap: 16px; background: var(--white); border: 1px dashed var(--rose-lighter); border-radius: var(--radius-lg); padding: 20px 28px; margin-top: 32px; }
.reviews-cta p { font-size: 0.92rem; color: var(--warm-500); margin: 0; }

/* Review Image Upload (create form) */
.rvw-upload { margin-bottom: 24px; }
.rvw-upload__label { display: block; font-size: 0.82rem; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: var(--charcoal); margin-bottom: 8px; }
.rvw-upload__zone { position: relative; border: 2px dashed var(--sand); border-radius: var(--radius-lg); padding: 28px; text-align: center; cursor: pointer; transition: all 0.3s; }
.rvw-upload__zone:hover, .rvw-upload__zone.dragover { border-color: var(--rose); background: rgba(181, 113, 90, 0.03); }
.rvw-upload__input { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }
.rvw-upload__placeholder { display: flex; flex-direction: column; align-items: center; gap: 6px; color: var(--warm-400); pointer-events: none; }
.rvw-upload__placeholder i { font-size: 1.8rem; color: var(--warm-300); }
.rvw-upload__placeholder span { font-size: 0.88rem; }
.rvw-upload__placeholder small { font-size: 0.75rem; color: var(--warm-300); }
.rvw-upload__preview { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.rvw-upload__thumb { position: relative; width: 72px; height: 72px; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--sand); }
.rvw-upload__thumb img { width: 100%; height: 100%; object-fit: cover; }
.rvw-upload__thumb-remove { position: absolute; top: 2px; right: 2px; width: 20px; height: 20px; border-radius: 50%; background: rgba(0,0,0,0.65); color: #fff; border: none; font-size: 0.8rem; line-height: 1; cursor: pointer; display: grid; place-items: center; }
.rvw-upload__thumb-remove:hover { background: var(--rose); }

/* Related / scrollable products row (product detail page) */
.products-scroll {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 40px;
    max-width: 100%; overflow: hidden;
}

@media (max-width: 1200px) {
    .products-scroll { grid-template-columns: repeat(3, 1fr); gap: 20px; }
}
@media (max-width: 1024px) {
    .reviews-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .products-scroll { grid-template-columns: repeat(3, 1fr); gap: 20px; }
}
@media (max-width: 768px) {
    .reviews-grid { grid-template-columns: 1fr; gap: 16px; }
    .products-scroll { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .rvw-summary { flex-direction: column; gap: 24px; padding: 24px; text-align: center; }
    .rvw-summary__score { min-width: auto; }
    .rvw-summary__number { font-size: 2.8rem; }
    .reviews-cta { flex-direction: column; text-align: center; gap: 12px; }
}
@media (max-width: 480px) {
    .products-scroll { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .review-card__header { flex-wrap: wrap; gap: 8px; }
    .rvw-summary { padding: 20px; }
    .rvw-summary__number { font-size: 2.4rem; }
}

/* ═══════════════════════════════════════════════════════════════
   REVIEW PROMPTS (Nudge banner, Popup, Dashboard pending cards)
   ═══════════════════════════════════════════════════════════════ */

/* Review Nudge Banner (order page — pre-delivery) */
.review-nudge { display: flex; align-items: center; gap: 16px; background: linear-gradient(135deg, rgba(181,113,90,0.06) 0%, rgba(218,165,32,0.06) 100%); border: 1px solid rgba(181,113,90,0.15); border-radius: var(--radius-lg); padding: 18px 24px; margin-bottom: 20px; }
.review-nudge__icon { font-size: 1.6rem; color: var(--gold); flex-shrink: 0; }
.review-nudge__text { display: flex; flex-direction: column; gap: 2px; }
.review-nudge__text strong { font-size: 0.92rem; color: var(--charcoal); }
.review-nudge__text span { font-size: 0.82rem; color: var(--warm-500); line-height: 1.5; }

/* Review Popup (order page — post-delivery) */
.review-popup { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: flex-end; justify-content: center; opacity: 0; transition: opacity 0.35s ease; }
.review-popup.active { opacity: 1; }
.review-popup__backdrop { position: absolute; inset: 0; background: rgba(26,23,20,0.45); backdrop-filter: blur(4px); }
.review-popup__card { position: relative; z-index: 1; background: var(--white); border-radius: 20px 20px 0 0; padding: 36px 32px 32px; max-width: 420px; width: 100%; text-align: center; transform: translateY(100%); transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1); box-shadow: 0 -8px 40px rgba(0,0,0,0.12); }
.review-popup.active .review-popup__card { transform: translateY(0); }
.review-popup__dismiss { position: absolute; top: 14px; right: 16px; background: none; border: none; font-size: 1.4rem; color: var(--warm-400); cursor: pointer; width: 32px; height: 32px; display: grid; place-items: center; border-radius: 50%; transition: all 0.2s; }
.review-popup__dismiss:hover { background: var(--sand); color: var(--charcoal); }
.review-popup__stars { color: var(--gold); font-size: 1.5rem; letter-spacing: 6px; margin-bottom: 16px; }
.review-popup__title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 500; color: var(--charcoal); margin-bottom: 8px; }
.review-popup__desc { font-size: 0.88rem; color: var(--warm-500); line-height: 1.6; margin-bottom: 20px; }
.review-popup__products { display: flex; justify-content: center; gap: 8px; margin-bottom: 24px; }
.review-popup__product-img { width: 56px; height: 56px; border-radius: 12px; object-fit: cover; border: 2px solid var(--sand); }
.review-popup__cta { display: inline-flex; align-items: center; gap: 8px; background: var(--rose); color: var(--white); font-weight: 700; font-size: 0.95rem; padding: 14px 36px; border-radius: var(--radius-lg); text-decoration: none; transition: all 0.3s; letter-spacing: 0.3px; }
.review-popup__cta:hover { background: var(--rose-darker); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(181,113,90,0.3); }
.review-popup__later { display: block; margin: 14px auto 0; background: none; border: none; font-size: 0.82rem; color: var(--warm-400); cursor: pointer; padding: 6px 12px; transition: color 0.2s; }
.review-popup__later:hover { color: var(--charcoal); }

/* Dashboard: Pending Reviews */
.pending-review-count { font-size: 0.78rem; color: var(--rose); font-weight: 600; background: rgba(181,113,90,0.08); padding: 4px 12px; border-radius: 20px; }
.pending-reviews-scroll { display: flex; gap: 16px; overflow-x: auto; padding-bottom: 8px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.pending-reviews-scroll::-webkit-scrollbar { height: 3px; }
.pending-reviews-scroll::-webkit-scrollbar-thumb { background: var(--sand); border-radius: 3px; }

.pending-review-card { flex: 0 0 280px; scroll-snap-align: start; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 18px; display: flex; flex-direction: column; gap: 14px; transition: all 0.3s; }
.pending-review-card:hover { border-color: var(--rose-lighter); box-shadow: var(--shadow-sm); }
.pending-review-card__images { display: flex; gap: 6px; }
.pending-review-card__img { width: 52px; height: 52px; border-radius: 10px; object-fit: cover; border: 1px solid var(--sand); }
.pending-review-card__img-ph { width: 52px; height: 52px; border-radius: 10px; background: var(--cream); display: grid; place-items: center; color: var(--warm-300); font-size: 1.2rem; }
.pending-review-card__body { flex: 1; }
.pending-review-card__order { font-size: 0.72rem; color: var(--warm-400); font-weight: 600; margin-bottom: 2px; }
.pending-review-card__items { font-size: 0.88rem; font-weight: 600; color: var(--charcoal); line-height: 1.3; }
.pending-review-card__items span { font-weight: 400; color: var(--warm-400); font-size: 0.78rem; }
.pending-review-card__date { font-size: 0.75rem; color: var(--warm-400); margin-top: 4px; }
.pending-review-card__cta { display: inline-flex; align-items: center; justify-content: center; gap: 6px; background: var(--rose); color: var(--white); font-size: 0.82rem; font-weight: 700; padding: 10px 20px; border-radius: var(--radius); text-decoration: none; transition: all 0.3s; align-self: flex-start; }
.pending-review-card__cta:hover { background: var(--rose-darker); }
.pending-review-card__cta i { font-size: 0.75rem; }

@media (max-width: 768px) {
    .review-nudge { flex-direction: column; text-align: center; gap: 10px; padding: 16px 20px; }
    .review-popup__card { padding: 28px 24px 24px; border-radius: 16px 16px 0 0; }
    .review-popup__title { font-size: 1.2rem; }
    .pending-review-card { flex: 0 0 240px; }
}
@media (max-width: 480px) {
    .review-popup__products { gap: 6px; }
    .review-popup__product-img { width: 48px; height: 48px; }
    .review-popup__cta { padding: 12px 28px; font-size: 0.88rem; }
    .pending-review-card { flex: 0 0 220px; padding: 14px; }
    .pending-review-card__img { width: 44px; height: 44px; }
}


/* ═══════════════════════════════════════════════════════════════
   POLICY PAGES (Privacy, Terms, Refund)
   ═══════════════════════════════════════════════════════════════ */
.policy-page { padding-top: 40px; }
.policy-header { text-align: center; margin-bottom: 48px; }
.policy-title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3rem); font-weight: 500; color: var(--charcoal); margin: 12px 0 8px; }
.policy-updated { font-size: 0.82rem; color: var(--warm-400); }
.policy-content { max-width: 820px; margin: 0 auto; }
.policy-section { margin-bottom: 40px; }
.policy-section h2 { font-family: var(--font-display); font-size: 1.35rem; font-weight: 600; color: var(--charcoal); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid var(--sand); }
.policy-section h3 { font-size: 1rem; font-weight: 600; color: var(--charcoal); margin: 20px 0 10px; }
.policy-section p { font-size: 0.95rem; line-height: 1.8; color: var(--warm-600); margin-bottom: 12px; }
.policy-section ul, .policy-section ol { padding-left: 24px; margin-bottom: 16px; }
.policy-section li { font-size: 0.95rem; line-height: 1.8; color: var(--warm-600); margin-bottom: 6px; }
.policy-section a { color: var(--rose); font-weight: 500; text-decoration: underline; text-underline-offset: 3px; }
.policy-section a:hover { color: var(--rose-dark); }
.policy-contact { background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 24px 28px; margin-top: 16px; }
.policy-contact p { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-size: 0.9rem; }
.policy-contact p:last-child { margin-bottom: 0; }
.policy-contact i { color: var(--rose); font-size: 1rem; flex-shrink: 0; }
.policy-table-wrap { overflow-x: auto; margin: 16px 0; }
.policy-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.policy-table th { background: var(--charcoal); color: var(--white); padding: 12px 16px; text-align: left; font-weight: 600; font-size: 0.85rem; }
.policy-table td { padding: 12px 16px; border-bottom: 1px solid var(--sand); color: var(--warm-600); }
.policy-table tr:nth-child(even) td { background: var(--ivory); }
.policy-table th:first-child { border-radius: var(--radius) 0 0 0; }
.policy-table th:last-child { border-radius: 0 var(--radius) 0 0; }

@media (max-width: 768px) {
    .policy-page { padding-top: 24px; }
    .policy-header { margin-bottom: 32px; }
    .policy-section { margin-bottom: 28px; }
    .policy-section h2 { font-size: 1.15rem; }
    .policy-section p, .policy-section li { font-size: 0.88rem; }
    .policy-contact { padding: 18px 20px; }
    .policy-table th, .policy-table td { padding: 10px 12px; font-size: 0.82rem; }
}
@media (max-width: 480px) {
    .policy-section h2 { font-size: 1.05rem; }
    .policy-section p, .policy-section li { font-size: 0.84rem; line-height: 1.7; }
    .policy-contact { padding: 14px 16px; }
    .policy-contact p { font-size: 0.82rem; gap: 8px; }
}


/* ═══════════════════════════════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════════════════════════════ */
.pagination { display: flex; flex-direction: column; align-items: center; gap: 24px; margin-top: 64px; }
.pagination__info { font-size: 0.85rem; color: var(--warm-400); }
.pagination__info strong { color: var(--charcoal); font-weight: 600; }
.pagination__list { display: flex; align-items: center; gap: 8px; list-style: none; }
.pagination__item { display: flex; }
.pagination__item--disabled { opacity: 0.4; cursor: not-allowed; }
.pagination__item--dots { pointer-events: none; }
.pagination__link { min-width: 44px; height: 44px; padding: 0 16px; display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 0.88rem; font-weight: 500; color: var(--warm-500); background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius); transition: all 0.3s var(--ease); text-decoration: none; }
.pagination__link:hover:not(.pagination__link--active) { background: var(--white); border-color: var(--rose-lighter); color: var(--rose); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.pagination__link--active { background: var(--rose); color: var(--white); border-color: var(--rose); box-shadow: var(--shadow-glow); cursor: default; }
.pagination__link--prev,
.pagination__link--next { padding: 0 20px; font-weight: 600; letter-spacing: 0.04em; }
.pagination__link--prev i,
.pagination__link--next i { font-size: 0.9rem; }
.pagination__item--disabled .pagination__link { cursor: not-allowed; opacity: 0.4; }
.pagination__item--disabled .pagination__link:hover { transform: none; box-shadow: none; border-color: var(--sand); background: var(--ivory); }

/* Simple Pagination */
.pagination--simple { flex-direction: row; justify-content: space-between; gap: 16px; }
.pagination__simple-nav { display: flex; gap: 12px; }
.pagination__simple-btn { padding: 12px 24px; background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius); font-size: 0.85rem; font-weight: 600; color: var(--charcoal); display: flex; align-items: center; gap: 8px; transition: all 0.3s var(--ease); text-decoration: none; }
.pagination__simple-btn:hover:not(.pagination__simple-btn--disabled) { background: var(--rose); color: var(--white); border-color: var(--rose); transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.pagination__simple-btn--disabled { opacity: 0.4; cursor: not-allowed; }


/* ═══════════════════════════════════════════════════════════════
   CART SIDEBAR
   ═══════════════════════════════════════════════════════════════ */
.cart-sidebar { position: fixed; inset: 0; z-index: 9999; pointer-events: none; }
.cart-sidebar.open { pointer-events: all; }
.cart-sidebar__overlay { position: absolute; inset: 0; background: rgba(26,23,20,0.6); backdrop-filter: blur(4px); opacity: 0; transition: opacity 0.4s var(--ease); }
.cart-sidebar.open .cart-sidebar__overlay { opacity: 1; }
.cart-sidebar__panel { position: absolute; top: 0; right: 0; width: 450px; max-width: 90vw; height: 100%; background: var(--white); box-shadow: -4px 0 40px rgba(26,23,20,0.15); display: flex; flex-direction: column; transform: translateX(100%); transition: transform 0.5s var(--ease); }
.cart-sidebar.open .cart-sidebar__panel { transform: translateX(0); }
.cart-sidebar__header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--sand); }
.cart-sidebar__title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 500; color: var(--charcoal); display: flex; align-items: center; gap: 10px; }
.cart-sidebar__title i { font-size: 1.2rem; color: var(--rose); }
.cart-sidebar__count { display: inline-flex; align-items: center; justify-content: center; min-width: 26px; height: 26px; padding: 0 7px; background: var(--rose); color: var(--white); font-size: 0.72rem; font-weight: 700; border-radius: 50%; font-family: var(--font-body); }
.cart-sidebar__header-actions { display: flex; align-items: center; gap: 8px; }
.cart-sidebar__clear { width: 36px; height: 36px; background: transparent; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.95rem; color: var(--warm-400); transition: all 0.2s; border: 1.5px solid var(--sand); }
.cart-sidebar__clear:hover { background: #fff1f1; color: var(--error); border-color: var(--error); }
.cart-sidebar__close { width: 36px; height: 36px; background: var(--cream); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.95rem; color: var(--warm-400); transition: all 0.2s; }
.cart-sidebar__close:hover { background: var(--rose); color: var(--white); transform: scale(1.05); }
.cart-sidebar__body { flex: 1; overflow-y: auto; padding: 20px 24px; }
.cart-sidebar__footer { border-top: 1px solid var(--sand); padding: 20px 24px; background: var(--ivory); }

/* Cart Empty */
.cart-empty { text-align: center; padding: 80px 20px; }
.cart-empty__icon { width: 80px; height: 80px; margin: 0 auto 24px; background: var(--cream); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 2rem; color: var(--warm-300); }
.cart-empty__title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 500; color: var(--charcoal); margin-bottom: 8px; }
.cart-empty__text { font-size: 0.9rem; color: var(--warm-400); margin-bottom: 24px; }

/* Cart Items */
.cart-items { display: flex; flex-direction: column; gap: 20px; }
.cart-item { display: flex; gap: 16px; padding: 16px; background: var(--ivory); border-radius: var(--radius-lg); transition: all 0.3s; }
.cart-item:hover { background: var(--cream); }
.cart-item__img { width: 80px; height: 80px; border-radius: var(--radius); overflow: hidden; flex-shrink: 0; background: var(--cream); }
.cart-item__img img { width: 100%; height: 100%; object-fit: cover; }
.cart-item__details { flex: 1; min-width: 0; }
.cart-item__name { font-size: 0.95rem; font-weight: 600; color: var(--charcoal); margin-bottom: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cart-item__meta { font-size: 0.75rem; color: var(--warm-400); margin-bottom: 8px; }
.cart-item__meta-row { display: flex; align-items: center; gap: 4px; margin-bottom: 4px; }
.cart-item__meta-row i { font-size: 0.7rem; color: var(--rose); }
.cart-item__footer { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cart-item__price { font-size: 1.05rem; font-weight: 700; color: var(--rose); }
.cart-item__qty { display: flex; align-items: center; gap: 8px; background: var(--white); border-radius: var(--radius-pill); padding: 4px; }
.cart-item__qty-btn { width: 28px; height: 28px; background: transparent; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.9rem; color: var(--warm-400); transition: all 0.2s; }
.cart-item__qty-btn:hover { background: var(--rose); color: var(--white); }
.cart-item__qty-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.cart-item__qty-value { min-width: 24px; text-align: center; font-weight: 600; font-size: 0.85rem; color: var(--charcoal); }
.cart-item__remove { width: 32px; height: 32px; background: transparent; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--warm-300); transition: all 0.2s; }
.cart-item__remove:hover { background: var(--error); color: var(--white); }

/* Cart Totals */
.cart-totals { margin-bottom: 20px; }
.cart-totals__row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; font-size: 1rem; }
.cart-totals__row--small { font-size: 0.85rem; color: var(--warm-400); }
.cart-totals__row:last-child { margin-bottom: 0; padding-top: 12px; border-top: 1px solid var(--sand); font-weight: 700; font-size: 1.15rem; }
.cart-actions { display: flex; flex-direction: row; gap: 10px; margin-bottom: 14px; }
.cart-actions__checkout { flex: 1; justify-content: center; padding: 12px 10px; font-size: 0.88rem; }
.cart-actions__continue { flex: 1; justify-content: center; padding: 12px 10px; font-size: 0.88rem; border: 1.5px solid var(--warm-200); color: var(--charcoal); background: transparent; font-weight: 600; }
.cart-actions__continue:hover { border-color: var(--rose); color: var(--rose); background: rgba(181,113,90,0.04); }
.cart-trust { display: flex; justify-content: center; gap: 24px; padding-top: 16px; border-top: 1px solid var(--sand); }
.cart-trust__item { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; color: var(--warm-400); }
.cart-trust__item i { color: var(--success); font-size: 0.85rem; }

/* ── Cart Addon Strip (in-cart horizontal scroller) ── */
.cart-addon-strip {
    margin: 16px 0 0;
    background: linear-gradient(135deg, #fff9f6 0%, #fdf3ee 100%);
    border-radius: var(--radius-lg);
    border: 1.5px solid rgba(181,113,90,0.14);
    overflow: hidden;
    animation: addonStripIn 0.3s cubic-bezier(0.4,0,0.2,1);
}
@keyframes addonStripIn {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cart-addon-strip__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 14px 6px;
}
.cart-addon-strip__label {
    font-size: 0.74rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.07em; color: var(--rose);
    display: flex; align-items: center; gap: 5px;
}
.cart-addon-strip__label i { font-size: 0.85rem; }
.cart-addon-strip__dismiss {
    width: 24px; height: 24px; background: none; border: none;
    cursor: pointer; border-radius: 50%; display: flex; align-items: center;
    justify-content: center; font-size: 0.8rem; color: var(--warm-400);
    transition: background 0.18s, color 0.18s; padding: 0;
}
.cart-addon-strip__dismiss:hover { background: rgba(181,113,90,0.12); color: var(--charcoal); }
.cart-addon-strip__scroll {
    display: flex; gap: 10px; overflow-x: auto; padding: 4px 14px 14px;
    scrollbar-width: none; -ms-overflow-style: none;
}
.cart-addon-strip__scroll::-webkit-scrollbar { display: none; }

/* Individual addon cards inside the strip */
.cart-ac {
    flex: 0 0 100px; background: #fff; border-radius: 10px;
    border: 1.5px solid var(--sand); padding: 10px 8px;
    display: flex; flex-direction: column; align-items: center; gap: 5px;
    text-align: center;
    transition: border-color 0.2s, box-shadow 0.18s, transform 0.18s;
}
.cart-ac:hover {
    border-color: var(--rose); box-shadow: 0 3px 14px rgba(181,113,90,0.13);
    transform: translateY(-2px);
}
.cart-ac.added { border-color: #28a745; background: #f0faf4; }
.cart-ac__img {
    width: 54px; height: 54px; border-radius: 8px; overflow: hidden;
    background: var(--cream); flex-shrink: 0;
}
.cart-ac__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cart-ac__placeholder {
    width: 54px; height: 54px; border-radius: 8px; background: var(--cream);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; color: var(--warm-300);
}
.cart-ac__name {
    font-size: 0.67rem; font-weight: 600; color: var(--charcoal);
    line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.cart-ac__price { font-size: 0.7rem; font-weight: 700; color: var(--rose); }
.cart-ac__btn {
    width: 100%; padding: 5px 4px; border-radius: 7px;
    border: 1.5px solid var(--rose); background: transparent;
    color: var(--rose); font-size: 0.6rem; font-weight: 700;
    cursor: pointer; transition: background 0.18s, color 0.18s;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.cart-ac__btn:hover { background: var(--rose); color: #fff; }
.cart-ac.added .cart-ac__btn {
    background: #28a745; color: #fff; border-color: #28a745;
}


/* ═══════════════════════════════════════════════════════════════
   AUTH PROMPT MODAL
   ═══════════════════════════════════════════════════════════════ */
.auth-prompt {
    position: fixed; inset: 0; z-index: 10000;
    display: none; align-items: center; justify-content: center;
    padding: 24px;
}
.auth-prompt.open { display: flex; }
.auth-prompt__overlay {
    position: absolute; inset: 0;
    background: rgba(26,23,20,0.65); backdrop-filter: blur(6px);
    animation: authFadeIn 0.3s ease;
}
.auth-prompt__panel {
    position: relative; z-index: 2;
    background: var(--white); border-radius: var(--radius-lg);
    padding: 48px 40px; max-width: 420px; width: 100%;
    text-align: center; box-shadow: 0 20px 60px rgba(26,23,20,0.2);
    animation: authSlideUp 0.4s cubic-bezier(.4,0,.2,1);
}
.auth-prompt__close {
    position: absolute; top: 16px; right: 16px;
    width: 36px; height: 36px; background: transparent;
    border-radius: 50%; display: flex; align-items: center;
    justify-content: center; font-size: 1rem; color: var(--warm-400);
    transition: all 0.2s;
}
.auth-prompt__close:hover { background: var(--cream); color: var(--charcoal); }
.auth-prompt__icon {
    width: 72px; height: 72px; margin: 0 auto 20px;
    background: var(--rose-bg); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem; color: var(--rose);
}
.auth-prompt__title {
    font-family: var(--font-display); font-size: 1.6rem;
    font-weight: 500; color: var(--charcoal); margin-bottom: 10px;
}
.auth-prompt__text {
    font-size: 0.9rem; color: var(--warm-500); line-height: 1.6;
    margin-bottom: 28px; max-width: 320px; margin-left: auto; margin-right: auto;
}
.auth-prompt__actions {
    display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px;
}
.auth-prompt__btn {
    width: 100%; justify-content: center; padding: 14px 24px;
    font-size: 0.85rem; font-weight: 600; border-radius: var(--radius-pill);
}
.auth-prompt__btn--login {
    background: var(--rose); color: var(--white);
    box-shadow: 0 4px 16px rgba(181,113,90,0.3);
}
.auth-prompt__btn--login:hover {
    background: var(--charcoal); box-shadow: var(--shadow-glow);
    transform: translateY(-1px);
}
.auth-prompt__btn--register {
    border: 1.5px solid var(--warm-200); color: var(--charcoal); background: transparent;
}
.auth-prompt__btn--register:hover {
    border-color: var(--rose); color: var(--rose);
}
.auth-prompt__note {
    font-size: 0.75rem; color: var(--warm-400);
    display: flex; align-items: center; justify-content: center; gap: 6px;
}
.auth-prompt__note i { font-size: 0.85rem; }

@keyframes authFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes authSlideUp {
    from { opacity: 0; transform: translateY(20px) scale(0.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ═══════════════════════════════════════════════════════════════
   FIRST-ORDER WELCOME BANNER (Dashboard)
   ═══════════════════════════════════════════════════════════════ */
.first-order-banner {
    padding: 0; background: linear-gradient(135deg, #fff9f5, #fef0e8);
    border-bottom: 1px solid rgba(181,113,90,0.12);
}
.first-order-banner__inner {
    display: flex; align-items: center; gap: 28px;
    padding: 32px 0;
}
.first-order-banner__icon {
    width: 64px; height: 64px; flex-shrink: 0;
    background: var(--rose); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem; color: var(--white);
    box-shadow: 0 6px 20px rgba(181,113,90,0.3);
}
.first-order-banner__content { flex: 1; }
.first-order-banner__title {
    font-family: var(--font-display); font-size: 1.4rem;
    font-weight: 500; color: var(--charcoal); margin-bottom: 6px;
}
.first-order-banner__text {
    font-size: 0.88rem; color: var(--warm-500); margin-bottom: 16px;
    line-height: 1.5;
}
.first-order-banner__coupons {
    display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 16px;
}
.first-order-coupon-mini {
    display: flex; align-items: center; gap: 10px;
    background: var(--white); border: 1.5px dashed var(--rose);
    border-radius: var(--radius); padding: 8px 14px;
}
.first-order-coupon-mini__value {
    font-size: 0.78rem; font-weight: 700; color: var(--rose);
    white-space: nowrap;
}
.first-order-coupon-mini__code {
    font-size: 0.72rem; font-weight: 600; color: var(--charcoal);
    background: var(--cream); border-radius: var(--radius-sm);
    padding: 4px 10px; cursor: pointer; transition: all 0.2s;
    display: flex; align-items: center; gap: 6px;
    border: none; font-family: monospace; letter-spacing: 0.08em;
}
.first-order-coupon-mini__code:hover {
    background: var(--rose); color: var(--white);
}
.first-order-coupon-mini__code i { font-size: 0.7rem; }

/* Offers page personalized highlight */
.offers-section__sub--highlight {
    color: var(--rose); font-weight: 500;
}
.offers-section__sub--highlight i { margin-right: 4px; }

/* ═══════════════════════════════════════════════════════════════
   CHECKOUT
   ═══════════════════════════════════════════════════════════════ */
.checkout-progress { background: var(--white); border-bottom: 1px solid var(--sand); padding: 32px 0; margin-top: calc(var(--promise-h) + var(--header-h)); }
.progress-steps { display: flex; align-items: center; justify-content: center; max-width: 600px; margin: 0 auto; }
.progress-step { display: flex; flex-direction: column; align-items: center; gap: 8px; position: relative; z-index: 2; }
.progress-step__icon { width: 56px; height: 56px; background: var(--cream); border: 2px solid var(--sand); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: var(--warm-400); transition: all 0.4s var(--ease); }
.progress-step.active .progress-step__icon { background: var(--rose); border-color: var(--rose); color: var(--white); transform: scale(1.1); box-shadow: var(--shadow-glow); }
.progress-step.completed .progress-step__icon { background: var(--success); border-color: var(--success); color: var(--white); }
.progress-step__label { font-size: 0.82rem; font-weight: 600; color: var(--warm-400); transition: color 0.3s; }
.progress-step.active .progress-step__label { color: var(--rose); }
.progress-step__line { flex: 1; height: 2px; background: var(--sand); margin: 0 16px; position: relative; top: -20px; }
.progress-step.completed + .progress-step__line { background: var(--success); }

/* Checkout Layout */
.checkout-section { padding-top: 48px; padding-bottom: 80px; overflow-x: hidden; }
.checkout-layout { display: grid; grid-template-columns: 1fr 420px; gap: 48px; align-items: start; max-width: 100%; }
.checkout-main { min-width: 0; }
.checkout-sidebar { min-width: 0; }
.checkout-step { animation: fadeInUp 0.5s var(--ease); }
.checkout-step__header { margin-bottom: 32px; }
.checkout-step__title { font-family: var(--font-display); font-size: 1.8rem; font-weight: 500; color: var(--charcoal); margin-bottom: 8px; display: flex; align-items: center; gap: 12px; word-break: break-word; }
.checkout-step__title i { color: var(--rose); font-size: 1.6rem; }
.checkout-step__subtitle { font-size: 0.95rem; color: var(--warm-400); }

/* Forms */
.checkout-form { display: flex; flex-direction: column; gap: 32px; }
.form-section { padding: 28px; background: var(--ivory); border-radius: var(--radius-lg); border: 1px solid var(--sand); max-width: 100%; overflow: hidden; }
.form-section__title { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--charcoal); margin-bottom: 16px; }
.form-section__subtitle { font-size: 0.85rem; color: var(--warm-400); margin-bottom: 16px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { margin-bottom: 20px; }
.form-group:last-child { margin-bottom: 0; }
.form-label { display: block; font-size: 0.85rem; font-weight: 600; color: var(--charcoal); margin-bottom: 8px; }
.required { color: var(--error); }
.form-input,
.form-textarea { width: 100%; max-width: 100%; padding: 14px 16px; background: var(--white); border: 2px solid var(--sand); border-radius: var(--radius); font-size: 0.95rem; color: var(--charcoal); transition: all 0.2s; }
.form-input:focus,
.form-textarea:focus { border-color: var(--rose); outline: none; box-shadow: 0 0 0 3px rgba(181, 113, 90, 0.08); }
.form-input::placeholder,
.form-textarea::placeholder { color: var(--warm-300); }
.form-textarea { resize: vertical; min-height: 80px; }
.input-with-button { display: flex; gap: 8px; max-width: 100%; }
.input-with-button .form-input { flex: 1; min-width: 0; width: auto; }
.input-button { padding: 14px 24px; background: var(--rose); color: var(--white); font-size: 0.85rem; font-weight: 600; border-radius: var(--radius); white-space: nowrap; transition: all 0.2s; flex-shrink: 0; border: none; cursor: pointer; }
.input-button:hover { background: var(--rose-dark); transform: translateY(-1px); }
.input-button:disabled { background: var(--warm-200); cursor: not-allowed; transform: none; }
.form-error   { display: block; font-size: 0.75rem; color: var(--error);   margin-top: 6px; }
.form-success { display: block; font-size: 0.75rem; color: var(--success); margin-top: 6px; }
.form-hint    { display: block; font-size: 0.75rem; color: var(--warm-400); margin-top: 6px; }
.form-checkbox { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.form-checkbox input[type="checkbox"] { width: 20px; height: 20px; margin-top: 2px; cursor: pointer; }
.form-checkbox__label { font-size: 0.9rem; color: var(--warm-500); line-height: 1.5; }
.form-checkbox__label a { color: var(--rose); text-decoration: underline; }
.form-actions { display: flex; gap: 12px; justify-content: space-between; align-items: center; padding-top: 24px; flex-wrap: wrap; }
.form-actions__left  { display: flex; align-items: center; gap: 6px; }
.form-actions__right { display: flex; align-items: center; gap: 10px; }

/* Mini buttons — compact secondary actions */
.btn--mini {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px 12px; font-size: 0.72rem; font-weight: 600;
    border-radius: var(--radius, 8px); cursor: pointer;
    text-decoration: none; white-space: nowrap;
    transition: all 0.2s var(--ease);
    line-height: 1.3;
}
.btn--mini-ghost {
    background: var(--cream, #f5f0eb); color: var(--warm-500);
    border: 1px solid var(--sand);
}
.btn--mini-ghost:hover { background: var(--sand); color: var(--warm-800); }
.btn--mini-danger {
    background: rgba(192,57,43,0.06); color: #c0392b;
    border: 1px solid rgba(192,57,43,0.2);
}
.btn--mini-danger:hover { background: #c0392b; color: #fff; border-color: #c0392b; }

/* Danger solid button (modal) */
.btn--danger {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 12px 28px; font-size: 0.95rem; font-weight: 600;
    color: #fff; background: #c0392b;
    border: none; border-radius: var(--radius-md);
    cursor: pointer; transition: all 0.25s var(--ease);
}
.btn--danger:hover { background: #a93226; }

/* Cancel Order Confirmation Modal */
.cancel-modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; visibility: hidden; opacity: 0; transition: visibility 0s 0.3s, opacity 0.3s; }
.cancel-modal.open { visibility: visible; opacity: 1; transition: visibility 0s, opacity 0.3s; }
.cancel-modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.45); }
.cancel-modal__dialog {
    position: relative; background: var(--white);
    border-radius: var(--radius-xl, 16px); padding: 36px 32px;
    max-width: 420px; width: 90%; text-align: center;
    box-shadow: 0 20px 60px rgba(0,0,0,0.2);
    transform: scale(0.9) translateY(20px);
    transition: transform 0.3s var(--ease);
}
.cancel-modal.open .cancel-modal__dialog { transform: scale(1) translateY(0); }
.cancel-modal__icon { font-size: 2.8rem; color: #e67e22; margin-bottom: 12px; }
.cancel-modal__title { font-size: 1.25rem; font-weight: 700; color: var(--warm-800); margin-bottom: 8px; }
.cancel-modal__text  { font-size: 0.92rem; color: var(--warm-500); margin-bottom: 28px; line-height: 1.6; }
.cancel-modal__actions { display: flex; gap: 12px; justify-content: center; }

/* Date Selector */
.date-selector { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 20px; }
.date-option { padding: 24px 16px; background: var(--white); border: 2px solid var(--sand); border-radius: var(--radius-lg); text-align: center; cursor: pointer; transition: all 0.3s var(--ease); position: relative; }
.date-option:hover { border-color: var(--rose-lighter); transform: translateY(-4px); box-shadow: var(--shadow-md); }
.date-option.active { border-color: var(--rose); background: var(--rose-bg); box-shadow: 0 0 0 4px rgba(181, 113, 90, 0.08); }
.date-option__icon { width: 48px; height: 48px; margin: 0 auto 12px; background: var(--cream); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; color: var(--rose); transition: all 0.3s; }
.date-option.active .date-option__icon { background: var(--rose); color: var(--white); }
.date-option__label { font-size: 1rem; font-weight: 600; color: var(--charcoal); margin-bottom: 4px; }
.date-option__date { font-size: 0.75rem; color: var(--warm-400); }
.date-option__badge { position: absolute; top: 8px; right: 8px; padding: 4px 10px; background: var(--success); color: var(--white); font-size: 0.65rem; font-weight: 700; border-radius: 6px; }

/* Timeslot Grid */
.timeslot-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.timeslot-loading { grid-column: 1 / -1; text-align: center; padding: 40px; color: var(--warm-400); font-size: 0.9rem; }
.timeslot-option { padding: 20px 16px; background: var(--white); border: 2px solid var(--sand); border-radius: var(--radius); cursor: pointer; transition: all 0.3s var(--ease); }
.timeslot-option:hover:not(.disabled) { border-color: var(--rose-lighter); transform: translateY(-2px); }
.timeslot-option.active { border-color: var(--rose); background: var(--rose-bg); box-shadow: 0 0 0 3px rgba(181, 113, 90, 0.08); }
.timeslot-option.disabled { opacity: 0.4; cursor: not-allowed; background: var(--cream); }
.timeslot-option__time { font-size: 1rem; font-weight: 700; color: var(--charcoal); margin-bottom: 4px; display: flex; align-items: center; gap: 6px; }
.timeslot-option__time i { font-size: 0.9rem; color: var(--rose); }
.timeslot-option__label { font-size: 0.75rem; color: var(--warm-400); }
.timeslot-option__slots { font-size: 0.7rem; color: var(--warm-300); margin-top: 6px; }

/* Timeslot cards (JS-rendered) */
.timeslot { padding: 20px 16px; background: var(--white); border: 2px solid var(--sand); border-radius: var(--radius); cursor: pointer; transition: all 0.3s var(--ease); }
.timeslot:hover:not(.timeslot--unavailable) { border-color: var(--rose-lighter); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.timeslot--selected { border-color: var(--rose) !important; background: var(--rose-bg) !important; box-shadow: 0 0 0 4px rgba(181,113,90,0.08); }
.timeslot--unavailable { opacity: 0.45; cursor: not-allowed; background: var(--cream); }
.timeslot__time { font-size: 1rem; font-weight: 700; color: var(--charcoal); display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.timeslot__time i { color: var(--rose); font-size: 0.95rem; }
.timeslot--selected .timeslot__time { color: var(--rose); }
.timeslot__status { font-size: 0.78rem; }
.timeslot__available { color: var(--success); font-weight: 600; }
.timeslot__full { color: var(--warm-300); font-weight: 500; }

/* Summary item image (position context for remove btn) */
.summary-item__img { position: relative; }

/* Progress line completed state */
.progress-step__line.completed { background: var(--success); }
.progress-step.completed .progress-step__label { color: var(--success); }

/* Countdown Alert */
.countdown-alert { margin-top: 24px; padding: 16px 20px; background: linear-gradient(135deg, rgba(90,154,110,0.1), rgba(90,154,110,0.05)); border: 1px solid rgba(90,154,110,0.3); border-radius: var(--radius); display: flex; align-items: center; gap: 16px; }
.countdown-alert__icon { width: 48px; height: 48px; background: var(--success); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; color: var(--white); flex-shrink: 0; }
.countdown-alert__content { display: flex; flex-direction: column; gap: 4px; }
.countdown-alert__content strong { font-size: 0.95rem; color: var(--charcoal); }
.countdown-alert__content span { font-size: 0.85rem; color: var(--warm-500); }
#countdownTimer { font-weight: 700; color: var(--success); }

/* Payment Methods */
.payment-methods { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; }
.payment-method { cursor: pointer; }
.payment-method input[type="radio"] { display: none; }
.payment-method__card { display: flex; align-items: center; gap: 16px; padding: 20px; background: var(--white); border: 2px solid var(--sand); border-radius: var(--radius-lg); transition: all 0.3s var(--ease); }
.payment-method input:checked + .payment-method__card { border-color: var(--rose); background: var(--rose-bg); box-shadow: 0 0 0 4px rgba(181, 113, 90, 0.08); }
.payment-method__card:hover { border-color: var(--rose-lighter); }
.payment-method__icon { width: 56px; height: 56px; background: var(--cream); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--rose); flex-shrink: 0; }
.payment-method input:checked + .payment-method__card .payment-method__icon { background: var(--rose); color: var(--white); }
.payment-method__details { flex: 1; }
.payment-method__name { font-size: 1.05rem; font-weight: 700; color: var(--charcoal); margin-bottom: 4px; }
.payment-method__desc { font-size: 0.82rem; color: var(--warm-400); }
.payment-method__badges { display: flex; gap: 6px; flex-wrap: wrap; }
.payment-badge { padding: 4px 10px; background: var(--cream); color: var(--warm-500); font-size: 0.7rem; font-weight: 700; border-radius: 6px; }
.payment-badge--cod { background: var(--gold-light); color: var(--wine); }

/* Payment Notice */
.payment-notice { display: flex; align-items: flex-start; gap: 12px; padding: 16px; background: rgba(201,169,110,0.1); border: 1px solid rgba(201,169,110,0.3); border-radius: var(--radius); margin-bottom: 24px; }
.payment-notice__icon { color: var(--gold); font-size: 1.2rem; }
.payment-notice__content { font-size: 0.85rem; color: var(--warm-500); }
.payment-notice__content strong { color: var(--charcoal); }

/* Checkout Add-ons Upsell (inside order-summary) */
.checkout-addons {
    border-top: 1px solid var(--sand);
    padding: 0;
    margin-bottom: 20px;
}
.checkout-addons__header {
    padding: 14px 0 10px;
}
.checkout-addons__title {
    font-size: 0.82rem; font-weight: 700;
    color: var(--charcoal);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    display: flex; align-items: center; gap: 6px;
    margin: 0;
}
.checkout-addons__title i { color: var(--rose); font-size: 0.9rem; }
.checkout-addons__grid {
    display: flex;
    overflow-x: auto;
    gap: 10px;
    padding-bottom: 6px;
    scrollbar-width: none;
    max-width: 100%;
}
.checkout-addons__grid::-webkit-scrollbar { display: none; }
.co-addon {
    flex: 0 0 110px;
    display: flex; flex-direction: column;
    align-items: center; text-align: center;
    padding: 10px 8px;
    border-radius: var(--radius);
    border: 1.5px solid var(--cream);
    background: var(--white);
    transition: border-color 0.2s, box-shadow 0.2s;
    gap: 6px;
}
.co-addon:hover { border-color: var(--sand); box-shadow: 0 2px 8px rgba(0,0,0,.05); }
.co-addon--added { border-color: var(--success); background: rgba(90,154,110,0.04); }
.co-addon__img {
    width: 56px; height: 56px; flex-shrink: 0;
    border-radius: var(--radius);
    overflow: hidden; background: var(--cream);
}
.co-addon__img img { width: 100%; height: 100%; object-fit: cover; }
.co-addon__info { min-width: 0; }
.co-addon__name {
    font-size: 0.7rem; font-weight: 600;
    color: var(--charcoal); line-height: 1.25;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.co-addon__price {
    font-size: 0.72rem; font-weight: 700;
    color: var(--rose); margin-top: 2px;
}
.co-addon__btn {
    width: 100%;
    padding: 5px 0;
    border-radius: var(--radius);
    border: 1.5px solid var(--rose);
    background: transparent;
    color: var(--rose);
    font-size: 0.68rem; font-weight: 700;
    cursor: pointer; transition: all 0.2s;
    display: inline-flex; align-items: center; justify-content: center; gap: 4px;
    white-space: nowrap;
}
.co-addon__btn:hover { background: var(--rose); color: #fff; }
.co-addon__btn--added {
    background: var(--success); border-color: var(--success);
    color: #fff; cursor: default;
}
.co-addon__btn--added:hover { background: var(--success); }

/* Order Summary Sidebar */
.checkout-sidebar { position: sticky; top: calc(var(--header-h) + 24px); }
.order-summary { background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 28px; max-width: 100%; overflow: hidden; }
.order-summary__title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 500; color: var(--charcoal); margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--sand); }
.order-summary__items { max-height: 300px; overflow-y: auto; margin-bottom: 20px; }
.summary-item { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--cream); position: relative; align-items: flex-start; }
.summary-item:last-child { border-bottom: none; }
.summary-item__img { width: 54px; height: 54px; border-radius: var(--radius); overflow: hidden; flex-shrink: 0; background: var(--cream); }
.summary-item__img img { width: 100%; height: 100%; object-fit: cover; }
.summary-item__details { flex: 1; min-width: 0; }
.summary-item__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.summary-item__name { font-size: 0.82rem; font-weight: 600; color: var(--charcoal); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; line-height: 1.3; }
.summary-item__bottom { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 4px; }
.summary-item__meta { font-size: 0.7rem; color: var(--warm-400); margin-bottom: 6px; }
.summary-item__price-row { display: flex; justify-content: space-between; align-items: center; }
.summary-item__price { font-size: 0.85rem; font-weight: 700; color: var(--rose); white-space: nowrap; }
.summary-item__qty { font-size: 0.75rem; color: var(--warm-400); }

/* Quantity controls in order summary */
.summary-item__qty-controls { display: inline-flex; align-items: center; gap: 0; border: 1px solid var(--sand); border-radius: 6px; overflow: hidden; background: var(--white); }
.summary-qty-btn { width: 26px; height: 26px; border: none; background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 0.75rem; color: var(--warm-500); transition: all 0.15s ease; padding: 0; }
.summary-qty-btn:hover { background: var(--cream); color: var(--charcoal); }
.summary-qty-btn--minus:hover { background: rgba(192,57,43,0.08); color: #c0392b; }
.summary-qty-btn--plus:hover { background: rgba(90,154,110,0.08); color: var(--success); }
.summary-qty-val { width: 24px; text-align: center; font-size: 0.75rem; font-weight: 700; color: var(--charcoal); line-height: 26px; border-left: 1px solid var(--sand); border-right: 1px solid var(--sand); }

/* Remove button */
.summary-item__remove { position: absolute; top: 10px; right: -2px; width: 22px; height: 22px; border: none; background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 0.6rem; color: var(--warm-300); border-radius: 50%; transition: all 0.2s ease; padding: 0; }
.summary-item__remove:hover { background: rgba(192,57,43,0.1); color: #c0392b; }
.order-summary__totals { padding: 20px 0; border-top: 1px solid var(--sand); }
.summary-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; font-size: 0.9rem; color: var(--warm-500); }
.summary-row:last-child { margin-bottom: 0; }
.summary-row--discount { color: var(--success); }
.summary-row--cod { color: var(--gold); }
.summary-row--total { padding-top: 16px; margin-top: 16px; border-top: 2px solid var(--sand); font-size: 1.15rem; font-weight: 700; color: var(--charcoal); }
.summary-row--total span:last-child { color: var(--rose); }

/* Order Summary Trust — scoped to avoid conflict with .trust-item in WHY CHOOSE US */
.order-summary__trust { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--sand); display: flex; flex-direction: column; gap: 10px; }
.order-summary__trust .trust-item { display: flex; align-items: center; gap: 10px; font-size: 0.8rem; color: var(--warm-500); padding: 0; background: none; border: none; border-radius: 0; text-align: left; }
.order-summary__trust .trust-item:hover { transform: none; box-shadow: none; border-color: transparent; }
.order-summary__trust .trust-item i { color: var(--success); font-size: 0.95rem; }

/* Order Summary — Sticky CTA */
.order-summary__cta { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--sand); }
.order-summary__cta-btn { padding: 16px 24px; font-size: 1rem; font-weight: 600; letter-spacing: .3px; border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: center; gap: 8px; transition: opacity .2s, background .2s; }
.order-summary__cta-btn:disabled { opacity: .45; cursor: not-allowed; }

/* Mobile fixed-bottom CTA bar — hidden on desktop, visible ≤1024px */
.checkout-bottom-cta { display: none; }
@media (max-width: 1024px) {
    /* Hide the in-summary CTA on mobile (summary is at top) */
    .order-summary__cta { display: none; }
    /* Show fixed bottom CTA bar */
    .checkout-bottom-cta {
        display: block; position: fixed; bottom: 0; left: 0; right: 0; z-index: 999;
        background: var(--white); border-top: 1px solid var(--sand);
        padding: 12px 20px; box-shadow: 0 -4px 20px rgba(0,0,0,.08);
    }
    .checkout-bottom-cta__inner {
        display: flex; align-items: center; justify-content: space-between; gap: 12px;
        max-width: 600px; margin: 0 auto;
    }
    .checkout-bottom-cta__total {
        display: flex; flex-direction: column; gap: 2px; min-width: 0;
    }
    .checkout-bottom-cta__label { font-size: 0.72rem; color: var(--warm-400); text-transform: uppercase; letter-spacing: .5px; }
    .checkout-bottom-cta__amount { font-size: 1.15rem; font-weight: 700; color: var(--charcoal); white-space: nowrap; }
    .checkout-bottom-cta__btn {
        padding: 14px 28px; font-size: 0.95rem; font-weight: 600; border-radius: var(--radius-lg);
        display: flex; align-items: center; gap: 8px; white-space: nowrap; flex-shrink: 0;
    }
    .checkout-bottom-cta__btn:disabled { opacity: .45; cursor: not-allowed; }
    /* Add bottom padding to prevent content from being hidden behind fixed CTA */
    .checkout-section { padding-bottom: 100px; }
}
@media (max-width: 480px) {
    .checkout-bottom-cta { padding: 10px 16px; }
    .checkout-bottom-cta__btn { padding: 12px 20px; font-size: 0.88rem; }
    .checkout-bottom-cta__amount { font-size: 1.05rem; }
    .checkout-bottom-cta__label { font-size: 0.65rem; }
}
@media (max-width: 360px) {
    .checkout-bottom-cta { padding: 8px 12px; }
    .checkout-bottom-cta__btn { padding: 10px 16px; font-size: 0.82rem; gap: 6px; }
    .checkout-bottom-cta__amount { font-size: 0.95rem; }
}


/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — ALL BREAKPOINTS CONSOLIDATED
   ═══════════════════════════════════════════════════════════════ */

@media (min-width: 769px) {
    body, body a, body button { cursor: none; }
}

@media (max-width: 1200px) {
    .cat-grid          { grid-template-columns: repeat(3, 1fr); }
    .occasion-chips    { grid-template-columns: repeat(3, 1fr); }
    .addon-grid        { grid-template-columns: repeat(3, 1fr); }
    .trust-grid        { grid-template-columns: repeat(2, 1fr); }
    .trust-counters    { grid-template-columns: repeat(2, 1fr); }
    .p-card            { width: 230px; }
    .products__track   { gap: 18px; }
}

@media (max-width: 1100px) {
    .hero                   { grid-template-columns: 1fr 1fr; }
    .hero__scene-pane       { min-height: 55vh; }
    .hero__text-pane        { padding: 40px; justify-content: flex-start; }
    .hero__text-pane::before { display: none; }
    .hero__pincode          { right: 40px; bottom: 40px; }
    .occasion__inner        { grid-template-columns: 1fr; }
    .occasion__visuals      { display: none; }
    .same-day__layout       { grid-template-columns: 1fr; }
    .same-day__visual       { min-height: 400px; }
    .reminder               { grid-template-columns: 1fr; gap: 48px; }
}

@media (max-width: 1024px) {
    .product-detail__layout { grid-template-columns: 1fr; gap: 48px; }
    .product-gallery        { position: relative; top: 0; }
    .checkout-layout        { grid-template-columns: 1fr; }
    .checkout-sidebar       { position: static; order: -1; }
    .products__scroll-wrap  { margin: 0 -36px; padding: 0 36px; }
    .products__scroll-wrap::before,
    .products__scroll-wrap::after { width: 60px; }

    /* Header — switch to hamburger at tablet */
    .header__nav             { display: none; }
    .header__cta-btn         { display: none; }
    .header__user-menu       { display: none; }
    .header__burger          { display: flex; }
}

/* @media (max-width: 900px) and (orientation: landscape) {
    .hero                 { grid-template-columns: 1fr; min-height: auto; padding: 80px 0 40px; }
    .hero__scene-pane     { min-height: 70vh; }
    .hero__text-pane      { padding: 40px 32px; }
} */

@media (max-width: 900px) {
    :root { --section-v: 80px; --promise-h: 0px; }
    .container { padding: 0 24px; }

    /* Promise + Header */
    .promise-bar           { display: none; }
    .site-header           { top: 0; }
    .checkout-progress     { padding: 24px 0; margin-top: var(--header-h); }

    /* Cursor */
    .cursor-dot, .cursor-ring { display: none !important; }
    body, body a, body button, body input, body select, body textarea { cursor: auto !important; }

    /* Hero */
    .hero                  { grid-template-columns: 1fr; min-height: auto; padding: calc(var(--header-h) + 24px) 0 0; overflow: visible; }
    .hero__text-pane       { padding: 28px 20px 32px; align-items: center; text-align: center; }
    .hero__scene-pane      { min-height: 60vh; }
    .hero__heading         { font-size: 2.6rem; margin-left: 0; margin-bottom: 14px; text-align: left; }
    .hero__sub             { margin-left: 0; margin-bottom: 22px; text-align: center; font-size: 0.95rem; max-width: 100%; }
    .hero__eyebrow         { margin-left: 0; margin-bottom: 20px; }
    .hero__ctas            { flex-direction: row; align-items: center; flex-wrap: wrap; gap: 10px; width: 100%; margin-left: 0; }
    .hero__ctas .btn       { justify-content: center; flex: 1; min-width: 0; text-align: center; }
    .hero__date-picker     { margin-left: 0; width: 100%; }
    .hero__date-label      { justify-content: center; }
    .hero__date-options    { flex-wrap: wrap; gap: 8px; }
    .hero__date-btn        { flex: 1; min-width: 0; padding: 12px 8px; border-radius: var(--radius-pill); }
    .hero__pincode         { position: relative; right: auto; bottom: auto; margin: 24px 24px; width: calc(100% - 48px); max-width: 400px; }
    .hero__pincode-saved   { position: relative; bottom: auto; right: auto; margin: 24px 24px; width: calc(100% - 48px); max-width: 400px; min-width: 0; }
    .hero__scene-pane      { min-height: 60vh; position: relative; background: linear-gradient(135deg, #F9F6F2 0%, #F0EBE3 100%); }
    .hero__canvas-wrap     { position: absolute; inset: 0; opacity: 1 !important; }
    #heroCanvas            { width: 100% !important; height: 100% !important; display: block; touch-action: pan-y; }
    .hero__scene-gradient  { width: 25%; background: linear-gradient(to right, rgba(249,246,242,0.6), transparent); }
    .hero__scene-gradient-bottom { height: 20%; background: linear-gradient(to top, rgba(249,246,242,0.5), transparent); }
    .hero__scroll-cue      { display: none; }
    .hero__pincode-input   { min-width: 0; }
    .hero__pincode-saved   { flex-wrap: wrap; }

    /* Grids */
    .occasion-chips        { grid-template-columns: repeat(2, 1fr); }
    .cat-grid              { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .addon-grid            { grid-template-columns: repeat(2, 1fr); }
    .trust-grid            { grid-template-columns: 1fr; gap: 20px; }
    .trust-counters        { grid-template-columns: repeat(2, 1fr); gap: 24px; }
    .trust-counter__num    { font-size: 2.5rem; }
    .steps                 { grid-template-columns: 1fr; gap: 32px; }
    .steps::before         { display: none; }
    .test-grid             { grid-template-columns: 1fr; }

    /* Products */
    .products__scroll-wrap { margin: 0 -24px; padding: 0 24px; }
    .products__scroll-wrap::before,
    .products__scroll-wrap::after { width: 40px; }
    .p-card                { width: 220px; scroll-snap-align: center; scroll-snap-stop: always; }
    .products__filters     { gap: 6px; }
    .products__filter      { padding: 6px 14px; font-size: 0.62rem; }
    .products__track       { scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; padding: 10px 0 30px; }
    .products__scroll-btn  { display: none; }

    /* Same Day */
    .same-day__visual      { min-height: 350px; }
    .same-day__card--1, .same-day__card--2 { width: 48%; }
    .same-day__card--floating { bottom: 20px; right: 50%; transform: translateX(50%); width: auto; }

    /* Occasion chip active */
    .occasion-chip         { padding: 28px 10px 24px; transition: all 0.3s var(--ease); }
    .occasion-chip:active  { transform: scale(0.95); background: var(--rose-bg); }

    /* Testimonials */
    .test-card             { padding: 32px 24px; }

    /* Footer */
    .footer__grid          { grid-template-columns: 1fr 1fr; gap: 32px; }
    .footer__cta-bar       { flex-direction: column; text-align: center; padding: 32px 24px; }
    .footer__cta-bar h3    { font-size: 1.5rem; }

    /* Product Detail */
    .product-actions       { grid-template-columns: 1fr; }
    .delivery-selector__options { grid-template-columns: 1fr; }
    .product-tabs__nav     { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .product-tabs__tab     { white-space: nowrap; flex: 0 0 auto; min-width: 120px; }
    .product-tabs__content { padding: 28px 20px; }
    .addons-grid           { grid-template-columns: 1fr; }
    .reviews-header        { flex-direction: column; align-items: flex-start; gap: 20px; }

    /* Pagination */
    .pagination            { gap: 16px; margin-top: 48px; }
    .pagination__info      { font-size: 0.75rem; text-align: center; }
    .pagination__list      { gap: 6px; flex-wrap: wrap; justify-content: center; }
    .pagination__link      { min-width: 40px; height: 40px; padding: 0 12px; font-size: 0.82rem; }
    .pagination__link-text { display: none; }
    .pagination__link--prev,
    .pagination__link--next { padding: 0 12px; }
    .pagination--simple    { flex-direction: column; align-items: stretch; }
    .pagination__simple-nav { flex-direction: column; }
    .pagination__simple-btn { justify-content: center; }

    /* Cart */
    .cart-sidebar__panel   { width: 100%; max-width: 100%; }
    .cart-sidebar__header,
    .cart-sidebar__body,
    .cart-sidebar__footer  { padding: 20px; }
    .cart-item             { padding: 12px; }
    .cart-item__img        { width: 70px; height: 70px; }

    /* ── Checkout — full mobile override ── */
    .checkout-section          { padding-top: 24px; padding-bottom: 100px; }
    .checkout-layout           { gap: 24px; }
    .checkout-main,
    .checkout-sidebar          { width: 100%; max-width: 100%; overflow: hidden; }
    .progress-steps            { padding: 0 16px; max-width: 100%; }
    .progress-step__icon       { width: 44px; height: 44px; font-size: 1rem; }
    .progress-step__label      { font-size: 0.7rem; }
    .progress-step__line       { margin: 0 8px; top: -14px; }
    .checkout-step__header     { margin-bottom: 20px; }
    .checkout-step__title      { font-size: 1.3rem; gap: 10px; }
    .checkout-step__title i    { font-size: 1.2rem; }
    .checkout-step__subtitle   { font-size: 0.88rem; }
    .checkout-form             { gap: 20px; }
    .form-row                  { grid-template-columns: 1fr; }
    .form-section              { padding: 18px; }
    .form-section__title       { font-size: 1rem; }
    .form-group                { margin-bottom: 14px; }
    .form-input,
    .form-textarea             { padding: 12px 14px; font-size: 0.9rem; }
    .input-with-button         { gap: 6px; }
    .input-button              { padding: 10px 16px; font-size: 0.82rem; white-space: nowrap; flex-shrink: 0; }
    .form-actions              { flex-direction: column-reverse; gap: 14px; }
    .form-actions .btn         { width: 100%; justify-content: center; }
    .form-actions__right       { width: 100%; flex-direction: column; gap: 10px; }
    .form-actions__right .btn  { width: 100%; justify-content: center; }
    .form-actions__left        { justify-content: center; flex-wrap: wrap; }
    .date-selector             { grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .date-option               { padding: 16px 8px; }
    .date-option__icon         { width: 40px; height: 40px; font-size: 1.1rem; margin-bottom: 8px; }
    .date-option__label        { font-size: 0.82rem; }
    .date-option__date         { font-size: 0.68rem; }
    .date-option__badge        { font-size: 0.55rem; padding: 3px 8px; }
    .timeslot-grid             { grid-template-columns: 1fr; }
    .timeslot                  { padding: 16px 14px; }
    .timeslot__time            { font-size: 0.95rem; }
    .countdown-alert           { padding: 12px 14px; gap: 12px; }
    .countdown-alert__icon     { width: 40px; height: 40px; font-size: 1rem; }
    .countdown-alert__content strong { font-size: 0.85rem; }
    .countdown-alert__content span   { font-size: 0.78rem; }
    .payment-method__card      { gap: 12px; padding: 14px; flex-wrap: wrap; }
    .payment-method__icon      { width: 40px; height: 40px; font-size: 1.1rem; border-radius: 10px; }
    .payment-method__badges    { display: none; }
    .payment-method__badge-single { display: none; }
    .payment-method__name      { font-size: 0.9rem; }
    .payment-method__desc      { font-size: 0.78rem; }
    .payment-notice            { padding: 12px; gap: 10px; }
    .checkout-offers__toggle   { padding: 10px 14px; font-size: 0.85rem; }
    .form-checkbox input[type="checkbox"] { width: 18px; height: 18px; }
    .form-checkbox__label      { font-size: 0.82rem; }
    .order-summary             { padding: 16px; }
    .order-summary__title      { font-size: 1.05rem; margin-bottom: 14px; padding-bottom: 12px; }
    .order-summary__items      { max-height: 240px; }
    .summary-item              { gap: 10px; padding: 10px 0; }
    .summary-item__img         { width: 44px; height: 44px; }
    .summary-item__name        { font-size: 0.78rem; }
    .summary-item__price       { font-size: 0.78rem; }
    .summary-qty-btn           { width: 24px; height: 24px; font-size: 0.7rem; }
    .summary-qty-val           { width: 22px; font-size: 0.7rem; line-height: 24px; }
    .summary-item__remove      { width: 20px; height: 20px; font-size: 0.55rem; }
    .summary-row               { font-size: 0.82rem; }
    .summary-row--total        { font-size: 1rem; }
    .checkout-addons           { margin-bottom: 14px; }
    .co-addon                  { flex: 0 0 90px; }
    .co-addon__img             { width: 44px; height: 44px; }
    .co-addon__name            { font-size: 0.62rem; }
    .co-addon__price           { font-size: 0.68rem; }
    .co-addon__btn             { font-size: 0.58rem; padding: 3px 6px; }
    .order-summary__trust      { gap: 8px; }
    .order-summary__trust .trust-item { font-size: 0.75rem; }
    .cancel-modal__dialog      { padding: 28px 20px; max-width: 90%; }
    .cancel-modal__icon        { font-size: 2.2rem; }
    .cancel-modal__title       { font-size: 1.1rem; }
    .cancel-modal__text        { font-size: 0.85rem; }
    .cancel-modal__actions     { flex-direction: column; gap: 10px; }
    .cancel-modal__actions .btn { width: 100%; justify-content: center; }
}

@media (max-width: 480px) {
    .pagination__link { min-width: 36px; height: 36px; padding: 0 10px; font-size: 0.75rem; }

    /* ── Checkout 480px ── */
    .checkout-progress         { padding: 16px 0; }
    .progress-steps            { padding: 0 10px; }
    .progress-step__icon       { width: 38px; height: 38px; font-size: 0.92rem; }
    .progress-step__label      { font-size: 0.62rem; }
    .progress-step__line       { margin: 0 6px; top: -12px; }
    .checkout-section          { padding-top: 16px; padding-bottom: 90px; }
    .checkout-layout           { gap: 16px; }
    .checkout-step__header     { margin-bottom: 14px; }
    .checkout-step__title      { font-size: 1.1rem; gap: 8px; }
    .checkout-step__title i    { font-size: 1rem; }
    .checkout-step__subtitle   { font-size: 0.8rem; }
    .checkout-form             { gap: 14px; }
    .form-section              { padding: 14px; }
    .form-section__title       { font-size: 0.88rem; margin-bottom: 10px; }
    .form-group                { margin-bottom: 12px; }
    .form-label                { font-size: 0.78rem; margin-bottom: 6px; }
    .form-input,
    .form-textarea             { padding: 10px 12px; font-size: 0.85rem; }
    .input-button              { padding: 8px 12px; font-size: 0.78rem; }
    .date-option               { padding: 12px 6px; }
    .date-option__icon         { width: 34px; height: 34px; font-size: 0.95rem; margin-bottom: 6px; }
    .date-option__label        { font-size: 0.75rem; }
    .date-option__date         { font-size: 0.62rem; }
    .date-option__badge        { font-size: 0.5rem; padding: 2px 6px; top: 4px; right: 4px; }
    .timeslot                  { padding: 12px 10px; }
    .timeslot__time            { font-size: 0.85rem; }
    .timeslot__status          { font-size: 0.72rem; }
    .countdown-alert           { padding: 10px 12px; gap: 10px; }
    .countdown-alert__icon     { width: 36px; height: 36px; font-size: 0.92rem; }
    .payment-method__card      { padding: 12px; gap: 10px; }
    .payment-method__icon      { width: 36px; height: 36px; font-size: 1rem; border-radius: 8px; }
    .payment-method__name      { font-size: 0.85rem; }
    .payment-method__desc      { font-size: 0.72rem; }
    .payment-notice            { padding: 10px; gap: 8px; font-size: 0.78rem; }
    .checkout-offers__toggle   { padding: 8px 12px; font-size: 0.78rem; }
    .form-checkbox__label      { font-size: 0.78rem; }
    .form-checkbox input[type="checkbox"] { width: 16px; height: 16px; }
    .order-summary             { padding: 14px; }
    .order-summary__title      { font-size: 0.95rem; margin-bottom: 12px; padding-bottom: 10px; }
    .summary-item__img         { width: 40px; height: 40px; }
    .summary-item__name        { font-size: 0.72rem; }
    .summary-item__price       { font-size: 0.72rem; }
    .summary-qty-btn           { width: 22px; height: 22px; font-size: 0.65rem; }
    .summary-qty-val           { width: 20px; font-size: 0.65rem; line-height: 22px; }
    .summary-item__remove      { width: 18px; height: 18px; font-size: 0.5rem; top: 8px; }
    .summary-row               { font-size: 0.78rem; margin-bottom: 8px; }
    .summary-row--total        { font-size: 0.92rem; }
    .co-addon                  { flex: 0 0 84px; }
    .co-addon__img             { width: 40px; height: 40px; }
    .co-addon__name            { font-size: 0.58rem; }
    .co-addon__price           { font-size: 0.62rem; }
    .co-addon__btn             { font-size: 0.55rem; padding: 2px 5px; }
    .btn--mini                 { font-size: 0.68rem; padding: 5px 10px; }
    .btn--danger               { padding: 10px 20px; font-size: 0.88rem; }
    .cancel-modal__dialog      { padding: 24px 18px; }
}

@media (max-width: 374px) {
    :root { --section-v: 60px; }
    .occasion-chips, .cat-grid { gap: 10px; }
    .p-card { width: 170px; }
}

@media (hover: none) and (pointer: coarse) {
    .p-card:active                 { transform: scale(0.98); }
    .occasion-chip:active,
    .cat-card:active,
    .addon-card:active             { transform: scale(0.97); }
    .btn:active                    { transform: scale(0.97); }
    .p-card__wish                  { opacity: 1; transform: translateY(0); }
    .p-card__add-wrap              { transform: translateY(0); background: linear-gradient(to top, rgba(0,0,0,0.7), transparent); padding: 20px 14px 14px; }
}

/* ═══════════════════════════════════════════════════════════════
   PART 2 — Pages & Global Responsive System
   ═══════════════════════════════════════════════════════════════ */

/* ── Additional Keyframes ── */
@keyframes spin          { to { transform: rotate(360deg); } }
@keyframes shake         { 0%, 100% { transform: translateX(0); } 25% { transform: translateX(-10px); } 75% { transform: translateX(10px); } }
/* pulseSpinner — payment-processing spinner icon (different from Part 1 'pulse') */
@keyframes pulseSpinner  { 0%, 100% { opacity: 1; transform: translate(-50%, -50%) scale(1); } 50% { opacity: 0.5; transform: translate(-50%, -50%) scale(0.9); } }


/* ═══════════════════════════════════════════════════════════════
   GLOBAL RESPONSIVE SYSTEM — Token overrides & utilities
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) { :root { --section-v: 100px; } }
@media (max-width: 768px)  { :root { --section-v: 72px; --header-h: 64px; } }
@media (max-width: 480px)  { :root { --section-v: 56px; --header-h: 60px; } }
@media (max-width: 374px)  { :root { --section-v: 48px; } }
@media (max-width: 1024px) { .container { padding: 0 36px; } }
@media (max-width: 768px)  { .container { padding: 0 20px; } .products__scroll-wrap { margin: 0 -20px; padding: 0 20px; } .products__scroll-wrap::before, .products__scroll-wrap::after { width: 32px; } }
@media (max-width: 480px)  { .container { padding: 0 16px; } }

.section-title, .section__title { word-break: break-word; overflow-wrap: break-word; }
.products-grid, .ft-grid, .cat-grid, .addon-grid, .trust-grid, .test-grid, .steps { width: 100%; max-width: 100%; }
img[loading="lazy"] { background: var(--cream); }

@media (max-width: 768px) {
    .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; width: 100%; }
    .orders-table, .invoice-table { min-width: 480px; }
}
@media (max-width: 480px) {
    input[type="text"], input[type="email"], input[type="tel"],
    input[type="number"], input[type="password"], input[type="date"],
    select, textarea { font-size: 16px !important; }
}
@media (hover: none) and (pointer: coarse) {
    .btn { min-height: 44px; }
    .header__icon-btn { min-width: 44px; min-height: 44px; }
    .filter-chip, .ft-filter-chip, .sd-cat-chip { min-height: 36px; padding-top: 8px; padding-bottom: 8px; }
    .pcard__wishlist, .p-card__wish { opacity: 1 !important; transform: translateY(0) !important; }
    .p-card__add-wrap { transform: translateY(0) !important; }
    .pcard:hover, .cat-card:hover, .occasion-chip:hover { transform: none; }
}
@media (max-width: 374px) { .breadcrumb { font-size: 0.68rem; gap: 4px; } }
@media (max-width: 480px) { .back-to-top { bottom: 16px; right: 16px; width: 40px; height: 40px; font-size: 0.9rem; } }
@media (max-width: 374px) { .btn { padding: 12px 20px; font-size: 0.82rem; } }


/* ═══════════════════════════════════════════════════════════════
   GLOBAL COMPONENTS
   ═══════════════════════════════════════════════════════════════ */
.breadcrumb { display: flex; align-items: center; gap: 12px; font-size: 0.82rem; color: var(--warm-400); margin-bottom: 32px; }
.breadcrumb__link { color: var(--warm-400); transition: color 0.2s; }
.breadcrumb__link:hover { color: var(--rose); }
.breadcrumb__current { color: var(--charcoal); font-weight: 600; }
.breadcrumb i { font-size: 0.7rem; }
.breadcrumb--light { color: rgba(255,255,255,0.7); }
.breadcrumb--light .breadcrumb__link { color: rgba(255,255,255,0.7); }
.breadcrumb--light .breadcrumb__link:hover { color: var(--white); }
.breadcrumb--light .breadcrumb__current { color: var(--white); }
.breadcrumb--light i { color: rgba(255,255,255,0.5); }

/* ═══════════════════════════════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════════════════════════════ */
.login-hero {
    flex: 1; background: linear-gradient(135deg, #1e1b4b 0%, #312e81 40%, #4338ca 100%);
    display: flex; flex-direction: column; justify-content: center; align-items: center;
    padding: 60px 48px; position: relative; overflow: hidden;
}
.login-hero::before { content: ''; position: absolute; width: 600px; height: 600px; background: radial-gradient(circle, rgba(99,102,241,.25) 0%, transparent 70%); top: -120px; right: -150px; pointer-events: none; }
.login-hero::after  { content: ''; position: absolute; width: 500px; height: 500px; background: radial-gradient(circle, rgba(139,92,246,.2) 0%, transparent 70%); bottom: -100px; left: -100px; pointer-events: none; }
.hero-content  { position: relative; z-index: 1; max-width: 440px; text-align: center; }
.hero-logo     { width: 72px; height: 72px; background: rgba(255,255,255,.1); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.15); border-radius: 20px; display: inline-grid; place-items: center; font-size: 2rem; color: #fff; margin-bottom: 28px; }
.hero-title    { font-size: 2.2rem; font-weight: 700; color: #fff; letter-spacing: -.02em; line-height: 1.2; margin-bottom: 12px; }
.hero-subtitle { font-size: 1rem; color: rgba(255,255,255,.6); line-height: 1.7; max-width: 360px; margin: 0 auto; }
.hero-dots     { position: absolute; z-index: 0; inset: 0; overflow: hidden; pointer-events: none; }
.hero-dots span { position: absolute; width: 6px; height: 6px; background: rgba(255,255,255,.08); border-radius: 50%; }
.hero-dots span:nth-child(1) { top:15%; left:20%; width:8px; height:8px; }
.hero-dots span:nth-child(2) { top:35%; left:75%; width:5px; height:5px; }
.hero-dots span:nth-child(3) { top:60%; left:12%; }
.hero-dots span:nth-child(4) { top:80%; left:65%; width:10px; height:10px; }
.hero-dots span:nth-child(5) { top:25%; left:55%; width:4px; height:4px; }
.hero-dots span:nth-child(6) { top:70%; left:40%; width:7px; height:7px; }
.hero-dots span:nth-child(7) { top:45%; left:90%; }
.hero-dots span:nth-child(8) { top:90%; left:25%; width:5px; height:5px; }
.hero-stats { position: relative; z-index: 1; display: flex; gap: 40px; margin-top: 56px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.1); }
.hero-stat__value { font-size: 1.5rem; font-weight: 700; color: #fff; }
.hero-stat__label { font-size: .75rem; color: rgba(255,255,255,.45); margin-top: 2px; }

.login-panel { width: 520px; min-height: 100vh; background: #0f172a; display: flex; flex-direction: column; justify-content: center; padding: 48px 56px; position: relative; }
.login-header { margin-bottom: 36px; }
.login-header__badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 14px; background: rgba(99,102,241,.12); border: 1px solid rgba(99,102,241,.2); border-radius: 20px; font-size: .72rem; font-weight: 600; color: #818cf8; margin-bottom: 20px; text-transform: uppercase; letter-spacing: .06em; }
.login-header__title { font-size: 1.6rem; font-weight: 700; color: #fff; margin-bottom: 6px; letter-spacing: -.01em; }
.login-header__sub   { font-size: .9rem; color: #64748b; line-height: 1.5; }

.login-error { background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.2); color: #fca5a5; padding: 13px 18px; border-radius: 10px; font-size: .85rem; font-weight: 500; margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.login-error i { color: #ef4444; font-size: 1.1rem; flex-shrink: 0; }

/* Login panel form styles — scoped to avoid conflict with Part 1 checkout forms */
.login-panel .form-group { margin-bottom: 22px; }
.login-panel .form-label { display: block; font-size: .8rem; font-weight: 600; color: #94a3b8; margin-bottom: 8px; letter-spacing: .02em; }
.form-input-wrap { position: relative; }
.form-input-wrap .input-icon { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: #475569; font-size: 1.05rem; transition: color .2s; pointer-events: none; }
.login-panel .form-input { width: 100%; padding: 13px 16px 13px 46px; background: #1e293b; border: 1.5px solid rgba(255,255,255,.08); border-radius: 10px; color: #e2e8f0; font-size: .92rem; font-family: 'Inter', sans-serif; transition: border-color .2s, box-shadow .2s; }
.login-panel .form-input:focus { outline: none; border-color: #6366f1; box-shadow: 0 0 0 3px rgba(99,102,241,.15); }
.login-panel .form-input:focus + .input-icon,
.login-panel .form-input-wrap:focus-within .input-icon { color: #6366f1; }
.login-panel .form-input::placeholder { color: #475569; }

.password-toggle { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); background: none; border: none; color: #475569; cursor: pointer; padding: 4px; font-size: 1.1rem; transition: color .2s; display: grid; place-items: center; }
.password-toggle:hover { color: #94a3b8; }

.form-options { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.form-check { display: flex; align-items: center; gap: 8px; }
.form-check input[type="checkbox"] { width: 16px; height: 16px; accent-color: #6366f1; cursor: pointer; border-radius: 4px; }
.form-check label { font-size: .85rem; color: #94a3b8; cursor: pointer; user-select: none; }

.login-btn { width: 100%; padding: 14px 24px; background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%); color: #fff; border: none; border-radius: 10px; font-size: .95rem; font-weight: 700; font-family: 'Inter', sans-serif; cursor: pointer; transition: transform .15s, box-shadow .2s, opacity .2s; display: flex; align-items: center; justify-content: center; gap: 10px; box-shadow: 0 4px 14px rgba(99,102,241,.35); letter-spacing: .01em; }
.login-btn:hover  { box-shadow: 0 6px 20px rgba(99,102,241,.45); transform: translateY(-1px); }
.login-btn:active { transform: translateY(0) scale(.99); box-shadow: 0 2px 8px rgba(99,102,241,.3); }
.login-btn.loading { opacity: .7; pointer-events: none; }
.login-btn.loading .btn-text { display: none; }
.login-btn.loading .btn-loader { display: inline-block; }
.btn-loader { display: none; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: spin .6s linear infinite; }

.login-footer { margin-top: 36px; text-align: center; }
.login-footer a { color: #64748b; font-size: .85rem; text-decoration: none; font-weight: 500; display: inline-flex; align-items: center; gap: 6px; transition: color .2s; }
.login-footer a:hover { color: #818cf8; }
.login-footer__copy { margin-top: 24px; font-size: .72rem; color: #334155; }


/* ═══════════════════════════════════════════════════════════════
   ORDERS — Shared Components
   ═══════════════════════════════════════════════════════════════ */
/* .ord-alert and .ord-btn are used on both the list and detail pages */
.ord-alert { display: flex; align-items: center; gap: 10px; padding: 14px 20px; border-radius: var(--radius); font-size: 0.9rem; font-weight: 500; margin-bottom: 24px; }
.ord-alert--success { background: #EDF7F1; border: 1px solid #B4E8C4; color: #3A7D54; }
.ord-alert--error   { background: #FFF0F0; border: 1px solid #F5A8A8; color: #AA2A2A; }

.ord-btn { display: inline-flex; align-items: center; gap: 7px; padding: 10px 20px; border-radius: var(--radius); font-size: 0.82rem; font-weight: 600; transition: all 0.2s; white-space: nowrap; }
.ord-btn--primary  { background: var(--charcoal); color: var(--white); }
.ord-btn--primary:hover  { background: var(--rose); }
.ord-btn--ghost    { background: transparent; border: 1px solid var(--sand); color: var(--warm-500); }
.ord-btn--ghost:hover    { border-color: var(--rose); color: var(--rose); }
.ord-btn--danger   { background: #FFF0F0; border: 1px solid #F5A8A8; color: #AA2A2A; width: 100%; justify-content: center; }
.ord-btn--danger:hover   { background: #AA2A2A; color: var(--white); }
.ord-btn--whatsapp { background: #25D366; color: var(--white); width: 100%; justify-content: center; }
.ord-btn--whatsapp:hover { background: #1AA54E; }


/* ═══════════════════════════════════════════════════════════════
   ORDERS LIST PAGE
   ═══════════════════════════════════════════════════════════════ */
.ord-page { padding: calc(var(--promise-h) + var(--header-h) + 48px) 0 var(--section-v); min-height: 80vh; background: var(--ivory); }
.ord-page__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 48px; gap: 24px; }
.ord-page__eyebrow { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--rose); margin-bottom: 10px; }
.ord-page__title { font-family: var(--font-display); font-size: clamp(2rem, 3.5vw, 3.2rem); font-weight: 400; line-height: 1.1; letter-spacing: -0.02em; color: var(--charcoal); }
.ord-page__title em { font-style: italic; color: var(--rose); }

.ord-list { display: flex; flex-direction: column; gap: 20px; }
.ord-card { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); overflow: hidden; transition: box-shadow 0.3s var(--ease), transform 0.3s var(--ease); }
.ord-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.ord-card__head { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--sand); background: var(--ivory); }
.ord-card__number { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--charcoal); margin-bottom: 4px; }
.ord-card__date   { display: flex; align-items: center; gap: 6px; font-size: 0.8rem; color: var(--warm-400); }
.ord-card__status { display: inline-flex; align-items: center; gap: 7px; padding: 6px 14px; border-radius: var(--radius-pill); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.03em; }
.ord-card__status--pending   { background: #FFF8E7; color: #B8860B; border: 1px solid #F0D88A; }
.ord-card__status--confirmed { background: #E8F4FF; color: #1A6FAA; border: 1px solid #B0D8F5; }
.ord-card__status--preparing { background: #FFF0E8; color: #B55A1A; border: 1px solid #F5C4A0; }
.ord-card__status--out       { background: #F0E8FF; color: #6A2AB5; border: 1px solid #C8A8F0; }
.ord-card__status--delivered { background: #EDF7F1; color: #2A7A44; border: 1px solid #A8E0C0; }
.ord-card__status--cancelled { background: #FFF0F0; color: #AA2A2A; border: 1px solid #F5A8A8; }
.ord-card__items { padding: 20px 24px; border-bottom: 1px solid var(--sand); }
.ord-item { display: flex; align-items: center; gap: 14px; padding: 10px 0; border-bottom: 1px solid var(--cream); }
.ord-item:last-child { border-bottom: none; padding-bottom: 0; }
.ord-item__img  { width: 52px; height: 52px; flex-shrink: 0; border-radius: 10px; overflow: hidden; background: var(--cream); }
.ord-item__img img { width: 100%; height: 100%; object-fit: cover; }
.ord-item__info { flex: 1; min-width: 0; }
.ord-item__name { font-size: 0.88rem; font-weight: 600; color: var(--charcoal); margin-bottom: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ord-item__qty  { font-size: 0.78rem; color: var(--warm-400); }
.ord-item__price { font-size: 0.9rem; font-weight: 600; color: var(--charcoal); }
.ord-card__more { font-size: 0.78rem; color: var(--rose); padding-top: 10px; font-weight: 600; }
.ord-card__delivery { display: flex; gap: 24px; flex-wrap: wrap; padding: 14px 24px; background: var(--ivory); border-bottom: 1px solid var(--sand); }
.ord-card__delivery-item { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; color: var(--warm-400); }
.ord-card__delivery-item i { color: var(--rose); }
.ord-card__delivery-item strong { color: var(--charcoal); }
.ord-card__foot { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; gap: 16px; }
.ord-card__total { display: flex; align-items: center; gap: 10px; font-size: 0.85rem; color: var(--warm-400); }
.ord-card__total strong { font-size: 1.1rem; color: var(--charcoal); font-family: var(--font-display); }
.ord-card__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.ord-card__photo { padding: 0 24px 20px; }
.ord-card__photo-label { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; font-weight: 600; color: var(--warm-400); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 10px; }
.ord-card__photo img { width: 100%; max-height: 220px; object-fit: cover; border-radius: var(--radius); border: 1px solid var(--sand); }
.ord-empty { text-align: center; padding: 80px 20px; }
.ord-empty__icon { width: 88px; height: 88px; margin: 0 auto 28px; background: var(--cream); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 2.2rem; color: var(--warm-200); }
.ord-empty__title { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 400; color: var(--charcoal); margin-bottom: 16px; }
.ord-empty__text  { font-size: 0.95rem; color: var(--warm-400); max-width: 480px; margin: 0 auto 32px; line-height: 1.7; }
.pagination-wrap { margin-top: 48px; display: flex; justify-content: center; }


/* ═══════════════════════════════════════════════════════════════
   INVOICE PRINT PAGE
   ═══════════════════════════════════════════════════════════════ */
.screen-wrap { background: #f5f0eb; min-height: 100vh; padding: 32px 16px; }
.no-print { display: flex; align-items: center; justify-content: space-between; max-width: 800px; margin: 0 auto 20px; gap: 12px; flex-wrap: wrap; }
.no-print-title { font-family: 'Georgia', serif; font-size: 1rem; color: #5a3040; letter-spacing: .04em; }
.no-print-actions { display: flex; gap: 10px; }
.btn-print, .btn-back { display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px; border-radius: 50px; font-size: .82rem; font-weight: 600; cursor: pointer; text-decoration: none; border: none; transition: opacity .2s, transform .15s; }
.btn-print { background: #b46478; color: #fff; }
.btn-back  { background: #fff; color: #5a3040; border: 1.5px solid #e8d5c4; }
.btn-print:hover, .btn-back:hover { opacity: .88; transform: translateY(-1px); }
.invoice { max-width: 800px; margin: 0 auto; background: #fff; box-shadow: 0 4px 40px rgba(0,0,0,.12); border-radius: 4px; overflow: hidden; }
.inv-header { background: linear-gradient(135deg, #2a1a1f 0%, #3a2028 100%); padding: 40px 48px; display: flex; align-items: flex-start; justify-content: space-between; }
.inv-brand__logo { font-family: 'Georgia', serif; font-size: 2rem; color: #fff; letter-spacing: .08em; margin-bottom: 4px; }
.inv-brand__logo span { color: #c8939e; }
.inv-brand__tagline { font-size: .7rem; color: rgba(255,255,255,.5); letter-spacing: .14em; text-transform: uppercase; }
.inv-brand__addr { margin-top: 14px; font-size: .72rem; color: rgba(255,255,255,.45); line-height: 1.7; }
.inv-meta { text-align: right; }
.inv-meta__badge  { display: inline-block; background: #b46478; color: #fff; font-size: .65rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; padding: 4px 12px; border-radius: 50px; margin-bottom: 12px; }
.inv-meta__number { font-size: 1.3rem; color: #fff; letter-spacing: .04em; margin-bottom: 6px; }
.inv-meta__date   { font-size: .72rem; color: rgba(255,255,255,.5); letter-spacing: .06em; }
.inv-ribbon { height: 4px; background: linear-gradient(90deg, #b46478 0%, #c8a260 50%, #b46478 100%); }
.inv-body { padding: 40px 48px; }
.inv-addresses { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; margin-bottom: 36px; padding-bottom: 32px; border-bottom: 1px solid #f0e8e0; }
.inv-addr__label  { font-size: .65rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #b46478; margin-bottom: 8px; }
.inv-addr__name   { font-size: .95rem; font-weight: 700; color: #2a1a1f; margin-bottom: 4px; }
.inv-addr__detail { font-size: .8rem; color: #6b5060; line-height: 1.65; }
.inv-delivery-strip { display: flex; gap: 24px; padding: 16px 20px; background: #fdf8f5; border-radius: 6px; border: 1px solid #f0e8e0; margin-bottom: 32px; flex-wrap: wrap; }
.inv-dstrip__item  { display: flex; flex-direction: column; gap: 3px; }
.inv-dstrip__label { font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #b46478; }
.inv-dstrip__val   { font-size: .82rem; color: #2a1a1f; font-weight: 500; }
.inv-table-label { font-size: .65rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #b46478; margin-bottom: 12px; }
table { width: 100%; border-collapse: collapse; margin-bottom: 8px; }
thead th { font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #8a6070; padding: 10px 12px; border-bottom: 2px solid #f0e8e0; text-align: left; }
thead th:last-child { text-align: right; }
tbody td { padding: 12px; border-bottom: 1px solid #faf5f0; font-size: .85rem; color: #2a1a1f; vertical-align: top; }
tbody td:last-child { text-align: right; font-weight: 600; }
tbody tr:last-child td { border-bottom: none; }
.inv-item-name { font-weight: 600; margin-bottom: 2px; }
.inv-item-meta { font-size: .72rem; color: #8a6070; }
.inv-totals { margin-top: 24px; border-top: 1px solid #f0e8e0; padding-top: 16px; display: flex; justify-content: flex-end; }
.inv-totals-table { width: 260px; }
.inv-totals-row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; font-size: .85rem; color: #2a1a1f; border-bottom: 1px solid #faf5f0; }
.inv-totals-row:last-child { border-bottom: none; }
.inv-totals-row__label { color: #6b5060; }
.inv-totals-row__val { font-weight: 600; }
.inv-totals-row.discount .inv-totals-row__val { color: #4a9f6a; }
.inv-grand-total { display: flex; justify-content: space-between; align-items: center; margin-top: 12px; padding: 14px 16px; background: #2a1a1f; border-radius: 6px; color: #fff; }
.inv-grand-total__label { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.inv-grand-total__val   { font-size: 1.2rem; font-weight: 700; letter-spacing: .02em; }
.inv-payment { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; padding: 6px 14px; border-radius: 50px; font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.inv-payment.paid   { background: #f0faf5; color: #2d7a55; border: 1px solid #a7e0c4; }
.inv-payment.unpaid { background: #fff5f5; color: #c0392b; border: 1px solid #fecaca; }
.inv-message { margin-top: 32px; padding: 20px 24px; background: #fdf8f5; border-left: 3px solid #b46478; border-radius: 0 6px 6px 0; }
.inv-message__label { font-size: .62rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #b46478; margin-bottom: 8px; }
.inv-message__text  { font-style: italic; color: #5a3040; font-size: .88rem; line-height: 1.7; }
.inv-footer { margin-top: 40px; padding-top: 24px; border-top: 1px solid #f0e8e0; display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.inv-footer__note { font-size: .72rem; color: #8a6070; line-height: 1.7; max-width: 380px; }
.inv-footer__note strong { color: #5a3040; }
.inv-footer__stamp { text-align: right; }
.inv-footer__stamp-box { width: 100px; height: 60px; border: 1.5px dashed #d4b8c0; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: .62rem; color: #c8a0b0; letter-spacing: .06em; text-transform: uppercase; margin-left: auto; margin-bottom: 8px; }
.inv-footer__stamp-label { font-size: .6rem; color: #c8a0b0; letter-spacing: .08em; text-transform: uppercase; }
.inv-watermark { text-align: center; padding: 20px 48px 32px; font-size: .7rem; color: #c8a0b0; letter-spacing: .06em; }


/* ═══════════════════════════════════════════════════════════════
   ORDER DETAIL PAGE
   ═══════════════════════════════════════════════════════════════ */
.ord-show { padding: calc(var(--promise-h) + var(--header-h) + 32px) 0 var(--section-v); background: var(--ivory); min-height: 80vh; }
.ord-show__layout { display: grid; grid-template-columns: 1fr 360px; gap: 32px; align-items: start; }
.ord-show__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 28px 32px; margin-bottom: 20px; }
.ord-show__eyebrow { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--rose); margin-bottom: 8px; }
.ord-show__title  { font-family: var(--font-display); font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 400; color: var(--charcoal); margin-bottom: 6px; }
.ord-show__placed { font-size: 0.82rem; color: var(--warm-400); }
.ord-show__actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-start; }
.ord-timeline { display: flex; align-items: center; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 28px 32px; margin-bottom: 20px; overflow-x: auto; }
.ord-timeline__step { display: flex; flex-direction: column; align-items: center; gap: 8px; min-width: 80px; flex-shrink: 0; }
.ord-timeline__dot { width: 36px; height: 36px; border-radius: 50%; background: var(--cream); border: 2px solid var(--sand); display: flex; align-items: center; justify-content: center; font-size: 0.8rem; color: var(--warm-300); transition: all 0.3s; }
.ord-timeline__step.done   .ord-timeline__dot { background: var(--rose); border-color: var(--rose); color: var(--white); }
.ord-timeline__step.active .ord-timeline__dot { background: var(--white); border-color: var(--gold); color: var(--gold); box-shadow: 0 0 0 5px rgba(201,169,110,0.15); }
.ord-timeline__label { font-size: 0.7rem; font-weight: 600; color: var(--warm-300); text-align: center; line-height: 1.3; white-space: nowrap; }
.ord-timeline__step.done .ord-timeline__label,
.ord-timeline__step.active .ord-timeline__label { color: var(--charcoal); }
.ord-timeline__time { font-size: 0.62rem; color: var(--warm-200); text-align: center; white-space: nowrap; }
.ord-timeline__line { flex: 1; height: 2px; background: var(--sand); margin: 0 4px; margin-bottom: 28px; min-width: 20px; }
.ord-timeline__line.done { background: var(--rose); }
.ord-cancelled-notice { display: flex; align-items: center; gap: 16px; background: #FFF0F0; border: 1px solid #F5A8A8; border-radius: var(--radius-lg); padding: 20px 24px; margin-bottom: 20px; color: #AA2A2A; }
.ord-cancelled-notice i { font-size: 1.5rem; flex-shrink: 0; }
.ord-cancelled-notice strong { display: block; font-size: 0.95rem; font-weight: 700; margin-bottom: 4px; }
.ord-cancelled-notice span  { font-size: 0.85rem; opacity: 0.8; }
.ord-show__photo { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 24px 28px; margin-bottom: 20px; }
.ord-show__photo-wrap { position: relative; }
.ord-show__photo-wrap img { width: 100%; max-height: 320px; object-fit: cover; border-radius: var(--radius); border: 1px solid var(--sand); }
.ord-show__photo-badge { position: absolute; bottom: 12px; left: 12px; background: #5A9A6E; color: var(--white); padding: 6px 14px; border-radius: var(--radius-pill); font-size: 0.75rem; font-weight: 700; display: flex; align-items: center; gap: 6px; }
.ord-show__items, .ord-show__message, .ord-show__history { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 24px 28px; margin-bottom: 20px; }
.ord-section-title { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--charcoal); margin-bottom: 20px; }
.ord-section-title i { color: var(--rose); }
.ord-show__item { display: flex; align-items: center; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--cream); }
.ord-show__item:last-child { border-bottom: none; padding-bottom: 0; }
.ord-show__item--addon { opacity: 0.75; }
.ord-show__item-img { width: 64px; height: 64px; flex-shrink: 0; border-radius: 12px; overflow: hidden; background: var(--cream); }
.ord-show__item-img img { width: 100%; height: 100%; object-fit: cover; }
.ord-show__item-img--addon { display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--rose); }
.ord-show__item-info  { flex: 1; min-width: 0; }
.ord-show__item-name  { font-size: 0.9rem; font-weight: 600; color: var(--charcoal); margin-bottom: 4px; }
.ord-show__item-note  { font-size: 0.78rem; color: var(--warm-400); margin-bottom: 4px; display: flex; align-items: center; gap: 5px; }
.ord-show__item-qty   { font-size: 0.78rem; color: var(--warm-400); }
.ord-show__item-price { text-align: right; }
.ord-show__item-unit  { font-size: 0.75rem; color: var(--warm-400); margin-bottom: 2px; }
.ord-show__item-total { font-size: 0.95rem; font-weight: 700; color: var(--charcoal); }
.ord-show__addons-label { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--warm-300); padding: 10px 0 4px; }
.ord-show__message-card { position: relative; background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius); padding: 20px 24px; font-size: 0.95rem; color: var(--warm-500); line-height: 1.7; font-style: italic; }
.ord-show__message-quote { position: absolute; top: 12px; left: 12px; font-size: 1.8rem; color: var(--rose-lighter); opacity: 0.5; }
.ord-show__message-from { margin-top: 12px; font-size: 0.85rem; color: var(--warm-400); font-style: normal; font-weight: 600; }
.ord-history { display: flex; flex-direction: column; }
.ord-history__item { display: flex; gap: 16px; padding-bottom: 20px; position: relative; }
.ord-history__item:last-child { padding-bottom: 0; }
.ord-history__item:not(:last-child)::before { content: ''; position: absolute; left: 7px; top: 18px; bottom: 0; width: 2px; background: var(--sand); }
.ord-history__dot    { width: 16px; height: 16px; border-radius: 50%; background: var(--rose); flex-shrink: 0; margin-top: 2px; }
.ord-history__status { font-size: 0.88rem; font-weight: 600; color: var(--charcoal); margin-bottom: 3px; }
.ord-history__notes  { font-size: 0.8rem; color: var(--warm-400); margin-bottom: 3px; }
.ord-history__time   { font-size: 0.75rem; color: var(--warm-300); }
/* Quick info strip (full-width, always at top) */
.ord-quickinfo { display: flex; align-items: center; gap: 0; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 18px 28px; margin-bottom: 20px; overflow-x: auto; flex-wrap: wrap; }
.ord-quickinfo__item { display: flex; align-items: center; gap: 10px; padding: 6px 0; min-width: 0; }
.ord-quickinfo__item--notes { flex: 1 1 auto; min-width: 160px; }
.ord-quickinfo__icon { width: 34px; height: 34px; border-radius: var(--radius); background: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 0.85rem; color: var(--rose); flex-shrink: 0; }
.ord-quickinfo__icon--warn { background: #FEF3C7; color: #D97706; }
.ord-quickinfo__label { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--warm-300); line-height: 1; margin-bottom: 3px; }
.ord-quickinfo__val { font-size: 0.88rem; font-weight: 600; color: var(--charcoal); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 180px; }
.ord-quickinfo__val--paid { color: var(--success); }
.ord-quickinfo__val--pending { color: var(--gold); }
.ord-quickinfo__val--failed { color: #EE5A6F; }
.ord-quickinfo__sep { width: 1px; height: 32px; background: var(--sand); margin: 0 20px; flex-shrink: 0; }

.ord-show__sidebar { display: flex; flex-direction: column; gap: 16px; }
.ord-sidebar-card { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 24px; }
.ord-sidebar-card__title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 500; color: var(--charcoal); margin-bottom: 16px; }
.ord-sidebar-card--help { text-align: center; }
.ord-help__icon { font-size: 2rem; color: var(--rose); margin-bottom: 12px; }
.ord-help__text { font-size: 0.85rem; color: var(--warm-400); margin-bottom: 16px; line-height: 1.6; }
.ord-summary { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.ord-summary__row { display: flex; justify-content: space-between; font-size: 0.88rem; color: var(--warm-400); }
.ord-summary__row--discount { color: #3A7D54; }
.ord-summary__total { display: flex; justify-content: space-between; padding-top: 12px; border-top: 1px solid var(--sand); font-size: 0.88rem; color: var(--warm-400); font-weight: 600; }
.ord-summary__total strong { font-family: var(--font-display); font-size: 1.3rem; color: var(--charcoal); }
.ord-summary__payment { display: flex; justify-content: space-between; align-items: center; padding-top: 12px; border-top: 1px solid var(--sand); font-size: 0.82rem; }
.ord-summary__pay-method { display: flex; align-items: center; gap: 6px; color: var(--warm-500); }
.ord-summary__pay-status--paid    { color: #3A7D54; font-weight: 600; }
.ord-summary__pay-status--pending { color: #B8860B; font-weight: 600; }
.ord-summary__pay-status--failed  { color: #AA2A2A; font-weight: 600; }
.ord-delivery-info { display: flex; flex-direction: column; gap: 14px; }
.ord-delivery-info__item { display: flex; align-items: flex-start; gap: 12px; }
.ord-delivery-info__item i { color: var(--rose); margin-top: 2px; flex-shrink: 0; }
.ord-delivery-info__label { font-size: 0.72rem; color: var(--warm-300); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 2px; }
.ord-delivery-info__val   { font-size: 0.88rem; color: var(--charcoal); line-height: 1.4; }
.ord-cancel__desc   { font-size: 0.85rem; color: var(--warm-400); margin-bottom: 14px; line-height: 1.6; }
.ord-cancel__reason { width: 100%; padding: 12px 14px; background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius); font-size: 0.85rem; color: var(--charcoal); resize: vertical; margin-bottom: 12px; }
.ord-cancel__note   { display: flex; align-items: flex-start; gap: 7px; font-size: 0.75rem; color: var(--warm-300); margin-top: 12px; line-height: 1.5; }


/* ═══════════════════════════════════════════════════════════════
   TRACK ORDER — Search Page
   ═══════════════════════════════════════════════════════════════ */
.trk-hero { min-height: calc(100vh - var(--header-h) - var(--promise-h)); display: flex; align-items: center; background: var(--ivory); padding: 80px 0; position: relative; overflow: hidden; }
.trk-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 70% 40%, rgba(180,100,120,.06) 0%, transparent 70%), radial-gradient(ellipse 40% 60% at 20% 70%, rgba(180,140,80,.04) 0%, transparent 60%); pointer-events: none; }
.trk-hero__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; position: relative; z-index: 1; }
.trk-copy__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: .75rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--rose); margin-bottom: 20px; }
.trk-copy__title { font-family: var(--font-display); font-size: clamp(2.4rem, 4vw, 3.4rem); font-weight: 400; line-height: 1.15; color: var(--charcoal); margin-bottom: 20px; }
.trk-copy__title em { font-style: italic; color: var(--rose); }
.trk-copy__sub { font-size: 1rem; color: var(--warm-500); line-height: 1.7; margin-bottom: 40px; max-width: 400px; }
.trk-reassurance { display: flex; flex-direction: column; gap: 14px; }
.trk-reassurance__item { display: flex; align-items: center; gap: 12px; font-size: .88rem; color: var(--warm-600); }
.trk-reassurance__icon { width: 32px; height: 32px; border-radius: 50%; background: var(--rose-bg); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--rose); font-size: .8rem; }
.trk-card { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; }
.trk-card__header { background: linear-gradient(135deg, var(--charcoal) 0%, #3a2a2d 100%); padding: 36px 40px 28px; position: relative; overflow: hidden; }
.trk-card__header::after { content: ''; position: absolute; bottom: -20px; right: -20px; width: 120px; height: 120px; border-radius: 50%; background: rgba(180,100,120,.15); }
.trk-card__header-icon  { width: 52px; height: 52px; border-radius: var(--radius); background: rgba(255,255,255,.12); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.4rem; margin-bottom: 16px; }
.trk-card__header-title { font-family: var(--font-display); font-size: 1.6rem; font-weight: 400; color: #fff; margin-bottom: 6px; }
.trk-card__header-sub   { font-size: .82rem; color: rgba(255,255,255,.6); letter-spacing: .04em; }
.trk-card__body { padding: 40px; }
.trk-field { margin-bottom: 22px; }
.trk-field label { display: block; font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-600); margin-bottom: 8px; }
.trk-field__wrap { position: relative; }
.trk-field__wrap i { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--warm-400); font-size: .95rem; pointer-events: none; }
.trk-field input { width: 100%; height: 52px; padding: 0 16px 0 44px; border: 1.5px solid var(--warm-200); border-radius: var(--radius); font-family: var(--font-body); font-size: .95rem; color: var(--charcoal); background: var(--cream); transition: border-color .2s, box-shadow .2s, background .2s; outline: none; }
.trk-field input::placeholder { color: var(--warm-400); }
.trk-field input:focus { border-color: var(--rose); background: var(--white); box-shadow: 0 0 0 3px rgba(180,100,120,.1); }
.trk-field input.is-invalid { border-color: var(--error); background: #fff5f5; }
.trk-field__hint  { margin-top: 6px; font-size: .76rem; color: var(--warm-400); display: flex; align-items: center; gap: 5px; }
.trk-field__error { margin-top: 6px; font-size: .78rem; color: var(--error); display: flex; align-items: center; gap: 5px; }
.trk-btn { width: 100%; height: 54px; display: flex; align-items: center; justify-content: center; gap: 10px; background: var(--rose); color: var(--white); border: none; border-radius: var(--radius-pill); font-family: var(--font-body); font-size: .95rem; font-weight: 600; letter-spacing: .04em; cursor: pointer; transition: background .2s, transform .15s, box-shadow .2s; margin-top: 8px; }
.trk-btn:hover  { background: var(--rose-dark); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(180,100,120,.3); }
.trk-btn:active { transform: translateY(0); }
.trk-divider { display: flex; align-items: center; gap: 16px; margin: 28px 0; color: var(--warm-300); font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; }
.trk-divider::before, .trk-divider::after { content: ''; flex: 1; height: 1px; background: var(--warm-100); }
.trk-alt-links { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.trk-alt-link { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 16px 12px; border: 1.5px solid var(--warm-100); border-radius: var(--radius); text-decoration: none; color: var(--warm-600); font-size: .82rem; font-weight: 500; transition: border-color .2s, background .2s, color .2s; text-align: center; }
.trk-alt-link i { font-size: 1.2rem; color: var(--rose); }
.trk-alt-link:hover { border-color: var(--rose-lighter); background: var(--rose-bg); color: var(--rose-dark); }
.trk-steps { background: var(--white); padding: 64px 0; border-top: 1px solid var(--warm-100); }
.trk-steps__title { text-align: center; font-family: var(--font-display); font-size: 1.5rem; font-weight: 400; color: var(--charcoal); margin-bottom: 40px; }
.trk-steps__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; position: relative; }
.trk-steps__grid::before { content: ''; position: absolute; top: 28px; left: calc(12.5% + 20px); right: calc(12.5% + 20px); height: 1px; background: var(--rose-lighter); z-index: 0; }
.trk-step { display: flex; flex-direction: column; align-items: center; text-align: center; position: relative; z-index: 1; }
.trk-step__num   { width: 56px; height: 56px; border-radius: 50%; background: var(--white); border: 2px solid var(--rose-lighter); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.2rem; font-weight: 600; color: var(--rose); margin-bottom: 16px; box-shadow: var(--shadow-sm); }
.trk-step__label { font-size: .88rem; font-weight: 600; color: var(--charcoal); margin-bottom: 6px; }
.trk-step__desc  { font-size: .78rem; color: var(--warm-400); line-height: 1.5; }
.trk-alert { display: flex; align-items: flex-start; gap: 12px; padding: 16px 20px; border-radius: var(--radius); background: #fff5f5; border: 1px solid #ffd5d5; margin-bottom: 24px; font-size: .88rem; color: #b91c1c; }
.trk-alert i { margin-top: 2px; flex-shrink: 0; }


/* ═══════════════════════════════════════════════════════════════
   TRACK ORDER — Result / Tracker Page
   ═══════════════════════════════════════════════════════════════ */
.trkr { background: var(--ivory); min-height: calc(100vh - var(--header-h) - var(--promise-h)); padding: 60px 0 80px; }
.trkr__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 40px; flex-wrap: wrap; gap: 16px; }
.trkr__back { display: inline-flex; align-items: center; gap: 8px; font-size: .85rem; font-weight: 500; color: var(--warm-500); text-decoration: none; transition: color .2s; }
.trkr__back:hover { color: var(--rose); }
.trkr__order-id { font-size: .8rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-400); background: var(--white); border: 1px solid var(--warm-100); border-radius: var(--radius-pill); padding: 6px 16px; }
.trkr__layout { display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start; }
.trkr-card { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); overflow: hidden; }
.trkr-card__head { padding: 32px 36px 28px; border-bottom: 1px solid var(--warm-100); display: flex; align-items: center; gap: 20px; }
.trkr-status-dot { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; }
.trkr-status-dot.pending          { background: #f59e0b; box-shadow: 0 0 0 4px rgba(245,158,11,.15); }
.trkr-status-dot.confirmed        { background: #3b82f6; box-shadow: 0 0 0 4px rgba(59,130,246,.15); }
.trkr-status-dot.preparing        { background: #f97316; box-shadow: 0 0 0 4px rgba(249,115,22,.15); }
.trkr-status-dot.out_for_delivery { background: var(--rose); box-shadow: 0 0 0 4px rgba(180,100,120,.15); }
.trkr-status-dot.delivered        { background: var(--success); box-shadow: 0 0 0 4px rgba(74,167,127,.15); }
.trkr-status-dot.cancelled        { background: #ef4444; box-shadow: 0 0 0 4px rgba(239,68,68,.15); }
.trkr-card__status-label { font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 4px; }
.trkr-card__status-val   { font-family: var(--font-display); font-size: 1.5rem; font-weight: 400; color: var(--charcoal); }
.trkr-card__head-eta     { margin-left: auto; text-align: right; }
.trkr-card__eta-label    { font-size: .72rem; color: var(--warm-400); letter-spacing: .06em; text-transform: uppercase; margin-bottom: 4px; }
.trkr-card__eta-val      { font-size: 1rem; font-weight: 600; color: var(--charcoal); }
.trkr-timeline { padding: 36px; }
.trkr-tl { position: relative; display: flex; flex-direction: column; }
.trkr-tl__item { display: flex; gap: 20px; position: relative; }
.trkr-tl__item:not(:last-child) { padding-bottom: 32px; }
.trkr-tl__item:not(:last-child) .trkr-tl__line { position: absolute; left: 17px; top: 36px; bottom: 0; width: 2px; background: var(--warm-100); }
.trkr-tl__item.done:not(:last-child)   .trkr-tl__line { background: linear-gradient(to bottom, var(--rose), var(--rose-lighter)); }
.trkr-tl__item.active:not(:last-child) .trkr-tl__line { background: linear-gradient(to bottom, var(--gold-light), var(--warm-100)); }
.trkr-tl__icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: .85rem; position: relative; z-index: 1; transition: all .3s; }
.trkr-tl__item.done      .trkr-tl__icon { background: var(--rose); color: #fff; }
.trkr-tl__item.active    .trkr-tl__icon { background: var(--gold); color: #fff; box-shadow: 0 0 0 4px rgba(180,140,80,.2); }
.trkr-tl__item.future    .trkr-tl__icon { background: var(--warm-100); color: var(--warm-300); border: 2px solid var(--warm-200); }
.trkr-tl__item.cancelled .trkr-tl__icon { background: #fef2f2; color: #ef4444; border: 2px solid #fecaca; }
.trkr-tl__body  { padding-top: 6px; flex: 1; }
.trkr-tl__title { font-size: .95rem; font-weight: 600; color: var(--charcoal); margin-bottom: 3px; }
.trkr-tl__item.future .trkr-tl__title { color: var(--warm-300); }
.trkr-tl__desc  { font-size: .82rem; color: var(--warm-400); line-height: 1.5; }
.trkr-tl__time  { font-size: .75rem; color: var(--warm-300); margin-top: 4px; }
.trkr-photo { padding: 0 36px 36px; }
.trkr-photo__label { font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.trkr-photo img { width: 100%; max-height: 320px; object-fit: cover; border-radius: var(--radius); border: 1px solid var(--warm-100); }
.trkr-items { padding: 0 36px 36px; border-top: 1px solid var(--warm-100); }
.trkr-items__label { font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-400); padding-top: 28px; margin-bottom: 16px; }
.trkr-item { display: flex; align-items: center; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--warm-100); }
.trkr-item:last-child { border-bottom: none; }
.trkr-item__img   { width: 52px; height: 52px; border-radius: var(--radius); object-fit: cover; background: var(--cream); flex-shrink: 0; }
.trkr-item__name  { font-size: .9rem; font-weight: 500; color: var(--charcoal); }
.trkr-item__meta  { font-size: .78rem; color: var(--warm-400); margin-top: 2px; }
.trkr-item__price { margin-left: auto; font-size: .9rem; font-weight: 600; color: var(--charcoal); white-space: nowrap; }
.trkr-sidebar { display: flex; flex-direction: column; gap: 20px; }
.trkr-scard { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: 24px; }
.trkr-scard__title { font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.trkr-scard__title i { color: var(--rose); }
.trkr-info-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; padding: 8px 0; font-size: .88rem; border-bottom: 1px solid var(--warm-100); }
.trkr-info-row:last-child { border-bottom: none; }
.trkr-info-row__label { color: var(--warm-400); flex-shrink: 0; }
.trkr-info-row__val   { color: var(--charcoal); font-weight: 500; text-align: right; }
.trkr-total-row { display: flex; justify-content: space-between; padding: 14px 0 0; margin-top: 8px; border-top: 1.5px solid var(--charcoal); font-size: 1rem; font-weight: 700; color: var(--charcoal); }
.trkr-rider { display: flex; align-items: center; gap: 14px; }
.trkr-rider__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--rose-bg); display: flex; align-items: center; justify-content: center; color: var(--rose); font-size: 1.1rem; flex-shrink: 0; }
.trkr-rider__name { font-size: .95rem; font-weight: 600; color: var(--charcoal); }
.trkr-rider__role { font-size: .78rem; color: var(--warm-400); margin-top: 2px; }
.trkr-wa-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 14px; background: #25d366; color: #fff; border: none; border-radius: var(--radius-pill); font-family: var(--font-body); font-size: .9rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: background .2s, transform .15s; }
.trkr-wa-btn:hover { background: #1db954; transform: translateY(-1px); }
.trkr-track-again { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 12px; border: 1.5px solid var(--warm-200); border-radius: var(--radius-pill); font-family: var(--font-body); font-size: .88rem; font-weight: 500; color: var(--warm-500); text-decoration: none; transition: border-color .2s, color .2s; }
.trkr-track-again:hover { border-color: var(--rose); color: var(--rose); }


/* ═══════════════════════════════════════════════════════════════
   HOW IT WORKS PAGE
   ═══════════════════════════════════════════════════════════════ */
.hiw-hero { background: var(--charcoal);  padding-top: calc(var(--promise-h) + var(--header-h) + 40px); padding-bottom: 80px; position: relative; overflow: hidden; text-align: center; }
.hiw-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 55% 60% at 20% 50%, rgba(180,100,120,.18) 0%, transparent 70%), radial-gradient(ellipse 50% 55% at 80% 40%, rgba(180,140,80,.12) 0%, transparent 65%); pointer-events: none; }
.hiw-hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: .72rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--rose); margin-bottom: 20px; position: relative; z-index: 1; }
.hiw-hero__title { font-family: var(--font-display); font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 400; color: #fff; line-height: 1.15; margin-bottom: 20px; position: relative; z-index: 1; }
.hiw-hero__title em { font-style: italic; color: var(--rose); }
.hiw-hero__sub { font-size: 1.05rem; color: rgba(255,255,255,.6); line-height: 1.7; max-width: 560px; margin: 0 auto 40px; position: relative; z-index: 1; }
.hiw-hero__cta { display: inline-flex; align-items: center; gap: 10px; padding: 14px 32px; background: var(--rose); color: #fff; border-radius: var(--radius-pill); font-size: .95rem; font-weight: 600; text-decoration: none; transition: background .2s, transform .15s, box-shadow .2s; position: relative; z-index: 1; }
.hiw-hero__cta:hover { background: var(--rose-dark); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(180,100,120,.4); }
.hiw-steps { background: var(--ivory); padding: var(--section-v) 0; }
.hiw-steps__header { text-align: center; margin-bottom: 72px; }
.hiw-steps__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: .72rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--rose); margin-bottom: 16px; }
.hiw-steps__title { font-family: var(--font-display); font-size: clamp(2rem, 3.5vw, 2.8rem); font-weight: 400; color: var(--charcoal); margin-bottom: 12px; line-height: 1.2; }
.hiw-steps__sub { font-size: .95rem; color: var(--warm-500); max-width: 480px; margin: 0 auto; line-height: 1.7; }
.hiw-steps__grid { display: flex; flex-direction: column; }
.hiw-step-row { display: grid; grid-template-columns: 1fr 80px 1fr; align-items: center; }
.hiw-step-row:nth-child(even) .hiw-step-visual    { order: -1; }
.hiw-step-row:nth-child(even) .hiw-step-connector { order: 0; }
.hiw-step-row:nth-child(even) .hiw-step-body      { order: 1; }
.hiw-step-visual { background: var(--white); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); padding: 32px; min-height: 340px; display: flex; align-items: center; justify-content: center; position: relative; }
.hiw-step-row:nth-child(1) .hiw-step-visual { border-top: 4px solid var(--rose); }
.hiw-step-row:nth-child(2) .hiw-step-visual { border-top: 4px solid var(--gold); }
.hiw-step-row:nth-child(3) .hiw-step-visual { border-top: 4px solid var(--success); }
.hiw-step-row:nth-child(4) .hiw-step-visual { border-top: 4px solid #6366f1; }
.hiw-step-connector { display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; height: 100%; min-height: 340px; }
.hiw-step-connector__num { width: 56px; height: 56px; border-radius: 50%; background: var(--rose); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.4rem; font-weight: 500; box-shadow: 0 4px 16px rgba(180,100,120,.3); z-index: 1; flex-shrink: 0; }
.hiw-step-row:nth-child(2) .hiw-step-connector__num { background: var(--gold);    box-shadow: 0 4px 16px rgba(180,140,80,.3); }
.hiw-step-row:nth-child(3) .hiw-step-connector__num { background: var(--success); box-shadow: 0 4px 16px rgba(74,167,127,.3); }
.hiw-step-row:nth-child(4) .hiw-step-connector__num { background: #6366f1;        box-shadow: 0 4px 16px rgba(99,102,241,.3); }
.hiw-step-connector::before { content: ''; position: absolute; top: 0; bottom: 0; left: 50%; transform: translateX(-50%); width: 2px; background: linear-gradient(to bottom, var(--warm-100) 0%, var(--rose-lighter) 50%, var(--warm-100) 100%); z-index: 0; }
.hiw-steps__grid > .hiw-step-row:last-child .hiw-step-connector::before { height: 50%; bottom: auto; }
.hiw-step-body { padding: 40px; }
.hiw-step-body__tag { display: inline-flex; align-items: center; gap: 6px; font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--rose); background: var(--rose-bg); padding: 5px 12px; border-radius: var(--radius-pill); margin-bottom: 16px; }
.hiw-step-row:nth-child(2) .hiw-step-body__tag { color: #a07830; background: #fef8e6; }
.hiw-step-row:nth-child(3) .hiw-step-body__tag { color: #2d7a55; background: #f0faf5; }
.hiw-step-row:nth-child(4) .hiw-step-body__tag { color: #4f46e5; background: #eef2ff; }
.hiw-step-body__title { font-family: var(--font-display); font-size: clamp(1.6rem, 2.5vw, 2rem); font-weight: 400; color: var(--charcoal); margin-bottom: 14px; line-height: 1.2; }
.hiw-step-body__desc  { font-size: .95rem; color: var(--warm-500); line-height: 1.75; margin-bottom: 24px; }
.hiw-step-body__bullets { display: flex; flex-direction: column; gap: 10px; }
.hiw-step-body__bullet { display: flex; align-items: flex-start; gap: 10px; font-size: .88rem; color: var(--warm-600); line-height: 1.5; }
.hiw-step-body__bullet-icon { width: 20px; height: 20px; border-radius: 50%; background: var(--rose-bg); color: var(--rose); display: flex; align-items: center; justify-content: center; font-size: .65rem; flex-shrink: 0; margin-top: 1px; }
.hiw-step-row:nth-child(2) .hiw-step-body__bullet-icon { background: #fef8e6; color: #a07830; }
.hiw-step-row:nth-child(3) .hiw-step-body__bullet-icon { background: #f0faf5; color: #2d7a55; }
.hiw-step-row:nth-child(4) .hiw-step-body__bullet-icon { background: #eef2ff; color: #4f46e5; }

/* Step mock-ups */
.hiw-mock-browse { width: 100%; max-width: 320px; margin: 0 auto; }
.hiw-mock-browse__search { display: flex; align-items: center; gap: 10px; background: var(--cream); border: 1.5px solid var(--warm-200); border-radius: var(--radius-pill); padding: 10px 16px; margin-bottom: 20px; font-size: .82rem; color: var(--warm-400); }
.hiw-mock-browse__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.hiw-mock-card { background: var(--cream); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-xs); }
.hiw-mock-card__img   { width: 100%; height: 80px; object-fit: cover; background: var(--warm-100); }
.hiw-mock-card__body  { padding: 8px 10px; }
.hiw-mock-card__name  { font-size: .7rem; font-weight: 600; color: var(--charcoal); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hiw-mock-card__price { font-size: .68rem; color: var(--rose); font-weight: 600; }
.hiw-mock-card.selected { border: 2px solid var(--rose); }
.hiw-mock-date { width: 100%; max-width: 300px; margin: 0 auto; }
.hiw-mock-date__pin   { display: flex; align-items: center; gap: 8px; background: var(--rose-bg); border: 1.5px solid var(--rose-lighter); border-radius: var(--radius); padding: 10px 14px; font-size: .8rem; color: var(--rose-dark); font-weight: 500; margin-bottom: 14px; }
.hiw-mock-date__label { font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 10px; }
.hiw-mock-slots { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.hiw-mock-slot { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border: 1.5px solid var(--warm-100); border-radius: var(--radius); font-size: .78rem; background: var(--cream); cursor: pointer; transition: all .2s; }
.hiw-mock-slot.active { border-color: var(--rose); background: var(--rose-bg); color: var(--rose-dark); font-weight: 600; }
.hiw-mock-slot__tag { font-size: .65rem; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--rose); color: #fff; font-weight: 600; }
.hiw-mock-pay { width: 100%; max-width: 300px; margin: 0 auto; }
.hiw-mock-pay__methods { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 16px; }
.hiw-mock-pay__method { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 14px 10px; border: 1.5px solid var(--warm-100); border-radius: var(--radius); font-size: .72rem; color: var(--warm-500); background: var(--cream); cursor: pointer; transition: all .2s; }
.hiw-mock-pay__method i { font-size: 1.2rem; color: var(--warm-400); }
.hiw-mock-pay__method.active { border-color: var(--success); background: #f0faf5; color: #2d7a55; }
.hiw-mock-pay__method.active i { color: var(--success); }
.hiw-mock-pay__total { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: var(--charcoal); border-radius: var(--radius); color: #fff; }
.hiw-mock-pay__total-label { font-size: .78rem; color: rgba(255,255,255,.6); }
.hiw-mock-pay__total-val   { font-family: var(--font-display); font-size: 1.3rem; }
.hiw-mock-secure { display: flex; align-items: center; justify-content: center; gap: 6px; font-size: .72rem; color: var(--warm-400); margin-top: 12px; }
.hiw-mock-delivery { width: 100%; max-width: 300px; margin: 0 auto; }
.hiw-mock-progress { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; position: relative; }
.hiw-mock-progress::before { content: ''; position: absolute; top: 20px; left: 20px; right: 20px; height: 2px; background: var(--warm-100); z-index: 0; }
.hiw-mock-progress__fill { position: absolute; top: 20px; left: 20px; width: 75%; height: 2px; background: linear-gradient(to right, var(--rose), var(--gold)); z-index: 1; }
.hiw-mock-prog-step { display: flex; flex-direction: column; align-items: center; gap: 6px; z-index: 2; }
.hiw-mock-prog-dot { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .8rem; background: var(--white); border: 2px solid var(--warm-100); color: var(--warm-300); }
.hiw-mock-prog-dot.done   { background: var(--rose); border-color: var(--rose); color: #fff; }
.hiw-mock-prog-dot.active { background: var(--gold); border-color: var(--gold); color: #fff; box-shadow: 0 0 0 4px rgba(180,140,80,.2); }
.hiw-mock-prog-label { font-size: .6rem; color: var(--warm-400); text-align: center; max-width: 44px; line-height: 1.3; }
.hiw-mock-prog-step:nth-child(-n+3) .hiw-mock-prog-label { color: var(--rose-dark); font-weight: 600; }
.hiw-mock-photo-proof { display: flex; align-items: center; gap: 12px; padding: 14px; background: #f0faf5; border: 1px solid #a7e0c4; border-radius: var(--radius); }
.hiw-mock-photo-proof__thumb { width: 52px; height: 52px; border-radius: 8px; background: linear-gradient(135deg, var(--rose-bg), var(--cream)); display: flex; align-items: center; justify-content: center; color: var(--rose); font-size: 1.3rem; flex-shrink: 0; }
.hiw-mock-photo-proof__title { font-size: .82rem; font-weight: 600; color: #2d7a55; margin-bottom: 2px; }
.hiw-mock-photo-proof__sub   { font-size: .72rem; color: #4a9a6f; }

/* Trust Strip */
.hiw-trust { background: var(--charcoal); padding: 64px 0; }
.hiw-trust__grid { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); overflow: hidden; }
.hiw-trust__item { padding: 36px 28px; text-align: center; border-right: 1px solid rgba(255,255,255,.08); }
.hiw-trust__item:last-child { border-right: none; }
.hiw-trust__icon  { font-size: 1.8rem; color: var(--rose); margin-bottom: 14px; display: block; }
.hiw-trust__val   { font-family: var(--font-display); font-size: 2.2rem; font-weight: 400; color: #fff; line-height: 1; margin-bottom: 6px; }
.hiw-trust__label { font-size: .8rem; color: rgba(255,255,255,.5); letter-spacing: .04em; line-height: 1.5; }

/* Delivery Types */
.hiw-delivery { background: var(--white); padding: var(--section-v) 0; }
.hiw-delivery__header { text-align: center; margin-bottom: 56px; }
.hiw-delivery__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.hiw-dtype { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: box-shadow .25s, transform .2s; }
.hiw-dtype:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.hiw-dtype__head { padding: 36px 32px 28px; position: relative; overflow: hidden; }
.hiw-dtype--sameday   .hiw-dtype__head { background: linear-gradient(135deg, #1a0a0e 0%, #2d1520 100%); }
.hiw-dtype--midnight  .hiw-dtype__head { background: linear-gradient(135deg, #0D0B14 0%, #1E1428 100%); }
.hiw-dtype--scheduled .hiw-dtype__head { background: linear-gradient(135deg, #0a1a14 0%, #152d20 100%); }
.hiw-dtype__glow { position: absolute; width: 180px; height: 180px; border-radius: 50%; top: -60px; right: -40px; pointer-events: none; opacity: .35; }
.hiw-dtype--sameday   .hiw-dtype__glow { background: radial-gradient(circle, var(--rose), transparent 70%); }
.hiw-dtype--midnight  .hiw-dtype__glow { background: radial-gradient(circle, #7B6FA0, transparent 70%); }
.hiw-dtype--scheduled .hiw-dtype__glow { background: radial-gradient(circle, var(--success), transparent 70%); }
.hiw-dtype__icon    { font-size: 2.2rem; margin-bottom: 16px; display: block; position: relative; z-index: 1; }
.hiw-dtype--sameday   .hiw-dtype__icon { color: var(--rose); }
.hiw-dtype--midnight  .hiw-dtype__icon { color: #B8A8D4; }
.hiw-dtype--scheduled .hiw-dtype__icon { color: var(--success); }
.hiw-dtype__name    { font-family: var(--font-display); font-size: 1.5rem; font-weight: 400; color: #fff; margin-bottom: 6px; position: relative; z-index: 1; }
.hiw-dtype__tagline { font-size: .78rem; color: rgba(255,255,255,.5); position: relative; z-index: 1; }
.hiw-dtype__body   { background: var(--cream); padding: 28px 32px; }
.hiw-dtype__detail { display: flex; align-items: flex-start; gap: 10px; font-size: .85rem; color: var(--warm-600); margin-bottom: 12px; line-height: 1.5; }
.hiw-dtype__detail i { color: var(--rose); font-size: .8rem; margin-top: 3px; flex-shrink: 0; }
.hiw-dtype--midnight  .hiw-dtype__detail i { color: #7B6FA0; }
.hiw-dtype--scheduled .hiw-dtype__detail i { color: var(--success); }
.hiw-dtype__cta { display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; padding: 11px 22px; border-radius: var(--radius-pill); font-size: .85rem; font-weight: 600; text-decoration: none; transition: all .2s; }
.hiw-dtype--sameday   .hiw-dtype__cta { background: var(--rose);    color: #fff; }
.hiw-dtype--midnight  .hiw-dtype__cta { background: #7B6FA0;        color: #fff; }
.hiw-dtype--scheduled .hiw-dtype__cta { background: var(--success); color: #fff; }
.hiw-dtype__cta:hover { opacity: .88; transform: translateY(-1px); }

/* FAQ */
.hiw-faq { background: var(--ivory); padding: var(--section-v) 0; }
.hiw-faq__header { text-align: center; margin-bottom: 48px; }
.hiw-faq__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 900px; margin: 0 auto; }
.hiw-faq-card { background: var(--white); border-radius: var(--radius-lg); padding: 28px; box-shadow: var(--shadow-sm); border-left: 3px solid var(--rose-lighter); transition: box-shadow .2s, border-color .2s; }
.hiw-faq-card:hover { box-shadow: var(--shadow-md); border-color: var(--rose); }
.hiw-faq-card__q { font-size: .95rem; font-weight: 600; color: var(--charcoal); margin-bottom: 10px; display: flex; align-items: flex-start; gap: 10px; }
.hiw-faq-card__q i { color: var(--rose); flex-shrink: 0; margin-top: 2px; }
.hiw-faq-card__a { font-size: .875rem; color: var(--warm-500); line-height: 1.7; }

/* Final CTA */
.hiw-cta { background: linear-gradient(135deg, var(--charcoal) 0%, #3a2028 100%); padding: 100px 0; text-align: center; position: relative; overflow: hidden; }
.hiw-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 50% 60% at 50% 50%, rgba(180,100,120,.2) 0%, transparent 70%); pointer-events: none; }
.hiw-cta__title { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); font-weight: 400; color: #fff; margin-bottom: 16px; position: relative; z-index: 1; }
.hiw-cta__title em { font-style: italic; color: var(--rose); }
.hiw-cta__sub { font-size: .95rem; color: rgba(255,255,255,.55); margin-bottom: 40px; position: relative; z-index: 1; }
.hiw-cta__actions { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; position: relative; z-index: 1; }
.hiw-cta__btn { display: inline-flex; align-items: center; gap: 10px; padding: 15px 34px; border-radius: var(--radius-pill); font-size: .95rem; font-weight: 600; text-decoration: none; transition: all .2s; }
.hiw-cta__btn.primary   { background: var(--rose); color: #fff; }
.hiw-cta__btn.primary:hover   { background: var(--rose-dark); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(180,100,120,.4); }
.hiw-cta__btn.secondary { background: rgba(255,255,255,.1); color: #fff; border: 1px solid rgba(255,255,255,.2); }
.hiw-cta__btn.secondary:hover { background: rgba(255,255,255,.18); transform: translateY(-2px); }


/* ═══════════════════════════════════════════════════════════════
   PAYMENT FAILED PAGE
   ═══════════════════════════════════════════════════════════════ */
.payment-failed { min-height: calc(100vh - var(--header-h)); padding: 80px 20px; background: linear-gradient(135deg, var(--ivory) 0%, var(--white) 100%); margin-top: var(--header-h); }
.payment-failed__content { max-width: 600px; margin: 0 auto; text-align: center; }
.failed-animation { margin-bottom: 32px; }
.failed-icon { width: 120px; height: 120px; margin: 0 auto; background: linear-gradient(135deg, #ff6b6b, #ee5a6f); border-radius: 50%; display: flex; align-items: center; justify-content: center; animation: shake 0.5s ease-in-out; }
.failed-icon i { font-size: 4rem; color: var(--white); }
.payment-failed__title    { font-family: var(--font-display); font-size: 2.5rem; font-weight: 500; color: var(--charcoal); margin-bottom: 12px; }
.payment-failed__subtitle { font-size: 1.05rem; color: var(--warm-400); line-height: 1.7; margin-bottom: 32px; }
.error-details { padding: 16px 20px; background: rgba(238,90,111,0.1); border: 1px solid rgba(238,90,111,0.3); border-radius: var(--radius); display: inline-flex; align-items: center; gap: 12px; font-size: 0.9rem; color: #c53030; margin-bottom: 32px; }
.error-details i { font-size: 1.2rem; }
.order-info-card { padding: 24px; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); margin-bottom: 32px; }
.order-info-card__row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; font-size: 0.95rem; color: var(--warm-500); }
.order-info-card__row:not(:last-child) { border-bottom: 1px solid var(--cream); }
.order-info-card__row strong { color: var(--charcoal); }
.failed-reasons { padding: 28px; background: var(--ivory); border-radius: var(--radius-lg); text-align: left; margin-bottom: 32px; }
.failed-reasons__title { font-size: 1.05rem; font-weight: 600; color: var(--charcoal); margin-bottom: 16px; }
.failed-reasons__list { list-style: none; padding: 0; }
.failed-reasons__list li { display: flex; align-items: center; gap: 8px; padding: 8px 0; font-size: 0.9rem; color: var(--warm-500); }
.failed-reasons__list i { color: var(--warm-300); font-size: 1.5rem; }
.payment-failed__actions { display: flex; gap: 12px; justify-content: center; margin-bottom: 32px; }
.payment-support { padding-top: 32px; border-top: 1px solid var(--sand); }
.payment-support p { font-size: 0.9rem; color: var(--warm-400); margin-bottom: 12px; }
.payment-support a { display: inline-flex; align-items: center; gap: 8px; font-size: 1rem; font-weight: 600; color: var(--rose); text-decoration: none; }
.payment-support a:hover { text-decoration: underline; }


/* ═══════════════════════════════════════════════════════════════
   PAYMENT INITIATE PAGE
   ═══════════════════════════════════════════════════════════════ */
.pay { background: var(--ivory); min-height: calc(100vh - var(--header-h) - var(--promise-h)); padding: 60px 0 80px; }
.pay__layout { display: grid; grid-template-columns: 1fr 380px; gap: 32px; align-items: start; }
.pay__header { margin-bottom: 28px; }
.pay__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--rose); margin-bottom: 10px; }
.pay__title { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 400; color: var(--charcoal); line-height: 1.2; margin-bottom: 6px; }
.pay__sub   { font-size: .9rem; color: var(--warm-500); }
.pay-card { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); overflow: hidden; }
.pay-card__head { padding: 24px 32px; border-bottom: 1px solid var(--warm-100); display: flex; align-items: center; gap: 14px; }
.pay-card__head-icon  { width: 44px; height: 44px; border-radius: var(--radius); background: var(--rose-bg); display: flex; align-items: center; justify-content: center; color: var(--rose); font-size: 1.1rem; flex-shrink: 0; }
.pay-card__head-title { font-size: 1rem; font-weight: 600; color: var(--charcoal); }
.pay-card__head-sub   { font-size: .78rem; color: var(--warm-400); margin-top: 2px; }
.pay-card__body { padding: 32px; }
.pay-methods { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 28px; }
.pay-method { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 2px solid var(--warm-100); border-radius: var(--radius); cursor: pointer; transition: all .2s; background: var(--cream); }
.pay-method:hover  { border-color: var(--rose-lighter); background: var(--rose-bg); }
.pay-method.active { border-color: var(--rose);          background: var(--rose-bg); }
.pay-method__icon  { width: 36px; height: 36px; border-radius: 8px; background: var(--white); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; box-shadow: var(--shadow-xs); }
.pay-method.active .pay-method__icon { background: var(--rose-bg); color: var(--rose); }
.pay-method__label { font-size: .88rem; font-weight: 500; color: var(--charcoal); }
.pay-method__sub   { font-size: .72rem; color: var(--warm-400); margin-top: 1px; }
.pay-upi { margin-bottom: 24px; }
.pay-upi__label  { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-500); margin-bottom: 8px; display: block; }
.pay-upi__wrap   { display: flex; gap: 10px; }
.pay-upi__input  { flex: 1; height: 50px; padding: 0 16px; border: 1.5px solid var(--warm-200); border-radius: var(--radius); font-family: var(--font-body); font-size: .95rem; color: var(--charcoal); background: var(--cream); outline: none; transition: border-color .2s, box-shadow .2s, background .2s; }
.pay-upi__input:focus { border-color: var(--rose); background: var(--white); box-shadow: 0 0 0 3px rgba(180,100,120,.1); }
.pay-upi__verify { height: 50px; padding: 0 20px; background: var(--rose); color: #fff; border: none; border-radius: var(--radius); font-family: var(--font-body); font-size: .88rem; font-weight: 600; cursor: pointer; transition: background .2s; white-space: nowrap; }
.pay-upi__verify:hover { background: var(--rose-dark); }
.pay-upi__apps { display: flex; gap: 10px; margin-top: 12px; }
.pay-upi__app  { display: flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--warm-100); border-radius: var(--radius-pill); font-size: .75rem; color: var(--warm-500); background: var(--cream); cursor: pointer; transition: all .2s; }
.pay-upi__app:hover { border-color: var(--rose-lighter); color: var(--rose); }
.pay-amount-row { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; background: var(--charcoal); border-radius: var(--radius-lg); margin-bottom: 16px; }
.pay-amount-row__label { font-size: .78rem; color: rgba(255,255,255,.55); letter-spacing: .04em; margin-bottom: 4px; }
.pay-amount-row__val   { font-family: var(--font-display); font-size: 1.8rem; color: #fff; line-height: 1; }
.pay-now-btn { height: 54px; padding: 0 36px; background: var(--rose); color: #fff; border: none; border-radius: var(--radius-pill); font-family: var(--font-body); font-size: 1rem; font-weight: 700; cursor: pointer; transition: background .2s, transform .15s, box-shadow .2s; display: flex; align-items: center; gap: 10px; white-space: nowrap; }
.pay-now-btn:hover    { background: var(--rose-dark); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(180,100,120,.4); }
.pay-now-btn:disabled { background: var(--warm-300); cursor: not-allowed; transform: none; box-shadow: none; }
.pay-secure { display: flex; align-items: center; justify-content: center; gap: 20px; padding: 14px 0 0; flex-wrap: wrap; }
.pay-secure__item { display: flex; align-items: center; gap: 6px; font-size: .75rem; color: var(--warm-400); }
.pay-secure__item i { color: var(--success); }
.pay-sidebar { display: flex; flex-direction: column; gap: 16px; }
.pay-scard { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); overflow: hidden; }
.pay-scard__head { padding: 16px 22px; background: var(--charcoal); display: flex; align-items: center; gap: 10px; }
.pay-scard__head i { color: var(--rose); }
.pay-scard__head-title { font-size: .82rem; font-weight: 600; color: rgba(255,255,255,.9); letter-spacing: .04em; }
.pay-scard__body { padding: 18px 22px; }
.pay-order-item { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--warm-100); }
.pay-order-item:last-child { border-bottom: none; }
.pay-order-item__img    { width: 44px; height: 44px; border-radius: var(--radius); object-fit: cover; background: var(--cream); flex-shrink: 0; }
.pay-order-item__img-ph { width: 44px; height: 44px; border-radius: var(--radius); background: var(--cream); display: flex; align-items: center; justify-content: center; color: var(--warm-300); flex-shrink: 0; }
.pay-order-item__name  { font-size: .85rem; font-weight: 500; color: var(--charcoal); flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pay-order-item__qty   { font-size: .75rem; color: var(--warm-400); margin-top: 2px; }
.pay-order-item__price { font-size: .88rem; font-weight: 600; color: var(--charcoal); white-space: nowrap; }
.pay-total-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: .88rem; border-bottom: 1px solid var(--warm-100); }
.pay-total-row:last-of-type { border-bottom: none; }
.pay-total-row__label { color: var(--warm-400); }
.pay-total-row__val   { font-weight: 500; color: var(--charcoal); }
.pay-total-row.discount .pay-total-row__val { color: var(--success); }
.pay-grand-total { display: flex; justify-content: space-between; align-items: center; padding: 14px 0 0; margin-top: 8px; border-top: 2px solid var(--charcoal); font-size: 1rem; font-weight: 700; color: var(--charcoal); }
.pay-deliv-row { display: flex; align-items: flex-start; gap: 10px; padding: 9px 0; font-size: .85rem; border-bottom: 1px solid var(--warm-100); }
.pay-deliv-row:last-child { border-bottom: none; }
.pay-deliv-row i { color: var(--rose); font-size: .85rem; margin-top: 2px; flex-shrink: 0; }
.pay-deliv-row__label { font-size: .72rem; color: var(--warm-400); margin-bottom: 2px; }
.pay-deliv-row__val   { font-weight: 500; color: var(--charcoal); }


/* ═══════════════════════════════════════════════════════════════
   PAYMENT PROCESSING PAGE
   ═══════════════════════════════════════════════════════════════ */
.payment-processing { min-height: calc(100vh - var(--header-h)); display: flex; align-items: center; justify-content: center; padding: 80px 20px; background: linear-gradient(135deg, var(--ivory) 0%, var(--white) 100%); margin-top: var(--header-h); }
.payment-processing__content { text-align: center; max-width: 500px; }
.payment-loader { margin-bottom: 40px; }
.payment-loader__spinner { position: relative; width: 120px; height: 120px; margin: 0 auto; }
.spinner-ring { position: absolute; inset: 0; border: 3px solid transparent; border-top-color: var(--rose); border-radius: 50%; animation: spin 1.2s cubic-bezier(0.5,0,0.5,1) infinite; }
.spinner-ring:nth-child(1) { animation-delay: -0.45s; }
.spinner-ring:nth-child(2) { animation-delay: -0.3s;  border-top-color: var(--gold); }
.spinner-ring:nth-child(3) { animation-delay: -0.15s; border-top-color: var(--success); }
.payment-loader__spinner i { position: absolute; top: 50%; left: 50%; font-size: 2.5rem; color: var(--rose); animation: pulseSpinner 2s ease-in-out infinite; }
.payment-processing__title { font-family: var(--font-display); font-size: 2rem; font-weight: 500; color: var(--charcoal); margin-bottom: 16px; }
.payment-processing__text  { font-size: 1rem; color: var(--warm-400); line-height: 1.7; margin-bottom: 32px; }
.payment-security { display: inline-flex; align-items: center; gap: 8px; padding: 12px 24px; background: rgba(90,154,110,0.1); border: 1px solid rgba(90,154,110,0.3); border-radius: var(--radius-pill); font-size: 0.85rem; color: var(--success); margin-bottom: 32px; }
.payment-security i { font-size: 1.2rem; }
.payment-order-summary { padding: 24px; background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); }
.payment-order-summary__row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; font-size: 0.95rem; color: var(--warm-500); }
.payment-order-summary__row:not(:last-child) { border-bottom: 1px solid var(--cream); }
.payment-order-summary__row strong { color: var(--charcoal); }


/* ═══════════════════════════════════════════════════════════════
   DUMMY PAYMENT GATEWAY
   ═══════════════════════════════════════════════════════════════ */
.pay-gateway { background: linear-gradient(180deg, #f5f0eb 0%, var(--ivory) 100%); min-height: calc(100vh - var(--header-h) - var(--promise-h)); padding: 40px 0 80px; margin-top: calc(var(--promise-h) + var(--header-h)); }

/* Header bar */
.pay-gw__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; padding: 16px 24px; background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.pay-gw__logo { display: flex; align-items: center; gap: 10px; font-size: 1rem; font-weight: 700; color: var(--charcoal); }
.pay-gw__logo i { font-size: 1.3rem; color: var(--success); }
.pay-gw__order-badge { font-size: 0.78rem; font-weight: 600; padding: 6px 14px; background: var(--rose-bg); color: var(--rose); border-radius: var(--radius-pill); letter-spacing: 0.03em; }

/* Layout */
.pay-gw__layout { display: grid; grid-template-columns: 1fr 380px; gap: 32px; align-items: start; }
.pay-gw__main { display: flex; flex-direction: column; gap: 20px; }

/* Amount banner */
.pay-gw__amount-banner { background: linear-gradient(135deg, var(--rose) 0%, #c97a89 60%, var(--gold) 100%); border-radius: var(--radius-lg); padding: 32px; text-align: center; color: #fff; box-shadow: 0 8px 32px rgba(180,100,120,0.25); }
.pay-gw__amount-label { font-size: 0.8rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.85; margin-bottom: 6px; }
.pay-gw__amount-value { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 400; line-height: 1.2; }

/* Methods section */
.pay-gw__methods { background: var(--white); border-radius: var(--radius-lg); padding: 28px; box-shadow: var(--shadow-sm); }
.pay-gw__section-title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--charcoal); margin-bottom: 18px; }
.pay-gw__method-grid { display: flex; flex-direction: column; gap: 10px; }

/* Individual method option */
.pay-gw__method { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border: 2px solid var(--sand); border-radius: var(--radius); cursor: pointer; transition: all 0.25s var(--ease); position: relative; background: var(--white); }
.pay-gw__method input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.pay-gw__method:hover { border-color: var(--warm-300); background: var(--cream); }
.pay-gw__method.active { border-color: var(--rose); background: rgba(180,100,120,0.04); box-shadow: 0 0 0 3px rgba(180,100,120,0.1); }
.pay-gw__method-icon { width: 44px; height: 44px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; background: var(--cream); color: var(--warm-500); transition: all 0.25s var(--ease); }
.pay-gw__method.active .pay-gw__method-icon { background: var(--rose-bg); color: var(--rose); }
.pay-gw__method-info { flex: 1; min-width: 0; }
.pay-gw__method-name { font-size: 0.92rem; font-weight: 600; color: var(--charcoal); }
.pay-gw__method-desc { font-size: 0.76rem; color: var(--warm-400); margin-top: 2px; }
.pay-gw__method-check { font-size: 1.2rem; color: var(--sand); transition: all 0.25s var(--ease); }
.pay-gw__method.active .pay-gw__method-check { color: var(--rose); }

/* Processing spinner */
.pay-gw__processing { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 40px 20px; text-align: center; }
.pay-gw__spinner { width: 48px; height: 48px; border: 3px solid var(--sand); border-top-color: var(--rose); border-radius: 50%; animation: spin 0.8s linear infinite; }
.pay-gw__processing-text { font-size: 1rem; font-weight: 600; color: var(--charcoal); }
.pay-gw__processing-sub  { font-size: 0.82rem; color: var(--warm-400); }

/* Actions area */
.pay-gw__actions { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.pay-gw__pay-btn { width: 100%; padding: 18px 32px; font-size: 1.05rem; font-weight: 700; color: #fff; background: linear-gradient(135deg, var(--rose) 0%, #c97a89 100%); border: none; border-radius: var(--radius); cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 10px; transition: all 0.3s var(--ease); box-shadow: 0 4px 20px rgba(180,100,120,0.3); letter-spacing: 0.02em; }
.pay-gw__pay-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(180,100,120,0.4); }
.pay-gw__pay-btn:active { transform: translateY(0); }
.pay-gw__pay-btn:disabled { opacity: 0.7; cursor: not-allowed; transform: none; box-shadow: 0 4px 20px rgba(180,100,120,0.15); }
.pay-gw__cancel-link { font-size: 0.82rem; font-weight: 500; color: var(--warm-400); text-decoration: none; transition: color 0.2s var(--ease); }
.pay-gw__cancel-link:hover { color: var(--rose); text-decoration: underline; }

/* Trust badges */
.pay-gw__trust { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; padding: 16px; }
.pay-gw__trust-item { display: flex; align-items: center; gap: 6px; font-size: 0.74rem; font-weight: 500; color: var(--warm-400); }
.pay-gw__trust-item i { color: var(--success); font-size: 0.9rem; }

/* Sidebar cards */
.pay-gw__sidebar { display: flex; flex-direction: column; gap: 16px; }
.pay-gw__scard { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); overflow: hidden; }
.pay-gw__scard-head { display: flex; align-items: center; gap: 10px; padding: 16px 20px; border-bottom: 1px solid var(--warm-100); font-size: 0.9rem; font-weight: 600; color: var(--charcoal); }
.pay-gw__scard-head i { color: var(--rose); font-size: 1rem; }
.pay-gw__scard-body { padding: 16px 20px; }

/* Order items */
.pay-gw__item { display: flex; align-items: center; gap: 12px; padding: 10px 0; }
.pay-gw__item:not(:last-child) { border-bottom: 1px solid var(--cream); }
.pay-gw__item-img { width: 44px; height: 44px; border-radius: var(--radius); object-fit: cover; flex-shrink: 0; }
.pay-gw__item-img-ph { width: 44px; height: 44px; border-radius: var(--radius); background: var(--cream); display: flex; align-items: center; justify-content: center; color: var(--warm-300); font-size: 1rem; flex-shrink: 0; }
.pay-gw__item-info { flex: 1; min-width: 0; }
.pay-gw__item-name { font-size: 0.82rem; font-weight: 600; color: var(--charcoal); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pay-gw__item-qty  { font-size: 0.72rem; color: var(--warm-400); margin-top: 2px; }
.pay-gw__item-price { font-size: 0.85rem; font-weight: 600; color: var(--charcoal); flex-shrink: 0; }

/* Total rows */
.pay-gw__total-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: 0.85rem; color: var(--warm-500); }
.pay-gw__total-row:not(:last-child) { border-bottom: 1px solid var(--cream); }
.pay-gw__total-row--discount span:last-child { color: var(--success); font-weight: 600; }
.pay-gw__free { color: var(--success); font-weight: 600; }
.pay-gw__grand-total { display: flex; justify-content: space-between; align-items: center; padding: 14px 0 4px; margin-top: 8px; border-top: 2px solid var(--warm-100); font-size: 1.05rem; font-weight: 700; color: var(--charcoal); }

/* Delivery info rows */
.pay-gw__deliv-row { display: flex; align-items: flex-start; gap: 12px; padding: 8px 0; }
.pay-gw__deliv-row:not(:last-child) { border-bottom: 1px solid var(--cream); }
.pay-gw__deliv-row > i { flex-shrink: 0; width: 20px; text-align: center; color: var(--rose); margin-top: 3px; }
.pay-gw__deliv-label { font-size: 0.72rem; color: var(--warm-400); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.pay-gw__deliv-val   { font-size: 0.85rem; font-weight: 500; color: var(--charcoal); margin-top: 2px; }

/* ── Payment gateway responsive ─────────────────────── */
@media (max-width: 900px) {
    .pay-gateway { margin-top: var(--header-h); padding: 32px 0 70px; }
    .pay-gw__layout { grid-template-columns: 1fr; gap: 24px; }
    .pay-gw__sidebar { order: -1; }
}
@media (max-width: 600px) {
    .pay-gateway { padding: 24px 0 60px; }
    .pay-gw__header { flex-direction: column; gap: 10px; text-align: center; padding: 14px 16px; }
    .pay-gw__amount-banner { padding: 24px 16px; }
    .pay-gw__amount-value { font-size: 2rem; }
    .pay-gw__methods { padding: 20px 16px; }
    .pay-gw__method { padding: 12px 14px; gap: 10px; }
    .pay-gw__method-icon { width: 36px; height: 36px; font-size: 0.95rem; }
    .pay-gw__method-name { font-size: 0.84rem; }
    .pay-gw__pay-btn { padding: 16px 24px; font-size: 0.95rem; }
    .pay-gw__trust { gap: 14px; }
    .pay-gw__trust-item { font-size: 0.68rem; }
}
@media (max-width: 374px) {
    .pay-gw__method { padding: 10px 12px; gap: 8px; }
    .pay-gw__method-icon { width: 32px; height: 32px; font-size: 0.85rem; }
    .pay-gw__method-name { font-size: 0.78rem; }
    .pay-gw__method-desc { font-size: 0.68rem; }
    .pay-gw__pay-btn { padding: 14px 20px; font-size: 0.88rem; }
    .pay-gw__amount-banner { padding: 20px 12px; }
    .pay-gw__scard-body { padding: 12px 14px; }
    .pay-gw__item-img, .pay-gw__item-img-ph { width: 36px; height: 36px; }
}


/* ═══════════════════════════════════════════════════════════════
   CATEGORY HERO + FILTERS + RELATED
   ═══════════════════════════════════════════════════════════════ */
.category-hero { position: relative; min-height: 480px; display: flex; align-items: center; overflow: hidden; margin-top: calc(var(--promise-h) + var(--header-h)); }
.category-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; }
.category-hero__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(26,23,20,0.85) 0%, rgba(26,23,20,0.6) 50%, rgba(26,23,20,0.75) 100%); }
.category-hero__overlay { position: absolute; inset: 0; background: radial-gradient(ellipse at center, transparent 0%, rgba(26,23,20,0.3) 100%); z-index: 1; }
.category-hero__content { position: relative; z-index: 2; padding: 80px 0; }
.category-hero__title { font-family: var(--font-display); font-size: clamp(2.8rem, 5vw, 4.5rem); font-weight: 400; color: var(--white); line-height: 1.1; letter-spacing: -0.02em; margin: 24px 0 20px; }
.category-hero__desc  { font-size: 1.15rem; color: rgba(255,255,255,0.85); line-height: 1.7; max-width: 600px; margin-bottom: 32px; }
.category-hero__stats { display: flex; gap: 48px; align-items: center; }
.category-stat { display: flex; flex-direction: column; }
.category-stat__number { font-family: var(--font-display); font-size: 2.2rem; font-weight: 400; color: var(--white); line-height: 1; margin-bottom: 6px; }
.category-stat__label  { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.6); }
.category-quick-filters { padding: 32px 0; background: var(--white); border-bottom: 1px solid var(--sand); }
.quick-filters { display: flex; align-items: center; gap: 20px; }
.quick-filters__label { font-size: 0.85rem; font-weight: 600; color: var(--warm-400); display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.quick-filters__label i { color: var(--rose); }
.quick-filters__chips { display: flex; gap: 10px; flex-wrap: wrap; flex: 1; }
.quick-filter-chip { padding: 9px 18px; background: var(--ivory); border: 1.5px solid var(--sand); border-radius: var(--radius-pill); font-size: 0.78rem; font-weight: 600; color: var(--warm-500); display: flex; align-items: center; gap: 6px; transition: all 0.3s var(--ease); white-space: nowrap; }
.quick-filter-chip:hover  { border-color: var(--rose-lighter); background: var(--white); color: var(--charcoal); transform: translateY(-2px); }
.quick-filter-chip.active { background: var(--rose); color: var(--white); border-color: var(--rose); box-shadow: var(--shadow-glow); }
.quick-filter-chip i { font-size: 0.85rem; }
.filter-sidebar-header { display: none; justify-content: space-between; align-items: center; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--sand); }
.filter-sidebar-title  { font-family: var(--font-display); font-size: 1.3rem; font-weight: 500; color: var(--charcoal); }
.filter-sidebar-close  { width: 36px; height: 36px; background: var(--cream); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.9rem; color: var(--warm-400); transition: all 0.2s; }
.filter-sidebar-close:hover { background: var(--rose); color: var(--white); }
.featured-occasion__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.featured-occasion__visual { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); }
.featured-occasion__visual img { width: 100%; height: auto; object-fit: cover; transition: transform 0.5s var(--ease); }
.featured-occasion__visual:hover img { transform: scale(1.05); }
.featured-occasion__desc { font-size: 1.05rem; color: var(--warm-400); line-height: 1.7; margin: 20px 0 32px; max-width: 500px; }
.related-categories { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 48px; }
.related-category-card { position: relative; aspect-ratio: 3/4; border-radius: var(--radius-lg); overflow: hidden; transition: all 0.4s var(--ease); }
.related-category-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.related-category-card__img { position: absolute; inset: 0; }
.related-category-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease); }
.related-category-card:hover .related-category-card__img img { transform: scale(1.08); }
.related-category-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(26,23,20,0.85) 0%, rgba(26,23,20,0.1) 60%, transparent 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 24px 20px; z-index: 2; }
.related-category-card__name  { font-family: var(--font-display); font-size: 1.25rem; font-weight: 500; color: var(--white); line-height: 1.2; margin-bottom: 6px; }
.related-category-card__count { font-size: 0.7rem; color: rgba(255,255,255,0.7); margin-bottom: 12px; }
.related-category-card__arrow { position: absolute; top: 16px; right: 16px; width: 36px; height: 36px; background: rgba(255,255,255,0.15); backdrop-filter: blur(8px); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--white); font-size: 0.9rem; opacity: 0; transform: translateY(6px); transition: all 0.3s; }
.related-category-card:hover .related-category-card__arrow { opacity: 1; transform: translateY(0); }


/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — PART 2 CONSOLIDATED
   ═══════════════════════════════════════════════════════════════ */

/* ── 1024px ──────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    /* Login */
    .login-hero  { display: none; }
    body.login-page { justify-content: center; }
    .login-panel { width: 100%; max-width: 480px; min-height: auto; padding: 40px 32px; margin: 20px; }
    /* Orders */
    .ord-show__layout  { grid-template-columns: 1fr; }
    .ord-quickinfo { padding: 14px 20px; gap: 0; }
    .ord-quickinfo__sep { margin: 0 14px; height: 28px; }
    .ord-quickinfo__icon { width: 30px; height: 30px; font-size: 0.78rem; }
    .ord-quickinfo__val { font-size: 0.82rem; }
    /* Track result */
    .trkr__layout  { grid-template-columns: 1fr; }
    .trkr-sidebar  { flex-direction: row; flex-wrap: wrap; }
    .trkr-scard    { flex: 1; min-width: 260px; }
    /* Pay */
    .pay__layout  { grid-template-columns: 1fr; }
    .pay-sidebar  { flex-direction: row; flex-wrap: wrap; }
    .pay-scard    { flex: 1; min-width: 260px; }
    /* HIW */
    .hiw-step-row { grid-template-columns: 1fr; margin-bottom: 48px; }
    .hiw-step-row:nth-child(even) .hiw-step-visual,
    .hiw-step-row:nth-child(even) .hiw-step-connector,
    .hiw-step-row:nth-child(even) .hiw-step-body { order: unset; }
    .hiw-step-connector { min-height: 60px; flex-direction: row; padding: 12px 0; }
    .hiw-step-connector::before { top: 50%; left: 0; right: 0; bottom: auto; width: 100%; height: 2px; transform: translateY(-50%); }
    .hiw-step-body   { padding: 28px 0; }
    .hiw-step-visual { min-height: 260px; }
    .hiw-trust__grid { grid-template-columns: repeat(2, 1fr); }
    .hiw-trust__item { border-bottom: 1px solid rgba(255,255,255,.08); }
    .hiw-trust__item:nth-child(2) { border-right: none; }
    .hiw-trust__item:nth-child(3),
    .hiw-trust__item:nth-child(4) { border-bottom: none; }
    .hiw-delivery__grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
    .hiw-faq__grid  { grid-template-columns: 1fr; }
}

/* ── 960px ───────────────────────────────────────────────────── */
@media (max-width: 960px) {
    .trk-hero__inner  { grid-template-columns: 1fr; gap: 48px; }
    .trk-copy__sub    { max-width: 100%; }
    .trk-steps__grid  { grid-template-columns: repeat(2, 1fr); }
    .trk-steps__grid::before { display: none; }
}

/* ── 768px ───────────────────────────────────────────────────── */
@media (max-width: 768px) {
    /* Footer */
    .footer__grid  { grid-template-columns: 1fr 1fr; gap: 28px; }
    .footer__grid > div { text-align: center; }
    .footer__brand { grid-column: 1 / -1; }
    .footer__desc  { margin-left: auto; margin-right: auto; }
    .footer__social { justify-content: center; }
    .footer__heading { text-align: center; }
    .footer__links { display: flex; flex-wrap: wrap; justify-content: center; gap: 4px 8px; list-style: none; padding: 0; }
    .footer__links li { margin-bottom: 0; display: flex; align-items: center; gap: 6px; }
    .footer__links li + li::before { content: '\b7'; color: var(--warm-600); font-size: 0.9em; }
    /* Orders list */
    .ord-page { padding-top: calc(var(--header-h) + 32px); }
    .ord-page__header  { flex-direction: column; align-items: flex-start; }
    .ord-card__head    { flex-direction: column; align-items: flex-start; gap: 12px; }
    .ord-card__delivery { flex-direction: column; gap: 10px; }
    .ord-card__foot    { flex-direction: column; align-items: flex-start; }
    /* Order detail */
    .ord-show { padding-top: calc(var(--header-h) + 24px); }
    .ord-show__head { flex-direction: column; padding: 20px; }
    .ord-timeline   { padding: 20px 16px; }
    .ord-quickinfo { padding: 12px 16px; flex-wrap: wrap; row-gap: 8px; }
    .ord-quickinfo__sep { height: 24px; margin: 0 12px; }
    .ord-quickinfo__icon { width: 28px; height: 28px; font-size: 0.72rem; }
    .ord-quickinfo__val { font-size: 0.78rem; max-width: 140px; }
    .ord-quickinfo__label { font-size: 0.6rem; }
    /* Layout — generic sidebar collapses */
    .orders-layout, .order-detail__layout { grid-template-columns: 1fr !important; }
    .order-detail__sidebar { position: static !important; order: -1; }
    .status-timeline { padding: 20px; }
    .timeline-step   { padding: 16px 16px 16px 20px; }
    /* Track */
    .track-layout  { grid-template-columns: 1fr !important; }
    .track-sidebar { position: static !important; order: -1; }
    /* Invoice */
    .invoice-wrap { padding: 20px 16px; }
    .invoice-addresses, .inv-addresses { grid-template-columns: 1fr !important; gap: 16px; }
    .invoice-header, .inv-header { flex-direction: column; gap: 16px; }
    .invoice-table th, .invoice-table td { padding: 10px 8px; font-size: 0.78rem; }
    /* Payment */
    .payment-layout   { grid-template-columns: 1fr !important; }
    .payment-sidebar  { order: -1; }
    .payment-failed__title   { font-size: 2rem; }
    .payment-failed__actions { flex-direction: column; }
    .payment-failed__actions .btn { width: 100%; }
    /* Reviews, profile, reminders, orders */
    .review-layout  { grid-template-columns: 1fr !important; }
    .review-sidebar { position: static !important; order: -1; }
    .profile-layout { grid-template-columns: 1fr !important; }
    .reminders-stats      { grid-template-columns: repeat(2, 1fr); }
    .reminders-grid-list  { grid-template-columns: 1fr; }
    .reminder-filter-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .reminder-filter-tab  { white-space: nowrap; flex: 0 0 auto; }
    /* Same-day / featured / listing sidebars */
    .ft-layout, .sd-layout, .mn-layout, .oc-layout { grid-template-columns: 1fr !important; }
    .ft-sidebar, .sd-sidebar, .mn-sidebar, .oc-sidebar { position: static !important; }
    .ft-bar__inner    { flex-direction: column; align-items: flex-start; gap: 8px; }
    .sd-hero          { padding: 3rem 0 2rem; }
    .sd-hero__title   { font-size: clamp(1.8rem, 6vw, 2.6rem); }
    .sd-hero__countdown-timer { gap: 10px; }
    /* Same-day section (homepage) */
    .same-day { padding: var(--section-v) 0; }
    .same-day__left { padding: 0; }
    .same-day__title { font-size: clamp(1.8rem, 6vw, 2.4rem); }
}

/* ── 640px ───────────────────────────────────────────────────── */
@media (max-width: 640px) {
    /* HIW */
    .hiw-hero { padding: 72px 0 56px; }
    .hiw-trust__grid { grid-template-columns: repeat(2, 1fr); }
    /* Track search card */
    .trk-card__header { padding: 28px 24px 20px; }
    .trk-card__body   { padding: 28px 24px; }
    .trk-alt-links    { grid-template-columns: 1fr; }
    .trk-steps__grid  { grid-template-columns: 1fr 1fr; }
    /* Track result */
    .trkr { padding: 40px 0 60px; }
    .trkr-card__head  { flex-wrap: wrap; gap: 12px; }
    .trkr-card__head-eta { margin-left: 0; text-align: left; }
    .trkr-timeline, .trkr-photo, .trkr-items { padding-left: 20px; padding-right: 20px; }
    .trkr-sidebar { flex-direction: column; }
    /* Pay */
    .pay { padding: 40px 0 60px; }
    .pay-card__body   { padding: 20px; }
    .pay-methods      { grid-template-columns: 1fr; }
    .pay-amount-row   { flex-direction: column; gap: 16px; align-items: flex-start; }
    .pay-now-btn      { width: 100%; justify-content: center; }
    .pay-sidebar      { flex-direction: column; }
}

/* ── 480px ───────────────────────────────────────────────────── */
@media (max-width: 480px) {
    /* Section titles */
    .section-title, .section__title { font-size: clamp(1.6rem, 6vw, 2rem); }
    /* Header */
    .site-header { padding: 0 16px; }
    .header__logo-text { font-size: 1.1rem; }
    .header__actions { gap: 8px; }
    .header__icon-btn { width: 36px; height: 36px; font-size: 1rem; }
    .cart-badge { width: 16px; height: 16px; font-size: 0.55rem; top: 4px; right: 2px; }
    /* Mobile nav — full width on small screens */
    .mobile-nav { width: 100% !important; max-width: 100% !important; }
    /* Hero */
    .hero__text-pane  { padding: 24px 16px 28px; }
    .hero__heading    { font-size: clamp(1.3rem, 7vw, 2.4rem); text-align: center; }
    .hero__sub        { font-size: 0.92rem; }
    .hero__ctas       { gap: 10px; }
    .hero__ctas .btn  { font-size: 0.85rem; padding: 13px 20px; }
    .hero__date-btn   { flex: 1 1 calc(33.333% - 6px); min-width: 0; padding: 10px 8px; font-size: 0.7rem; }
    .hero__date-btn strong { font-size: 0.72rem; }
    .hero__pincode    { margin: 16px; width: calc(100% - 32px); }
    .hero__scene-pane { min-height: 50vw; }
    /* Occasion chips */
    .occasion-chips { grid-template-columns: repeat(3, 1fr); gap: 8px; }
    .occasion-chip  { padding: 18px 6px 14px; }
    .occasion-chip__emoji { font-size: 1.6rem; }
    .occasion-chip__label { font-size: 0.65rem; }
    /* Category grid */
    .cat-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .cat-card__name { font-size: 0.78rem; }
    .cat-card { min-height: 120px; }
    /* Product carousel */
    .products__scroll-wrap { margin: 0 -16px; padding: 0 16px; }
    .products__scroll-wrap::before,
    .products__scroll-wrap::after { width: 24px; }
    .p-card { width: 185px; }
    .p-card__body { padding: 12px; }
    .p-card__name { font-size: 0.85rem; min-height: 2.2em; }
    .p-card__price { font-size: 0.95rem; }
    /* Add-on grid */
    .addon-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .addon-card__body { padding: 10px; }
    .addon-card__name { font-size: 0.82rem; }
    .addon-card__add-btn { font-size: 0.78rem; padding: 6px 0; }
    .addon-card__minus, .addon-card__plus { width: 32px; height: 30px; font-size: 1rem; }
    .addon-card__count { height: 30px; font-size: 0.8rem; }
    /* Trust counters */
    .trust-counters { grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 28px 20px; }
    .trust-counter__num   { font-size: 2rem; }
    .trust-counter__label { font-size: 0.7rem; }
    /* Same-day */
    .same-day__card--1, .same-day__card--2 { width: 46%; }
    .same-day__countdown-timer { gap: 8px; }
    .same-day__countdown-unit  { font-size: 1.8rem; }
    .same-day__feature  { font-size: 0.78rem; }
    .same-day__features { gap: 8px; }
    /* Testimonials */
    .test-grid { grid-template-columns: 1fr; gap: 16px; }
    .test-card { padding: 24px 20px; }
    .test-card__text { font-size: 0.9rem; }
    /* Reminder */
    .reminder { gap: 32px; }
    .reminder__heading { font-size: clamp(1.8rem, 6vw, 2.4rem); }
    .reminder__form    { padding: 24px 20px; }
    .reminder__field-row { flex-direction: column; gap: 10px; }
    /* Footer */
    .footer__grid  { grid-template-columns: 1fr; gap: 24px; }
    .footer__brand { grid-column: unset; }
    .footer__links { gap: 4px 14px; }
    .footer__credits { flex-direction: column; gap: 4px; text-align: center; font-size: 0.7rem; }
    .footer__bottom { flex-direction: column; gap: 8px; text-align: center; }
    .footer__bottom a { margin-left: 0; }
    .footer__bottom div { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
    .footer__bottom-links { flex-wrap: wrap; justify-content: center; gap: 12px; }
    .footer__cta-bar { padding: 28px 20px; }
    .footer__cta-bar h3 { font-size: 1.3rem; }
    /* Products listing */
    .products-listing__main { padding-top: 0; }
    .products-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .product-card__body, .prd-card__body { padding: 10px; }
    .product-card__name, .prd-card__name { font-size: 0.82rem; -webkit-line-clamp: 2; }
    .product-card__price, .prd-card__price { font-size: 1rem; }
    .product-card__badges { gap: 4px; }
    .product-card__badge  { font-size: 0.55rem; padding: 2px 6px; }
    .products-listing__controls { gap: 8px; }
    .breadcrumb-section { padding: calc(var(--header-h) + 16px) 0 8px; }
    /* Product detail */
    .product-detail__layout   { gap: 28px; }
    .product-info__title      { font-size: clamp(1.6rem, 6vw, 2rem); }
    .product-price__current   { font-size: 1.6rem; }
    .quantity-selector        { flex-direction: row; }
    .product-tabs__nav        { gap: 0; }
    .product-tabs__tab        { padding: 14px; font-size: 0.78rem; min-width: 90px; }
    .addons-grid              { grid-template-columns: 1fr; gap: 10px; }
    .product-actions          { gap: 10px; }
    .product-actions .btn     { padding: 14px 16px; font-size: 0.82rem; }
    .related-products         { gap: 10px; }
    /* Category hero */
    .category-hero { min-height: 280px; }
    .category-hero__title { font-size: clamp(1.6rem, 6vw, 2rem) !important; }
    .category-hero__stats { gap: 16px; }
    .category-hero__stat-num   { font-size: 1.4rem; }
    .category-hero__stat-label { font-size: 0.65rem; }
    .category-benefits-grid { grid-template-columns: 1fr; gap: 16px; }
    .related-categories { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .quick-filters__chips { gap: 6px; }
    .filter-chip { padding: 6px 12px; font-size: 0.72rem; }
    /* Checkout */
    .checkout-step__title { font-size: 1.2rem; }
    .checkout-step  { padding: 20px 16px; }
    .form-section   { padding: 16px; }
    .date-option    { padding: 12px 10px; }
    .date-option__date  { font-size: 0.85rem; }
    .date-option__label { font-size: 0.65rem; }
    .timeslot-grid  { grid-template-columns: 1fr; }
    .timeslot-btn   { padding: 12px 10px; font-size: 0.78rem; }
    .checkout-progress { padding: 16px 0; }
    .progress-step__label { display: none; }
    .progress-step__icon  { width: 40px; height: 40px; font-size: 1rem; }
    /* Payment method cards */
    .payment-method-cards { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .payment-method-card  { padding: 12px 8px; }
    .payment-method-card__label { font-size: 0.72rem; }
    .payment-method-card__icon  { font-size: 1.2rem; }
    /* Orders filter */
    .orders-filter-bar  { flex-direction: column; align-items: flex-start; gap: 10px; }
    .orders-filter-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; width: 100%; }
    .filter-tab { white-space: nowrap; flex: 0 0 auto; }
    .order-summary-card { padding: 16px; }
    .order-items-list   { gap: 12px; }
    .order-item { flex-direction: column; gap: 10px; }
    .order-item__img { width: 80px; height: 80px; }
    /* Orders list page */
    .ord-page { padding-top: calc(var(--header-h) + 20px); padding-bottom: 40px; }
    .ord-page__title  { font-size: 1.4rem; }
    .ord-filter-tabs  { overflow-x: auto; -webkit-overflow-scrolling: touch; display: flex; gap: 6px; flex-wrap: nowrap; padding-bottom: 4px; }
    .ord-filter-tab   { white-space: nowrap; flex: 0 0 auto; padding: 6px 14px; font-size: 0.75rem; }
    .ord-card { padding: 16px; }
    .ord-card__items  { gap: 8px; }
    .ord-card__foot   { gap: 12px; }
    .ord-card__actions { width: 100%; display: flex; gap: 8px; }
    .ord-card__actions .btn { flex: 1; justify-content: center; font-size: 0.78rem; padding: 10px 12px; }
    .ord-empty { padding: 48px 16px; }
    /* Order detail page */
    .ord-show { padding-top: calc(var(--header-h) + 16px); padding-bottom: 40px; }
    .ord-show__head { padding: 16px; gap: 12px; }
    .ord-timeline { padding: 20px 16px; }
    .ord-show__items, .ord-show__message,
    .ord-show__history, .ord-sidebar-card { padding: 16px; margin-bottom: 14px; }
    .ord-section-title { font-size: 1rem; margin-bottom: 14px; }
    .ord-show__actions { flex-direction: column; gap: 8px; }
    .ord-show__actions .ord-btn { width: 100%; justify-content: center; }
    .ord-btn { padding: 10px 16px; font-size: 0.8rem; }
    .ord-quickinfo { padding: 10px 12px; row-gap: 6px; }
    .ord-quickinfo__sep { display: none; }
    .ord-quickinfo__item { flex: 1 1 45%; min-width: 0; gap: 8px; padding: 6px 8px; background: var(--cream); border-radius: var(--radius); }
    .ord-quickinfo__item--notes { flex: 1 1 100%; }
    .ord-quickinfo__icon { width: 26px; height: 26px; font-size: 0.7rem; }
    .ord-quickinfo__val { font-size: 0.75rem; max-width: none; }
    .ord-quickinfo__label { font-size: 0.55rem; }
    /* Track search page */
    .trk-hero { padding: 32px 0 24px; }
    .trk-copy__title  { font-size: clamp(1.6rem, 6vw, 2rem); }
    .trk-copy__sub    { font-size: 0.88rem; }
    .trk-card__header { padding: 20px 16px 16px; }
    .trk-card__body   { padding: 20px 16px; }
    .trk-alt-links    { gap: 8px; }
    .trk-steps__grid  { grid-template-columns: 1fr; gap: 12px; }
    .trk-step         { padding: 16px; }
    /* Track result page */
    .trkr { padding: 24px 0 48px; }
    .trkr-card { border-radius: 12px; }
    .trkr-card__head { padding: 16px; }
    .trkr-timeline, .trkr-photo, .trkr-items { padding: 16px; }
    .trkr-scard { padding: 16px; min-width: unset; }
    /* Reminders */
    .reminders-stats { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .stat-card { padding: 16px; }
    .stat-card__value { font-size: 1.6rem; }
    .reminder-card-item { flex-direction: column; align-items: flex-start; gap: 12px; }
    .reminder-card-item__actions { width: 100%; justify-content: flex-end; }
    /* Reviews */
    .star-rating-group { gap: 8px; }
    .star-label { font-size: 1.8rem; }
    .review-product-chips { grid-template-columns: repeat(2, 1fr); }
    /* Auth */
    .auth-card  { padding: 28px 20px; margin: 16px; }
    .auth-title { font-size: 1.4rem; }
    .auth-form .form-group { margin-bottom: 16px; }
    /* Profile */
    .profile-section    { padding: 20px 16px; }
    .profile-section h2 { font-size: 1.2rem; }
    /* Featured / same-day / midnight listing grids */
    .ft-grid, .sd-products__grid, .mn-products__grid, .oc-products__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .pcard__body  { padding: 10px; }
    .pcard__name  { font-size: 0.82rem; }
    .pcard__price { font-size: 1rem; }
    .pcard__badge { font-size: 0.55rem; padding: 2px 5px; }
    .sd-cats__wrap  { gap: 6px; }
    .sd-cat-chip    { padding: 6px 10px; font-size: 0.72rem; }
    .ft-hero__mosaic { display: none !important; }
    .ft-hero { padding: 3rem 0 2.5rem; }
    .ft-hero__title { font-size: clamp(1.6rem, 7vw, 2.2rem); }
    .ft-hero__stats { gap: 16px; flex-wrap: wrap; }
    .ft-hero__stat-num { font-size: 1.3rem; }
    .ft-bar__filters { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; }
    .ft-filter-chip { white-space: nowrap; flex: 0 0 auto; }
    /* Search results */
    .search-hero { padding: 36px 0 24px; }
    .search-hero__input-wrap { font-size: 0.9rem; }
    .search-results__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    /* Login */
    .login-panel { padding: 32px 24px; margin: 16px; }
    .login-header__title { font-size: 1.35rem; }
    /* Pay */
    .pay { padding: 24px 0 48px; }
    .pay__title { font-size: 1.3rem; }
    .pay-card__body { padding: 16px; }
    .pay-methods  { grid-template-columns: repeat(2, 1fr); gap: 8px; }
    .pay-method   { padding: 14px 8px; }
    .pay-scard    { padding: 16px; min-width: unset; }
    /* HIW */
    .hiw-hero { padding: 48px 0 36px; }
    .hiw-hero__title { font-size: clamp(1.6rem, 6vw, 2.2rem); }
    .hiw-hero__sub   { font-size: 0.88rem; }
    .hiw-steps__header { margin-bottom: 48px; }
    .hiw-steps__title  { font-size: clamp(1.4rem, 5vw, 1.8rem); }
    .hiw-trust { padding: var(--section-v) 0; }
    .hiw-trust__grid { grid-template-columns: repeat(2, 1fr); }
    .hiw-trust__item { padding: 24px 16px; }
    .hiw-faq__grid { grid-template-columns: 1fr; }
    .hiw-cta { padding: 60px 0; }
    .hiw-cta__title { font-size: clamp(1.6rem, 6vw, 2.2rem); }
    .hiw-cta__actions { flex-direction: column; align-items: stretch; gap: 12px; }
    .hiw-cta__actions .btn { justify-content: center; }
    /* Track search page steps grid */
    .track-steps { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .track-hero  { padding: 48px 0 32px; }
    .track-hero__title { font-size: clamp(1.6rem, 6vw, 2rem); }
    .track-form  { padding: 20px 16px; }
}

/* ── 374px ───────────────────────────────────────────────────── */
@media (max-width: 374px) {
    .occasion-chips { grid-template-columns: repeat(2, 1fr); }
    .p-card  { width: 165px; }
    .products-grid { grid-template-columns: 1fr !important; }
    .cart-sidebar__header { padding: 16px; }
    .cart-sidebar__body   { padding: 12px 16px; }
    .cart-sidebar__footer { padding: 16px; }
    .cart-item__img  { width: 60px; height: 60px; }
    .cart-item__name { font-size: 0.82rem; }
}
/* ================================================================
   APP.CSS — DEDUPLICATED  (last ~4 000-line block)
   Sections:
     1. Category Benefits
     2. FT (Featured/Filters) Page
     3. Shared — Breadcrumb
     4. Shared — Products-Listing Header / Sort
     5. Shared — Products Grid & Pagination
     6. Shared — Empty State
     7. Shared — Filter Sidebar Sections
     8. HIW (How It Works)
     9. MN (Midnight) Page
    10. OCC (Occasion) Page
    11. SD (Same Day) Page
    12. Search Page
    13. REMF (Reminder Form)
    14. REM (Reminders Index)
    15. RVW (Review)
    16. Dashboard
    17. Consolidated Media Queries
================================================================ */


/* ── 1. CATEGORY BENEFITS ───────────────────────────────────── */

.category-benefits-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
}
.category-benefit {
    text-align: center;
    padding: 32px 20px;
}
.category-benefit__icon {
    width: 72px; height: 72px;
    margin: 0 auto 20px;
    background: var(--ivory);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem; color: var(--rose);
    transition: all 0.4s var(--ease);
}
.category-benefit:hover .category-benefit__icon {
    background: var(--rose); color: var(--white);
    transform: translateY(-4px) scale(1.05);
    box-shadow: var(--shadow-glow);
}
.category-benefit__title {
    font-family: var(--font-display);
    font-size: 1.15rem; font-weight: 500;
    color: var(--charcoal); margin-bottom: 10px;
}
.category-benefit__text {
    font-size: 0.88rem; color: var(--warm-400); line-height: 1.6;
}

/* related-categories & quick-filters (category page specific) */
.quick-filters {
    display: flex; align-items: center; gap: 12px;
}
.quick-filters__chips { display: flex; gap: 8px; flex-wrap: wrap; }

.featured-occasion__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
}
.related-categories {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.filter-sidebar-header { display: none; }


/* ── 2. FT (FEATURED / FILTER) PAGE ────────────────────────── */

.ft-hero {
    position: relative;
    background: linear-gradient(135deg, var(--charcoal) 0%, #1a0a0f 60%, #2d1520 100%);
    padding: 5rem 0 4rem;
    overflow: hidden;
}
.ft-hero::before {
    content: '';
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 80% 50%, rgba(var(--rose-rgb,180,60,80),.15) 0%, transparent 60%),
        radial-gradient(ellipse 40% 60% at 10% 80%, rgba(var(--gold-rgb,212,175,55),.1) 0%, transparent 50%);
    pointer-events: none;
}
.ft-hero__grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 3rem; align-items: center;
}
.ft-hero__eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    color: var(--gold);
    font-family: var(--font-body);
    font-size: .75rem; font-weight: 600;
    letter-spacing: .12em; text-transform: uppercase;
    padding: .4rem 1rem;
    border-radius: var(--radius-pill);
    margin-bottom: 1.25rem;
}
.ft-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.4rem,5vw,3.6rem); font-weight: 500;
    color: #fff; line-height: 1.15; margin-bottom: 1rem;
}
.ft-hero__title em { font-style: italic; color: var(--rose); }
.ft-hero__desc {
    color: rgba(255,255,255,.65); font-size: 1.05rem;
    line-height: 1.7; max-width: 480px; margin-bottom: 2rem;
}
.ft-hero__stats { display: flex; gap: 2rem; flex-wrap: wrap; }
.ft-hero__stat { display: flex; flex-direction: column; }
.ft-hero__stat-num {
    font-family: var(--font-display);
    font-size: 1.75rem; font-weight: 600;
    color: #fff; line-height: 1;
}
.ft-hero__stat-label {
    font-size: .72rem; letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.5); margin-top: .2rem;
}

/* Hero mosaic */
.ft-hero__mosaic {
    display: grid; grid-template-columns: 1fr 1fr; gap: .75rem;
}
.ft-hero__mosaic-card {
    border-radius: var(--radius); overflow: hidden;
    position: relative; aspect-ratio: 1;
    box-shadow: 0 8px 32px rgba(0,0,0,.35);
}
.ft-hero__mosaic-card:first-child { grid-row: 1/3; aspect-ratio: unset; }
.ft-hero__mosaic-img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .5s var(--ease);
}
.ft-hero__mosaic-card:hover .ft-hero__mosaic-img { transform: scale(1.07); }
.ft-hero__mosaic-badge {
    position: absolute; bottom: .75rem; left: .75rem;
    background: rgba(0,0,0,.6); backdrop-filter: blur(6px);
    color: #fff; font-size: .68rem; font-weight: 600;
    letter-spacing: .08em; text-transform: uppercase;
    padding: .3rem .7rem; border-radius: var(--radius-pill);
}

/* FT Bar */
.ft-bar {
    background: var(--ivory);
    border-bottom: 1px solid rgba(0,0,0,.07);
    position: sticky; top: 68px; z-index: 40; padding: .75rem 0;
}
.ft-bar__inner {
    display: flex; align-items: center;
    justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}
.ft-bar__count { font-size: .85rem; color: rgba(0,0,0,.5); flex-shrink: 0; }
.ft-bar__count strong { color: var(--charcoal); font-weight: 600; }
.ft-bar__filters { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; }
.ft-filter-chip {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .35rem .85rem;
    border-radius: var(--radius-pill);
    border: 1.5px solid rgba(0,0,0,.12);
    background: #fff; color: var(--charcoal);
    font-size: .78rem; font-weight: 500;
    cursor: pointer; transition: all .2s; text-decoration: none;
}
.ft-filter-chip:hover, .ft-filter-chip--active {
    border-color: var(--rose); background: var(--rose); color: #fff;
}
.ft-sort-select {
    padding: .35rem .9rem .35rem .75rem;
    border: 1.5px solid rgba(0,0,0,.12);
    border-radius: var(--radius-pill);
    background: #fff; color: var(--charcoal);
    font-size: .78rem; font-family: var(--font-body);
    cursor: pointer; appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23666' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .6rem center;
    padding-right: 1.8rem; transition: border-color .2s;
}
.ft-sort-select:focus { outline: none; border-color: var(--rose); }

/* FT Layout & Sidebar */
.ft-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 2rem; align-items: start;
    padding: 2rem 0 4rem;
}
.ft-sidebar {
    position: sticky;
    top: calc(68px + 57px + 1.5rem);
}
.ft-sidebar__section {
    background: #fff;
    border: 1px solid rgba(0,0,0,.07);
    border-radius: var(--radius); padding: 1.25rem; margin-bottom: 1rem;
}
.ft-sidebar__title {
    font-family: var(--font-display);
    font-size: 1rem; font-weight: 600; color: var(--charcoal);
    margin-bottom: 1rem; padding-bottom: .6rem;
    border-bottom: 1px solid rgba(0,0,0,.07);
}
.ft-sidebar__cats { display: flex; flex-direction: column; gap: .4rem; }
.ft-sidebar__cat-link {
    display: flex; justify-content: space-between; align-items: center;
    padding: .5rem .6rem; border-radius: 6px;
    text-decoration: none; color: var(--charcoal);
    font-size: .85rem; transition: background .15s;
}
.ft-sidebar__cat-link:hover { background: var(--ivory); color: var(--rose); }
.ft-sidebar__cat-count {
    font-size: .72rem; color: rgba(0,0,0,.4);
    background: rgba(0,0,0,.05); border-radius: 20px; padding: .1rem .45rem;
}
.ft-sidebar__price-range { display: flex; flex-direction: column; gap: .6rem; }
.ft-sidebar__price-inputs { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.ft-sidebar__price-input {
    width: 100%; padding: .45rem .6rem;
    border: 1.5px solid rgba(0,0,0,.1); border-radius: 6px;
    font-size: .82rem; font-family: var(--font-body); color: var(--charcoal);
}
.ft-sidebar__price-input:focus { outline: none; border-color: var(--rose); }
.ft-sidebar__apply-btn {
    width: 100%; padding: .5rem;
    background: var(--charcoal); color: #fff; border: none;
    border-radius: 6px; font-size: .8rem; font-weight: 600;
    cursor: pointer; transition: background .2s;
}
.ft-sidebar__apply-btn:hover { background: var(--rose); }
.ft-sidebar__toggle-row {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: .6rem; font-size: .85rem; color: var(--charcoal);
}
.ft-sidebar__toggle {
    width: 38px; height: 20px; border-radius: 10px;
    background: rgba(0,0,0,.15);
    position: relative; cursor: pointer;
    transition: background .2s; flex-shrink: 0; border: none;
}
.ft-sidebar__toggle.active { background: var(--rose); }
.ft-sidebar__toggle::after {
    content: ''; position: absolute;
    width: 14px; height: 14px; border-radius: 50%;
    background: #fff; top: 3px; left: 3px;
    transition: left .2s; box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.ft-sidebar__toggle.active::after { left: 21px; }

/* FT Product Grid */
.ft-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1.25rem;
}

/* Product card (.pcard) */
.pcard {
    background: #fff; border-radius: var(--radius);
    overflow: hidden; border: 1px solid rgba(0,0,0,.06);
    box-shadow: var(--shadow-sm);
    transition: transform .25s var(--ease), box-shadow .25s var(--ease);
    display: flex; flex-direction: column;
    text-decoration: none; color: inherit;
}
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.pcard__img-wrap {
    position: relative; overflow: hidden;
    aspect-ratio: 1; background: var(--ivory);
}
.pcard__img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .45s var(--ease);
}
.pcard:hover .pcard__img { transform: scale(1.08); }
.pcard__badges {
    position: absolute; top: .6rem; left: .6rem;
    display: flex; flex-direction: column; gap: .3rem;
}
.pcard__badge {
    font-size: .62rem; font-weight: 700;
    letter-spacing: .07em; text-transform: uppercase;
    padding: .25rem .55rem; border-radius: var(--radius-pill); line-height: 1;
}
.pcard__badge--featured { background: var(--gold); color: #fff; }
.pcard__badge--same-day { background: var(--rose); color: #fff; }
.pcard__badge--midnight { background: #1a1a2e; color: #fff; }
.pcard__badge--sale { background: #fff; color: var(--rose); border: 1px solid var(--rose); }
.pcard__wishlist {
    position: absolute; top: .6rem; right: .6rem;
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(255,255,255,.9); border: none;
    display: grid; place-items: center;
    cursor: pointer; font-size: .9rem; color: rgba(0,0,0,.4);
    transition: all .2s; opacity: 0;
}
.pcard:hover .pcard__wishlist { opacity: 1; }
.pcard__wishlist:hover { background: var(--rose); color: #fff; }
.pcard__wishlist.liked { opacity: 1; color: var(--rose); background: rgba(255,255,255,.95); }
.pcard__wishlist.liked:hover { background: var(--rose); color: #fff; }
.pcard__body { padding: .85rem; flex: 1; display: flex; flex-direction: column; }
.pcard__cat {
    font-size: .68rem; letter-spacing: .1em;
    text-transform: uppercase; color: var(--rose);
    font-weight: 600; margin-bottom: .35rem;
}
.pcard__name {
    font-family: var(--font-display); font-size: 1rem; font-weight: 500;
    color: var(--charcoal); line-height: 1.3; margin-bottom: .3rem;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.pcard__rating {
    display: flex; align-items: center; gap: .3rem;
    font-size: .72rem; color: rgba(0,0,0,.5); margin-bottom: .6rem;
}
.pcard__stars { color: var(--gold); letter-spacing: -.05em; }
.pcard__price-row {
    display: flex; align-items: center; gap: .5rem;
    margin-top: auto; margin-bottom: .7rem;
}
.pcard__price {
    font-family: var(--font-display); font-size: 1.15rem;
    font-weight: 600; color: var(--charcoal);
}
.pcard__compare { font-size: .8rem; text-decoration: line-through; color: rgba(0,0,0,.35); }
.pcard__discount {
    font-size: .72rem; font-weight: 700; color: #16a34a;
    background: #f0fdf4; padding: .15rem .4rem; border-radius: 4px;
}
.pcard__btn {
    width: 100%; padding: .55rem;
    background: var(--charcoal); color: #fff; border: none;
    border-radius: 6px; font-size: .8rem; font-weight: 600;
    cursor: pointer; transition: background .2s;
    text-align: center; display: block; text-decoration: none;
}
.pcard__btn:hover { background: var(--rose); color: #fff; }

/* FT Empty */
.ft-empty { text-align: center; padding: 5rem 2rem; grid-column: 1/-1; }
.ft-empty__icon { font-size: 3rem; color: rgba(0,0,0,.15); margin-bottom: 1rem; }
.ft-empty__title { font-family: var(--font-display); font-size: 1.5rem; color: var(--charcoal); margin-bottom: .5rem; }
.ft-empty__desc { color: rgba(0,0,0,.5); font-size: .9rem; margin-bottom: 1.5rem; }

/* FT Pagination */
.ft-pagination {
    display: flex; justify-content: center; align-items: center;
    gap: .4rem; margin-top: 2.5rem; flex-wrap: wrap;
}
.ft-pagination a, .ft-pagination span {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 6px;
    border: 1.5px solid rgba(0,0,0,.1);
    font-size: .82rem; color: var(--charcoal); text-decoration: none; transition: all .18s;
}
.ft-pagination a:hover { border-color: var(--rose); color: var(--rose); }
.ft-pagination span.active {
    background: var(--rose); border-color: var(--rose); color: #fff; font-weight: 600;
}
.ft-pagination span.disabled { opacity: .35; cursor: not-allowed; }


/* ── 3. SHARED — BREADCRUMB ─────────────────────────────────── */

.breadcrumb-section {
    padding: calc(var(--promise-h) + var(--header-h) + 32px) 0 16px;
    background: var(--ivory);
}
.breadcrumb {
    display: flex; align-items: center; gap: 12px;
    font-size: 0.82rem; color: var(--warm-400);
    margin-bottom: 32px;      /* used by occ-hero; no-op elsewhere */
}
.breadcrumb__link { color: var(--warm-400); transition: color 0.2s; }
.breadcrumb__link:hover { color: var(--rose); }
.breadcrumb__current { color: var(--charcoal); font-weight: 600; }
.breadcrumb i { font-size: 0.7rem; }

/* Light variant (dark backgrounds: mn-, sd-) */
.breadcrumb--light,
.breadcrumb--light .breadcrumb__link { color: rgba(255,255,255,.35); }
.breadcrumb--light .breadcrumb__link:hover { color: rgba(255,255,255,.7); }
.breadcrumb--light .breadcrumb__current { color: rgba(255,255,255,.65); }


/* ── 4. SHARED — PRODUCTS-LISTING HEADER / SORT ─────────────── */

.products-listing__header {
    display: flex; align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 48px; gap: 24px;
}
.products-listing__title {
    font-family: var(--font-display);
    font-size: clamp(2rem,3.5vw,3rem); font-weight: 400;
    line-height: 1.12; letter-spacing: -0.02em;
    color: var(--charcoal); margin-bottom: 8px;
}
.products-listing__title em { font-style: italic; color: var(--rose); }
.products-listing__subtitle { font-size: 0.95rem; color: var(--warm-400); }
.products-listing__controls { display: flex; align-items: center; gap: 12px; }
.products-listing__filter-toggle {
    display: inline-flex;
    padding: 10px 20px;
    background: var(--ivory); border: 1px solid var(--sand);
    border-radius: var(--radius);
    font-size: 0.82rem; font-weight: 600; color: var(--charcoal);
    gap: 8px; align-items: center; transition: all 0.2s;
    cursor: pointer;
}
.products-listing__filter-toggle:hover { border-color: var(--rose); color: var(--rose); }

/* Filter sidebar header */
.filter-sidebar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    border-bottom: 1px solid var(--sand);
    margin-bottom: 8px;
}
.filter-sidebar__title {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: 8px;
}
.filter-sidebar__close {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    background: var(--cream); border: none; border-radius: 50%;
    font-size: 1rem; color: var(--warm-500); cursor: pointer;
    transition: all 0.2s;
}
.filter-sidebar__close:hover { background: var(--rose-bg); color: var(--rose); }

/* Filter overlay (mobile) */
.filter-overlay {
    display: none;
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.4); backdrop-filter: blur(2px);
    z-index: 999; opacity: 0; transition: opacity 0.3s;
}
.filter-overlay.open { display: block; opacity: 1; }
.products-listing__sort {
    padding: 10px 20px;
    background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius);
    font-size: 0.82rem; font-weight: 500; color: var(--charcoal);
    cursor: pointer; transition: border-color 0.2s;
}
.products-listing__sort:hover { border-color: var(--rose); }

/* Products-listing layout (full width, filter is a slide-out drawer) */
.products-listing__layout {
    display: block;
}
.products-listing__sidebar {
    position: fixed; top: 0; left: 0;
    width: 360px; max-width: 88vw; height: 100vh; z-index: 1000;
    background: var(--white); border-radius: 0;
    padding: 0 0 24px; overflow-y: auto;
    transform: translateX(-100%); transition: transform 0.35s var(--ease);
    box-shadow: var(--shadow-xl, 0 20px 50px rgba(0,0,0,.15));
}
.products-listing__sidebar.open { transform: translateX(0); }
.products-listing__sidebar .filter-section { padding: 0 24px 24px; margin-bottom: 0; border-bottom: 1px solid var(--sand); }
.products-listing__sidebar .filter-section:last-of-type { border-bottom: none; }
.products-listing__sidebar .filter-section__title { padding-top: 20px; }
.products-listing__sidebar .filter-actions { padding: 16px 24px; position: sticky; bottom: 0; background: var(--white); border-top: 1px solid var(--sand); }

/* ── Active Filter Chips Bar ───────────────────────────────── */
.active-filters {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 0 20px;
    flex-wrap: wrap;
}
.active-filters__label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--warm-400);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    flex-shrink: 0;
}
.active-filters__chips {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.active-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px 6px 14px;
    background: var(--rose-bg);
    color: var(--rose);
    font-size: 0.8rem;
    font-weight: 600;
    border-radius: 40px;
    border: 1.5px solid rgba(181,113,90,0.2);
    transition: all 0.2s;
    white-space: nowrap;
}
.active-filter-chip:hover {
    background: rgba(181,113,90,0.12);
    border-color: var(--rose);
}
.active-filter-chip__x {
    width: 20px; height: 20px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    border: none; background: rgba(181,113,90,0.15);
    color: var(--rose); font-size: 0.75rem;
    cursor: pointer; transition: all 0.2s;
    flex-shrink: 0; padding: 0;
}
.active-filter-chip__x:hover {
    background: var(--rose);
    color: var(--white);
}
.active-filters__clear {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--warm-400);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.2s;
    margin-left: auto;
    flex-shrink: 0;
    white-space: nowrap;
}
.active-filters__clear:hover { color: var(--rose); }

@media (max-width: 480px) {
    .active-filters { padding: 10px 0 14px; gap: 8px; }
    .active-filters__label { display: none; }
    .active-filter-chip { font-size: 0.72rem; padding: 5px 8px 5px 12px; }
}

/* ── 5. SHARED — PRODUCTS GRID & PAGINATION ─────────────────── */

.products-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
.products-grid .p-card, .products-scroll .p-card { width: 100%; min-width: 0; }
.products-grid--4col { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) { .products-grid--4col { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .products-grid--4col { grid-template-columns: repeat(2, 1fr); gap: 14px; } }
@media (max-width: 374px)  { .products-grid--4col { grid-template-columns: 1fr; } }
.pagination-wrap { margin-top: 64px; display: flex; justify-content: center; }


/* ── 6. SHARED — EMPTY STATE ────────────────────────────────── */

.empty-state { text-align: center; padding: 80px 20px; }
.empty-state__icon {
    width: 80px; height: 80px; margin: 0 auto 24px;
    background: var(--cream); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: var(--warm-300);
}
.empty-state__title {
    font-family: var(--font-display); font-size: 1.8rem;
    font-weight: 400; color: var(--charcoal); margin-bottom: 12px;
}
.empty-state__text { font-size: 0.95rem; color: var(--warm-400); margin-bottom: 28px; }


/* ── 7. SHARED — FILTER SIDEBAR SECTIONS ───────────────────── */

.filter-section {
    padding-bottom: 24px; margin-bottom: 24px;
    border-bottom: 1px solid var(--sand);
}
.filter-section:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.filter-section__title {
    font-family: var(--font-display);
    font-size: 1.05rem; font-weight: 500;
    color: var(--charcoal); margin-bottom: 16px;
}
.filter-section__content { display: flex; flex-direction: column; gap: 10px; }
.filter-checkbox {
    display: flex; align-items: center;
    padding: 8px 12px; border-radius: var(--radius);
    cursor: pointer; transition: background 0.2s;
}
.filter-checkbox:hover { background: rgba(181,113,90,.04); }
.filter-checkbox input[type="checkbox"],
.filter-checkbox input[type="radio"] {
    width: 18px; height: 18px; margin-right: 10px; cursor: pointer;
}
.filter-checkbox__label {
    flex: 1; font-size: 0.88rem; color: var(--warm-500);
    display: flex; align-items: center; gap: 6px;
}
.filter-checkbox__count { font-size: 0.75rem; color: var(--warm-300); }
.rating-stars { color: var(--gold); }

/* Price range input fields (category page sidebar) */
.price-range-inputs {
    display: flex; align-items: center; gap: 10px;
}
.price-range-inputs__field {
    flex: 1; padding: 10px 14px;
    background: var(--white); border: 1.5px solid var(--sand);
    border-radius: var(--radius); font-size: 0.85rem;
    color: var(--charcoal); transition: border-color 0.2s;
    -moz-appearance: textfield;
}
.price-range-inputs__field::-webkit-outer-spin-button,
.price-range-inputs__field::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.price-range-inputs__field:focus { border-color: var(--rose); outline: none; }
.price-range-inputs__sep { color: var(--warm-300); font-size: 0.9rem; flex-shrink: 0; }

/* Dual-thumb price range slider */
.price-slider { padding: 4px 0; }
.price-slider__values {
    display: flex; justify-content: space-between;
    font-size: 0.82rem; font-weight: 600; color: var(--charcoal);
    margin-bottom: 14px;
}
.price-slider__track {
    position: relative; height: 6px; width: 100%;
}
.price-slider__fill {
    position: absolute; top: 0; height: 6px;
    background: var(--rose); border-radius: 3px; z-index: 1;
}
.price-slider__track::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0;
    height: 6px; background: var(--warm-100); border-radius: 3px;
}
.price-slider__input {
    position: absolute; top: -6px; left: 0; width: 100%;
    -webkit-appearance: none; appearance: none;
    background: transparent; pointer-events: none;
    margin: 0; padding: 0; z-index: 2; height: 18px;
}
.price-slider__input::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--rose); border: 3px solid var(--white);
    box-shadow: 0 2px 6px rgba(180,100,120,0.35);
    cursor: pointer; pointer-events: all;
    transition: transform 0.15s;
}
.price-slider__input::-webkit-slider-thumb:hover { transform: scale(1.2); }
.price-slider__input::-moz-range-thumb {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--rose); border: 3px solid var(--white);
    box-shadow: 0 2px 6px rgba(180,100,120,0.35);
    cursor: pointer; pointer-events: all;
}

/* Filter action buttons */
.filter-actions {
    display: flex; flex-direction: column; gap: 8px;
    margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--sand);
}
.filter-actions__apply {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    width: 100%; padding: 12px; font-weight: 600;
}


/* ── 8. HIW (HOW IT WORKS) ──────────────────────────────────── */

.hiw-section {
    background: var(--ivory);
    padding-top: var(--section-v); padding-bottom: var(--section-v);
}
.hiw__header { max-width: 640px; margin: 0 auto 80px; }
.hiw__eyebrow {
    font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--rose); margin-bottom: 16px;
}
.hiw__title {
    font-family: var(--font-display);
    font-size: clamp(2.4rem,4vw,3.6rem); font-weight: 400;
    line-height: 1.1; letter-spacing: -0.02em;
    color: var(--charcoal); margin-bottom: 20px;
}
.hiw__title em { font-style: italic; color: var(--rose); }
.hiw__subtitle {
    font-size: 1rem; color: var(--warm-400); line-height: 1.7;
    max-width: 520px; margin: 0 auto;
}

/* Steps */
.hiw__steps { display: flex; flex-direction: column; gap: 0; }
.hiw__step {
    display: grid;
    grid-template-columns: 80px 1fr 1fr;
    gap: 0 56px; align-items: center;
    padding: 64px 0;
    border-bottom: 1px solid var(--sand); position: relative;
}
.hiw__step:last-child { border-bottom: none; }
.hiw__step--reverse { grid-template-columns: 80px 1fr 1fr; }
.hiw__step--reverse .hiw__step-visual { order: -1; grid-column: 2; }
.hiw__step--reverse .hiw__step-body   { grid-column: 3; }
.hiw__step--reverse .hiw__step-num    { grid-column: 1; grid-row: 1; }

.hiw__step-num {
    font-family: var(--font-display);
    font-size: clamp(3.5rem,5vw,5.5rem); font-weight: 300;
    color: var(--sand); line-height: 1;
    align-self: start; padding-top: 4px; letter-spacing: -0.03em;
}
.hiw__step-icon {
    width: 56px; height: 56px; background: var(--rose-bg);
    border-radius: 16px; display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; color: var(--rose); margin-bottom: 24px;
}
.hiw__step-title {
    font-family: var(--font-display);
    font-size: clamp(1.6rem,2.5vw,2.2rem); font-weight: 400;
    line-height: 1.15; color: var(--charcoal);
    margin-bottom: 16px; letter-spacing: -0.01em;
}
.hiw__step-text {
    font-size: 0.95rem; color: var(--warm-400);
    line-height: 1.75; margin-bottom: 24px;
}
.hiw__step-details { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.hiw__step-details li {
    display: flex; align-items: center; gap: 10px;
    font-size: 0.88rem; color: var(--warm-500); font-weight: 500;
}
.hiw__step-details li i { color: var(--rose); font-size: 0.9rem; flex-shrink: 0; }

/* Payment pills */
.hiw__payment-row { display: flex; gap: 8px; flex-wrap: wrap; }
.hiw__pay-pill {
    padding: 4px 12px; background: var(--cream);
    border: 1px solid var(--sand); border-radius: var(--radius-pill);
    font-size: 0.72rem; font-weight: 700; letter-spacing: 0.04em; color: var(--warm-500);
}
.hiw__cta-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 14px 28px; background: var(--charcoal); color: var(--white);
    border-radius: var(--radius); font-size: 0.88rem; font-weight: 600;
    letter-spacing: 0.02em; transition: background 0.25s var(--ease), transform 0.2s var(--ease);
}
.hiw__cta-btn:hover { background: var(--rose); transform: translateY(-2px); }

/* Visual card */
.hiw__visual-card {
    background: var(--white); border-radius: var(--radius-lg);
    overflow: hidden; box-shadow: var(--shadow-md);
    border: 1px solid rgba(227,220,210,.6);
    transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.hiw__step:hover .hiw__visual-card { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.hiw__visual-img { position: relative; aspect-ratio: 16/10; overflow: hidden; }
.hiw__visual-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease); }
.hiw__step:hover .hiw__visual-img img { transform: scale(1.04); }
.hiw__visual-badge {
    position: absolute; top: 16px; right: 16px;
    padding: 6px 14px; border-radius: var(--radius-pill);
    font-size: 0.72rem; font-weight: 700; letter-spacing: 0.05em;
    display: flex; align-items: center; gap: 6px; backdrop-filter: blur(8px);
}
.hiw__visual-badge--rose   { background: var(--rose); color: var(--white); }
.hiw__visual-badge--gold   { background: var(--gold); color: var(--charcoal); }
.hiw__visual-badge--success{ background: #5A9A6E; color: var(--white); }

.hiw__visual-tags { display: flex; gap: 8px; flex-wrap: wrap; padding: 16px 20px; }
.hiw__tag {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 14px; background: var(--ivory);
    border: 1px solid var(--sand); border-radius: var(--radius-pill);
    font-size: 0.78rem; color: var(--warm-500); transition: border-color 0.2s, color 0.2s;
}
.hiw__tag:hover { border-color: var(--rose-light); color: var(--rose); }

/* Delivery slots */
.hiw__slots { display: flex; flex-direction: column; gap: 0; padding: 16px 20px; }
.hiw__slot {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 14px; border-radius: var(--radius);
    font-size: 0.83rem; color: var(--warm-400); transition: background 0.2s;
}
.hiw__slot:hover { background: var(--ivory); }
.hiw__slot i { font-size: 1rem; color: var(--warm-300); }
.hiw__slot--active { background: var(--rose-bg); }
.hiw__slot--active i { color: var(--rose); }
.hiw__slot-label { font-weight: 600; color: var(--charcoal); font-size: 0.83rem; margin-bottom: 2px; }
.hiw__slot-time  { font-size: 0.78rem; color: var(--warm-400); }

/* Order tracker */
.hiw__tracker {
    display: flex; align-items: center; padding: 20px 24px; gap: 0;
}
.hiw__tracker-step {
    display: flex; flex-direction: column; align-items: center; gap: 6px; flex-shrink: 0;
}
.hiw__tracker-dot {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--cream); border: 2px solid var(--sand);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.75rem; color: var(--warm-300);
}
.hiw__tracker-label {
    font-size: 0.65rem; font-weight: 600; color: var(--warm-300);
    text-align: center; letter-spacing: 0.03em; white-space: nowrap;
}
.hiw__tracker-step--done .hiw__tracker-dot  { background: var(--rose); border-color: var(--rose); color: var(--white); }
.hiw__tracker-step--done .hiw__tracker-label { color: var(--rose); }
.hiw__tracker-step--active .hiw__tracker-dot {
    background: var(--white); border-color: var(--gold); color: var(--gold);
    border-width: 2px; box-shadow: 0 0 0 4px rgba(201,169,110,.15);
}
.hiw__tracker-step--active .hiw__tracker-label { color: var(--gold); }
.hiw__tracker-line        { flex: 1; height: 2px; background: var(--sand); margin: 0 4px; margin-bottom: 22px; }
.hiw__tracker-line--done  { background: var(--rose); }
.hiw__tracker-line--active{ background: linear-gradient(90deg, var(--rose), var(--gold)); }

/* Delivery proof */
.hiw__delivery-proof { display: flex; align-items: center; gap: 14px; padding: 16px 20px; }
.hiw__proof-avatar { font-size: 2rem; line-height: 1; flex-shrink: 0; }
.hiw__proof-text { display: flex; flex-direction: column; gap: 3px; }
.hiw__proof-text strong { font-size: 0.88rem; font-weight: 600; color: var(--charcoal); }
.hiw__proof-text span   { font-size: 0.78rem; color: var(--warm-400); }

/* Connector */
.hiw__connector { display: flex; flex-direction: column; align-items: center; gap: 0; padding: 12px 0; }
.hiw__connector-line { width: 1px; height: 40px; background: linear-gradient(to bottom, transparent, var(--sand), transparent); }
.hiw__connector-dot {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--cream); border: 1px solid var(--sand);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.85rem; color: var(--warm-300);
}

/* Trust bar */
.hiw__trust {
    display: flex; align-items: center; justify-content: center;
    gap: 0;
    background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius-lg); padding: 40px 48px;
    margin-top: 80px; box-shadow: var(--shadow-sm); flex-wrap: wrap;
}
.hiw__trust-item {
    display: flex; align-items: center; gap: 16px;
    flex: 1; min-width: 160px; justify-content: center; padding: 12px 24px;
}
.hiw__trust-icon {
    width: 48px; height: 48px; background: var(--rose-bg); border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--rose); flex-shrink: 0;
}
.hiw__trust-num {
    font-family: var(--font-display); font-size: 1.7rem; font-weight: 400;
    color: var(--charcoal); line-height: 1; margin-bottom: 4px;
}
.hiw__trust-label { font-size: 0.78rem; color: var(--warm-400); font-weight: 500; line-height: 1.3; }
.hiw__trust-div  { width: 1px; height: 56px; background: var(--sand); flex-shrink: 0; }

/* FAQ */
.hiw__faq { margin-top: 64px; }
.hiw__faq-title {
    font-family: var(--font-display); font-size: clamp(1.4rem,2vw,1.8rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 32px; text-align: center;
}
.hiw__faq-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.hiw__faq-item {
    background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius-lg); padding: 28px 32px;
    transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s var(--ease);
}
.hiw__faq-item:hover { border-color: var(--rose-lighter); box-shadow: var(--shadow-sm); transform: translateY(-3px); }
.hiw__faq-q {
    display: flex; align-items: center; gap: 10px;
    font-size: 0.92rem; font-weight: 600; color: var(--charcoal); margin-bottom: 12px;
}
.hiw__faq-q i { color: var(--rose); font-size: 0.95rem; flex-shrink: 0; }
.hiw__faq-a { font-size: 0.88rem; color: var(--warm-400); line-height: 1.7; }


/* ── 9. MN (MIDNIGHT) PAGE ──────────────────────────────────── */

.mn-hero {
    position: relative;
    background: linear-gradient(135deg, #0D0B14 0%, #1A1520 40%, #1E1428 100%);
    min-height: 520px; display: flex; align-items: flex-end;
    padding-top: calc(var(--promise-h) + var(--header-h)); overflow: hidden;
}
.mn-hero::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 80% 20%, rgba(123,111,160,.25) 0%, transparent 60%),
        radial-gradient(ellipse at 20% 80%, rgba(181,113,90,.1) 0%, transparent 50%);
}
.mn-hero .container { position: relative; z-index: 2; }
.mn-hero__content { padding: 64px 0 80px; }
.mn-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
    color: #B8A8D4; background: rgba(123,111,160,.15);
    border: 1px solid rgba(123,111,160,.3);
    padding: 6px 16px; border-radius: var(--radius-pill);
    margin-top: 24px; margin-bottom: 20px;
}
.mn-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.8rem,5vw,5rem); font-weight: 300; color: var(--white);
    line-height: 1.08; letter-spacing: -0.02em; margin-bottom: 20px;
}
.mn-hero__title em { color: #B8A8D4; font-style: italic; }
.mn-hero__desc {
    font-size: 1rem; color: rgba(255,255,255,.55);
    max-width: 540px; line-height: 1.75; margin-bottom: 40px;
}
.mn-hero__desc strong { color: #B8A8D4; }
.mn-hero__features { display: flex; flex-direction: column; gap: 16px; }
.mn-hero__feature { display: flex; align-items: center; gap: 16px; }
.mn-hero__feature-icon {
    width: 40px; height: 40px; flex-shrink: 0;
    background: rgba(123,111,160,.2); border: 1px solid rgba(123,111,160,.3);
    border-radius: 12px; display: flex; align-items: center; justify-content: center;
    font-size: 1rem; color: #B8A8D4;
}
.mn-hero__feature-title { font-size: 0.9rem; font-weight: 600; color: rgba(255,255,255,.85); margin-bottom: 2px; }
.mn-hero__feature-text  { font-size: 0.8rem; color: rgba(255,255,255,.35); }

/* Stars animation */
.mn-hero__stars { position: absolute; inset: 0; pointer-events: none; }
.mn-hero__stars span {
    position: absolute; width: 2px; height: 2px;
    background: rgba(255,255,255,.6); border-radius: 50%;
    animation: twinkle 3s ease-in-out infinite;
}
.mn-hero__stars span:nth-child(1)  { top:12%; left:10%; animation-delay:0s; }
.mn-hero__stars span:nth-child(2)  { top:24%; left:78%; animation-delay:0.4s; }
.mn-hero__stars span:nth-child(3)  { top:8%;  left:55%; animation-delay:0.8s; width:3px; height:3px; }
.mn-hero__stars span:nth-child(4)  { top:45%; left:88%; animation-delay:1.2s; }
.mn-hero__stars span:nth-child(5)  { top:65%; left:92%; animation-delay:0.6s; }
.mn-hero__stars span:nth-child(6)  { top:18%; left:32%; animation-delay:1.8s; width:3px; height:3px; }
.mn-hero__stars span:nth-child(7)  { top:75%; left:15%; animation-delay:2.2s; }
.mn-hero__stars span:nth-child(8)  { top:35%; left:65%; animation-delay:1s; }
.mn-hero__stars span:nth-child(9)  { top:55%; left:42%; animation-delay:2.6s; width:4px; height:4px; opacity:0.4; }
.mn-hero__stars span:nth-child(10) { top:5%;  left:90%; animation-delay:1.4s; }
@keyframes twinkle {
    0%, 100% { opacity: 0.2; transform: scale(1); }
    50%       { opacity: 1;   transform: scale(1.4); }
}

.mn-products { padding-top: 48px; }

/* MN How it works */
.mn-how { padding-top: 80px; }
.mn-how__eyebrow {
    font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em;
    text-transform: uppercase; color: #7B6FA0; margin-bottom: 14px; text-align: center;
}
.mn-how__title {
    font-family: var(--font-display); font-size: clamp(2rem,3.5vw,3rem);
    font-weight: 400; color: var(--charcoal);
    letter-spacing: -0.02em; margin-bottom: 56px; text-align: center;
}
.mn-how__title em { font-style: italic; color: #7B6FA0; }
.mn-how__steps { display: flex; align-items: center; gap: 0; justify-content: center; }
.mn-how__step { flex: 1; max-width: 280px; text-align: center; padding: 0 24px; }
.mn-how__step-num {
    font-family: var(--font-display); font-size: 3rem; font-weight: 300;
    color: var(--sand); line-height: 1; margin-bottom: 16px;
}
.mn-how__step-icon {
    width: 56px; height: 56px; margin: 0 auto 20px;
    background: rgba(123,111,160,.1); border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; color: #7B6FA0;
}
.mn-how__step-title {
    font-family: var(--font-display); font-size: 1.3rem; font-weight: 500;
    color: var(--charcoal); margin-bottom: 10px;
}
.mn-how__step-text { font-size: 0.86rem; color: var(--warm-400); line-height: 1.65; }
.mn-how__connector { font-size: 1.2rem; color: var(--sand); flex-shrink: 0; margin: 0 8px; }

/* MN Also try */
.mn-also { padding: 72px 0; }
.mn-also__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.mn-also__eyebrow {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--gold); background: rgba(201,169,110,.1); border: 1px solid rgba(201,169,110,.2);
    padding: 5px 14px; border-radius: var(--radius-pill); margin-bottom: 16px;
}
.mn-also__title {
    font-family: var(--font-display); font-size: clamp(1.8rem,3vw,2.6rem);
    font-weight: 400; color: var(--charcoal); line-height: 1.15; margin-bottom: 16px;
}
.mn-also__title em { font-style: italic; color: var(--rose); }
.mn-also__desc { font-size: 0.95rem; color: var(--warm-400); line-height: 1.7; margin-bottom: 28px; }
.mn-also__visual {
    position: relative; border-radius: var(--radius-lg);
    overflow: hidden; box-shadow: var(--shadow-md);
}
.mn-also__visual img { width: 100%; aspect-ratio: 3/2; object-fit: cover; }
.mn-also__badge {
    position: absolute; bottom: 16px; left: 16px;
    background: var(--gold); color: var(--charcoal);
    padding: 6px 14px; border-radius: var(--radius-pill);
    font-size: 0.75rem; font-weight: 700;
    display: flex; align-items: center; gap: 6px;
}


/* ── 10. OCC (OCCASION) PAGE ────────────────────────────────── */

.occ-hero {
    background: var(--occ-bg, var(--ivory));
    padding-top: calc(var(--promise-h) + var(--header-h) + 40px);
    padding-bottom: 56px;
    border-bottom: 1px solid var(--occ-border, var(--sand));
}
.occ-hero__content { max-width: 720px; }
.occ-hero__emoji { font-size: 3.5rem; line-height: 1; margin-bottom: 16px; display: block; }
.occ-hero__eyebrow {
    font-size: 0.72rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--occ-color, var(--rose)); margin-bottom: 16px;
}
.occ-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.6rem,5vw,4.5rem); font-weight: 300; color: var(--charcoal);
    line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 20px;
}
.occ-hero__title em { font-style: italic; color: var(--occ-color, var(--rose)); }
.occ-hero__desc {
    font-size: 1rem; color: var(--warm-400); line-height: 1.75;
    margin-bottom: 28px; max-width: 560px;
}
.occ-hero__pills { display: flex; flex-wrap: wrap; gap: 10px; }
.occ-hero__pill {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 16px; background: var(--white);
    border: 1px solid var(--occ-border, var(--sand));
    border-radius: var(--radius-pill);
    font-size: 0.8rem; font-weight: 600; color: var(--warm-500);
}
.occ-hero__pill .bi-lightning-charge-fill { color: var(--gold); }
.occ-hero__pill .bi-moon-stars-fill       { color: #7B6FA0; }
.occ-hero__pill .bi-camera-fill           { color: var(--rose); }

/* Occasion nav */
.occ-nav { padding: 20px 0; border-bottom: 1px solid var(--sand); }
.occ-nav__wrap { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.occ-nav__label { font-size: 0.8rem; color: var(--warm-300); font-weight: 600; white-space: nowrap; }
.occ-nav__chip {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 7px 16px; background: var(--ivory); border: 1px solid var(--sand);
    border-radius: var(--radius-pill); font-size: 0.82rem; color: var(--warm-500); transition: all 0.2s;
}
.occ-nav__chip:hover { background: var(--rose-bg); border-color: var(--rose-lighter); color: var(--rose); }

.occ-products { padding-top: 48px; }

/* Occasion empty */
.occ-empty { text-align: center; padding: 80px 20px; }
.occ-empty__emoji { font-size: 4rem; margin-bottom: 24px; }
.occ-empty__title {
    font-family: var(--font-display); font-size: clamp(1.6rem,3vw,2.4rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 16px;
}
.occ-empty__title em { color: var(--rose); font-style: italic; }
.occ-empty__text {
    font-size: 0.95rem; color: var(--warm-400);
    max-width: 500px; margin: 0 auto 32px; line-height: 1.7;
}
.occ-empty__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 48px; }
.occ-empty__cats p  { font-size: 0.88rem; color: var(--warm-400); margin-bottom: 14px; }
.occ-empty__cat-row { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.occ-empty__cat-btn {
    padding: 10px 22px; background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius); font-size: 0.86rem; font-weight: 600;
    color: var(--warm-500); transition: all 0.2s;
}
.occ-empty__cat-btn:hover { border-color: var(--rose); color: var(--rose); }

/* Occasions grid */
.occ-others { padding-top: 72px; }
.occ-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 16px; }
.occ-grid__card {
    display: flex; flex-direction: column; align-items: center; gap: 10px;
    padding: 24px 16px; background: var(--ivory); border: 1px solid var(--sand);
    border-radius: var(--radius-lg); text-align: center;
    transition: all 0.25s var(--ease); position: relative;
}
.occ-grid__card:hover {
    background: var(--rose-bg); border-color: var(--rose-lighter);
    transform: translateY(-4px); box-shadow: var(--shadow-sm);
}
.occ-grid__card--active { background: var(--rose-bg); border-color: var(--rose-lighter); box-shadow: var(--shadow-sm); }
.occ-grid__icon {
    width: 48px; height: 48px; background: var(--white); border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--rose);
}
.occ-grid__name { font-size: 0.82rem; font-weight: 600; color: var(--warm-500); line-height: 1.3; }
.occ-grid__current {
    position: absolute; top: -8px; right: -8px;
    background: var(--rose); color: var(--white);
    font-size: 0.6rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
    padding: 3px 8px; border-radius: var(--radius-pill);
}

/* OCC Trust */
.occ-trust { padding: 64px 0; }
.occ-trust__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 32px; }
.occ-trust__item { display: flex; align-items: flex-start; gap: 14px; }
.occ-trust__icon {
    width: 44px; height: 44px; flex-shrink: 0;
    background: var(--rose-bg); border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; color: var(--rose);
}
.occ-trust__title { font-size: 0.92rem; font-weight: 600; color: var(--charcoal); margin-bottom: 5px; }
.occ-trust__text  { font-size: 0.82rem; color: var(--warm-400); line-height: 1.6; }

/* Shared section labels */
.section__eyebrow {
    font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--rose); margin-bottom: 14px;
}
.section__title {
    font-family: var(--font-display); font-size: clamp(2rem,3.5vw,3rem);
    font-weight: 400; color: var(--charcoal); letter-spacing: -0.02em;
}
.section__title em { font-style: italic; color: var(--rose); }


/* ── 11. SD (SAME-DAY) PAGE ─────────────────────────────────── */

.sd-hero {
    position: relative; min-height: 480px;
    display: flex; align-items: flex-end;
    background: var(--charcoal);
    padding-top: calc(var(--promise-h) + var(--header-h)); overflow: hidden;
}
.sd-hero__img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover; object-position: center 40%;
    z-index: 0;
}
.sd-hero__overlay {
    position: absolute; inset: 0; z-index: 1;
    background: linear-gradient(135deg, rgba(26,23,20,0.88) 0%, rgba(42,36,32,0.72) 100%);
}
.sd-hero::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 70% 50%, rgba(181,113,90,.18) 0%, transparent 70%);
    z-index: 1;
}
.sd-hero .container { position: relative; z-index: 2; }
.sd-hero__content { padding: 64px 0 72px; }
.sd-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--gold); background: rgba(201,169,110,.12);
    border: 1px solid rgba(201,169,110,.25);
    padding: 6px 16px; border-radius: var(--radius-pill);
    margin-top: 24px; margin-bottom: 20px;
}
.sd-hero__title {
    font-family: var(--font-display); font-size: clamp(2.8rem,5vw,5rem); font-weight: 300;
    color: var(--white); line-height: 1.08; letter-spacing: -0.02em; margin-bottom: 20px;
}
.sd-hero__title em { color: var(--rose-lighter); font-style: italic; }
.sd-hero__desc {
    font-size: 1.05rem; color: rgba(255,255,255,.6);
    max-width: 520px; line-height: 1.7; margin-bottom: 36px;
}
.sd-hero__desc strong { color: var(--gold); }

/* Countdown */
.sd-hero__countdown {
    display: inline-flex; flex-direction: column;
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius-lg); padding: 20px 28px;
    margin-bottom: 28px; backdrop-filter: blur(8px);
}
.sd-hero__countdown-label {
    font-size: 0.68rem; font-weight: 600; letter-spacing: 0.12em;
    text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: 10px;
}
.sd-hero__countdown-timer { display: flex; align-items: center; gap: 8px; }
.sd-hero__countdown-unit { display: flex; flex-direction: column; align-items: center; min-width: 52px; }
.sd-hero__countdown-unit span {
    font-family: var(--font-display); font-size: 2.2rem; font-weight: 300;
    color: var(--white); line-height: 1;
}
.sd-hero__countdown-unit small {
    font-size: 0.6rem; letter-spacing: 0.1em; color: rgba(255,255,255,.35);
    text-transform: uppercase; margin-top: 4px;
}
.sd-hero__countdown-sep {
    font-size: 1.8rem; color: rgba(255,255,255,.2);
    font-family: var(--font-display); align-self: flex-start; padding-top: 2px;
}
.sd-hero__countdown--expired { opacity: 0.5; }

/* Badges */
.sd-hero__badges { display: flex; flex-wrap: wrap; gap: 14px; }
.sd-hero__badge { display: inline-flex; align-items: center; gap: 8px; font-size: 0.82rem; color: rgba(255,255,255,.65); }
.sd-hero__badge i { color: var(--gold); }

/* Category chips */
.sd-cats { padding: 28px 0; }
.sd-cats__wrap { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.sd-cat-chip {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 20px; background: var(--ivory); border: 1px solid var(--sand);
    border-radius: var(--radius-pill); font-size: 0.86rem; font-weight: 500;
    color: var(--warm-500); transition: all 0.2s;
}
.sd-cat-chip:hover { background: var(--rose-bg); border-color: var(--rose-lighter); color: var(--rose); }
.sd-cat-chip__bolt { color: var(--gold); font-size: 0.8em; }

.products-listing { padding-top: 48px; }

/* SD Trust */
.sd-trust { padding: 72px 0; }
.sd-trust__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 32px; }
.sd-trust__item { display: flex; gap: 16px; align-items: flex-start; }
.sd-trust__icon {
    width: 48px; height: 48px; flex-shrink: 0; background: var(--rose-bg);
    border-radius: 14px; display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; color: var(--rose);
}
.sd-trust__title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; color: var(--charcoal); margin-bottom: 6px; }
.sd-trust__text  { font-size: 0.85rem; color: var(--warm-400); line-height: 1.6; }


/* ── 12. SEARCH PAGE ────────────────────────────────────────── */

.search-page { padding-top: 48px; padding-bottom: var(--section-v); }
.search-page__bar { margin-bottom: 40px; }
.search-page__form { display: flex; gap: 12px; max-width: 760px; }
.search-page__input-wrap { flex: 1; position: relative; display: flex; align-items: center; }
.search-page__icon {
    position: absolute; left: 18px; font-size: 1rem;
    color: var(--warm-300); pointer-events: none;
}
.search-page__input {
    width: 100%; padding: 16px 48px; background: var(--ivory);
    border: 2px solid var(--sand); border-radius: var(--radius);
    font-size: 1rem; color: var(--charcoal);
    transition: border-color 0.25s, box-shadow 0.25s;
}
.search-page__input:focus { border-color: var(--rose-light); box-shadow: 0 0 0 4px var(--rose-glow); outline: none; }
.search-page__clear { position: absolute; right: 16px; color: var(--warm-300); font-size: 0.85rem; transition: color 0.2s; }
.search-page__clear:hover { color: var(--rose); }
.search-page__submit {
    padding: 16px 32px; background: var(--charcoal); color: var(--white);
    border-radius: var(--radius); font-size: 0.9rem; font-weight: 600;
    display: flex; align-items: center; gap: 8px;
    transition: background 0.25s, transform 0.2s; white-space: nowrap;
}
.search-page__submit:hover { background: var(--rose); transform: translateY(-1px); }

.search-page__meta {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 16px; margin-bottom: 40px;
    padding-bottom: 24px; border-bottom: 1px solid var(--sand);
}
.search-page__count { font-size: 1rem; color: var(--warm-400); }
.search-page__count strong { color: var(--charcoal); font-size: 1.05rem; }
.search-page__count em   { color: var(--rose); font-style: italic; }
.search-page__suggestions {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    font-size: 0.82rem; color: var(--warm-300);
}
.search-page__pill {
    padding: 4px 12px; background: var(--cream); border: 1px solid var(--sand);
    border-radius: var(--radius-pill); font-size: 0.78rem; color: var(--warm-500); transition: all 0.2s;
}
.search-page__pill:hover { border-color: var(--rose-light); color: var(--rose); background: var(--rose-bg); }

.search-page__layout { display: grid; grid-template-columns: 260px 1fr; gap: 48px; align-items: start; }
.search-page__sidebar {
    background: var(--ivory); border-radius: var(--radius-lg); padding: 28px 22px;
    position: sticky; top: calc(var(--header-h) + var(--promise-h) + 16px);
}

.search-cat-link {
    display: flex; align-items: center; gap: 8px; padding: 8px 10px;
    border-radius: var(--radius); font-size: 0.86rem; color: var(--warm-500);
    transition: background 0.2s, color 0.2s;
}
.search-cat-link:hover { background: var(--cream); color: var(--rose); }
.search-cat-link i { font-size: 0.7rem; color: var(--warm-200); }
.search-cat-count { margin-left: auto; font-size: 0.72rem; color: var(--warm-300); }

.search-delivery-link {
    display: flex; align-items: center; gap: 8px; padding: 10px 14px;
    border-radius: var(--radius); font-size: 0.86rem; color: var(--warm-500);
    border: 1px solid var(--sand); background: var(--white); transition: all 0.2s;
}
.search-delivery-link:hover { border-color: var(--rose-light); color: var(--rose); background: var(--rose-bg); }
.search-delivery-link .bi-lightning-charge-fill { color: var(--gold); }
.search-delivery-link .bi-moon-stars-fill { color: #7B6FA0; }

.search-popular { display: flex; flex-wrap: wrap; gap: 8px; }
.search-popular__tag {
    padding: 5px 12px; background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius-pill); font-size: 0.78rem; color: var(--warm-500); transition: all 0.2s;
}
.search-popular__tag:hover,
.search-popular__tag.active { background: var(--rose-bg); border-color: var(--rose-lighter); color: var(--rose); }

/* Search empty */
.search-empty { text-align: center; padding: 80px 20px; }
.search-empty__icon {
    width: 80px; height: 80px; margin: 0 auto 28px; background: var(--cream);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: var(--warm-300);
}
.search-empty__title {
    font-family: var(--font-display); font-size: clamp(1.6rem,3vw,2.4rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 14px; line-height: 1.2;
}
.search-empty__title em { color: var(--rose); font-style: italic; }
.search-empty__text {
    font-size: 0.95rem; color: var(--warm-400); max-width: 480px; margin: 0 auto 32px; line-height: 1.7;
}
.search-empty__suggestions {
    display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 40px;
}
.search-empty__chip {
    display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px;
    background: var(--ivory); border: 1px solid var(--sand); border-radius: var(--radius-pill);
    font-size: 0.86rem; color: var(--warm-500); transition: all 0.2s;
}
.search-empty__chip:hover { border-color: var(--rose-light); color: var(--rose); background: var(--rose-bg); }
.search-empty__cats p { font-size: 0.88rem; color: var(--warm-400); margin-bottom: 14px; }
.search-empty__cat-row { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.search-empty__cat-btn {
    padding: 10px 24px; background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius); font-size: 0.86rem; font-weight: 600;
    color: var(--warm-500); transition: all 0.2s;
}
.search-empty__cat-btn:hover { border-color: var(--rose); color: var(--rose); }


/* ── 13. REMF (REMINDER FORM) ───────────────────────────────── */

.remf {
    background: var(--ivory);
    min-height: calc(100vh - var(--header-h) - var(--promise-h));
    padding: 60px 0 80px;
}
.remf__layout { display: grid; grid-template-columns: 1fr 360px; gap: 32px; align-items: start; }
.remf__header { margin-bottom: 28px; }
.remf__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    color: var(--rose); margin-bottom: 10px;
}
.remf__title {
    font-family: var(--font-display); font-size: clamp(1.8rem,3vw,2.4rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 6px; line-height: 1.2;
}
.remf__title em { font-style: italic; color: var(--rose); }
.remf__sub { font-size: .9rem; color: var(--warm-500); }

.remf-card { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.remf-card__body { padding: 36px; }
.remf-section {
    font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    color: var(--rose); margin: 28px 0 16px; padding-bottom: 8px;
    border-bottom: 1px solid var(--rose-lighter);
}
.remf-section:first-of-type { margin-top: 0; }
.remf-field { margin-bottom: 20px; }
.remf-field label {
    display: block; font-size: .75rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    color: var(--warm-500); margin-bottom: 8px;
}
.remf-field__wrap { position: relative; }
.remf-field__wrap i {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    color: var(--warm-400); font-size: .9rem; pointer-events: none;
}
.remf-input {
    width: 100%; height: 50px; padding: 0 14px 0 40px;
    border: 1.5px solid var(--warm-200); border-radius: var(--radius);
    font-family: var(--font-body); font-size: .95rem; color: var(--charcoal);
    background: var(--cream); outline: none;
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.remf-input::placeholder { color: var(--warm-400); }
.remf-input:focus { border-color: var(--rose); background: var(--white); box-shadow: 0 0 0 3px rgba(180,100,120,.1); }
.remf-input.is-invalid { border-color: var(--error); background: #fff5f5; }
.remf-input.no-icon { padding-left: 14px; }

.remf-occasions { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 20px; }
.remf-occ-card { position: relative; cursor: pointer; }
.remf-occ-card input[type="radio"] { display: none; }
.remf-occ-card__inner {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 6px; padding: 14px 8px;
    border: 2px solid var(--warm-100); border-radius: var(--radius);
    background: var(--cream); transition: all .2s; text-align: center;
}
.remf-occ-card__emoji { font-size: 1.6rem; line-height: 1; }
.remf-occ-card__name  { font-size: .72rem; font-weight: 500; color: var(--warm-500); line-height: 1.3; }
.remf-occ-card:hover .remf-occ-card__inner,
.remf-occ-card input:checked + .remf-occ-card__inner { border-color: var(--rose); background: var(--rose-bg); }
.remf-occ-card input:checked + .remf-occ-card__inner .remf-occ-card__name { color: var(--rose-dark); font-weight: 700; }

.remf-slider-wrap { padding: 8px 0; }
.remf-slider {
    -webkit-appearance: none; width: 100%; height: 4px; border-radius: 2px;
    background: linear-gradient(to right, var(--rose) 0%, var(--rose) var(--fill,20%), var(--warm-100) var(--fill,20%));
    outline: none; cursor: pointer; margin-bottom: 10px;
}
.remf-slider::-webkit-slider-thumb {
    -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%;
    background: var(--rose); border: 3px solid #fff;
    box-shadow: 0 2px 6px rgba(180,100,120,.3); cursor: pointer; transition: transform .15s;
}
.remf-slider::-webkit-slider-thumb:hover { transform: scale(1.2); }
.remf-slider-labels { display: flex; justify-content: space-between; font-size: .72rem; color: var(--warm-400); }
.remf-slider-val { text-align: center; font-size: .9rem; font-weight: 600; color: var(--charcoal); margin-bottom: 6px; }
.remf-slider-val span { color: var(--rose); }

.remf-field__error { margin-top: 5px; font-size: .76rem; color: var(--error); display: flex; align-items: center; gap: 5px; }
.remf-field__hint  { margin-top: 5px; font-size: .76rem; color: var(--warm-400); display: flex; align-items: center; gap: 5px; }
.remf-error {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 18px; background: #fff5f5; border: 1px solid #ffd5d5;
    border-radius: var(--radius); margin-bottom: 24px;
    font-size: .88rem; color: #b91c1c;
}
.remf-actions { display: flex; align-items: center; gap: 14px; padding-top: 8px; flex-wrap: wrap; }
.remf-btn {
    flex: 1; min-width: 160px; height: 52px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
    background: var(--rose); color: var(--white); border: none;
    border-radius: var(--radius-pill); font-family: var(--font-body);
    font-size: .95rem; font-weight: 600; cursor: pointer;
    transition: background .2s, transform .15s, box-shadow .2s;
}
.remf-btn:hover { background: var(--rose-dark); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(180,100,120,.3); }
.remf-btn-cancel {
    font-size: .88rem; color: var(--warm-400); text-decoration: none;
    padding: 8px 16px; border-radius: var(--radius-pill); transition: color .2s, background .2s;
}
.remf-btn-cancel:hover { color: var(--charcoal); background: var(--warm-100); }
.remf-btn-delete {
    display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px;
    border-radius: var(--radius-pill); border: 1.5px solid #fecaca;
    background: transparent; color: #ef4444; font-family: var(--font-body);
    font-size: .82rem; font-weight: 500; cursor: pointer; transition: all .2s;
}
.remf-btn-delete:hover { background: #fff5f5; border-color: #ef4444; }

/* REMF Sidebar */
.remf-sidebar {
    position: sticky; top: calc(var(--header-h) + 24px);
    display: flex; flex-direction: column; gap: 16px;
}
.remf-info-card { background: var(--white); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-sm); }
.remf-info-card__title {
    font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--warm-400); margin-bottom: 16px;
    display: flex; align-items: center; gap: 8px;
}
.remf-info-card__title i { color: var(--rose); }
.remf-existing {
    padding: 16px 20px; background: var(--cream);
    border-radius: var(--radius); border: 1px solid var(--warm-100); margin-bottom: 24px;
}
.remf-existing__label {
    font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--warm-400); margin-bottom: 8px;
}
.remf-existing__detail { font-size: .85rem; color: var(--warm-600); line-height: 1.7; }
.remf-existing__detail strong { color: var(--charcoal); }


/* ── 14. REM (REMINDERS INDEX) ──────────────────────────────── */

.rem {
    background: var(--ivory);
    min-height: calc(100vh - var(--header-h) - var(--promise-h));
    padding: 60px 0 80px;
}
.rem__top {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 20px; margin-bottom: 40px; flex-wrap: wrap;
}
.rem__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    color: var(--rose); margin-bottom: 10px;
}
.rem__title {
    font-family: var(--font-display); font-size: clamp(1.8rem,3vw,2.4rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 6px; line-height: 1.2;
}
.rem__sub { font-size: .9rem; color: var(--warm-500); }
.rem__cta {
    display: inline-flex; align-items: center; gap: 8px; padding: 13px 26px;
    background: var(--rose); color: var(--white); border-radius: var(--radius-pill);
    font-size: .88rem; font-weight: 600; text-decoration: none;
    transition: background .2s, transform .15s, box-shadow .2s;
    white-space: nowrap; flex-shrink: 0; margin-top: 4px;
}
.rem__cta:hover { background: var(--rose-dark); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(180,100,120,.3); }

.rem-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 36px; }
.rem-stat {
    background: var(--white); border-radius: var(--radius-lg);
    padding: 20px 22px; box-shadow: var(--shadow-sm);
    display: flex; align-items: center; gap: 14px;
}
.rem-stat__icon {
    width: 44px; height: 44px; border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
}
.rem-stat--total  .rem-stat__icon { background: #f0f0f8; color: #6366f1; }
.rem-stat--active .rem-stat__icon { background: var(--rose-bg); color: var(--rose); }
.rem-stat--paused .rem-stat__icon { background: #fffbeb; color: #d97706; }
.rem-stat--soon   .rem-stat__icon { background: #f0faf5; color: var(--success); }
.rem-stat__val {
    font-family: var(--font-display); font-size: 1.6rem; font-weight: 400;
    color: var(--charcoal); line-height: 1; margin-bottom: 3px;
}
.rem-stat__label { font-size: .75rem; color: var(--warm-400); letter-spacing: .04em; }

.rem-flash {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 18px; border-radius: var(--radius);
    margin-bottom: 24px; font-size: .88rem;
}
.rem-flash.success { background: #f0faf5; border: 1px solid #a7e0c4; color: #2d7a55; }
.rem-flash.error   { background: #fff5f5; border: 1px solid #ffd5d5; color: #b91c1c; }

.rem-filters { display: flex; align-items: center; gap: 8px; margin-bottom: 24px; flex-wrap: wrap; }
.rem-filter-btn {
    padding: 7px 18px; border-radius: var(--radius-pill);
    border: 1.5px solid var(--warm-100); background: var(--white);
    font-family: var(--font-body); font-size: .82rem; font-weight: 500;
    color: var(--warm-500); cursor: pointer; transition: all .2s;
}
.rem-filter-btn:hover { border-color: var(--rose-lighter); color: var(--rose); background: var(--rose-bg); }
.rem-filter-btn.active { border-color: var(--rose); background: var(--rose); color: var(--white); }

/* Reminder cards */
.rem-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px,1fr)); gap: 20px; }
.rem-card {
    background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
    overflow: hidden; transition: box-shadow .25s, transform .2s;
    position: relative; border: 1.5px solid transparent;
}
.rem-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.rem-card.inactive { opacity: .7; border-color: var(--warm-100); }
.rem-card__badge {
    position: absolute; top: 14px; right: 14px;
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px; border-radius: var(--radius-pill);
    font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
}
.rem-card__badge.soon   { background: var(--rose-bg); color: var(--rose); }
.rem-card__badge.future { background: #f0faf5; color: var(--success); }
.rem-card__badge.past   { background: var(--warm-100); color: var(--warm-400); }
.rem-card__head { padding: 22px 22px 16px; display: flex; align-items: flex-start; gap: 14px; }
.rem-card__occ-icon {
    width: 46px; height: 46px; border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; background: var(--rose-bg); flex-shrink: 0;
}
.rem-card__info { flex: 1; min-width: 0; }
.rem-card__name {
    font-size: 1rem; font-weight: 600; color: var(--charcoal); margin-bottom: 2px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rem-card__occasion { font-size: .78rem; color: var(--rose); font-weight: 500; letter-spacing: .04em; }
.rem-card__body { padding: 0 22px 16px; display: flex; flex-direction: column; gap: 8px; }
.rem-card__meta { display: flex; align-items: center; gap: 8px; font-size: .82rem; color: var(--warm-500); }
.rem-card__meta i { color: var(--warm-300); font-size: .8rem; }
.rem-card__countdown {
    display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px;
    border-radius: var(--radius); background: var(--cream);
    font-size: .8rem; font-weight: 600; color: var(--charcoal); align-self: flex-start;
}
.rem-card__countdown.urgent { background: var(--rose-bg); color: var(--rose); }
.rem-card__countdown.due    { background: #f0faf5; color: var(--success); }
.rem-card__foot {
    padding: 14px 22px; border-top: 1px solid var(--warm-100);
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.rem-card__toggle { display: flex; align-items: center; gap: 8px; font-size: .78rem; color: var(--warm-400); }

/* Toggle switch */
.toggle-switch { position: relative; width: 38px; height: 22px; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-track {
    position: absolute; inset: 0; border-radius: 11px;
    background: var(--warm-200); cursor: pointer; transition: background .25s;
}
.toggle-track::before {
    content: ''; position: absolute;
    width: 16px; height: 16px; border-radius: 50%; background: #fff;
    left: 3px; top: 3px; transition: transform .25s;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.toggle-switch input:checked + .toggle-track { background: var(--rose); }
.toggle-switch input:checked + .toggle-track::before { transform: translateX(16px); }

.rem-card__actions { display: flex; align-items: center; gap: 6px; }
.rem-card__action {
    width: 32px; height: 32px; border-radius: var(--radius);
    border: 1.5px solid var(--warm-100); background: transparent;
    display: flex; align-items: center; justify-content: center;
    color: var(--warm-400); text-decoration: none; font-size: .85rem;
    cursor: pointer; transition: all .2s;
}
.rem-card__action:hover       { border-color: var(--rose-lighter); background: var(--rose-bg); color: var(--rose); }
.rem-card__action.delete:hover{ border-color: #fecaca; background: #fff5f5; color: #ef4444; }

/* REM Empty */
.rem-empty {
    grid-column: 1/-1; text-align: center; padding: 80px 24px;
    background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.rem-empty__icon { font-size: 3rem; color: var(--warm-200); margin-bottom: 20px; display: block; }
.rem-empty__title { font-family: var(--font-display); font-size: 1.4rem; color: var(--charcoal); margin-bottom: 8px; }
.rem-empty__sub {
    font-size: .9rem; color: var(--warm-400); margin-bottom: 28px;
    max-width: 360px; margin-left: auto; margin-right: auto; line-height: 1.6;
}
.rem-empty__btn {
    display: inline-flex; align-items: center; gap: 8px; padding: 12px 28px;
    background: var(--rose); color: var(--white); border-radius: var(--radius-pill);
    font-size: .9rem; font-weight: 600; text-decoration: none; transition: background .2s, transform .15s;
}
.rem-empty__btn:hover { background: var(--rose-dark); transform: translateY(-1px); }

/* Delete modal */
.modal-bg {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,.5); z-index: 9000;
    align-items: center; justify-content: center; padding: 20px;
}
.modal-bg.open { display: flex; }
.modal-box {
    background: var(--white); border-radius: var(--radius-lg);
    padding: 36px; max-width: 400px; width: 100%;
    box-shadow: var(--shadow-lg); text-align: center;
}
.modal-box__icon  { font-size: 2.4rem; color: #ef4444; margin-bottom: 16px; }
.modal-box__title { font-family: var(--font-display); font-size: 1.3rem; color: var(--charcoal); margin-bottom: 8px; }
.modal-box__sub   { font-size: .88rem; color: var(--warm-500); margin-bottom: 28px; line-height: 1.6; }
.modal-box__actions { display: flex; gap: 12px; justify-content: center; }
.modal-btn {
    padding: 11px 24px; border-radius: var(--radius-pill); border: none;
    font-family: var(--font-body); font-size: .9rem; font-weight: 600;
    cursor: pointer; text-decoration: none; transition: opacity .2s, transform .15s;
}
.modal-btn:hover   { opacity: .88; transform: translateY(-1px); }
.modal-btn.cancel  { background: var(--warm-100); color: var(--warm-600); }
.modal-btn.confirm { background: #ef4444; color: #fff; }


/* ── 15. RVW (REVIEW PAGE) ──────────────────────────────────── */

.rvw {
    background: var(--ivory);
    min-height: calc(100vh - var(--header-h) - var(--promise-h));
    padding: 60px 0 80px;
}
.rvw__layout { display: grid; grid-template-columns: 1fr 380px; gap: 32px; align-items: start; }
.rvw__header { margin-bottom: 32px; }
.rvw__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
    color: var(--rose); margin-bottom: 12px;
}
.rvw__title {
    font-family: var(--font-display); font-size: clamp(1.8rem,3vw,2.4rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 8px; line-height: 1.2;
}
.rvw__title em { font-style: italic; color: var(--rose); }
.rvw__sub { font-size: .9rem; color: var(--warm-500); line-height: 1.6; }

.rvw-card { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); overflow: hidden; }
.rvw-card__body { padding: 36px; }

/* Star rating */
.rvw-stars { margin-bottom: 32px; }
.rvw-stars__label {
    font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--warm-500); margin-bottom: 16px; display: block;
}
.rvw-stars__input {
    display: flex; gap: 8px; flex-direction: row-reverse; justify-content: flex-end;
}
.rvw-stars__input input[type="radio"] { display: none; }
.rvw-stars__input label {
    font-size: 2.4rem; color: var(--warm-200); cursor: pointer;
    transition: color .15s, transform .15s; line-height: 1; user-select: none;
}
.rvw-stars__input label:hover,
.rvw-stars__input label:hover ~ label,
.rvw-stars__input input:checked ~ label { color: #f59e0b; transform: scale(1.08); }
.rvw-stars__caption { margin-top: 12px; font-size: .85rem; font-weight: 500; color: var(--warm-400); min-height: 22px; transition: color .2s; }
.rvw-stars__caption.rated { color: #f59e0b; }

/* Product chips */
.rvw-products { margin-bottom: 28px; }
.rvw-products__label {
    font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--warm-500); margin-bottom: 12px; display: block;
}
.rvw-product-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.rvw-product-chip {
    display: flex; align-items: center; gap: 10px; padding: 10px 16px;
    border: 2px solid var(--warm-100); border-radius: var(--radius);
    cursor: pointer; transition: border-color .2s, background .2s; background: var(--cream);
}
.rvw-product-chip:hover { border-color: var(--rose-lighter); background: var(--rose-bg); }
.rvw-product-chip input[type="radio"] { display: none; }
.rvw-product-chip.selected { border-color: var(--rose); background: var(--rose-bg); }
.rvw-product-chip__img {
    width: 40px; height: 40px; border-radius: 8px;
    object-fit: cover; background: var(--warm-100); flex-shrink: 0;
}
.rvw-product-chip__img-placeholder {
    width: 40px; height: 40px; border-radius: 8px; background: var(--warm-100);
    display: flex; align-items: center; justify-content: center;
    color: var(--warm-300); font-size: 1rem; flex-shrink: 0;
}
.rvw-product-chip__name {
    font-size: .85rem; font-weight: 500; color: var(--charcoal);
    max-width: 160px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Comment / photo */
.rvw-field { margin-bottom: 24px; }
.rvw-field label {
    display: block; font-size: .75rem; font-weight: 700; letter-spacing: .1em;
    text-transform: uppercase; color: var(--warm-500); margin-bottom: 8px;
}
.rvw-field textarea {
    width: 100%; min-height: 130px; padding: 14px 16px;
    border: 1.5px solid var(--warm-200); border-radius: var(--radius);
    font-family: var(--font-body); font-size: .95rem; color: var(--charcoal);
    background: var(--cream); resize: vertical; outline: none;
    transition: border-color .2s, box-shadow .2s, background .2s; line-height: 1.6;
}
.rvw-field textarea::placeholder { color: var(--warm-400); }
.rvw-field textarea:focus { border-color: var(--rose); background: var(--white); box-shadow: 0 0 0 3px rgba(180,100,120,.1); }
.rvw-field__count { margin-top: 6px; text-align: right; font-size: .75rem; color: var(--warm-300); }

.rvw-photos { margin-bottom: 28px; }
.rvw-photos__label {
    display: flex; align-items: center; justify-content: space-between;
    font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--warm-500); margin-bottom: 10px;
}
.rvw-photos__opt { font-size: .7rem; font-weight: 400; color: var(--warm-300); letter-spacing: 0; text-transform: none; }
.rvw-upload-zone {
    border: 2px dashed var(--warm-200); border-radius: var(--radius);
    padding: 24px; text-align: center; cursor: pointer;
    transition: border-color .2s, background .2s; background: var(--cream);
}
.rvw-upload-zone:hover { border-color: var(--rose-lighter); background: var(--rose-bg); }
.rvw-upload-zone i { font-size: 1.6rem; color: var(--warm-300); display: block; margin-bottom: 8px; }
.rvw-upload-zone p { font-size: .82rem; color: var(--warm-400); margin: 0; }
.rvw-upload-zone span { color: var(--rose); font-weight: 500; }

.rvw-submit-wrap { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.rvw-btn {
    flex: 1; min-width: 180px; height: 52px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
    background: var(--rose); color: var(--white); border: none;
    border-radius: var(--radius-pill); font-family: var(--font-body);
    font-size: .95rem; font-weight: 600; letter-spacing: .04em;
    cursor: pointer; transition: background .2s, transform .15s, box-shadow .2s;
}
.rvw-btn:hover { background: var(--rose-dark); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(180,100,120,.3); }
.rvw-btn:disabled { background: var(--warm-200); color: var(--warm-400); cursor: not-allowed; transform: none; box-shadow: none; }
.rvw-btn-cancel {
    font-size: .88rem; color: var(--warm-400); text-decoration: none;
    padding: 8px 16px; border-radius: var(--radius-pill); transition: color .2s, background .2s;
}
.rvw-btn-cancel:hover { color: var(--charcoal); background: var(--warm-100); }
.rvw-error {
    display: flex; align-items: flex-start; gap: 12px; padding: 14px 18px;
    background: #fff5f5; border: 1px solid #ffd5d5; border-radius: var(--radius);
    margin-bottom: 24px; font-size: .88rem; color: #b91c1c;
}

/* RVW sidebar / order card */
.rvw-order-card {
    background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
    overflow: hidden; position: sticky; top: calc(var(--header-h) + 24px);
}
.rvw-order-card__head {
    padding: 20px 24px; background: var(--charcoal);
    display: flex; align-items: center; gap: 12px;
}
.rvw-order-card__head i { color: var(--rose); font-size: 1rem; }
.rvw-order-card__num  { font-size: .78rem; font-weight: 600; color: rgba(255,255,255,.9); letter-spacing: .06em; }
.rvw-order-card__date { font-size: .72rem; color: rgba(255,255,255,.45); margin-top: 2px; }
.rvw-order-card__body { padding: 20px 24px; }
.rvw-order-item {
    display: flex; align-items: center; gap: 12px; padding: 10px 0;
    border-bottom: 1px solid var(--warm-100);
}
.rvw-order-item:last-child { border-bottom: none; }
.rvw-order-item__img {
    width: 44px; height: 44px; border-radius: var(--radius);
    object-fit: cover; background: var(--cream); flex-shrink: 0;
}
.rvw-order-item__img-ph {
    width: 44px; height: 44px; border-radius: var(--radius); background: var(--cream);
    display: flex; align-items: center; justify-content: center; color: var(--warm-300); flex-shrink: 0;
}
.rvw-order-item__name { font-size: .85rem; font-weight: 500; color: var(--charcoal); }
.rvw-order-item__qty  { font-size: .75rem; color: var(--warm-400); margin-top: 2px; }

/* Tips */
.rvw-tips { margin-top: 16px; background: var(--white); border-radius: var(--radius-lg); padding: 20px 24px; box-shadow: var(--shadow-sm); }
.rvw-tips__title {
    font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
    color: var(--warm-400); margin-bottom: 12px;
}
.rvw-tips__item {
    display: flex; align-items: flex-start; gap: 10px; font-size: .82rem;
    color: var(--warm-500); margin-bottom: 10px; line-height: 1.5;
}
.rvw-tips__item i { color: var(--rose); margin-top: 2px; font-size: .8rem; flex-shrink: 0; }


/* ── 16. DASHBOARD ──────────────────────────────────────────── */

.dashboard-header {
    padding: 60px 0 40px;
    background: linear-gradient(135deg, var(--rose-bg) 0%, var(--ivory) 100%);
    margin-top: calc(var(--promise-h) + var(--header-h));
    border-bottom: 1px solid var(--sand);
    overflow: hidden;
}
.dashboard-header__content { display: flex; flex-direction: column; gap: 32px; }
.dashboard-welcome { margin-bottom: 0; }
.dashboard-welcome__title {
    font-family: var(--font-display); font-size: clamp(2rem,4vw,2.8rem);
    font-weight: 400; color: var(--charcoal); margin-bottom: 8px;
}
.dashboard-welcome__subtitle { font-size: 1rem; color: var(--warm-400); }
.dashboard-quick-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.quick-stat-card {
    display: flex; align-items: center; gap: 16px; padding: 24px;
    background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius-lg); transition: all 0.3s var(--ease);
}
.quick-stat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--rose-lighter); }
.quick-stat-card__icon {
    width: 56px; height: 56px; background: var(--rose-bg); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; color: var(--rose); flex-shrink: 0;
}
.quick-stat-card__value {
    font-family: var(--font-display); font-size: 2rem; font-weight: 500;
    color: var(--charcoal); line-height: 1; margin-bottom: 4px;
}
.quick-stat-card__label { font-size: 0.8rem; color: var(--warm-400); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.dashboard-content { padding-top: 60px; padding-bottom: 80px; overflow-x: hidden; }
.dashboard-layout { display: grid; grid-template-columns: 1fr 380px; gap: 40px; align-items: start; max-width: 100%; overflow: hidden; }
.dashboard-main { min-width: 0; overflow: hidden; }
.dashboard-sidebar { min-width: 0; }
.dashboard-section { margin-bottom: 48px; }
.dashboard-section__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.dashboard-section__title {
    font-family: var(--font-display); font-size: 1.6rem; font-weight: 500;
    color: var(--charcoal); display: flex; align-items: center; gap: 12px;
}
.dashboard-section__title i { color: var(--rose); font-size: 1.4rem; }
.dashboard-section__link {
    font-size: 0.9rem; font-weight: 600; color: var(--rose);
    display: flex; align-items: center; gap: 6px; transition: all 0.2s;
}
.dashboard-section__link:hover { gap: 10px; }

/* Orders */
.active-orders { display: grid; gap: 20px; }
.order-card {
    background: var(--white); border: 1px solid var(--sand);
    border-radius: var(--radius-lg); overflow: hidden; transition: all 0.3s; max-width: 100%;
}
.order-card:hover { box-shadow: var(--shadow-md); border-color: var(--rose-lighter); }
.order-card__header {
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px;
    padding: 20px 24px; background: var(--ivory); border-bottom: 1px solid var(--sand);
}
.order-card__number { font-size: 0.95rem; font-weight: 700; color: var(--charcoal); display: flex; align-items: center; gap: 8px; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.order-card__number i { color: var(--rose); }
.order-status-badge {
    padding: 6px 14px; border-radius: var(--radius-pill);
    font-size: 0.75rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
    white-space: nowrap; flex-shrink: 0;
}
.order-status-badge--pending          { background: rgba(201,169,110,.2); color: var(--gold); }
.order-status-badge--confirmed        { background: rgba(90,154,110,.2); color: var(--success); }
.order-status-badge--preparing        { background: rgba(135,158,216,.2); color: #5577D8; }
.order-status-badge--out_for_delivery { background: rgba(181,113,90,.2); color: var(--rose); }
.order-status-badge--delivered        { background: rgba(90,154,110,.2); color: var(--success); }
.order-status-badge--cancelled        { background: rgba(238,90,111,.2); color: #ee5a6f; }
.order-card__body { padding: 24px; overflow: hidden; }
.order-card__items { display: flex; gap: 8px; margin-bottom: 16px; }
.order-item-mini {
    width: 48px; height: 48px; border-radius: var(--radius);
    overflow: hidden; border: 1px solid var(--sand); background: var(--cream);
}
.order-item-mini img { width: 100%; height: 100%; object-fit: cover; }
.order-item-mini--more {
    display: flex; align-items: center; justify-content: center;
    font-size: 0.75rem; font-weight: 700; color: var(--warm-400);
}
.order-card__details { display: flex; flex-wrap: wrap; gap: 16px; }
.order-detail-item { display: flex; align-items: center; gap: 6px; font-size: 0.85rem; color: var(--warm-500); min-width: 0; overflow-wrap: break-word; }
.order-detail-item i { color: var(--rose); }
.order-card__footer {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px 24px; background: var(--ivory); border-top: 1px solid var(--sand);
}
.order-card__amount { font-size: 0.95rem; color: var(--warm-500); }
.order-card__amount strong { font-size: 1.15rem; color: var(--rose); }
.order-card__actions { display: flex; gap: 8px; }

/* Recent orders table */
.recent-orders-table { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); overflow: hidden; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.orders-table { width: 100%; border-collapse: collapse; }
.orders-table thead { background: var(--ivory); }
.orders-table th {
    padding: 16px 20px; text-align: left;
    font-size: 0.8rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--warm-400); border-bottom: 1px solid var(--sand);
}
.orders-table td {
    padding: 16px 20px; font-size: 0.9rem; color: var(--warm-500);
    border-bottom: 1px solid var(--cream);
}
.orders-table tbody tr:last-child td { border-bottom: none; }
.orders-table tbody tr:hover { background: var(--ivory); }
.order-number-cell { font-weight: 700; color: var(--charcoal); }
.table-status-badge {
    display: inline-block; padding: 4px 10px; border-radius: 6px;
    font-size: 0.7rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
}
.table-status-badge--pending          { background: rgba(201,169,110,.2); color: var(--gold); }
.table-status-badge--confirmed        { background: rgba(90,154,110,.2); color: var(--success); }
.table-status-badge--preparing        { background: rgba(135,158,216,.2); color: #5577D8; }
.table-status-badge--out_for_delivery { background: rgba(181,113,90,.2); color: var(--rose); }
.table-status-badge--delivered        { background: rgba(90,154,110,.2); color: var(--success); }
.table-status-badge--cancelled        { background: rgba(238,90,111,.2); color: #ee5a6f; }
.table-action-btn {
    width: 32px; height: 32px; background: var(--cream); border-radius: 6px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1rem; color: var(--warm-500); transition: all 0.2s;
}
.table-action-btn:hover { background: var(--rose); color: var(--white); }

/* Recent orders — mobile horizontal scroll cards (hidden on desktop) */
.recent-orders--mobile { display: none; max-width: 100%; }
.recent-orders__scroll {
    display: flex; gap: 14px; overflow-x: auto; -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory; padding: 4px 0 16px;
    scrollbar-width: none;
}
.recent-orders__scroll::-webkit-scrollbar { display: none; }
.recent-order-chip {
    flex: 0 0 220px; scroll-snap-align: start;
    background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius);
    padding: 16px; display: flex; flex-direction: column; gap: 10px;
    text-decoration: none; transition: all 0.25s var(--ease);
}
.recent-order-chip:hover { border-color: var(--rose-lighter); box-shadow: var(--shadow-sm); }
.recent-order-chip__top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.recent-order-chip__number { font-size: 0.75rem; font-weight: 700; color: var(--charcoal); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.recent-order-chip__top .order-status-badge { font-size: 0.6rem; padding: 3px 8px; flex-shrink: 0; white-space: nowrap; }
.recent-order-chip__mid { display: flex; align-items: center; gap: 6px; }
.recent-order-chip__amount { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; color: var(--rose); }
.recent-order-chip__dot { color: var(--warm-300); }
.recent-order-chip__items { font-size: 0.78rem; color: var(--warm-400); }
.recent-order-chip__bottom { font-size: 0.72rem; color: var(--warm-400); display: flex; align-items: center; gap: 5px; }
.recent-order-chip__bottom i { font-size: 0.68rem; color: var(--warm-300); }

/* Reminders grid */
.reminders-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.reminder-card {
    display: flex; gap: 16px; padding: 20px; background: var(--white);
    border: 1px solid var(--sand); border-radius: var(--radius-lg); transition: all 0.3s;
}
.reminder-card:hover { box-shadow: var(--shadow-sm); border-color: var(--rose-lighter); }
.reminder-date-badge {
    width: 56px; height: 56px; background: var(--rose-bg);
    border-radius: var(--radius); display: flex; flex-direction: column;
    align-items: center; justify-content: center; flex-shrink: 0;
}
.reminder-date-badge__day   { font-family: var(--font-display); font-size: 1.5rem; font-weight: 500; color: var(--rose); line-height: 1; }
.reminder-date-badge__month { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--rose); }
.reminder-card__content { flex: 1; }
.reminder-card__occasion { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 4px; }
.reminder-card__name    { font-size: 1rem; font-weight: 700; color: var(--charcoal); margin-bottom: 4px; }
.reminder-card__days    { font-size: 0.8rem; color: var(--warm-500); }

/* Dashboard sidebar & widgets */
.dashboard-sidebar { position: sticky; top: calc(var(--header-h) + 24px); }
.dashboard-widget { background: var(--white); border: 1px solid var(--sand); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 24px; }
.dashboard-widget__title {
    font-size: 1.1rem; font-weight: 700; color: var(--charcoal);
    margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--sand);
}
.quick-actions { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.quick-action-btn {
    padding: 16px 12px; background: var(--ivory); border: 1px solid var(--sand);
    border-radius: var(--radius); text-align: center; text-decoration: none; transition: all 0.3s;
}
.quick-action-btn:hover { background: var(--rose); color: var(--white); border-color: var(--rose); transform: translateY(-2px); }
.quick-action-btn--active { background: var(--rose-bg); border-color: var(--rose); }
.quick-action-btn--active i    { color: var(--rose); }
.quick-action-btn--active span { color: var(--rose); font-weight: 700; }
.quick-action-btn i { display: block; font-size: 1.5rem; margin-bottom: 8px; color: var(--rose); }
.quick-action-btn:hover i   { color: var(--white); }
.quick-action-btn span      { display: block; font-size: 0.8rem; font-weight: 600; color: var(--charcoal); }
.quick-action-btn:hover span{ color: var(--white); }
.account-info      { display: flex; flex-direction: column; gap: 16px; margin-bottom: 20px; }
.account-info-row  { display: flex; gap: 12px; }
.account-info-row > i { font-size: 1.2rem; color: var(--rose); margin-top: 2px; }
.account-info-label{ font-size: 0.75rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 4px; }
.account-info-value{ font-size: 0.95rem; color: var(--charcoal); word-break: break-word; overflow-wrap: break-word; }
.saved-addresses   { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.address-card-mini { padding: 16px; background: var(--ivory); border-radius: var(--radius); }
.address-card-mini__label { font-size: 0.75rem; font-weight: 700; color: var(--rose); margin-bottom: 8px; display: flex; align-items: center; gap: 4px; }
.address-card-mini__text  { font-size: 0.85rem; color: var(--warm-500); line-height: 1.5; }
.address-more { font-size: 0.8rem; color: var(--warm-400); text-align: center; margin-bottom: 16px; }
.rewards-card {
    display: flex; align-items: center; gap: 16px; padding: 20px;
    background: linear-gradient(135deg, var(--rose-bg), var(--ivory));
    border-radius: var(--radius); margin-bottom: 12px;
}
.rewards-card__icon { width: 56px; height: 56px; background: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--rose); }
.rewards-card__label  { font-size: 0.75rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--warm-400); margin-bottom: 4px; }
.rewards-card__points { font-family: var(--font-display); font-size: 2rem; font-weight: 500; color: var(--charcoal); line-height: 1; margin-bottom: 4px; }
.rewards-card__value  { font-size: 0.85rem; color: var(--warm-500); }
.rewards-note { font-size: 0.75rem; color: var(--warm-400); display: flex; align-items: center; gap: 6px; }
.rewards-note i { color: var(--rose); }
.support-card { text-align: center; padding: 20px; background: var(--ivory); border-radius: var(--radius); }
.support-card__icon { width: 56px; height: 56px; margin: 0 auto 16px; background: var(--rose-bg); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--rose); }
.support-card__title { font-size: 1.05rem; font-weight: 700; color: var(--charcoal); margin-bottom: 8px; }
.support-card__text  { font-size: 0.85rem; color: var(--warm-400); margin-bottom: 16px; }


/* ── 17. CONSOLIDATED MEDIA QUERIES ─────────────────────────── */

/* — 1200px — */
@media (max-width: 1200px) {
    .dashboard-layout          { grid-template-columns: 1fr; gap: 32px; }
    .dashboard-sidebar         { position: static; display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
    .dashboard-widget          { margin-bottom: 0; }
}

/* — 1024px — */
@media (max-width: 1024px) {
    /* Category */
    .related-categories         { grid-template-columns: repeat(2,1fr); }
    .category-benefits-grid     { grid-template-columns: repeat(2,1fr); }

    /* FT */
    .ft-hero__grid              { grid-template-columns: 1fr; }
    .ft-hero__mosaic            { display: none; }
    .ft-layout                  { grid-template-columns: 1fr; }
    .ft-sidebar                 { position: static; }

    /* HIW */
    .hiw__step,
    .hiw__step--reverse         { grid-template-columns: 60px 1fr; grid-template-rows: auto auto; gap: 32px; }
    .hiw__step-num              { grid-column: 1; grid-row: 1; }
    .hiw__step-body             { grid-column: 2; grid-row: 1; }
    .hiw__step-visual,
    .hiw__step--reverse .hiw__step-visual { grid-column: 1/-1; grid-row: 2; order: unset; }
    .hiw__step--reverse .hiw__step-body   { grid-column: 2; grid-row: 1; }
    .hiw__step--reverse .hiw__step-num    { grid-column: 1; grid-row: 1; }
    .hiw__faq-grid              { grid-template-columns: 1fr; }
    .hiw__trust                 { padding: 28px 24px; }
    .hiw__trust-div             { height: 1px; width: 60%; }

    /* Products sidebar — smaller width on tablet */
    .products-listing__sidebar { width: 320px; }

    /* MN */
    .mn-also__inner             { grid-template-columns: 1fr; gap: 40px; }
    .mn-how__steps              { flex-direction: column; }
    .mn-how__connector          { transform: rotate(90deg); margin: 8px 0; }

    /* OCC */
    .occ-grid                   { grid-template-columns: repeat(3,1fr); }
    .occ-trust__grid            { grid-template-columns: repeat(2,1fr); }

    /* SD */
    .sd-trust__grid             { grid-template-columns: repeat(2,1fr); }

    /* Search */
    .search-page__layout        { grid-template-columns: 1fr; }
    .search-page__sidebar       { position: static; }

    /* REMF */
    .remf__layout               { grid-template-columns: 1fr; }
    .remf-sidebar               { position: static; flex-direction: row; flex-wrap: wrap; }
    .remf-info-card             { flex: 1; min-width: 240px; }

    /* RVW */
    .rvw__layout                { grid-template-columns: 1fr; }
    .rvw-order-card             { position: static; }
    .rvw-sidebar                { display: flex; gap: 16px; flex-wrap: wrap; }
    .rvw-order-card, .rvw-tips  { flex: 1; min-width: 260px; }
}

/* — 900px — */
@media (max-width: 900px) {
    .rem-stats { grid-template-columns: repeat(2,1fr); }
}

/* — 768px — */
@media (max-width: 768px) {
    /* Breadcrumb */
    .breadcrumb-section { padding: calc(var(--header-h) + 24px) 0 12px; }

    /* Category */
    .category-benefits-grid     { grid-template-columns: 1fr; gap: 24px; }
    .quick-filters              { flex-direction: column; align-items: flex-start; }
    .quick-filters__chips       { width: 100%; }
    .filter-sidebar-header      { display: flex; }
    .related-categories         { grid-template-columns: 1fr; }
    .featured-occasion__layout  { grid-template-columns: 1fr; gap: 40px; }

    /* Shared listing */
    .products-listing__header   { flex-direction: column; align-items: flex-start; }
    .products-listing__controls { width: 100%; justify-content: space-between; }
    .products-grid              { grid-template-columns: repeat(2, 1fr); gap: 16px; }

    /* FT */
    .ft-bar__inner              { flex-direction: column; align-items: flex-start; gap: .75rem; }
    .ft-grid                    { grid-template-columns: repeat(2,1fr); gap: .75rem; }

    /* HIW */
    .hiw__step,
    .hiw__step--reverse         { grid-template-columns: 1fr; padding: 40px 0; }
    .hiw__step-num              { font-size: 3rem; grid-column: 1; }
    .hiw__step-body,
    .hiw__step-visual,
    .hiw__step--reverse .hiw__step-visual { grid-column: 1; }
    .hiw__step--reverse .hiw__step-visual { order: unset; }
    .hiw__tracker               { padding: 16px 12px; gap: 0; overflow-x: auto; }
    .hiw__tracker-label         { font-size: 0.6rem; }
    .hiw__trust-item            { min-width: 50%; }
    .hiw__trust-div             { display: none; }
    .hiw__header                { margin-bottom: 48px; }
    .hiw__faq-item              { padding: 20px 22px; }

    /* MN */
    .mn-hero__title             { font-size: 2.6rem; }
    .mn-how__steps              { gap: 24px; }

    /* OCC */
    .occ-hero__title            { font-size: 2.6rem; }
    .occ-grid                   { grid-template-columns: repeat(2,1fr); }
    .occ-trust__grid            { grid-template-columns: 1fr; gap: 24px; }

    /* SD */
    .sd-hero__title             { font-size: 2.6rem; }
    .sd-trust__grid             { grid-template-columns: 1fr; gap: 24px; }
    .sd-cats__wrap              { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
    .sd-cat-chip                { flex: 0 0 auto; white-space: nowrap; }

    /* Search */
    .search-page__form          { flex-direction: column; }
    .search-page__submit        { justify-content: center; }
    .search-page__meta          { flex-direction: column; align-items: flex-start; }

    /* First-order banner */
    .first-order-banner__inner  { flex-direction: column; text-align: center; gap: 20px; }
    .first-order-banner__coupons { justify-content: center; }

    /* Dashboard */
    .dashboard-header           { padding: 48px 0 32px; }
    .dashboard-quick-stats      { grid-template-columns: repeat(2,1fr); gap: 14px; }
    .dashboard-content          { padding-top: 40px; padding-bottom: 60px; }
    .dashboard-sidebar          { grid-template-columns: 1fr; }
    .dashboard-widget           { margin-bottom: 0; }
    .reminders-grid             { grid-template-columns: 1fr; }
    .recent-orders--desktop     { display: none !important; }
    .recent-orders--mobile      { display: block !important; }
    .order-card__header         { padding: 16px 18px; }
    .order-card__body           { padding: 18px; }
    .order-card__footer         { flex-direction: column; align-items: flex-start; gap: 12px; padding: 16px 18px; }
    .order-card__actions        { width: 100%; }
    .order-card__actions .btn   { flex: 1; justify-content: center; }
    .order-detail-item          { font-size: 0.82rem; }
    .dashboard-section          { margin-bottom: 36px; }
    .dashboard-section__header  { flex-direction: column; align-items: flex-start; gap: 8px; }

    /* RVW */
    .rvw-stars__input label     { font-size: 2rem; }
    .rvw-product-chips          { flex-direction: column; }
    .rvw-product-chip__name     { max-width: 100%; white-space: normal; }
}

/* — 640px — */
@media (max-width: 640px) {
    .header__inner              { padding: 0 10px; }
    .remf { padding: 40px 0 60px; }
    .remf-card__body            { padding: 24px 20px; }
    .remf-occasions             { grid-template-columns: repeat(4,1fr); gap: 6px; }
    .remf-occ-card__inner       { padding: 10px 4px; }
    .remf-occ-card__emoji       { font-size: 1.3rem; }
    .remf-occ-card__name        { font-size: .62rem; }

    .rem { padding: 40px 0 60px; }
    .rem-stats                  { grid-template-columns: repeat(2,1fr); gap: 12px; }
    .rem-grid                   { grid-template-columns: 1fr; }
    .rem__top                   { flex-direction: column; }

    .rvw { padding: 40px 0 60px; }
    .rvw-card__body             { padding: 24px 20px; }
}

/* — 600px — */
@media (max-width: 600px) {
    .ft-hero { padding: 3.5rem 0 2.5rem; }
    .dashboard-header           { padding: 32px 0 20px; margin-top: var(--header-h); }
    .dashboard-welcome__title   { font-size: 1.5rem; }
    .dashboard-welcome__subtitle{ font-size: 0.88rem; }
    .dashboard-welcome          { margin-bottom: 20px; }
    .dashboard-content          { padding-top: 28px; padding-bottom: 48px; }
    .dashboard-section__title   { font-size: 1.15rem; }
    .dashboard-section__title i { font-size: 1.1rem; }
    .dashboard-section__link    { font-size: 0.82rem; }
    .dashboard-widget           { padding: 16px; }

    /* Order cards — stack layout for small phones */
    .order-card__footer         { flex-direction: column; align-items: stretch; gap: 10px; }
    .order-card__actions        { width: 100%; flex-direction: row; }
    .order-card__actions .btn   { flex: 1; justify-content: center; text-align: center; }
    .order-card__details        { flex-direction: column; gap: 8px; }
    .order-card__number         { font-size: 0.85rem; }
    .order-status-badge         { font-size: 0.68rem; padding: 5px 10px; }
    .order-card__amount         { font-size: 0.88rem; }

    /* Recent orders — force mobile cards */
    .recent-orders--desktop     { display: none !important; }
    .recent-orders--mobile      { display: block !important; }
    .recent-order-chip          { flex: 0 0 200px; padding: 14px; gap: 8px; }
    .recent-order-chip__amount  { font-size: 1rem; }

    /* Quick stat cards */
    .quick-stat-card            { padding: 16px; gap: 12px; }
    .quick-stat-card__icon      { width: 42px; height: 42px; font-size: 1.1rem; }
    .quick-stat-card__value     { font-size: 1.6rem; }

    /* Sidebar widgets */
    .quick-actions              { gap: 10px; }
    .quick-action-btn           { padding: 16px 12px; }
    .quick-action-btn i         { font-size: 1.3rem; }
    .account-info-value         { font-size: 0.88rem; word-break: break-all; }
    .rewards-card               { flex-direction: row; gap: 16px; align-items: center; }
    .rewards-card__icon         { width: 44px; height: 44px; font-size: 1.2rem; flex-shrink: 0; }
    .rewards-card__points       { font-size: 1.6rem; }
}

/* — 480px — */
@media (max-width: 480px) {
    /* FT */
    .ft-hero { padding: 2.5rem 0 2rem; }

    /* MN */
    .mn-hero { padding: 2.5rem 0 2rem; }
    .mn-hero__title             { font-size: clamp(1.6rem,7vw,2.2rem); }
    .mn-hero__desc              { font-size: 0.88rem; }
    .mn-hero__badges            { gap: 8px; flex-direction: column; align-items: flex-start; }
    .mn-how { padding: var(--section-v) 0; }
    .mn-how__step               { padding: 20px 16px; }
    .mn-how__step-num           { font-size: 1.6rem; }
    .mn-also__inner             { gap: 28px; }
    .mn-also__title             { font-size: clamp(1.4rem,5vw,1.8rem); }
    .mn-also__cta               { padding: 12px 24px; font-size: 0.88rem; }

    /* OCC */
    .occ-hero { padding: 2.5rem 0 2rem; }
    .occ-hero__title            { font-size: clamp(1.6rem,7vw,2.2rem); }
    .occ-hero__meta             { flex-direction: column; align-items: flex-start; gap: 8px; }
    .occ-grid                   { grid-template-columns: repeat(2,1fr); gap: 10px; }
    .occ-trust__grid            { gap: 16px; }

    /* SD */
    .sd-hero { padding: 2.5rem 0 2rem; }
    .sd-hero__title             { font-size: clamp(1.6rem,7vw,2.2rem); }
    .sd-hero__desc              { font-size: 0.88rem; }
    .sd-hero__badges            { gap: 8px; flex-direction: column; align-items: flex-start; }
    .sd-hero__badge             { font-size: 0.72rem; padding: 5px 12px; }
    .sd-hero__countdown-label   { font-size: 0.72rem; }
    .sd-hero__countdown-unit span { font-size: 1.8rem; }
    .sd-hero__countdown-unit small{ font-size: 0.6rem; }
    .sd-trust__grid             { gap: 16px; }

    /* Shared products grid — force 2 col */
    .products-grid,
    .ft-grid                    { grid-template-columns: repeat(2,1fr) !important; gap: 10px !important; }
    .products-listing__controls { gap: 8px; }

    /* REMF */
    .remf { padding: 28px 0 48px; }
    .remf-card__body            { padding: 20px 14px; }
    .remf-occasions             { grid-template-columns: repeat(2,1fr); gap: 8px; }
    .remf-occ-card__emoji       { font-size: 1.5rem; }
    .remf-occ-card__name        { font-size: 0.7rem; }
    .remf-info-card             { padding: 16px; min-width: unset; }
    .remf-existing              { padding: 16px; }

    /* REM */
    .rem { padding: 28px 0 48px; }
    .rem__title                 { font-size: 1.4rem; }
    .rem__sub                   { font-size: 0.85rem; }
    .rem__cta                   { padding: 10px 18px; font-size: 0.82rem; }
    .rem-stats                  { gap: 10px; }
    .rem-stat                   { padding: 14px; }
    .rem-stat__val              { font-size: 1.4rem; }
    .rem-stat__label            { font-size: 0.68rem; }
    .rem-filter-tabs            { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; gap: 6px; padding-bottom: 4px; }
    .rem-empty                  { padding: 40px 16px; }

    /* RVW */
    .rvw { padding: 28px 0 48px; }
    .rvw__title                 { font-size: 1.4rem; }
    .rvw-stars__input           { gap: 4px; }
    .rvw-stars__input label     { font-size: 2.4rem; }
    .rvw-product-chips          { gap: 8px; }
    .rvw-product-chip           { flex-direction: row; gap: 10px; padding: 12px; }
    .rvw-product-chip__img      { width: 48px; height: 48px; }
    .rvw-tips                   { padding: 16px; }
    .rvw-sidebar                { gap: 12px; }
    .rvw-order-card, .rvw-tips  { min-width: unset; }

    /* Dashboard */
    .dashboard-header           { padding: 24px 0 16px; }
    .dashboard-welcome__title   { font-size: 1.3rem; }
    .dashboard-quick-stats      { gap: 8px; }
    .quick-stat-card            { padding: 12px; flex-direction: column; gap: 4px; align-items: flex-start; }
    .quick-stat-card__icon      { width: 30px; height: 30px; font-size: 0.85rem; }
    .quick-stat-card__value     { font-size: 1.3rem; }
    .quick-stat-card__label     { font-size: 0.65rem; }
    .dashboard-content          { padding-top: 20px; padding-bottom: 40px; }
    .dashboard-section          { margin-bottom: 28px; }
    .dashboard-section__header  { margin-bottom: 16px; }
    .dashboard-section__title   { font-size: 1.05rem; gap: 8px; }
    .order-card__header         { padding: 12px 14px; flex-wrap: wrap; gap: 8px; }
    .order-card__body           { padding: 14px; }
    .order-card__footer         { flex-direction: column; align-items: stretch; gap: 10px; padding: 12px 14px; }
    .order-card__items          { gap: 6px; }
    .order-item-mini            { width: 40px; height: 40px; }
    .order-card__actions        { width: 100%; flex-direction: row; gap: 8px; }
    .order-card__actions .btn   { flex: 1; justify-content: center; text-align: center; min-width: 0; font-size: 0.8rem; padding: 10px 8px; }
    .recent-orders--desktop     { display: none !important; }
    .recent-orders--mobile      { display: block !important; }
    .recent-order-chip          { flex: 0 0 180px; padding: 12px; gap: 8px; }
    .recent-order-chip__number  { font-size: 0.68rem; }
    .recent-order-chip__amount  { font-size: 0.95rem; }
    .recent-order-chip__items   { font-size: 0.72rem; }
    .recent-order-chip__bottom  { font-size: 0.68rem; }
    .quick-actions              { gap: 8px; }
    .quick-action-btn           { padding: 12px 8px; }
    .quick-action-btn i         { font-size: 1.2rem; margin-bottom: 6px; }
    .quick-action-btn span      { font-size: 0.72rem; }
    .account-info-row           { gap: 10px; }
    .account-info-label         { font-size: 0.7rem; }
    .account-info-value         { font-size: 0.85rem; }
    .address-card-mini          { padding: 12px; }
    .address-card-mini__text    { font-size: 0.8rem; }
    .reminder-card              { flex-direction: column; align-items: flex-start; gap: 10px; padding: 14px; }
    .reminder-card__action      { width: 100%; }
    .reminder-card__action .btn { width: 100%; justify-content: center; }
    .rewards-card               { flex-direction: row; gap: 12px; align-items: center; padding: 16px; }
    .rewards-card__icon         { width: 40px; height: 40px; font-size: 1.1rem; }
    .rewards-card__points       { font-size: 1.4rem; }
    .rewards-note               { font-size: 0.75rem; }
    .support-card               { padding: 16px; }
    .support-card__icon         { width: 44px; height: 44px; font-size: 1.2rem; margin-bottom: 12px; }
    .support-card__title        { font-size: 0.95rem; }
    .support-card__text         { font-size: 0.8rem; margin-bottom: 12px; }
    .empty-state                { padding: 48px 16px; }
    .empty-state__icon i        { font-size: 2.5rem; }
    .empty-state__title         { font-size: 1.1rem; }
    .empty-state__text          { font-size: 0.85rem; }
}

/* — 400px — */
@media (max-width: 400px) {
    .remf-card__header  { padding: 20px 16px; }
    .remf-card__body    { padding: 20px 14px; }
    .remf-occasions     { grid-template-columns: repeat(2,1fr); gap: 8px; }
    .remf-info-card     { padding: 16px; min-width: unset; }

    /* Dashboard */
    .dashboard-header           { padding: 20px 0 14px; }
    .dashboard-welcome__title   { font-size: 1.15rem; }
    .dashboard-welcome          { margin-bottom: 16px; }
    .dashboard-quick-stats      { grid-template-columns: 1fr 1fr; gap: 6px; }
    .quick-stat-card            { padding: 10px; gap: 2px; }
    .quick-stat-card__icon      { width: 26px; height: 26px; font-size: 0.75rem; }
    .quick-stat-card__value     { font-size: 1.15rem; }
    .quick-stat-card__label     { font-size: 0.6rem; }
    .dashboard-content          { padding-top: 16px; padding-bottom: 32px; }
    .dashboard-section          { margin-bottom: 24px; }
    .dashboard-section__title   { font-size: 0.95rem; }
    .order-card__number         { font-size: 0.78rem; }
    .order-card__header         { padding: 10px 12px; }
    .order-card__body           { padding: 12px; }
    .order-card__footer         { padding: 10px 12px; }
    .order-card__amount strong  { font-size: 1rem; }
    .order-detail-item          { font-size: 0.78rem; }
    .recent-order-chip          { flex: 0 0 170px; padding: 10px; }
    .recent-orders__scroll      { gap: 10px; }
    .quick-actions              { grid-template-columns: 1fr 1fr; gap: 6px; }
    .quick-action-btn           { padding: 10px 6px; }
    .quick-action-btn i         { font-size: 1rem; margin-bottom: 4px; }
    .quick-action-btn span      { font-size: 0.68rem; }
    .dashboard-widget           { padding: 14px; }
    .dashboard-widget__title    { font-size: 0.95rem; margin-bottom: 14px; }
    .account-info-row > i       { font-size: 1rem; }
    .support-card__icon         { width: 40px; height: 40px; font-size: 1rem; }
    .reminder-date-badge__day   { font-size: 1.2rem; }

    /* ── Hero ── */
    .hero__text-pane            { padding: 20px 14px 28px; }
    .hero__heading              { font-size: 1.65rem; margin-bottom: 14px; }
    .hero__sub                  { font-size: 0.9rem; margin-bottom: 18px; }
    .hero__eyebrow              { font-size: 0.56rem; margin-bottom: 14px; }
    .hero__ctas                 { flex-direction: column; width: 100%; gap: 8px; }
    .hero__ctas .btn            { width: 100%; padding: 12px 18px; font-size: 0.82rem; }
    .hero__date-picker          { margin-top: 28px; }
    .hero__date-options         { gap: 6px; }
    .hero__date-btn             { padding: 9px 6px; font-size: 0.65rem; min-width: 0; flex: 1 1 calc(33.333% - 4px); }
    .hero__pincode              { padding: 20px 16px; width: calc(100% - 28px); margin: 14px; }
    .hero__pincode-label        { font-size: 0.95rem; }
    .hero__pincode-input        { padding: 10px 12px; font-size: 0.85rem; }
    .hero__pincode-btn          { padding: 10px 10px; font-size: 0.68rem; }
    .hero__scene-pane           { min-height: 42vh; }
    .hero__pincode-saved        { width: calc(100% - 28px); margin: 14px; }
}

/* — 360px — COMPREHENSIVE ALL-COMPONENT RESPONSIVE ────────── */
@media (max-width: 360px) {
    .container                  { padding: 0 12px; }

    /* ── Global elements ── */
    .section                    { padding: 36px 0; }
    .btn                        { padding: 10px 18px; font-size: 0.82rem; }
    .btn--sm                    { font-size: 0.72rem; padding: 6px 12px; }
    .btn--full                  { padding: 10px 16px; font-size: 0.82rem; }
    .breadcrumb                 { font-size: 0.65rem; gap: 3px; padding: 8px 0; }
    .back-to-top                { width: 36px; height: 36px; font-size: 0.8rem; bottom: 12px; right: 12px; }

    /* ── Forms ── */
    .form-group                 { margin-bottom: 14px; }
    .form-label                 { font-size: 0.75rem; margin-bottom: 5px; }
    .form-input, .form-control, .form-select, .form-textarea { padding: 10px 12px; font-size: 0.85rem; }
    .form-row                   { gap: 10px; }

    /* ── Toast ── */
    .toast-box                  { top: 70px; right: 12px; left: 12px; }
    .toast-item                 { padding: 10px 14px 10px 12px; font-size: 0.75rem; }

    /* ── Header ── */
    .header__inner              { padding: 0 12px; }
    .header__logo-icon          { width: 34px; height: 34px; font-size: 1rem; border-radius: 8px; }
    .header__logo-name          { font-size: 1.15rem; }
    .header__logo-tag           { font-size: 0.48rem; letter-spacing: 0.12em; }
    .header__logo               { gap: 10px; }
    .header__icon-btn           { width: 38px; height: 38px; font-size: 1rem; }
    .header__burger             { width: 38px; height: 38px; }
    .header__burger span        { width: 20px; }
    .header__actions            { gap: 2px; }
    .cart-badge                 { min-width: 15px; height: 15px; font-size: 0.5rem; top: 4px; right: 2px; }
    .search-overlay             { padding: 16px 12px; }
    .search-overlay__input      { font-size: 1rem; padding: 10px 0; }
    .search-overlay__tags       { gap: 6px; margin-top: 10px; flex-wrap: wrap; }
    .search-overlay__tags a     { font-size: 0.72rem; padding: 4px 10px; }

    /* ── Mobile Nav ── */
    .mobile-nav                 { width: 100% !important; max-width: 100% !important; }
    .mobile-nav__header         { padding: 20px 20px 16px; }
    .mobile-nav__brand          { font-size: 1.15rem; }
    .mobile-nav__close          { width: 34px; height: 34px; font-size: 0.88rem; }
    .mobile-nav__body           { padding: 6px 20px; }
    .mobile-nav__links a        { padding: 12px 0; font-size: 0.95rem; gap: 10px; }
    .mobile-nav__links a i      { font-size: 0.95rem; width: 20px; }
    .mobile-nav__footer         { padding: 16px 20px 20px; }
    .mobile-nav__contact        { gap: 8px; }
    .mobile-nav__contact a      { font-size: 0.78rem; }

    /* ── Hero ── */
    .hero__text-pane            { padding: 18px 12px 24px; }
    .hero__heading              { font-size: 1.5rem; margin-bottom: 14px; }
    .hero__sub                  { font-size: 0.85rem; margin-bottom: 18px; }
    .hero__eyebrow              { font-size: 0.55rem; margin-bottom: 12px; padding: 7px 14px; }
    .hero__ctas                 { flex-direction: column; width: 100%; }
    .hero__ctas .btn            { width: 100%; padding: 12px 20px; font-size: 0.82rem; }
    .hero__date-picker          { margin-top: 28px; }
    .hero__date-options         { gap: 6px; }
    .hero__date-btn             { padding: 8px 6px; font-size: 0.62rem; min-width: 0; flex: 1 1 calc(33.333% - 4px); }
    .hero__date-btn-sub         { font-size: 0.55rem; }
    .hero__pincode              { padding: 18px 14px; width: calc(100% - 24px); margin: 12px; position: relative; right: auto; bottom: auto; }
    .hero__pincode-label        { font-size: 0.92rem; }
    .hero__pincode-hint         { font-size: 0.7rem; margin-bottom: 14px; }
    .hero__pincode-input        { padding: 10px 12px; font-size: 0.85rem; }
    .hero__pincode-btn          { padding: 10px 10px; font-size: 0.65rem; }
    .hero__scene-pane           { min-height: 40vh; }
    .hero__pincode-saved        { width: calc(100% - 24px); margin: 12px; }

    /* ── Homepage: Categories ── */
    .cat-grid                   { gap: 8px; margin-top: 28px; }
    .cat-card__name             { font-size: 0.72rem; }
    .occasion-chips             { grid-template-columns: repeat(2,1fr); gap: 6px; }
    .occasion-chip              { padding: 14px 4px 12px; }
    .occasion-chip__emoji       { font-size: 1.4rem; }
    .occasion-chip__label       { font-size: 0.55rem; }

    /* ── Homepage: Same Day ── */
    .same-day__layout           { gap: 24px; }
    .same-day__visual           { min-height: 260px; }
    .same-day__card--1,
    .same-day__card--2          { width: 44%; }
    .same-day__countdown        { padding: 16px 20px; }
    .same-day__countdown-unit span { font-size: 1.5rem; }
    .same-day__feature          { font-size: 0.75rem; }

    /* ── Homepage: Trust ── */
    .trust-grid                 { gap: 12px; }
    .trust-item                 { padding: 20px 12px; }
    .trust-item__icon           { width: 48px; height: 48px; font-size: 1.1rem; margin-bottom: 12px; }
    .trust-item__title          { font-size: 0.88rem; }
    .trust-item__desc           { font-size: 0.75rem; }
    .trust-counters             { gap: 12px; padding: 24px 16px; }

    /* ── Homepage: Testimonials ── */
    .test-grid                  { gap: 12px; }
    .test-card                  { padding: 20px 16px; }
    .test-card__text            { font-size: 0.82rem; margin-bottom: 14px; }
    .test-card__avatar          { width: 36px; height: 36px; font-size: 0.68rem; }
    .test-card__name            { font-size: 0.78rem; }

    /* ── Homepage: Reminder CTA ── */
    .reminder                   { gap: 20px; }
    .reminder__form             { padding: 20px 16px; }
    .reminder__btn              { padding: 10px 16px; font-size: 0.78rem; }

    /* ── Section Headings ── */
    .section__eyebrow           { font-size: 0.55rem; }
    .section__title             { font-size: clamp(1.4rem, 5vw, 1.8rem); }
    .section__subtitle          { font-size: 0.85rem; }

    /* ── Products Scroll ── */
    .products__scroll-wrap      { margin: 0 -12px; padding: 0 12px; }
    .products__scroll-wrap::before,
    .products__scroll-wrap::after { width: 16px; }

    /* ── Product Cards ── */
    .p-card                     { border-radius: 10px; }
    .p-card__body               { padding: 10px 8px; }
    .p-card__cat                { font-size: 0.55rem; margin-bottom: 4px; }
    .p-card__name               { font-size: 0.75rem; }
    .p-card__price              { font-size: 0.92rem; }
    .p-card__mrp                { font-size: 0.62rem; }
    .p-card__wish               { width: 30px; height: 30px; font-size: 0.82rem; }
    .p-card__badge              { font-size: 0.52rem; padding: 3px 8px; }
    .p-card__rating             { font-size: 0.6rem; }
    .products-grid              { gap: 8px !important; }
    .products-listing__header   { gap: 10px; }
    .products-listing__count    { font-size: 0.72rem; }

    /* ── Product Detail ── */
    .product-detail__layout     { gap: 24px; }
    .product-gallery__thumbs    { gap: 6px; }
    .product-gallery__thumb     { width: 48px; height: 48px; }
    .product-info__title        { font-size: clamp(1.3rem, 5vw, 1.6rem); }
    .product-price__current     { font-size: 1.3rem; }
    .product-price__mrp         { font-size: 0.82rem; }
    .product-actions            { gap: 8px; flex-direction: column; }
    .product-actions .btn       { width: 100%; justify-content: center; }
    .addons-grid                { grid-template-columns: 1fr; gap: 8px; }
    .addon-card                 { padding: 12px; }
    .addon-card__name           { font-size: 0.82rem; }
    .addon-card__price          { font-size: 0.78rem; }

    /* ── Cart Sidebar ── */
    .cart-sidebar__panel        { width: 100%; }
    .cart-sidebar__header       { padding: 14px 12px; }
    .cart-sidebar__body         { padding: 10px 12px; }
    .cart-sidebar__footer       { padding: 12px; }
    .cart-item                  { padding: 8px; gap: 10px; }
    .cart-item__img             { width: 56px; height: 56px; border-radius: 8px; }
    .cart-item__name            { font-size: 0.78rem; }
    .cart-item__price           { font-size: 0.88rem; }
    .cart-item__remove          { font-size: 0.75rem; }

    /* ── Checkout ── */
    .checkout-progress          { padding: 14px 0; }
    .progress-steps             { padding: 0 12px; }
    .progress-step__icon        { width: 36px; height: 36px; font-size: 0.88rem; }
    .progress-step__label       { font-size: 0.6rem; }
    .progress-step__line        { margin: 0 6px; }
    .checkout-section           { padding-top: 24px; padding-bottom: 90px; }
    .checkout-step              { padding: 0; }
    .checkout-step__title       { font-size: 1.15rem; margin-bottom: 16px; }
    .form-section               { padding: 16px; margin-bottom: 0; }
    .form-section__title        { font-size: 0.88rem; margin-bottom: 12px; }
    .checkout-form              { gap: 20px; }
    .date-selector              { gap: 10px; }
    .date-option                { padding: 16px 10px; }
    .date-option__icon          { width: 38px; height: 38px; font-size: 1rem; margin-bottom: 8px; }
    .date-option__label         { font-size: 0.82rem; }
    .date-option__date          { font-size: 0.68rem; }
    .date-option__badge         { font-size: 0.55rem; padding: 2px 8px; }
    .timeslot                   { padding: 16px 12px; }
    .timeslot__time             { font-size: 0.9rem; }
    .timeslot-grid              { gap: 6px; }
    .timeslot-btn               { padding: 10px 8px; font-size: 0.72rem; }
    .payment-method__card       { padding: 14px; gap: 12px; }
    .payment-method__icon       { width: 40px; height: 40px; font-size: 1.1rem; border-radius: 8px; }
    .payment-method__name       { font-size: 0.88rem; }
    .payment-method__desc       { font-size: 0.75rem; }
    .checkout-sidebar           { padding: 0; }
    .checkout-offers            { padding: 12px; }
    .offer-mini                 { padding: 10px; }
    .payment-method-cards       { grid-template-columns: 1fr; gap: 6px; }
    .payment-method-card        { padding: 12px; }
    .btn--mini                  { font-size: 0.65rem; padding: 5px 8px; }
    .cancel-modal__dialog       { padding: 28px 20px; }
    .cancel-modal__actions      { flex-direction: column; gap: 8px; }
    .cancel-modal__actions .btn { width: 100%; justify-content: center; }

    /* ── Payment Pages ── */
    .pay                        { padding: 32px 0 48px; }
    .pay__layout                { gap: 16px; }
    .pay-card__body             { padding: 16px; }
    .pay-card__head             { padding: 16px; }
    .pay-methods                { gap: 6px; }
    .pay-method                 { padding: 10px 12px; font-size: 0.8rem; }
    .pay-scard                  { padding: 16px; }
    .pay-order-item__name       { font-size: 0.78rem; }
    .pay-order-item__price      { font-size: 0.82rem; }

    /* ── Orders List ── */
    .ord-page                   { padding-top: calc(var(--header-h) + 16px); padding-bottom: 32px; }
    .ord-page__title            { font-size: 1.2rem; }
    .ord-filter-tabs            { gap: 4px; }
    .ord-filter-tab             { padding: 5px 12px; font-size: 0.68rem; }
    .ord-card                   { padding: 14px; border-radius: 10px; }
    .ord-card__head             { gap: 8px; }
    .ord-card__number           { font-size: 0.78rem; }
    .ord-card__items            { gap: 6px; }
    .ord-card__foot             { gap: 8px; }
    .ord-card__actions .btn     { font-size: 0.72rem; padding: 8px 12px; }

    /* ── Order Detail ── */
    .ord-show                   { padding-top: calc(var(--header-h) + 12px); padding-bottom: 32px; }
    .ord-show__layout           { gap: 16px; }
    .ord-show__head             { padding: 14px 12px; gap: 10px; }
    .ord-show__eyebrow          { font-size: 0.58rem; }
    .ord-show__title            { font-size: 1.3rem; }
    .ord-show__placed           { font-size: 0.72rem; }
    .ord-quickinfo              { padding: 8px 10px; margin-bottom: 14px; }
    .ord-quickinfo__item        { padding: 5px 6px; gap: 6px; }
    .ord-quickinfo__icon        { width: 24px; height: 24px; font-size: 0.65rem; border-radius: 6px; }
    .ord-quickinfo__val         { font-size: 0.72rem; }
    .ord-quickinfo__label       { font-size: 0.52rem; }
    .ord-timeline               { padding: 14px 12px; }
    .ord-timeline__step         { min-width: 56px; }
    .ord-timeline__dot          { width: 30px; height: 30px; font-size: 0.68rem; }
    .ord-timeline__label        { font-size: 0.58rem; }
    .ord-timeline__time         { font-size: 0.52rem; }
    .ord-timeline__line         { min-width: 14px; margin-bottom: 20px; }
    .ord-show__items,
    .ord-show__message,
    .ord-show__history          { padding: 14px 12px; margin-bottom: 14px; }
    .ord-section-title          { font-size: 0.95rem; margin-bottom: 12px; gap: 8px; }
    .ord-show__item             { gap: 10px; padding: 10px 0; }
    .ord-show__item-img         { width: 48px; height: 48px; border-radius: 8px; }
    .ord-show__item-name        { font-size: 0.78rem; }
    .ord-show__item-qty         { font-size: 0.68rem; }
    .ord-show__item-unit        { font-size: 0.65rem; }
    .ord-show__item-total       { font-size: 0.85rem; }
    .ord-sidebar-card           { padding: 14px; }
    .ord-sidebar-card__title    { font-size: 0.92rem; margin-bottom: 12px; }
    .ord-summary__row           { font-size: 0.78rem; }
    .ord-summary__total strong  { font-size: 1.1rem; }
    .ord-delivery-info          { gap: 10px; }
    .ord-delivery-info__label   { font-size: 0.62rem; }
    .ord-delivery-info__val     { font-size: 0.78rem; }
    .ord-cancel__reason         { padding: 10px 12px; font-size: 0.78rem; }
    .ord-btn                    { padding: 8px 14px; font-size: 0.75rem; }
    .ord-history__status        { font-size: 0.78rem; }
    .ord-history__notes         { font-size: 0.72rem; }
    .ord-history__time          { font-size: 0.65rem; }

    /* ── Track Pages ── */
    .trk-hero                   { padding: 32px 0 20px; }
    .trk-copy__title            { font-size: clamp(1.4rem, 5vw, 1.7rem); }
    .trk-copy__sub              { font-size: 0.82rem; }
    .trk-card__header           { padding: 16px 12px; }
    .trk-card__body             { padding: 16px 12px; }
    .trk-steps__grid            { gap: 8px; }
    .trk-step                   { padding: 14px; }
    .trkr                       { padding: 20px 0 40px; }
    .trkr__layout               { gap: 16px; }
    .trkr-card                  { border-radius: 10px; }
    .trkr-card__head            { padding: 14px; }
    .trkr-timeline              { padding: 14px; }
    .trkr-scard                 { padding: 14px; min-width: unset; }
    .trkr-item__name            { font-size: 0.78rem; }
    .trkr-item__price           { font-size: 0.82rem; }

    /* ── Invoice ── */
    .invoice                    { padding: 16px; }
    .invoice-header             { flex-direction: column; gap: 12px; }

    /* ── Auth / Login ── */
    .login-panel                { padding: 24px 16px; margin: 0; max-width: 100%; }
    .login-header               { margin-bottom: 24px; }
    .login-header__title        { font-size: 1.15rem; }
    .login-header__sub          { font-size: 0.78rem; }
    .login-header__badge        { font-size: 0.62rem; padding: 4px 10px; }
    .login-social-btn           { padding: 10px; font-size: 0.82rem; }
    .login-divider              { margin: 16px 0; font-size: 0.72rem; }

    /* ── Reminders ── */
    .remf-card__body            { padding: 16px 12px; }
    .remf-occasions             { grid-template-columns: repeat(2,1fr); gap: 6px; }
    .remf-occ-card__inner       { padding: 8px 4px; }
    .remf-occ-card__emoji       { font-size: 1.2rem; }
    .remf-occ-card__name        { font-size: 0.55rem; }
    .remf-info-card             { padding: 14px; }
    .rem-stats                  { gap: 8px; }
    .rem-stat                   { padding: 12px; }
    .rem-stat__val              { font-size: 1.2rem; }
    .rem-stat__label            { font-size: 0.6rem; }
    .rem-grid                   { gap: 12px; }

    /* ── Reviews ── */
    .rvw-card__body             { padding: 16px 12px; }
    .rvw-stars__input label     { font-size: 2rem; }
    .rvw-product-chip           { padding: 10px; }
    .rvw-product-chip__img      { width: 44px; height: 44px; }
    .rvw-tips                   { padding: 12px; }

    /* ── Offers ── */
    .offers-hero                { padding: 80px 0 28px; }
    .offers-hero__icon          { width: 56px; height: 56px; font-size: 1.4rem; }
    .offers-hero__title         { font-size: 1.5rem; }
    .offers-hero__sub           { font-size: 0.82rem; }
    .offers-grid                { gap: 14px; }
    .coupon-card__left          { width: 80px; min-height: 110px; padding: 10px 6px; }
    .coupon-card__number        { font-size: 1.1rem; }
    .coupon-card__right         { padding: 12px; }
    .coupon-card__code          { font-size: 0.68rem; padding: 4px 10px; }
    .coupon-card__detail        { font-size: 0.72rem; }
    .offers-banner__item        { font-size: 0.75rem; }

    /* ── Search Page ── */
    .search-page__layout        { gap: 16px; }
    .search-page__sidebar       { padding: 14px; }
    .search-page__pill          { font-size: 0.65rem; padding: 3px 8px; }
    .search-page__title         { font-size: 1.3rem; }

    /* ── How It Works ── */
    .hiw__step,
    .hiw__step--reverse         { grid-template-columns: 1fr; padding: 28px 0; gap: 16px; }
    .hiw__step-num              { margin: 0 auto 8px; }
    .hiw__step-visual           { grid-column: auto; min-height: 200px; }
    .hiw__step-body             { grid-column: auto; padding: 16px 0; }
    .step__title                { font-size: 1.05rem; }
    .step__text                 { font-size: 0.8rem; }
    .hiw__faq-grid              { gap: 12px; }
    .hiw__trust                 { padding: 20px 16px; }

    /* ── Occasion / Same-Day / Monogram Hero Pages ── */
    .occ-hero__title            { font-size: clamp(1.4rem, 6vw, 1.8rem); }
    .occ-grid                   { grid-template-columns: 1fr 1fr; gap: 8px; }
    .mn-hero__title             { font-size: clamp(1.3rem, 6vw, 1.7rem); }
    .sd-hero__title             { font-size: clamp(1.4rem, 6vw, 1.8rem); }

    /* ── Footer ── */
    .footer__cta-bar            { padding: 20px 14px; gap: 14px; }
    .footer__cta-bar h3         { font-size: 1.15rem; }
    .footer__cta-bar p          { font-size: 0.78rem; }
    .footer__grid               { gap: 20px; padding-bottom: 28px; }
    .footer__heading            { font-size: 0.88rem; margin-bottom: 12px; }
    .footer__links              { gap: 3px 10px; }
    .footer__links a            { font-size: 0.75rem; padding: 4px 0; }
    .footer__social a           { width: 32px; height: 32px; font-size: 0.85rem; }
    .footer__credits            { font-size: 0.65rem; }
    .footer__bottom             { padding: 16px 0; font-size: 0.68rem; }

    /* ── Dashboard (already defined above — additions) ── */
    .dashboard-header           { padding: 16px 0 12px; }
    .dashboard-header__content  { gap: 16px; }
    .dashboard-welcome__title   { font-size: 1.05rem; line-height: 1.3; }
    .dashboard-welcome__title em{ display: block; }
    .dashboard-welcome__subtitle{ font-size: 0.78rem; }
    .dashboard-welcome          { margin-bottom: 12px; }
    .dashboard-quick-stats      { grid-template-columns: 1fr 1fr; gap: 5px; }
    .quick-stat-card            { padding: 8px; gap: 2px; border-radius: 8px; }
    .quick-stat-card__icon      { width: 24px; height: 24px; font-size: 0.7rem; }
    .quick-stat-card__value     { font-size: 1.05rem; }
    .quick-stat-card__label     { font-size: 0.58rem; letter-spacing: 0; }
    .dashboard-content          { padding-top: 14px; padding-bottom: 28px; }
    .dashboard-section          { margin-bottom: 20px; }
    .dashboard-section__header  { margin-bottom: 12px; gap: 4px; }
    .dashboard-section__title   { font-size: 0.88rem; gap: 6px; }
    .dashboard-section__title i { font-size: 0.88rem; }
    .dashboard-section__link    { font-size: 0.75rem; gap: 4px; }
    .active-orders              { gap: 14px; }
    .order-card                 { border-radius: 10px; }
    .order-card__header         { padding: 8px 10px; gap: 6px; }
    .order-card__number         { font-size: 0.72rem; gap: 5px; }
    .order-card__number i       { font-size: 0.75rem; }
    .order-status-badge         { font-size: 0.6rem; padding: 3px 8px; letter-spacing: 0; }
    .order-card__body           { padding: 10px; }
    .order-card__items          { gap: 4px; margin-bottom: 10px; }
    .order-item-mini            { width: 36px; height: 36px; border-radius: 6px; }
    .order-item-mini--more      { font-size: 0.65rem; }
    .order-card__details        { gap: 6px; }
    .order-detail-item          { font-size: 0.72rem; gap: 4px; }
    .order-detail-item i        { font-size: 0.72rem; }
    .order-card__footer         { padding: 8px 10px; gap: 10px; }
    .order-card__amount         { font-size: 0.8rem; }
    .order-card__amount strong  { font-size: 0.92rem; }
    .order-card__actions        { gap: 6px; }
    .order-card__actions .btn   { font-size: 0.72rem; padding: 8px 10px; }
    .recent-order-chip          { flex: 0 0 160px; padding: 10px; gap: 7px; }
    .recent-order-chip__number  { font-size: 0.62rem; }
    .recent-order-chip__amount  { font-size: 0.88rem; }
    .recent-order-chip__top .order-status-badge { font-size: 0.55rem; padding: 2px 6px; }
    .recent-orders__scroll      { gap: 8px; }
    .reminder-card              { padding: 10px; gap: 8px; border-radius: 10px; }
    .reminder-date-badge        { width: 44px; height: 44px; border-radius: 8px; }
    .reminder-date-badge__day   { font-size: 1rem; }
    .reminder-date-badge__month { font-size: 0.6rem; }
    .reminder-card__occasion    { font-size: 0.65rem; }
    .reminder-card__name        { font-size: 0.85rem; }
    .reminder-card__days        { font-size: 0.72rem; }
    .reminder-card__action .btn { font-size: 0.72rem; padding: 6px 12px; }
    .dashboard-widget           { padding: 12px; border-radius: 10px; }
    .dashboard-widget__title    { font-size: 0.88rem; margin-bottom: 12px; padding-bottom: 10px; }
    .quick-actions              { gap: 5px; }
    .quick-action-btn           { padding: 8px 4px; border-radius: 8px; }
    .quick-action-btn i         { font-size: 0.92rem; margin-bottom: 3px; }
    .quick-action-btn span      { font-size: 0.62rem; }
    .account-info               { gap: 12px; margin-bottom: 14px; }
    .account-info-row           { gap: 8px; }
    .account-info-row > i       { font-size: 0.88rem; }
    .account-info-label         { font-size: 0.62rem; }
    .account-info-value         { font-size: 0.78rem; word-break: break-all; }
    .saved-addresses            { gap: 8px; margin-bottom: 12px; }
    .address-card-mini          { padding: 10px; border-radius: 8px; }
    .address-card-mini__label   { font-size: 0.68rem; margin-bottom: 6px; }
    .address-card-mini__text    { font-size: 0.75rem; }
    .address-more               { font-size: 0.72rem; margin-bottom: 12px; }
    .rewards-card               { padding: 12px; gap: 10px; border-radius: 8px; margin-bottom: 8px; }
    .rewards-card__icon         { width: 36px; height: 36px; font-size: 1rem; }
    .rewards-card__label        { font-size: 0.65rem; }
    .rewards-card__points       { font-size: 1.2rem; }
    .rewards-card__value        { font-size: 0.75rem; }
    .rewards-note               { font-size: 0.68rem; }
    .support-card               { padding: 14px; border-radius: 8px; }
    .support-card__icon         { width: 36px; height: 36px; font-size: 0.92rem; margin-bottom: 10px; }
    .support-card__title        { font-size: 0.88rem; margin-bottom: 6px; }
    .support-card__text         { font-size: 0.75rem; margin-bottom: 12px; }
    .support-card .btn          { font-size: 0.78rem; padding: 8px 14px; }
    .empty-state                { padding: 36px 12px; }
    .empty-state__icon          { width: 60px; height: 60px; margin-bottom: 16px; }
    .empty-state__icon i        { font-size: 2rem; }
    .empty-state__title         { font-size: 1rem; margin-bottom: 8px; }
    .empty-state__text          { font-size: 0.8rem; margin-bottom: 20px; }
    .empty-state .btn           { font-size: 0.82rem; padding: 10px 20px; }

    /* ── Auth Prompt Modal ── */
    .auth-prompt                { padding: 16px; }
    .auth-prompt__panel         { padding: 36px 24px; }
    .auth-prompt__icon          { width: 60px; height: 60px; font-size: 1.5rem; margin-bottom: 16px; }
    .auth-prompt__title         { font-size: 1.3rem; }
    .auth-prompt__text          { font-size: 0.82rem; margin-bottom: 20px; }
    .auth-prompt__btn           { padding: 12px 20px; font-size: 0.8rem; }
    .auth-prompt__note          { font-size: 0.68rem; }

    /* ── First-Order Banner ── */
    .first-order-banner__inner  { flex-direction: column; text-align: center; gap: 16px; padding: 24px 0; }
    .first-order-banner__icon   { width: 52px; height: 52px; font-size: 1.3rem; }
    .first-order-banner__title  { font-size: 1.15rem; }
    .first-order-banner__text   { font-size: 0.82rem; }
    .first-order-banner__coupons { justify-content: center; }
    .first-order-coupon-mini    { padding: 6px 10px; }
    .first-order-coupon-mini__value { font-size: 0.72rem; }
    .first-order-coupon-mini__code  { font-size: 0.65rem; padding: 3px 8px; }
    .first-order-banner .btn    { font-size: 0.8rem; }
}

/* — 320px — COMPREHENSIVE ALL-COMPONENT RESPONSIVE ────────── */
@media (max-width: 320px) {
    .container                  { padding: 0 10px; }
    .section                    { padding: 28px 0; }
    .btn                        { padding: 8px 14px; font-size: 0.78rem; }
    .btn--sm                    { font-size: 0.65rem; padding: 5px 10px; }
    .breadcrumb                 { font-size: 0.6rem; }

    /* ── Forms ── */
    .form-group                 { margin-bottom: 12px; }
    .form-label                 { font-size: 0.68rem; }
    .form-input, .form-control, .form-select, .form-textarea { padding: 8px 10px; font-size: 0.8rem; }

    /* ── Toast ── */
    .toast-box                  { top: 64px; right: 8px; left: 8px; }
    .toast-item                 { padding: 8px 12px 8px 10px; font-size: 0.7rem; }

    /* ── Header ── */
    .header__inner              { padding: 0 10px; }
    .header__logo-icon          { width: 30px; height: 30px; font-size: 0.88rem; }
    .header__logo-name          { font-size: 1.05rem; }
    .header__logo-tag           { font-size: 0.45rem; }
    .header__logo               { gap: 8px; }
    .header__icon-btn           { width: 34px; height: 34px; font-size: 0.92rem; }
    .header__burger             { width: 34px; height: 34px; }
    .cart-badge                 { min-width: 14px; height: 14px; font-size: 0.48rem; }
    .search-overlay             { padding: 12px 10px; }
    .search-overlay__input      { font-size: 0.88rem; }
    .search-overlay__tags a     { font-size: 0.65rem; }

    /* ── Mobile Nav ── */
    .mobile-nav__header         { padding: 16px 16px 12px; }
    .mobile-nav__brand          { font-size: 1rem; }
    .mobile-nav__close          { width: 30px; height: 30px; }
    .mobile-nav__body           { padding: 4px 16px; }
    .mobile-nav__links a        { padding: 10px 0; font-size: 0.85rem; gap: 8px; }
    .mobile-nav__links a i      { font-size: 0.85rem; width: 18px; }
    .mobile-nav__footer         { padding: 14px 16px 16px; }
    .mobile-nav__contact a      { font-size: 0.72rem; }

    /* ── Hero ── */
    .hero__text-pane            { padding: 14px 10px 18px; }
    .hero__heading              { font-size: 1.38rem; margin-bottom: 10px; }
    .hero__sub                  { font-size: 0.78rem; margin-bottom: 14px; line-height: 1.55; }
    .hero__eyebrow              { font-size: 0.5rem; padding: 6px 12px; gap: 7px; margin-bottom: 10px; }
    .hero__ctas .btn            { padding: 10px 14px; font-size: 0.75rem; }
    .hero__date-picker          { margin-top: 20px; }
    .hero__date-label           { font-size: 0.65rem; margin-bottom: 8px; }
    .hero__date-options         { gap: 4px; }
    .hero__date-btn             { padding: 6px 4px; font-size: 0.58rem; }
    .hero__date-btn-day         { font-size: 0.65rem; }
    .hero__date-btn-sub         { font-size: 0.5rem; }
    .hero__pincode              { padding: 14px 12px; width: calc(100% - 20px); margin: 10px; }
    .hero__pincode-label        { font-size: 0.85rem; margin-bottom: 2px; }
    .hero__pincode-hint         { font-size: 0.65rem; margin-bottom: 12px; }
    .hero__pincode-input        { padding: 9px 10px; font-size: 0.8rem; }
    .hero__pincode-btn          { padding: 9px 8px; font-size: 0.6rem; }
    .hero__pincode-result       { font-size: 0.72rem; }
    .hero__scene-pane           { min-height: 35vh; }
    .hero__pincode-saved        { width: calc(100% - 20px); margin: 10px; padding: 14px; }

    /* ── Homepage Sections ── */
    .products__scroll-wrap      { margin: 0 -10px; padding: 0 10px; }
    .products__scroll-wrap::before,
    .products__scroll-wrap::after { width: 12px; }
    .cat-grid                   { gap: 6px; }
    .occasion-chip              { padding: 10px 2px 8px; }
    .occasion-chip__emoji       { font-size: 1.2rem; }
    .same-day__visual           { min-height: 220px; }
    .same-day__countdown-unit span { font-size: 1.3rem; }
    .trust-item                 { padding: 16px 10px; }
    .trust-item__icon           { width: 40px; height: 40px; font-size: 1rem; }
    .test-card                  { padding: 16px 12px; }
    .test-card__text            { font-size: 0.78rem; }
    .reminder__form             { padding: 16px 12px; }

    /* ── Product Cards ── */
    .p-card__body               { padding: 8px 6px; }
    .p-card__name               { font-size: 0.68rem; }
    .p-card__price              { font-size: 0.85rem; }
    .p-card__wish               { width: 26px; height: 26px; font-size: 0.72rem; }

    /* ── Product Detail ── */
    .product-info__title        { font-size: 1.2rem; }
    .product-price__current     { font-size: 1.15rem; }
    .product-gallery__thumb     { width: 40px; height: 40px; }

    /* ── Cart Sidebar ── */
    .cart-sidebar__header       { padding: 12px 10px; }
    .cart-item                  { padding: 6px; gap: 8px; }
    .cart-item__img             { width: 48px; height: 48px; }
    .cart-item__name            { font-size: 0.72rem; }
    .cart-item__price           { font-size: 0.82rem; }

    /* ── Checkout ── */
    .checkout-progress          { padding: 12px 0; }
    .progress-steps             { padding: 0 10px; }
    .progress-step__icon        { width: 32px; height: 32px; font-size: 0.78rem; }
    .progress-step__label       { display: none; }
    .progress-step__line        { margin: 0 6px; top: -8px; }
    .checkout-section           { padding-top: 20px; padding-bottom: 85px; }
    .checkout-step              { padding: 0; }
    .checkout-step__header      { margin-bottom: 16px; }
    .checkout-step__title       { font-size: 1rem; gap: 8px; }
    .checkout-step__title i     { font-size: 1rem; }
    .checkout-step__subtitle    { font-size: 0.78rem; }
    .form-section               { padding: 12px; margin-bottom: 0; }
    .form-section__title        { font-size: 0.82rem; margin-bottom: 10px; }
    .checkout-form              { gap: 16px; }
    .timeslot-btn               { padding: 8px 6px; font-size: 0.65rem; }
    .date-selector              { gap: 8px; }
    .date-option                { padding: 14px 8px; }
    .date-option__icon          { width: 36px; height: 36px; margin-bottom: 8px; font-size: 1rem; }
    .date-option__label         { font-size: 0.75rem; }
    .date-option__date          { font-size: 0.65rem; }
    .date-option__badge         { font-size: 0.5rem; padding: 2px 6px; top: 4px; right: 4px; }
    .timeslot                   { padding: 14px 10px; }
    .timeslot__time             { font-size: 0.85rem; gap: 6px; }
    .timeslot__status           { font-size: 0.7rem; }
    .payment-method__card       { padding: 12px; gap: 10px; }
    .payment-method__icon       { width: 36px; height: 36px; font-size: 1rem; border-radius: 8px; }
    .payment-method__name       { font-size: 0.85rem; }
    .payment-method__desc       { font-size: 0.72rem; }
    .payment-notice             { padding: 12px; gap: 10px; font-size: 0.78rem; }
    .checkout-offers__toggle    { padding: 10px 12px; font-size: 0.78rem; }
    .order-summary              { padding: 14px; }
    .order-summary__title       { font-size: 1rem; margin-bottom: 12px; padding-bottom: 10px; }
    .summary-item__img          { width: 44px; height: 44px; }
    .summary-item__name         { font-size: 0.75rem; }
    .summary-item__price        { font-size: 0.78rem; }
    .summary-qty-btn            { width: 24px; height: 24px; font-size: 0.7rem; }
    .summary-qty-val            { width: 22px; font-size: 0.7rem; line-height: 24px; }
    .summary-item__remove       { width: 20px; height: 20px; font-size: 0.55rem; }
    .summary-row                { font-size: 0.78rem; margin-bottom: 8px; }
    .summary-row--total         { font-size: 0.92rem; }
    .co-addon                   { flex: 0 0 90px; }
    .co-addon__img              { width: 42px; height: 42px; }
    .co-addon__name             { font-size: 0.6rem; }
    .co-addon__price            { font-size: 0.65rem; }
    .co-addon__btn              { font-size: 0.55rem; padding: 2px 5px; }
    .btn--mini                  { font-size: 0.62rem; padding: 4px 7px; }
    .countdown-alert            { padding: 10px 12px; gap: 10px; }
    .countdown-alert__icon      { width: 34px; height: 34px; font-size: 0.88rem; }
    .countdown-alert__content strong { font-size: 0.78rem; }
    .countdown-alert__content span   { font-size: 0.72rem; }
    .cancel-modal__dialog       { padding: 24px 16px; }
    .cancel-modal__icon         { font-size: 2rem; }
    .cancel-modal__title        { font-size: 1rem; }
    .cancel-modal__text         { font-size: 0.8rem; margin-bottom: 20px; }
    .btn--danger                { padding: 10px 20px; font-size: 0.85rem; }
    .payment-method-card        { padding: 10px; }

    /* ── Payment ── */
    .pay-card__body             { padding: 12px; }
    .pay-method                 { padding: 8px 10px; font-size: 0.75rem; }

    /* ── Orders ── */
    .ord-page__title            { font-size: 1.05rem; }
    .ord-filter-tab             { padding: 4px 10px; font-size: 0.62rem; }
    .ord-card                   { padding: 12px; }
    .ord-show__head             { padding: 12px 10px; }
    .ord-show__title            { font-size: 1.15rem; }
    .ord-quickinfo              { padding: 6px 8px; margin-bottom: 12px; row-gap: 4px; }
    .ord-quickinfo__item        { padding: 4px 5px; gap: 5px; }
    .ord-quickinfo__icon        { width: 22px; height: 22px; font-size: 0.6rem; }
    .ord-quickinfo__val         { font-size: 0.68rem; }
    .ord-quickinfo__label       { font-size: 0.5rem; }
    .ord-timeline               { padding: 12px 10px; }
    .ord-timeline__dot          { width: 26px; height: 26px; font-size: 0.6rem; }
    .ord-timeline__label        { font-size: 0.52rem; }
    .ord-show__items, .ord-show__message, .ord-show__history { padding: 12px 10px; }
    .ord-show__item-img         { width: 40px; height: 40px; }
    .ord-show__item-name        { font-size: 0.72rem; }
    .ord-show__item-total       { font-size: 0.78rem; }
    .ord-sidebar-card           { padding: 12px; }
    .ord-summary__total strong  { font-size: 1rem; }
    .ord-btn                    { padding: 7px 12px; font-size: 0.7rem; }

    /* ── Track ── */
    .trk-hero                   { padding: 24px 0 16px; }
    .trk-copy__title            { font-size: 1.3rem; }
    .trkr-card__head            { padding: 12px; }
    .trkr-timeline              { padding: 12px; }
    .trkr-scard                 { padding: 12px; }

    /* ── Auth ── */
    .login-panel                { padding: 20px 12px; }
    .login-header__title        { font-size: 1rem; }
    .login-header__badge        { font-size: 0.58rem; }

    /* ── Reminders ── */
    .remf-card__body            { padding: 14px 10px; }
    .rem-stat                   { padding: 10px; }
    .rem-stat__val              { font-size: 1.1rem; }

    /* ── Offers ── */
    .offers-hero__title         { font-size: 1.3rem; }
    .offers-hero                { padding: 70px 0 24px; }
    .coupon-card__left          { width: 70px; min-height: 100px; }
    .coupon-card__number        { font-size: 1rem; }

    /* ── HIW ── */
    .hiw__step                  { padding: 20px 0; }
    .step__title                { font-size: 0.92rem; }
    .step__text                 { font-size: 0.75rem; }

    /* ── Footer ── */
    .footer__cta-bar            { padding: 16px 12px; }
    .footer__cta-bar h3         { font-size: 1rem; }
    .footer__grid               { gap: 16px; padding-bottom: 20px; }
    .footer__heading            { font-size: 0.82rem; }
    .footer__links              { gap: 2px 8px; }
    .footer__links a            { font-size: 0.7rem; }
    .footer__social a           { width: 28px; height: 28px; font-size: 0.78rem; }
    .footer__credits            { font-size: 0.6rem; }
    .footer__bottom             { font-size: 0.62rem; }

    /* ── Dashboard ── */
    .dashboard-header           { padding: 14px 0 10px; }
    .dashboard-welcome__title   { font-size: 0.95rem; }
    .dashboard-welcome__subtitle{ font-size: 0.72rem; }
    .dashboard-quick-stats      { gap: 4px; }
    .quick-stat-card            { padding: 6px; }
    .quick-stat-card__icon      { display: none; }
    .quick-stat-card__value     { font-size: 0.95rem; }
    .quick-stat-card__label     { font-size: 0.55rem; }
    .dashboard-content          { padding-top: 10px; padding-bottom: 24px; }
    .dashboard-section          { margin-bottom: 16px; }
    .dashboard-section__title   { font-size: 0.82rem; }
    .dashboard-section__link    { font-size: 0.7rem; }
    .order-card                 { border-radius: 8px; }
    .order-card__header         { padding: 7px 8px; }
    .order-card__number         { font-size: 0.65rem; gap: 4px; }
    .order-status-badge         { font-size: 0.55rem; padding: 2px 6px; }
    .order-card__body           { padding: 8px; }
    .order-item-mini            { width: 32px; height: 32px; }
    .order-card__details        { gap: 4px; }
    .order-detail-item          { font-size: 0.65rem; }
    .order-card__footer         { padding: 7px 8px; flex-direction: column; align-items: stretch; gap: 8px; }
    .order-card__amount         { font-size: 0.75rem; }
    .order-card__amount strong  { font-size: 0.85rem; }
    .order-card__actions        { width: 100%; flex-direction: row; gap: 6px; }
    .order-card__actions .btn   { flex: 1; justify-content: center; text-align: center; min-width: 0; font-size: 0.65rem; padding: 6px 8px; }
    .recent-orders--desktop     { display: none !important; }
    .recent-orders--mobile      { display: block !important; }
    .recent-order-chip          { flex: 0 0 150px; padding: 8px; gap: 6px; }
    .recent-order-chip__number  { font-size: 0.58rem; }
    .recent-order-chip__amount  { font-size: 0.82rem; }
    .recent-order-chip__top .order-status-badge { font-size: 0.5rem; padding: 2px 5px; }
    .recent-orders__scroll      { gap: 6px; }
    .dashboard-widget           { padding: 10px; border-radius: 8px; }
    .dashboard-widget__title    { font-size: 0.82rem; margin-bottom: 10px; padding-bottom: 8px; }
    .quick-actions              { gap: 4px; }
    .quick-action-btn           { padding: 7px 3px; border-radius: 6px; }
    .quick-action-btn i         { font-size: 0.82rem; margin-bottom: 2px; }
    .quick-action-btn span      { font-size: 0.58rem; }
    .account-info               { gap: 10px; }
    .account-info-row > i       { font-size: 0.82rem; }
    .account-info-label         { font-size: 0.58rem; }
    .account-info-value         { font-size: 0.72rem; }
    .address-card-mini          { padding: 8px; }
    .address-card-mini__label   { font-size: 0.62rem; }
    .address-card-mini__text    { font-size: 0.68rem; }
    .rewards-card               { padding: 10px; gap: 8px; }
    .rewards-card__icon         { width: 32px; height: 32px; font-size: 0.88rem; }
    .rewards-card__points       { font-size: 1.05rem; }
    .rewards-card__value        { font-size: 0.68rem; }
    .support-card               { padding: 10px; }
    .support-card__icon         { width: 32px; height: 32px; font-size: 0.82rem; }
    .support-card__title        { font-size: 0.82rem; }
    .support-card__text         { font-size: 0.7rem; }
    .reminder-card              { padding: 8px; gap: 6px; }
    .reminder-date-badge        { width: 38px; height: 38px; }
    .reminder-date-badge__day   { font-size: 0.88rem; }
    .reminder-date-badge__month { font-size: 0.55rem; }
    .reminder-card__name        { font-size: 0.78rem; }
    .reminder-card__days        { font-size: 0.65rem; }
    .empty-state                { padding: 28px 8px; }
    .empty-state__icon i        { font-size: 1.8rem; }
    .empty-state__title         { font-size: 0.92rem; }
}

/* — 280px — COMPREHENSIVE ALL-COMPONENT RESPONSIVE ────────── */
@media (max-width: 280px) {
    .container                  { padding: 0 8px; }
    .section                    { padding: 20px 0; }
    .btn                        { padding: 7px 12px; font-size: 0.72rem; }
    .btn--sm                    { font-size: 0.6rem; padding: 4px 8px; }
    .btn--full                  { padding: 8px 12px; font-size: 0.72rem; }
    .breadcrumb                 { font-size: 0.55rem; gap: 2px; }

    /* ── Forms ── */
    .form-group                 { margin-bottom: 10px; }
    .form-label                 { font-size: 0.62rem; }
    .form-input, .form-control, .form-select, .form-textarea { padding: 6px 8px; font-size: 0.75rem; }
    .form-row                   { grid-template-columns: 1fr; gap: 8px; }

    /* ── Toast ── */
    .toast-box                  { top: 56px; right: 4px; left: 4px; }
    .toast-item                 { padding: 6px 10px; font-size: 0.65rem; }

    /* ── Header ── */
    .header__inner              { padding: 0 8px; }
    .header__logo-icon          { width: 26px; height: 26px; font-size: 0.78rem; border-radius: 6px; }
    .header__logo-name          { font-size: 0.92rem; }
    .header__logo-tag           { display: none; }
    .header__logo               { gap: 6px; }
    .header__icon-btn           { width: 30px; height: 30px; font-size: 0.85rem; }
    .header__burger             { width: 30px; height: 30px; }
    .header__burger span        { width: 18px; }
    .header__actions            { gap: 1px; }
    .cart-badge                 { min-width: 13px; height: 13px; font-size: 0.45rem; top: 2px; right: 0; }
    .search-overlay             { padding: 10px 8px; }
    .search-overlay__input      { font-size: 0.82rem; padding: 8px 0; }
    .search-overlay__tags       { display: none; }

    /* ── Mobile Nav ── */
    .mobile-nav__header         { padding: 12px 12px 10px; }
    .mobile-nav__brand          { font-size: 0.92rem; }
    .mobile-nav__close          { width: 28px; height: 28px; font-size: 0.78rem; }
    .mobile-nav__body           { padding: 2px 12px; }
    .mobile-nav__links a        { padding: 8px 0; font-size: 0.78rem; gap: 6px; }
    .mobile-nav__links a i      { font-size: 0.78rem; width: 16px; }
    .mobile-nav__footer         { padding: 12px 12px 14px; }
    .mobile-nav__contact a      { font-size: 0.65rem; }

    /* ── Hero ── */
    .hero__text-pane            { padding: 14px 8px 16px; }
    .hero__heading              { font-size: 1.3rem; margin-bottom: 8px; }
    .hero__sub                  { font-size: 0.72rem; margin-bottom: 12px; line-height: 1.5; }
    .hero__eyebrow              { font-size: 0.45rem; padding: 6px 10px; gap: 6px; margin-bottom: 10px; }
    .hero__eyebrow-pulse        { width: 4px; height: 4px; }
    .hero__ctas .btn            { padding: 10px 12px; font-size: 0.72rem; }
    .hero__date-picker          { margin-top: 18px; }
    .hero__date-label           { font-size: 0.62rem; gap: 6px; margin-bottom: 8px; }
    .hero__date-options         { gap: 3px; }
    .hero__date-btn             { padding: 5px 3px; font-size: 0.52rem; }
    .hero__date-btn-day         { font-size: 0.58rem; }
    .hero__date-btn-sub         { font-size: 0.48rem; }
    .hero__pincode              { padding: 12px 10px; width: calc(100% - 16px); margin: 8px; }
    .hero__pincode-label        { font-size: 0.82rem; margin-bottom: 2px; }
    .hero__pincode-hint         { font-size: 0.62rem; margin-bottom: 10px; }
    .hero__pincode-row          { gap: 6px; }
    .hero__pincode-input        { padding: 8px 8px; font-size: 0.78rem; letter-spacing: 0.08em; }
    .hero__pincode-btn          { padding: 8px 6px; font-size: 0.58rem; }
    .hero__pincode-result       { font-size: 0.7rem; margin-top: 8px; }
    .hero__scene-pane           { min-height: 30vh; }
    .hero__pincode-saved        { width: calc(100% - 16px); margin: 8px; padding: 12px; gap: 10px; }
    .hero__pincode-saved-pin    { font-size: 0.95rem; }
    .hero__pincode-saved-label  { font-size: 0.58rem; }
    .hero__pincode-saved-change { font-size: 0.65rem; padding: 4px 8px; }

    /* ── Homepage Sections ── */
    .products__scroll-wrap      { margin: 0 -8px; padding: 0 8px; }
    .products__scroll-wrap::before,
    .products__scroll-wrap::after { width: 8px; }
    .cat-grid                   { gap: 4px; }
    .cat-card__name             { font-size: 0.62rem; }
    .occasion-chips             { grid-template-columns: 1fr 1fr; gap: 4px; }
    .occasion-chip              { padding: 8px 2px 6px; }
    .occasion-chip__emoji       { font-size: 1rem; }
    .occasion-chip__label       { font-size: 0.48rem; }
    .same-day__visual           { min-height: 180px; }
    .same-day__countdown        { padding: 12px 14px; }
    .same-day__countdown-unit span { font-size: 1.1rem; }
    .trust-item                 { padding: 12px 8px; }
    .trust-item__icon           { width: 36px; height: 36px; font-size: 0.88rem; }
    .trust-item__title          { font-size: 0.78rem; }
    .trust-item__desc           { font-size: 0.68rem; }
    .test-card                  { padding: 12px 10px; }
    .test-card__text            { font-size: 0.72rem; }
    .test-card__avatar          { width: 30px; height: 30px; font-size: 0.58rem; }
    .test-card__name            { font-size: 0.68rem; }
    .reminder__form             { padding: 12px 10px; }
    .reminder__btn              { padding: 8px 12px; font-size: 0.72rem; }
    .section__title             { font-size: clamp(1.1rem, 5vw, 1.4rem); }
    .section__subtitle          { font-size: 0.75rem; }
    .section__eyebrow           { font-size: 0.48rem; }

    /* ── Product Cards ── */
    .p-card__body               { padding: 6px 4px; }
    .p-card__cat                { font-size: 0.48rem; }
    .p-card__name               { font-size: 0.62rem; }
    .p-card__price              { font-size: 0.78rem; }
    .p-card__mrp                { font-size: 0.55rem; }
    .p-card__wish               { width: 24px; height: 24px; font-size: 0.65rem; }
    .p-card__badge              { font-size: 0.45rem; padding: 2px 6px; }
    .p-card__rating             { font-size: 0.52rem; }
    .products-grid              { gap: 6px !important; }

    /* ── Product Detail ── */
    .product-detail__layout     { gap: 16px; }
    .product-info__title        { font-size: 1.05rem; }
    .product-price__current     { font-size: 1.05rem; }
    .product-gallery__thumb     { width: 34px; height: 34px; }
    .addon-card                 { padding: 8px; }
    .addon-card__name           { font-size: 0.72rem; }

    /* ── Cart Sidebar ── */
    .cart-sidebar__header       { padding: 10px 8px; }
    .cart-sidebar__body         { padding: 8px; }
    .cart-sidebar__footer       { padding: 8px; }
    .cart-item                  { padding: 5px; gap: 6px; }
    .cart-item__img             { width: 40px; height: 40px; }
    .cart-item__name            { font-size: 0.65rem; }
    .cart-item__price           { font-size: 0.75rem; }

    /* ── Checkout ── */
    .checkout-progress          { padding: 10px 0; }
    .progress-steps             { padding: 0 4px; gap: 0; }
    .progress-step__icon        { width: 26px; height: 26px; font-size: 0.62rem; }
    .progress-step__line        { margin: 0 4px; top: -6px; }
    .checkout-section           { padding-top: 14px; padding-bottom: 80px; }
    .checkout-step              { padding: 0; }
    .checkout-step__header      { margin-bottom: 12px; }
    .checkout-step__title       { font-size: 0.88rem; gap: 6px; flex-wrap: wrap; }
    .checkout-step__title i     { font-size: 0.88rem; }
    .checkout-step__subtitle    { font-size: 0.72rem; }
    .checkout-form              { gap: 12px; }
    .form-section               { padding: 8px; margin-bottom: 0; }
    .form-section__title        { font-size: 0.75rem; margin-bottom: 8px; }
    .form-hint                  { font-size: 0.62rem; }
    .form-error, .form-success  { font-size: 0.62rem; }
    .input-with-button          { gap: 4px; }
    .input-button               { padding: 0 8px; font-size: 0.72rem; }
    .date-selector              { grid-template-columns: 1fr 1fr 1fr; gap: 4px; }
    .date-option                { padding: 10px 4px; }
    .date-option__icon          { width: 28px; height: 28px; margin-bottom: 6px; font-size: 0.82rem; }
    .date-option__label         { font-size: 0.62rem; }
    .date-option__date          { font-size: 0.55rem; }
    .date-option__badge         { font-size: 0.42rem; padding: 1px 4px; top: 2px; right: 2px; }
    .timeslot                   { padding: 10px 8px; }
    .timeslot__time             { font-size: 0.78rem; gap: 4px; margin-bottom: 4px; }
    .timeslot__time i           { font-size: 0.72rem; }
    .timeslot__status           { font-size: 0.65rem; }
    .timeslot-btn               { padding: 6px 4px; font-size: 0.6rem; }
    .payment-method__card       { padding: 10px; gap: 8px; }
    .payment-method__icon       { width: 32px; height: 32px; font-size: 0.88rem; border-radius: 6px; }
    .payment-method__name       { font-size: 0.78rem; }
    .payment-method__desc       { font-size: 0.65rem; }
    .payment-notice             { padding: 10px; gap: 8px; }
    .payment-notice__icon       { font-size: 0.95rem; }
    .payment-notice__content    { font-size: 0.72rem; }
    .checkout-offers__toggle    { padding: 8px 10px; font-size: 0.72rem; gap: 6px; }
    .form-checkbox__label       { font-size: 0.72rem; }
    .form-actions               { gap: 10px; padding-top: 14px; }
    .form-actions .btn          { padding: 10px 12px; font-size: 0.75rem; }
    .btn--mini                  { font-size: 0.58rem; padding: 3px 6px; gap: 2px; }
    .checkout-sidebar           { padding: 0; }
    .order-summary              { padding: 10px; }
    .order-summary__title       { font-size: 0.88rem; margin-bottom: 10px; padding-bottom: 8px; }
    .order-summary__items       { max-height: 200px; }
    .summary-item               { padding: 6px 0; gap: 6px; }
    .summary-item__img          { width: 32px; height: 32px; }
    .summary-item__name         { font-size: 0.65rem; }
    .summary-item__price        { font-size: 0.65rem; }
    .summary-item__bottom       { gap: 4px; margin-top: 2px; }
    .summary-qty-btn            { width: 20px; height: 20px; font-size: 0.6rem; }
    .summary-qty-val            { width: 18px; font-size: 0.6rem; line-height: 20px; }
    .summary-item__remove       { width: 16px; height: 16px; font-size: 0.45rem; top: 4px; right: -4px; }
    .summary-row                { font-size: 0.72rem; margin-bottom: 6px; }
    .summary-row--total         { font-size: 0.82rem; padding-top: 10px; margin-top: 10px; }
    .order-summary__trust       { margin-top: 12px; padding-top: 12px; gap: 6px; }
    .order-summary__trust .trust-item { font-size: 0.68rem; gap: 6px; }
    .order-summary__trust .trust-item i { font-size: 0.78rem; }
    .checkout-addons__title     { font-size: 0.75rem; }
    .co-addon                   { flex: 0 0 80px; }
    .co-addon__img              { width: 36px; height: 36px; }
    .co-addon__name             { font-size: 0.55rem; }
    .co-addon__price            { font-size: 0.6rem; }
    .co-addon__btn              { font-size: 0.5rem; padding: 2px 4px; }
    .countdown-alert            { padding: 8px 10px; gap: 8px; flex-wrap: wrap; }
    .countdown-alert__icon      { width: 30px; height: 30px; font-size: 0.78rem; }
    .countdown-alert__content strong { font-size: 0.72rem; }
    .countdown-alert__content span   { font-size: 0.65rem; }
    .cancel-modal__dialog       { padding: 20px 14px; max-width: 260px; }
    .cancel-modal__icon         { font-size: 1.8rem; margin-bottom: 8px; }
    .cancel-modal__title        { font-size: 0.92rem; }
    .cancel-modal__text         { font-size: 0.72rem; margin-bottom: 16px; }
    .cancel-modal__actions      { flex-direction: column; gap: 8px; }
    .cancel-modal__actions .btn { width: 100%; justify-content: center; font-size: 0.78rem; }
    .btn--danger                { padding: 8px 16px; font-size: 0.78rem; }

    /* ── Payment ── */
    .pay                        { padding: 24px 0 36px; }
    .pay-card__body             { padding: 10px; }
    .pay-card__head             { padding: 10px; }
    .pay-method                 { padding: 6px 8px; font-size: 0.68rem; }
    .pay-scard                  { padding: 10px; }

    /* ── Orders ── */
    .ord-page                   { padding-top: calc(var(--header-h) + 10px); padding-bottom: 24px; }
    .ord-page__title            { font-size: 0.92rem; }
    .ord-filter-tab             { padding: 3px 8px; font-size: 0.55rem; }
    .ord-card                   { padding: 10px; border-radius: 8px; }
    .ord-card__actions .btn     { font-size: 0.62rem; padding: 6px 8px; }
    .ord-show                   { padding-top: calc(var(--header-h) + 8px); padding-bottom: 24px; }
    .ord-show__head             { padding: 10px 8px; }
    .ord-show__eyebrow          { font-size: 0.52rem; }
    .ord-show__title            { font-size: 1rem; }
    .ord-show__placed           { font-size: 0.62rem; }
    .ord-quickinfo              { padding: 6px; margin-bottom: 10px; row-gap: 3px; }
    .ord-quickinfo__item        { padding: 3px 4px; gap: 4px; border-radius: 4px; }
    .ord-quickinfo__icon        { width: 20px; height: 20px; font-size: 0.55rem; border-radius: 4px; }
    .ord-quickinfo__val         { font-size: 0.62rem; }
    .ord-quickinfo__label       { font-size: 0.46rem; margin-bottom: 1px; }
    .ord-timeline               { padding: 10px 8px; }
    .ord-timeline__dot          { width: 22px; height: 22px; font-size: 0.52rem; }
    .ord-timeline__label        { font-size: 0.48rem; }
    .ord-timeline__step         { min-width: 44px; }
    .ord-timeline__line         { min-width: 10px; margin-bottom: 16px; }
    .ord-show__items, .ord-show__message, .ord-show__history { padding: 10px 8px; margin-bottom: 10px; }
    .ord-section-title          { font-size: 0.82rem; gap: 6px; margin-bottom: 10px; }
    .ord-show__item             { gap: 8px; padding: 8px 0; }
    .ord-show__item-img         { width: 36px; height: 36px; border-radius: 6px; }
    .ord-show__item-name        { font-size: 0.68rem; }
    .ord-show__item-total       { font-size: 0.72rem; }
    .ord-sidebar-card           { padding: 10px; }
    .ord-sidebar-card__title    { font-size: 0.82rem; margin-bottom: 10px; }
    .ord-summary__row           { font-size: 0.68rem; }
    .ord-summary__total strong  { font-size: 0.92rem; }
    .ord-delivery-info__label   { font-size: 0.55rem; }
    .ord-delivery-info__val     { font-size: 0.68rem; }
    .ord-btn                    { padding: 6px 10px; font-size: 0.65rem; }
    .ord-cancelled-notice       { padding: 12px 10px; gap: 10px; }
    .ord-cancelled-notice i     { font-size: 1.1rem; }

    /* ── Track ── */
    .trk-hero                   { padding: 16px 0 12px; }
    .trk-copy__title            { font-size: 1.1rem; }
    .trk-copy__sub              { font-size: 0.72rem; }
    .trkr                       { padding: 16px 0 32px; }
    .trkr-card__head            { padding: 10px; }
    .trkr-timeline              { padding: 10px; }
    .trkr-scard                 { padding: 10px; }

    /* ── Auth ── */
    .login-panel                { padding: 16px 10px; }
    .login-header__title        { font-size: 0.88rem; }
    .login-header__sub          { font-size: 0.68rem; }
    .login-social-btn           { padding: 8px; font-size: 0.72rem; }
    .login-divider              { margin: 12px 0; font-size: 0.65rem; }

    /* ── Reminders ── */
    .remf-card__body            { padding: 10px 8px; }
    .remf-occasions             { gap: 4px; }
    .remf-info-card             { padding: 10px; }
    .rem-stat                   { padding: 8px; }
    .rem-stat__val              { font-size: 0.95rem; }
    .rem-stat__label            { font-size: 0.52rem; }

    /* ── Reviews ── */
    .rvw-card__body             { padding: 12px 10px; }
    .rvw-stars__input label     { font-size: 1.6rem; }
    .rvw-product-chip           { padding: 8px; }
    .rvw-product-chip__img      { width: 36px; height: 36px; }
    .rvw-tips                   { padding: 10px; }

    /* ── Offers ── */
    .offers-hero                { padding: 56px 0 16px; }
    .offers-hero__icon          { width: 44px; height: 44px; font-size: 1.1rem; }
    .offers-hero__title         { font-size: 1.1rem; }
    .offers-hero__sub           { font-size: 0.72rem; }
    .offers-grid                { gap: 10px; }
    .coupon-card                { flex-direction: column; }
    .coupon-card__left          { width: 100%; min-height: auto; padding: 10px; flex-direction: row; gap: 8px; }
    .coupon-card__number        { font-size: 0.95rem; }
    .coupon-card__right         { padding: 10px; }
    .coupon-card__code          { font-size: 0.62rem; }
    .coupon-card__detail        { font-size: 0.65rem; }
    .offers-banner__item        { font-size: 0.65rem; }

    /* ── Search ── */
    .search-page__sidebar       { padding: 10px; }
    .search-page__pill          { font-size: 0.58rem; padding: 2px 6px; }
    .search-page__title         { font-size: 1.05rem; }

    /* ── HIW ── */
    .hiw__step                  { padding: 14px 0; }
    .hiw__step-visual           { min-height: 160px; }
    .step__title                { font-size: 0.82rem; }
    .step__text                 { font-size: 0.68rem; }
    .hiw__trust                 { padding: 14px 10px; }

    /* ── Occasion / Same-Day / Monogram ── */
    .occ-hero__title            { font-size: clamp(1.1rem, 5vw, 1.4rem); }
    .occ-grid                   { grid-template-columns: 1fr; gap: 6px; }
    .mn-hero__title             { font-size: clamp(1rem, 5vw, 1.3rem); }
    .sd-hero__title             { font-size: clamp(1.1rem, 5vw, 1.4rem); }

    /* ── Footer ── */
    .footer__cta-bar            { padding: 14px 8px; gap: 10px; }
    .footer__cta-bar h3         { font-size: 0.92rem; }
    .footer__cta-bar p          { font-size: 0.68rem; }
    .footer__grid               { gap: 14px; padding-bottom: 16px; }
    .footer__heading            { font-size: 0.75rem; margin-bottom: 8px; }
    .footer__links              { gap: 2px 6px; }
    .footer__links a            { font-size: 0.65rem; }
    .footer__social a           { width: 26px; height: 26px; font-size: 0.72rem; }
    .footer__credits            { font-size: 0.55rem; padding: 12px 0 0; }
    .footer__bottom             { padding: 12px 0; font-size: 0.55rem; }
    .footer__bottom div         { gap: 10px; }

    /* ── Dashboard ── */
    .dashboard-header           { padding: 10px 0 8px; }
    .dashboard-header__content  { gap: 10px; }
    .dashboard-welcome__title   { font-size: 0.85rem; }
    .dashboard-welcome__subtitle{ font-size: 0.65rem; }
    .dashboard-welcome          { margin-bottom: 8px; }
    .dashboard-quick-stats      { grid-template-columns: 1fr; gap: 4px; }
    .quick-stat-card            { flex-direction: row; align-items: center; gap: 8px; padding: 6px 8px; }
    .quick-stat-card__icon      { display: flex; width: 22px; height: 22px; font-size: 0.6rem; }
    .quick-stat-card__content   { display: flex; align-items: center; gap: 6px; }
    .quick-stat-card__value     { font-size: 0.88rem; margin-bottom: 0; }
    .quick-stat-card__label     { font-size: 0.55rem; }
    .dashboard-content          { padding-top: 8px; padding-bottom: 20px; }
    .dashboard-section          { margin-bottom: 14px; }
    .dashboard-section__header  { margin-bottom: 8px; }
    .dashboard-section__title   { font-size: 0.78rem; gap: 5px; }
    .dashboard-section__title i { font-size: 0.72rem; }
    .dashboard-section__link    { font-size: 0.65rem; }
    .active-orders              { gap: 10px; }
    .order-card                 { border-radius: 6px; }
    .order-card__header         { padding: 6px; flex-direction: column; align-items: flex-start; gap: 4px; }
    .order-card__number         { font-size: 0.6rem; }
    .order-card__number i       { font-size: 0.6rem; }
    .order-status-badge         { font-size: 0.5rem; padding: 2px 5px; }
    .order-card__body           { padding: 6px; }
    .order-card__items          { gap: 3px; margin-bottom: 6px; }
    .order-item-mini            { width: 28px; height: 28px; border-radius: 4px; }
    .order-item-mini--more      { font-size: 0.55rem; }
    .order-card__details        { gap: 3px; }
    .order-detail-item          { font-size: 0.6rem; gap: 3px; }
    .order-detail-item i        { font-size: 0.6rem; }
    .order-card__footer         { padding: 6px; gap: 6px; flex-direction: column; align-items: stretch; }
    .order-card__amount         { font-size: 0.68rem; }
    .order-card__amount strong  { font-size: 0.78rem; }
    .order-card__actions        { width: 100%; flex-direction: row; gap: 4px; }
    .order-card__actions .btn   { flex: 1; justify-content: center; text-align: center; min-width: 0; font-size: 0.6rem; padding: 5px 6px; gap: 3px; }
    .order-card__actions .btn i { font-size: 0.6rem; }
    .recent-orders--desktop     { display: none !important; }
    .recent-orders--mobile      { display: block !important; }
    .recent-order-chip          { flex: 0 0 140px; padding: 8px; gap: 5px; }
    .recent-order-chip__number  { font-size: 0.55rem; }
    .recent-order-chip__amount  { font-size: 0.78rem; }
    .recent-order-chip__items   { font-size: 0.62rem; }
    .recent-order-chip__bottom  { font-size: 0.6rem; }
    .recent-order-chip__top .order-status-badge { font-size: 0.48rem; padding: 2px 4px; }
    .recent-orders__scroll      { gap: 6px; }
    .dashboard-widget           { padding: 8px; border-radius: 6px; }
    .dashboard-widget__title    { font-size: 0.75rem; margin-bottom: 8px; padding-bottom: 6px; }
    .quick-actions              { grid-template-columns: 1fr 1fr; gap: 3px; }
    .quick-action-btn           { padding: 6px 2px; border-radius: 5px; }
    .quick-action-btn i         { font-size: 0.75rem; margin-bottom: 1px; }
    .quick-action-btn span      { font-size: 0.52rem; }
    .account-info               { gap: 8px; margin-bottom: 10px; }
    .account-info-row           { gap: 6px; }
    .account-info-row > i       { font-size: 0.75rem; }
    .account-info-label         { font-size: 0.52rem; margin-bottom: 1px; }
    .account-info-value         { font-size: 0.65rem; }
    .saved-addresses            { gap: 6px; margin-bottom: 8px; }
    .address-card-mini          { padding: 6px; border-radius: 6px; }
    .address-card-mini__label   { font-size: 0.58rem; margin-bottom: 4px; }
    .address-card-mini__text    { font-size: 0.62rem; }
    .address-more               { font-size: 0.62rem; margin-bottom: 8px; }
    .rewards-card               { padding: 8px; gap: 6px; border-radius: 6px; }
    .rewards-card__icon         { width: 28px; height: 28px; font-size: 0.78rem; }
    .rewards-card__label        { font-size: 0.58rem; }
    .rewards-card__points       { font-size: 0.95rem; }
    .rewards-card__value        { font-size: 0.62rem; }
    .rewards-note               { font-size: 0.6rem; gap: 4px; }
    .support-card               { padding: 8px; border-radius: 6px; }
    .support-card__icon         { width: 28px; height: 28px; font-size: 0.75rem; margin-bottom: 8px; }
    .support-card__title        { font-size: 0.75rem; }
    .support-card__text         { font-size: 0.62rem; margin-bottom: 8px; }
    .support-card .btn          { font-size: 0.68rem; padding: 6px 10px; }
    .reminder-card              { padding: 6px; gap: 5px; border-radius: 6px; }
    .reminder-date-badge        { width: 34px; height: 34px; border-radius: 6px; }
    .reminder-date-badge__day   { font-size: 0.78rem; }
    .reminder-date-badge__month { font-size: 0.5rem; }
    .reminder-card__occasion    { font-size: 0.55rem; }
    .reminder-card__name        { font-size: 0.72rem; }
    .reminder-card__days        { font-size: 0.6rem; }
    .reminder-card__action .btn { font-size: 0.62rem; padding: 5px 8px; }
    .empty-state                { padding: 20px 6px; }
    .empty-state__icon          { width: 48px; height: 48px; }
    .empty-state__icon i        { font-size: 1.5rem; }
    .empty-state__title         { font-size: 0.85rem; }
    .empty-state__text          { font-size: 0.72rem; }
    .empty-state .btn           { font-size: 0.72rem; padding: 8px 14px; }

    /* ── Auth Prompt Modal ── */
    .auth-prompt                { padding: 10px; }
    .auth-prompt__panel         { padding: 28px 16px; }
    .auth-prompt__icon          { width: 48px; height: 48px; font-size: 1.2rem; margin-bottom: 12px; }
    .auth-prompt__title         { font-size: 1.1rem; }
    .auth-prompt__text          { font-size: 0.75rem; margin-bottom: 16px; }
    .auth-prompt__btn           { padding: 10px 16px; font-size: 0.72rem; }
    .auth-prompt__note          { font-size: 0.6rem; }

    /* ── First-Order Banner ── */
    .first-order-banner__inner  { padding: 16px 0; gap: 12px; }
    .first-order-banner__icon   { width: 40px; height: 40px; font-size: 1rem; }
    .first-order-banner__title  { font-size: 0.95rem; }
    .first-order-banner__text   { font-size: 0.72rem; }
    .first-order-banner__coupons { flex-direction: column; }
    .first-order-coupon-mini    { padding: 5px 8px; gap: 6px; }
    .first-order-coupon-mini__value { font-size: 0.65rem; }
    .first-order-coupon-mini__code  { font-size: 0.6rem; padding: 2px 6px; }
}

/* ── Pulse animation for active order status dot ──────── */
@keyframes pulse-ring {
    0%   { box-shadow: 0 0 0 0 currentColor; opacity:.8; }
    70%  { box-shadow: 0 0 0 8px transparent; opacity:0; }
    100% { box-shadow: 0 0 0 0 transparent; opacity:0; }
}
.pulse-dot { animation: pulse-ring 2s infinite; }

/* ══════════════════════════════════════════════════════════════
   OFFERS & COUPONS
   ══════════════════════════════════════════════════════════════ */

/* ── Nav link accent ─────────────────────────────────────── */
.header__nav-link--offers { color: var(--rose) !important; font-weight: 600; }
.header__nav-link--offers i { font-size: 0.8em; margin-right: 2px; }

/* ── Homepage Offers Banner (ticker) ─────────────────────── */
.offers-banner { background: linear-gradient(135deg, var(--rose), #c97a5e); overflow: hidden; position: relative; display: flex; align-items: center; }
.offers-banner__track { display: flex; gap: 48px; animation: offers-scroll 25s linear infinite; white-space: nowrap; padding: 12px 0; }
.offers-banner__item { display: flex; align-items: center; gap: 10px; color: var(--white); font-size: 0.88rem; font-weight: 500; flex-shrink: 0; }
.offers-banner__item i { font-size: 0.8rem; opacity: 0.7; }
.offers-banner__code { background: rgba(255,255,255,0.2); padding: 3px 10px; border-radius: 6px; font-family: var(--font-mono, monospace); font-weight: 700; font-size: 0.85rem; letter-spacing: 0.5px; }
.offers-banner__text { opacity: 0.9; }
.offers-banner__link { position: absolute; right: 0; top: 0; bottom: 0; display: flex; align-items: center; padding: 0 24px; background: linear-gradient(90deg, transparent, rgba(140,70,50,0.95) 40%); color: var(--white); font-size: 0.82rem; font-weight: 600; text-decoration: none; gap: 6px; transition: gap 0.3s; z-index: 2; }
.offers-banner__link:hover { gap: 10px; }
@keyframes offers-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ── Offers Hero (page) ──────────────────────────────────── */
.offers-hero { padding: 120px 0 48px; background: linear-gradient(135deg, var(--cream), var(--rose-bg)); text-align: center; margin-top: var(--promise-h, 0); }
.offers-hero__inner { max-width: 600px; margin: 0 auto; }
.offers-hero__icon { width: 72px; height: 72px; margin: 0 auto 20px; background: var(--rose); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.8rem; color: var(--white); box-shadow: var(--shadow-glow); }
.offers-hero__title { font-family: var(--font-display); font-size: 2.4rem; font-weight: 500; color: var(--charcoal); margin-bottom: 12px; }
.offers-hero__title em { color: var(--rose); font-style: normal; }
.offers-hero__sub { font-size: 1rem; color: var(--warm-400); max-width: 480px; margin: 0 auto; }

/* ── Offers Page Sections ────────────────────────────────── */
.offers-section { margin-bottom: 56px; }
.offers-section__header { margin-bottom: 28px; }
.offers-section__badge { display: inline-block; padding: 5px 14px; background: var(--cream); color: var(--warm-500); font-size: 0.72rem; font-weight: 700; border-radius: 20px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.offers-section__badge--new { background: var(--rose); color: var(--white); }
.offers-section__title { font-family: var(--font-display); font-size: 1.6rem; font-weight: 500; color: var(--charcoal); margin-bottom: 6px; }
.offers-section__sub { font-size: 0.9rem; color: var(--warm-400); }
.offers-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.offers-empty { text-align: center; padding: 80px 20px; }
.offers-empty__icon { font-size: 3rem; color: var(--warm-200); margin-bottom: 16px; }
.offers-empty h3 { font-family: var(--font-display); font-size: 1.4rem; margin-bottom: 8px; color: var(--charcoal); }
.offers-empty p { color: var(--warm-400); font-size: 0.9rem; margin-bottom: 24px; }

/* ── Coupon Card (ticket style) ──────────────────────────── */
.coupon-card { display: flex; background: var(--white); border: 1.5px solid var(--sand); border-radius: var(--radius-lg); overflow: hidden; transition: all 0.3s var(--ease); }
.coupon-card:hover { border-color: var(--rose-lighter); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.coupon-card--highlight { border-color: var(--rose); background: linear-gradient(135deg, var(--rose-bg), var(--white)); }
.coupon-card__left { width: 120px; min-height: 140px; background: linear-gradient(135deg, var(--rose), #c97a5e); display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--white); flex-shrink: 0; padding: 16px 8px; }
.coupon-card--highlight .coupon-card__left { background: linear-gradient(135deg, #b5714a, #8c4632); }
.coupon-card__number { font-size: 2rem; font-weight: 800; line-height: 1; }
.coupon-card__number--rupee::before { content: '\20B9'; font-size: 1.1rem; vertical-align: top; font-weight: 600; }
.coupon-card__label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; opacity: 0.9; margin-top: 4px; }
.coupon-card__truck-icon { font-size: 2rem; margin-bottom: 4px; }

/* Divider with punched holes */
.coupon-card__divider { position: relative; width: 1px; flex-shrink: 0; }
.coupon-card__punch { position: absolute; width: 18px; height: 18px; background: var(--cream); border-radius: 50%; left: -9px; z-index: 1; }
.coupon-card__punch--top { top: -9px; }
.coupon-card__punch--bottom { bottom: -9px; }
.coupon-card__dash { position: absolute; top: 10px; bottom: 10px; left: 0; width: 1px; border-left: 2px dashed var(--sand); }

/* Right section */
.coupon-card__right { flex: 1; padding: 18px 20px; display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.coupon-card__header { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.coupon-card__title { font-size: 1.1rem; font-weight: 700; color: var(--charcoal); }
.coupon-card__tag { padding: 3px 10px; border-radius: 12px; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; }
.coupon-card__tag--new { background: var(--rose-bg); color: var(--rose); }
.coupon-card__desc { font-size: 0.85rem; color: var(--warm-400); line-height: 1.5; }
.coupon-card__meta { display: flex; flex-wrap: wrap; gap: 12px; }
.coupon-card__meta-item { display: flex; align-items: center; gap: 4px; font-size: 0.75rem; color: var(--warm-300); }
.coupon-card__meta-item i { font-size: 0.7rem; }
.coupon-card__footer { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: auto; padding-top: 10px; border-top: 1px solid var(--cream); }
.coupon-card__code { display: flex; align-items: center; gap: 8px; padding: 7px 16px; background: var(--cream); border: 2px dashed var(--sand); border-radius: 8px; font-family: var(--font-mono, monospace); font-size: 0.9rem; font-weight: 800; color: var(--rose); letter-spacing: 1.5px; cursor: pointer; transition: all 0.2s; }
.coupon-card__code:hover { background: var(--rose-bg); border-color: var(--rose); }
.coupon-card__code i { font-size: 0.8rem; color: var(--warm-300); }
.coupon-card__code.copied { background: var(--success-bg, rgba(90,154,110,.1)); border-color: var(--success); color: var(--success); }
.coupon-card__code.copied i::before { content: '\F26A'; } /* bi-check-lg */
.coupon-card__shop { font-size: 0.82rem; font-weight: 600; color: var(--rose); text-decoration: none; display: flex; align-items: center; gap: 4px; transition: gap 0.2s; white-space: nowrap; }
.coupon-card__shop:hover { gap: 8px; }

/* ── How to Use (offers page) ────────────────────────────── */
.offers-howto { margin-top: 56px; padding: 32px; background: var(--cream); border-radius: var(--radius-lg); }
.offers-howto__title { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--charcoal); margin-bottom: 20px; display: flex; align-items: center; gap: 10px; }
.offers-howto__title i { color: var(--rose); }
.offers-howto__steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.offers-howto__step { display: flex; align-items: flex-start; gap: 12px; font-size: 0.88rem; color: var(--warm-500); }
.offers-howto__num { width: 28px; height: 28px; background: var(--rose); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.78rem; font-weight: 700; flex-shrink: 0; }

/* ── Cart Sidebar Offers Strip ───────────────────────────── */
.cart-offers { padding: 0 0 12px; }
.cart-offers__strip { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: linear-gradient(135deg, var(--rose-bg), rgba(181,113,90,0.06)); border: 1px solid rgba(181,113,90,0.15); border-radius: var(--radius); text-decoration: none; color: var(--charcoal); transition: all 0.3s; }
.cart-offers__strip:hover { border-color: var(--rose); background: var(--rose-bg); }
.cart-offers__strip > i:first-child { color: var(--rose); font-size: 1rem; }
.cart-offers__text { flex: 1; font-size: 0.82rem; color: var(--warm-500); }
.cart-offers__text strong { color: var(--rose); font-weight: 700; }
.cart-offers__strip > i:last-child { font-size: 0.7rem; color: var(--warm-300); }

/* ── Checkout Offers Drawer ──────────────────────────────── */
.checkout-offers { margin-bottom: 16px; }
.checkout-offers__toggle { display: flex; align-items: center; gap: 10px; width: 100%; padding: 12px 16px; background: var(--rose-bg); border: 1.5px dashed rgba(181,113,90,0.3); border-radius: var(--radius); color: var(--rose); font-size: 0.88rem; font-weight: 600; cursor: pointer; transition: all 0.3s; }
.checkout-offers__toggle:hover { background: rgba(181,113,90,0.1); border-color: var(--rose); }
.checkout-offers__toggle i:first-child { font-size: 1rem; }
.checkout-offers__toggle span { flex: 1; text-align: left; }
.checkout-offers__arrow { font-size: 0.75rem; transition: transform 0.3s; }
.checkout-offers__arrow.open { transform: rotate(180deg); }
.checkout-offers__list { margin-top: 12px; display: flex; flex-direction: column; gap: 10px; max-height: 300px; overflow-y: auto; }
.checkout-offers__loading { text-align: center; padding: 20px; color: var(--warm-300); font-size: 0.85rem; }

/* Mini offer card for checkout drawer */
.offer-mini { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--white); border: 1.5px solid var(--sand); border-radius: var(--radius); cursor: pointer; transition: all 0.25s; }
.offer-mini:hover { border-color: var(--rose-lighter); background: var(--rose-bg); }
.offer-mini__badge { min-width: 64px; padding: 6px 10px; background: linear-gradient(135deg, var(--rose), #c97a5e); color: var(--white); font-size: 0.78rem; font-weight: 800; border-radius: 6px; text-align: center; white-space: nowrap; }
.offer-mini__info { flex: 1; min-width: 0; }
.offer-mini__code { font-family: var(--font-mono, monospace); font-size: 0.82rem; font-weight: 700; color: var(--charcoal); letter-spacing: 1px; }
.offer-mini__desc { font-size: 0.72rem; color: var(--warm-400); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.offer-mini__apply { padding: 5px 14px; background: transparent; border: 1.5px solid var(--rose); color: var(--rose); font-size: 0.75rem; font-weight: 700; border-radius: 6px; cursor: pointer; transition: all 0.2s; white-space: nowrap; }
.offer-mini__apply:hover { background: var(--rose); color: var(--white); }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
    .offers-grid { grid-template-columns: 1fr; }
    .offers-howto__steps { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .offers-hero { padding: 100px 0 36px; }
    .offers-hero__title { font-size: 1.8rem; }
    .coupon-card__left { width: 90px; min-height: 120px; }
    .coupon-card__number { font-size: 1.5rem; }
    .coupon-card__right { padding: 14px; }
    .coupon-card__footer { flex-direction: column; align-items: flex-start; }
    .offers-howto__steps { grid-template-columns: 1fr; }
    .offers-howto { padding: 24px; }
    .offers-banner__link { padding: 0 16px; font-size: 0.75rem; }
}
@media (max-width: 480px) {
    .coupon-card { flex-direction: column; }
    .coupon-card__left { width: 100%; min-height: auto; padding: 14px; flex-direction: row; gap: 8px; }
    .coupon-card__divider { display: none; }
    .coupon-card__number { font-size: 1.3rem; }
    .coupon-card__label { margin-top: 0; }
}

/* ═══════════════════════════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero Split ─────────────────────────────────────────────── */
.contact-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 88vh;
    overflow: hidden;
}
.contact-hero__left {
    position: relative;
    background: var(--charcoal);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 48px;
    overflow: hidden;
}
.contact-hero__right {
    padding: 100px 64px 80px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: var(--white);
}
.contact-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--rose);
    margin-bottom: 24px;
}
.contact-hero__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--rose);
    animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .5; transform: scale(1.4); }
}
.contact-hero__title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(3rem, 6vw, 5.5rem);
    font-weight: 600;
    line-height: 1.05;
    color: var(--charcoal);
    margin: 0 0 24px;
}
.contact-hero__title em {
    font-style: italic;
    color: var(--rose);
}
.contact-hero__sub {
    font-size: 1.05rem;
    color: var(--warm-400);
    line-height: 1.7;
    max-width: 420px;
    margin: 0 0 48px;
}

/* ── Contact Channels ───────────────────────────────────────── */
.contact-channels {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.contact-channel {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 20px;
    border: 1.5px solid var(--warm-100);
    border-radius: 14px;
    text-decoration: none;
    background: var(--white);
    transition: all 0.3s var(--ease);
    position: relative;
    overflow: hidden;
}
.contact-channel::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--rose-bg);
    opacity: 0;
    transition: opacity 0.3s var(--ease);
}
.contact-channel:hover {
    border-color: var(--rose-lighter);
    transform: translateX(4px);
    box-shadow: 0 4px 20px var(--rose-glow);
}
.contact-channel:hover::before { opacity: 1; }
.contact-channel--wa:hover { border-color: #25d366; box-shadow: 0 4px 20px rgba(37,211,102,.15); }
.contact-channel--wa:hover::before { background: rgba(37,211,102,.06); }
.contact-channel--wa .contact-channel__icon { background: rgba(37,211,102,.12); color: #25d366; }
.contact-channel__icon {
    position: relative;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: var(--rose-bg);
    color: var(--rose);
    display: grid;
    place-items: center;
    font-size: 1.1rem;
    flex-shrink: 0;
    transition: background 0.3s;
}
.contact-channel__body {
    position: relative;
    flex: 1;
}
.contact-channel__label {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--warm-300);
    margin-bottom: 2px;
}
.contact-channel__value {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--charcoal);
}
.contact-channel__hint {
    font-size: 0.72rem;
    color: var(--warm-400);
    margin-top: 1px;
}
.contact-channel__arrow {
    position: relative;
    color: var(--warm-200);
    font-size: 0.9rem;
    transition: transform 0.3s var(--ease), color 0.3s;
}
.contact-channel:hover .contact-channel__arrow {
    transform: translateX(4px);
    color: var(--rose);
}

/* ── Float Card (right panel) ───────────────────────────────── */
.contact-floatcard {
    position: relative;
    z-index: 2;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 24px;
    padding: 36px;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    color: var(--white);
    width: 100%;
    max-width: 360px;
}
.contact-floatcard__tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--rose-lighter);
    margin-bottom: 20px;
}
.contact-floatcard__addr {
    font-size: 1.05rem;
    line-height: 1.7;
    color: rgba(255,255,255,0.9);
    margin-bottom: 28px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding-bottom: 24px;
}
.contact-floatcard__hours {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 28px;
}
.contact-floatcard__hours-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.88rem;
    color: rgba(255,255,255,0.7);
}
.contact-floatcard__hours-row span:last-child {
    color: rgba(255,255,255,0.95);
    font-weight: 500;
}
.contact-floatcard__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.contact-floatcard__badges span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    background: rgba(255,255,255,0.08);
    border-radius: 100px;
    font-size: 0.72rem;
    font-weight: 500;
    color: rgba(255,255,255,0.7);
}
.contact-floatcard__badges span i { color: var(--rose-lighter); }

/* Decorative blobs */
.contact-hero__blob {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
.contact-hero__blob--1 {
    width: 320px;
    height: 320px;
    background: radial-gradient(circle, rgba(181,113,90,.25) 0%, transparent 70%);
    top: -80px;
    right: -80px;
}
.contact-hero__blob--2 {
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(181,113,90,.15) 0%, transparent 70%);
    bottom: 60px;
    left: 40px;
}

/* ── Strip ──────────────────────────────────────────────────── */
.contact-strip {
    background: var(--charcoal);
    padding: 18px 0;
    overflow: hidden;
}
.contact-strip__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px 32px;
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    color: rgba(255,255,255,0.55);
    text-transform: uppercase;
}
.contact-strip__inner i { color: var(--rose-lighter); margin-right: 5px; }
.contact-strip__dot {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: rgba(255,255,255,0.2);
}

/* ── Reach Out Section ──────────────────────────────────────── */
.contact-reach {
    padding: 100px 0 120px;
    background: var(--white);
}
.contact-reach__grid {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 80px;
    align-items: start;
}
.contact-reach__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--rose);
    margin-bottom: 14px;
}
.contact-reach__title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 600;
    color: var(--charcoal);
    margin: 0 0 14px;
    line-height: 1.1;
}
.contact-reach__sub {
    font-size: 0.95rem;
    color: var(--warm-400);
    line-height: 1.7;
    margin: 0 0 36px;
    max-width: 480px;
}

/* ── Contact Form ───────────────────────────────────────────── */
.contact-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
    transition: opacity 0.3s var(--ease);
}
.contact-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.contact-form__group {
    display: flex;
    flex-direction: column;
    gap: 7px;
}
.contact-form__label {
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: var(--warm-500);
    text-transform: uppercase;
}
.contact-form__input {
    padding: 14px 18px;
    border: 1.5px solid var(--warm-100);
    border-radius: 12px;
    font-size: 0.95rem;
    font-family: inherit;
    color: var(--charcoal);
    background: var(--white);
    outline: none;
    transition: border-color 0.25s var(--ease), box-shadow 0.25s var(--ease);
    width: 100%;
    -webkit-appearance: none;
}
.contact-form__input:focus {
    border-color: var(--rose);
    box-shadow: 0 0 0 3px var(--rose-glow);
}
.contact-form__input::placeholder { color: var(--warm-200); }
.contact-form__input--error {
    border-color: #e05252;
    box-shadow: 0 0 0 3px rgba(224,82,82,.12);
    animation: cf-shake 0.35s var(--ease);
}
@keyframes cf-shake {
    0%, 100% { transform: translateX(0); }
    20%       { transform: translateX(-6px); }
    60%       { transform: translateX(5px); }
    80%       { transform: translateX(-3px); }
}
.contact-form__select-wrap {
    position: relative;
}
.contact-form__select {
    cursor: pointer;
    padding-right: 40px;
}
.contact-form__select-icon {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--warm-300);
    font-size: 0.8rem;
    pointer-events: none;
}
.contact-form__textarea {
    resize: vertical;
    min-height: 120px;
}
.contact-form__btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 15px 32px;
    background: var(--charcoal);
    color: var(--white);
    border: none;
    border-radius: 12px;
    font-size: 0.92rem;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.3s var(--ease), transform 0.2s var(--ease), box-shadow 0.3s;
    align-self: flex-start;
}
.contact-form__btn:hover {
    background: var(--rose);
    box-shadow: 0 6px 24px var(--rose-glow);
    transform: translateY(-2px);
}
.contact-form__btn:hover .contact-form__btn-icon {
    transform: translateX(4px);
}
.contact-form__btn-icon {
    transition: transform 0.3s var(--ease);
}
.contact-form__btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}
.contact-form__success {
    display: none;
    align-items: flex-start;
    gap: 16px;
    padding: 24px;
    background: #edf7f0;
    border: 1.5px solid #a8d9b8;
    border-radius: 14px;
    color: #1e6b3a;
}
.contact-form__success i {
    font-size: 1.5rem;
    flex-shrink: 0;
    margin-top: 2px;
}
.contact-form__success strong { display: block; margin-bottom: 4px; font-size: 0.95rem; }
.contact-form__success p { margin: 0; font-size: 0.875rem; opacity: .8; }
.contact-form__success--visible {
    display: flex !important;
    animation: cf-success-in 0.5s var(--ease) forwards;
}
@keyframes cf-success-in {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── FAQ Accordion ──────────────────────────────────────────── */
.contact-faq {
    background: var(--cream);
    border-radius: 20px;
    padding: 28px;
    margin-bottom: 24px;
}
.contact-faq__header {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--warm-400);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 7px;
}
.contact-faq__list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.contact-faq__item {
    border-bottom: 1px solid var(--warm-100);
}
.contact-faq__item:last-child { border-bottom: none; }
.contact-faq__q {
    list-style: none;
    padding: 14px 4px;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--charcoal);
    cursor: pointer;
    user-select: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    transition: color 0.2s;
}
.contact-faq__q::-webkit-details-marker { display: none; }
.contact-faq__q::after {
    content: '\f282';
    font-family: 'bootstrap-icons';
    font-size: 0.75rem;
    color: var(--warm-300);
    flex-shrink: 0;
    transition: transform 0.3s var(--ease), color 0.2s;
}
.contact-faq__item[open] .contact-faq__q { color: var(--rose); }
.contact-faq__item[open] .contact-faq__q::after {
    transform: rotate(180deg);
    color: var(--rose);
}
.contact-faq__a {
    font-size: 0.865rem;
    color: var(--warm-400);
    line-height: 1.7;
    padding: 0 4px 16px;
    margin: 0;
}
.contact-faq__a strong { color: var(--charcoal); }

/* ── Social Links ───────────────────────────────────────────── */
.contact-social {
    padding: 24px;
    border: 1.5px solid var(--warm-100);
    border-radius: 20px;
}
.contact-social__label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--warm-400);
    margin-bottom: 16px;
}
.contact-social__links {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.contact-social__link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 10px;
    text-decoration: none;
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--charcoal);
    background: var(--cream);
    transition: all 0.25s var(--ease);
}
.contact-social__link i {
    font-size: 1.05rem;
    color: var(--warm-400);
    transition: color 0.2s;
}
.contact-social__link:hover {
    background: var(--rose-bg);
    color: var(--rose);
    transform: translateX(3px);
}
.contact-social__link:hover i { color: var(--rose); }
.contact-social__link--wa:hover {
    background: rgba(37,211,102,.08);
    color: #128c5e;
}
.contact-social__link--wa:hover i { color: #25d366; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1100px) {
    .contact-hero__left { padding: 80px 48px 64px; }
    .contact-reach__grid { grid-template-columns: 1fr 360px; gap: 60px; }
}
@media (max-width: 900px) {
    .contact-hero {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    .contact-hero__left { padding: 80px 32px 56px; }
    .contact-hero__right {
        padding: 56px 32px;
        min-height: 400px;
    }
    .contact-reach__grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }
    .contact-reach__sub { max-width: 100%; }
}
@media (max-width: 640px) {
    .contact-hero__left { padding: 64px 24px 48px; }
    .contact-hero__right { padding: 40px 24px; }
    .contact-hero__title { font-size: 2.8rem; }
    .contact-form__row { grid-template-columns: 1fr; }
    .contact-floatcard { padding: 24px; }
    .contact-reach { padding: 64px 0 80px; }
    .contact-faq { padding: 20px; }
    .contact-strip__dot { display: none; }
    .contact-strip__inner { justify-content: flex-start; padding: 0 24px; }
}
@media (max-width: 400px) {
    .contact-hero__title { font-size: 2.2rem; }
    .contact-channel { padding: 14px 16px; gap: 12px; }
    .contact-channel__icon { width: 38px; height: 38px; font-size: 0.95rem; }
}

/* ═══════════════════════════════════════════════════════════════
   WISHLIST PAGE
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero ──────────────────────────────────────────────────── */
.wl-hero {
    margin-top: calc(var(--promise-h) + var(--header-h));
    background: linear-gradient(135deg, var(--ivory) 0%, #fdf3ee 100%);
    border-bottom: 1.5px solid var(--sand);
    padding: 40px 0 32px;
}
.wl-hero__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.wl-hero__left { flex: 1; min-width: 0; }
.wl-hero__title {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 500;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 6px;
    line-height: 1.2;
}
.wl-hero__title i { color: var(--rose); font-size: 1.7rem; }
.wl-hero__sub {
    font-size: 0.9rem;
    color: var(--warm-400);
    margin: 0;
}
.wl-hero__cta { flex-shrink: 0; }

/* ── Body ──────────────────────────────────────────────────── */
.wl-body {
    background: var(--white);
    padding: 40px 0 64px;
    min-height: 50vh;
}

/* ── Empty State ───────────────────────────────────────────── */
.wl-empty {
    text-align: center;
    padding: 80px 20px;
}
.wl-empty__icon {
    width: 88px;
    height: 88px;
    margin: 0 auto 24px;
    background: var(--cream);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    color: var(--rose);
}
.wl-empty__title {
    font-family: var(--font-display);
    font-size: 1.6rem;
    color: var(--charcoal);
    margin-bottom: 10px;
}
.wl-empty__text {
    font-size: 0.9rem;
    color: var(--warm-400);
    max-width: 340px;
    margin: 0 auto 28px;
    line-height: 1.6;
}

/* ── Grid ──────────────────────────────────────────────────── */
.wl-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 24px;
    padding: 4px 0 8px;
}

/* ── Card ──────────────────────────────────────────────────── */
.wl-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    border: 1.5px solid var(--sand);
    overflow: hidden;
    transition: box-shadow 0.25s, transform 0.25s;
    display: flex;
    flex-direction: column;
}
.wl-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px);
}
.wl-card__img-wrap {
    display: block;
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--cream);
}
.wl-card__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s var(--ease);
}
.wl-card:hover .wl-card__img-wrap img { transform: scale(1.05); }
.wl-card__out-badge {
    position: absolute;
    bottom: 10px;
    left: 10px;
    background: rgba(26,23,20,0.75);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 20px;
}
.wl-card__body {
    padding: 14px 16px 8px;
    flex: 1;
}
.wl-card__name {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--charcoal);
    text-decoration: none;
    line-height: 1.35;
    margin-bottom: 6px;
    transition: color 0.2s;
}
.wl-card__name:hover { color: var(--rose); }
.wl-card__price {
    font-size: 1rem;
    font-weight: 700;
    color: var(--rose);
}
.wl-card__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px 12px;
}
.wl-card__add-btn {
    flex: 1;
    justify-content: center;
}
.wl-card__remove {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: 1.5px solid var(--sand);
    background: transparent;
    color: var(--warm-400);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
    flex-shrink: 0;
}
.wl-card__remove:hover {
    border-color: #e53935;
    color: #e53935;
    background: #fff1f1;
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 768px) {
    .wl-hero {
        margin-top: var(--header-h);
        padding: 28px 0 22px;
    }
    .wl-hero__title { font-size: 1.5rem; }
    .wl-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
    .wl-body { padding: 28px 0 48px; }
}
@media (max-width: 480px) {
    .wl-hero { padding: 22px 0 18px; }
    .wl-hero__title { font-size: 1.3rem; gap: 8px; }
    .wl-hero__title i { font-size: 1.2rem; }
    .wl-hero__cta { font-size: 0.82rem; padding: 9px 14px; }
    .wl-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .wl-card__body { padding: 10px 12px 6px; }
    .wl-card__name { font-size: 0.82rem; }
    .wl-card__price { font-size: 0.9rem; }
    .wl-card__actions { padding: 8px 10px 10px; gap: 6px; }
}

/* ═══════════════════════════════════════════════════════════════
   PROFILE PAGE
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero ──────────────────────────────────────────────────── */
.prof-hero {
    margin-top: calc(var(--promise-h) + var(--header-h));
    background: linear-gradient(135deg, var(--ivory) 0%, #fdf3ee 100%);
    border-bottom: 1.5px solid var(--sand);
    padding: 40px 0 36px;
}
.prof-hero__inner {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.prof-hero__avatar {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--rose) 0%, var(--rose-dark, #a05a3c) 100%);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.prof-hero__avatar span {
    font-family: var(--font-display);
    font-size: 1.8rem; font-weight: 600;
    color: var(--white);
}
.prof-hero__info { flex: 1; min-width: 0; }
.prof-hero__name {
    font-family: var(--font-display);
    font-size: 1.8rem; font-weight: 500;
    color: var(--charcoal);
    margin: 0 0 4px; line-height: 1.2;
}
.prof-hero__email,
.prof-hero__since {
    font-size: 0.82rem; color: var(--warm-400);
    margin: 0; display: flex; align-items: center; gap: 6px;
}
.prof-hero__since { margin-top: 2px; }
.prof-hero__back { flex-shrink: 0; }

/* ── Body ──────────────────────────────────────────────────── */
.prof-body {
    background: var(--white);
    padding: 40px 0 80px;
    min-height: 60vh;
}

/* ── Layout ────────────────────────────────────────────────── */
.prof-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 40px;
    align-items: start;
}

/* ── Sidebar Nav ───────────────────────────────────────────── */
.prof-nav {
    position: sticky;
    top: calc(var(--header-h) + var(--promise-h) + 24px);
    display: flex; flex-direction: column; gap: 4px;
    background: var(--ivory);
    border-radius: var(--radius-lg);
    padding: 16px 12px;
    border: 1.5px solid var(--sand);
}
.prof-nav__link {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 14px;
    border-radius: var(--radius);
    font-size: 0.85rem; font-weight: 600;
    color: var(--warm-500);
    text-decoration: none;
    transition: all 0.2s;
}
.prof-nav__link:hover { background: var(--cream); color: var(--charcoal); }
.prof-nav__link--active {
    background: var(--rose-bg);
    color: var(--rose);
}
.prof-nav__link--active i { color: var(--rose); }
.prof-nav__link--danger { color: var(--warm-400); }
.prof-nav__link--danger:hover { color: #e53935; background: #fff1f1; }
.prof-nav__link--danger.prof-nav__link--active { background: #fff1f1; color: #e53935; }

/* ── Cards ─────────────────────────────────────────────────── */
.prof-card {
    background: var(--white);
    border: 1.5px solid var(--sand);
    border-radius: var(--radius-lg);
    padding: 0;
    margin-bottom: 28px;
    overflow: hidden;
    scroll-margin-top: calc(var(--header-h) + var(--promise-h) + 24px);
}
.prof-card__header {
    padding: 24px 28px;
    border-bottom: 1px solid var(--sand);
    background: var(--ivory);
}
.prof-card__title {
    font-family: var(--font-display);
    font-size: 1.2rem; font-weight: 600;
    color: var(--charcoal);
    display: flex; align-items: center; gap: 10px;
    margin: 0 0 4px;
}
.prof-card__title i { color: var(--rose); font-size: 1.1rem; }
.prof-card__sub {
    font-size: 0.82rem; color: var(--warm-400); margin: 0;
}
.prof-card--danger { border-color: #f5c6c6; }
.prof-card--danger .prof-card__header { background: #fff8f8; }
.prof-card--danger .prof-card__title i { color: #e53935; }

/* ── Form ──────────────────────────────────────────────────── */
.prof-form { padding: 28px; }
.prof-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
}
.prof-form__group { display: flex; flex-direction: column; }
.prof-form__label {
    font-size: 0.78rem; font-weight: 700;
    color: var(--charcoal);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 8px;
}
.prof-form__input-wrap {
    position: relative;
}
.prof-form__input-wrap .fi {
    position: absolute;
    left: 14px; top: 50%;
    transform: translateY(-50%);
    color: var(--warm-300);
    font-size: 0.9rem;
    pointer-events: none;
}
.prof-form__input {
    width: 100%;
    padding: 12px 14px 12px 42px;
    border: 1.5px solid var(--sand);
    border-radius: var(--radius);
    font-size: 0.88rem;
    color: var(--charcoal);
    background: var(--white);
    transition: border-color 0.2s, box-shadow 0.2s;
    font-family: var(--font-body);
    appearance: none; -webkit-appearance: none;
}
.prof-form__input:focus {
    outline: none;
    border-color: var(--rose);
    box-shadow: 0 0 0 3px rgba(181,113,90,0.1);
}
.prof-form__input::placeholder { color: var(--warm-300); }
.prof-form__error {
    font-size: 0.75rem; color: #e53935;
    margin: 6px 0 0; font-weight: 500;
}
.prof-form__verify {
    font-size: 0.78rem; color: var(--warm-400);
    margin-top: 6px;
    display: flex; align-items: center; gap: 8px;
}
.prof-form__verify-link {
    background: none; border: none;
    color: var(--rose); font-weight: 600;
    text-decoration: underline; cursor: pointer;
    font-size: 0.78rem;
}
.prof-form__actions {
    padding-top: 12px;
    display: flex; align-items: center; gap: 12px;
}

/* ── Danger Zone ───────────────────────────────────────────── */
.prof-danger { padding: 28px; }
.prof-danger__confirm-text {
    font-size: 0.88rem; color: var(--warm-500);
    margin-bottom: 16px; font-weight: 500;
}
.prof-danger__form { margin-top: 20px; }
.prof-danger__actions {
    display: flex; align-items: center; gap: 12px;
    margin-top: 16px;
}
.btn--outline-danger {
    background: transparent;
    border: 1.5px solid #e53935;
    color: #e53935;
    font-size: 0.85rem; font-weight: 600;
    padding: 10px 20px; border-radius: var(--radius);
    cursor: pointer; transition: all 0.2s;
    display: inline-flex; align-items: center; gap: 8px;
}
.btn--outline-danger:hover { background: #e53935; color: #fff; }
.btn--danger {
    background: #e53935; color: #fff;
    border: none; padding: 10px 20px;
    border-radius: var(--radius);
    font-size: 0.85rem; font-weight: 600;
    cursor: pointer; transition: all 0.2s;
    display: inline-flex; align-items: center; gap: 8px;
}
.btn--danger:hover { background: #c62828; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 768px) {
    .prof-hero { margin-top: var(--header-h); padding: 28px 0 22px; }
    .prof-hero__name { font-size: 1.4rem; }
    .prof-hero__avatar { width: 56px; height: 56px; }
    .prof-hero__avatar span { font-size: 1.4rem; }
    .prof-hero__back { display: none; }
    .prof-layout { grid-template-columns: 1fr; gap: 0; }
    .prof-nav {
        position: static;
        flex-direction: row;
        border-radius: 0;
        border-left: none; border-right: none; border-top: none;
        padding: 12px 0;
        gap: 0;
        overflow-x: auto;
        scrollbar-width: none;
        background: var(--white);
        border-bottom: 1.5px solid var(--sand);
        margin: 0 -16px;
        padding-left: 16px; padding-right: 16px;
    }
    .prof-nav::-webkit-scrollbar { display: none; }
    .prof-nav__link {
        white-space: nowrap;
        padding: 9px 14px;
        font-size: 0.78rem;
    }
    .prof-body { padding: 24px 0 48px; }
    .prof-card { border-radius: var(--radius); margin-bottom: 20px; }
    .prof-form { padding: 20px; }
    .prof-form__row { grid-template-columns: 1fr; gap: 16px; margin-bottom: 16px; }
    .prof-card__header { padding: 18px 20px; }
    .prof-danger { padding: 20px; }
}
@media (max-width: 480px) {
    .prof-hero { padding: 20px 0 16px; }
    .prof-hero__name { font-size: 1.2rem; }
    .prof-hero__inner { gap: 14px; }
    .prof-form__input { padding: 10px 10px 10px 38px; font-size: 0.84rem; }
    .prof-form__label { font-size: 0.72rem; }
}