/* ============================================
   Next Day Balloons - Fixed Styles
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&family=Libre+Baskerville:wght@400;700&display=swap');

:root {
    --color-primary: #1a1a1a;
    --color-primary-dark: #0d0d0d;
    --color-primary-light: #3d3d3d;
    --color-secondary: #0066b3;
    --color-accent-gold: #d4af37;
    --color-card-blue: #c5e8f7;
    --color-card-blue-hover: #b0dff5;
    --color-white: #FFFDF9;
    --color-pure-white: #FFFDF9;
    --color-gray-50: #FAFAFA;
    --color-gray-100: #F5F5F5;
    --color-gray-200: #EEEEEE;
    --color-gray-300: #E0E0E0;
    --color-gray-400: #BDBDBD;
    --color-gray-500: #9E9E9E;
    --color-gray-600: #757575;
    --color-gray-700: #616161;
    --color-gray-800: #424242;
    --color-gray-900: #212121;
    --color-success: #4CAF50;
    --color-error: #F44336;
    --color-background: #FFFDF9;
    --color-header-bg: #FFFDF9;
    --color-header-text: #333333;
    --font-primary: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-display: 'Libre Baskerville', Georgia, serif;
    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 1.875rem;
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-2xl: 24px;
    --radius-full: 9999px;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
    --shadow-lg: 0 10px 40px rgba(0,0,0,0.12);
    --container-max: 1280px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { 
    font-size: 16px; 
    scroll-behavior: smooth; 
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
body { 
    font-family: var(--font-primary); 
    font-size: var(--text-base); 
    line-height: 1.6; 
    color: var(--color-gray-800); 
    background-color: var(--color-background);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}
.main-content { flex: 1; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }
.container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-6); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-primary); font-weight: 700; line-height: 1.2; color: var(--color-gray-900); }

/* BUTTONS - Fixed sizing */
.btn { 
    display: inline-flex; 
    align-items: center; 
    justify-content: center; 
    gap: var(--space-2); 
    padding: 10px 20px; 
    font-size: var(--text-sm); 
    font-weight: 600; 
    border-radius: var(--radius-md); 
    transition: all 0.2s ease; 
    cursor: pointer; 
    white-space: nowrap;
    border: none;
}
.btn-sm { padding: 8px 16px; font-size: var(--text-xs); }
.btn-lg { padding: 14px 28px; font-size: var(--text-base); }
.btn-primary { background: var(--color-primary); color: #FFFFFF; }
.btn-primary:hover { background: var(--color-primary-dark); }
.btn-secondary { background: var(--color-pure-white); color: var(--color-gray-900); border: 1px solid var(--color-gray-300); }
.btn-secondary:hover { background: var(--color-gray-100); }
.btn-outline { background: transparent; color: var(--color-gray-700); border: 1px solid var(--color-gray-300); }
.btn-outline:hover { border-color: var(--color-primary); color: var(--color-primary); }
.btn-white { background: var(--color-pure-white); color: var(--color-primary); }
.btn-white:hover { background: var(--color-gray-100); }
.btn-ghost { background: transparent; color: var(--color-gray-600); }
.btn-ghost:hover { color: var(--color-primary); }
.btn-block { display: flex; width: 100%; }

/* ANNOUNCEMENT BAR */
.announcement-bar { background: var(--color-primary); color: #FFFFFF; padding: var(--space-2) 0; text-align: center; font-size: var(--text-sm); font-weight: 500; }
.announcement-bar i { margin-right: var(--space-2); }

/* STICKY HEADER - FIXED */
.main-header { 
    background: var(--color-header-bg); 
    border-bottom: 1px solid var(--color-gray-200); 
    position: -webkit-sticky;
    position: sticky; 
    top: 0; 
    z-index: 100;
    transition: box-shadow 0.3s ease;
}
.main-header.no-sticky {
    position: relative;
}
.main-header.scrolled { 
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
.header-wrapper { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) 0; }
.logo { display: flex; align-items: center; gap: var(--space-2); }
.logo-icon { font-size: var(--text-2xl); }
.logo-text { font-size: var(--text-lg); font-weight: 800; color: var(--color-primary); }
.main-nav { flex: 1; display: flex; justify-content: center; }
.nav-list { display: flex; align-items: center; }
.nav-item > a { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-3) var(--space-4); font-size: var(--text-sm); font-weight: 600; color: var(--color-gray-800); }
.nav-item > a:hover { color: var(--color-primary); }
.nav-item > a .nav-arrow { font-size: 10px; opacity: 0.5; }
.has-dropdown { position: relative; }
.dropdown-menu { position: absolute; top: 100%; left: 0; background: var(--color-pure-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-md); min-width: 220px; opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.2s; z-index: 100; box-shadow: var(--shadow-lg); }
.has-dropdown:hover .dropdown-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.dropdown-menu ul li a { display: block; padding: var(--space-3) var(--space-4); font-size: var(--text-sm); color: var(--color-gray-700); border-bottom: 1px solid var(--color-gray-100); }
.dropdown-menu ul li:last-child a { border-bottom: none; }
.dropdown-menu ul li a:hover { background: var(--color-gray-50); color: var(--color-primary); }
.header-actions { display: flex; align-items: center; gap: var(--space-2); }
.action-btn { position: relative; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; font-size: var(--text-lg); color: var(--color-gray-700); border-radius: var(--radius-full); }
.action-btn:hover { color: var(--color-primary); background: var(--color-gray-100); }
.cart-count { position: absolute; top: 0; right: 0; min-width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: var(--color-white); background: var(--color-primary); border-radius: 50%; }
.mobile-menu-btn { 
    display: none; 
    flex-direction: column; 
    justify-content: center;
    align-items: center;
    gap: 6px; 
    width: 44px; 
    height: 44px; 
    padding: 10px;
    cursor: pointer;
    position: relative;
}
.mobile-menu-btn span { 
    display: block; 
    width: 22px; 
    height: 1.5px; 
    background: var(--color-header-text); 
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    transform-origin: center;
    border-radius: 2px;
}
.mobile-menu-btn.active span:nth-child(1) {
    transform: translateY(7.5px) rotate(45deg);
}
.mobile-menu-btn.active span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}
.mobile-menu-btn.active span:nth-child(3) {
    transform: translateY(-7.5px) rotate(-45deg);
}

/* Premium Cart Icon */
.cart-icon {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    font-size: 1.25rem;
    color: var(--color-header-text);
    transition: all 0.2s ease;
}
.cart-icon:hover {
    transform: scale(1.05);
}
.cart-icon i {
    font-weight: 300;
}

/* HEADER SEARCH BAR */
.header-search-container {
    padding: var(--space-2) 0 var(--space-3);
}
.search-input-wrapper {
    display: flex;
    align-items: center;
    max-width: 500px;
    margin: 0 auto;
    border: 1px solid var(--color-primary);
    border-radius: var(--search-radius, 1px);
    overflow: hidden;
    background: var(--color-pure-white);
}
.header-search-input {
    flex: 1;
    border: none;
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    font-family: var(--font-body, inherit);
    outline: none;
    background: transparent;
    min-width: 0;
}
.header-search-input::placeholder {
    color: var(--color-gray-400);
    font-family: var(--font-body, inherit);
}
.header-search-btn {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    color: var(--color-primary);
    font-size: var(--text-base);
    cursor: pointer;
    transition: all 0.2s;
    flex-shrink: 0;
}
.header-search-btn:hover {
    background: var(--color-primary);
    color: var(--color-white);
}

@media (max-width: 768px) {
    .header-search-container {
        padding: var(--space-2) var(--space-4) var(--space-3);
    }
    .search-input-wrapper {
        max-width: 85%;
    }
    .header-search-input {
        font-size: var(--text-xs);
        padding: var(--space-2) var(--space-3);
    }
    .header-search-btn {
        width: 36px;
        height: 36px;
    }
}

/* HERO */
.hero { padding: var(--space-16) 0; background: var(--color-pure-white); text-align: center; }
.hero-content { max-width: 600px; margin: 0 auto; }
.hero-title { font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; margin-bottom: var(--space-4); }
.hero-text { font-size: var(--text-lg); color: var(--color-gray-600); margin-bottom: var(--space-6); }
.hero-buttons { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }

/* HERO SLIDER SECTION - PREMIUM */
.hero-section {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: var(--color-gray-900);
}
.hero-slider {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}
.hero-slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.8s ease-in-out;
    overflow: hidden;
}
.hero-slide.active {
    opacity: 1;
}
.hero-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    transform-origin: center center;
}
.hero-slide video,
.hero-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    background: transparent;
}
/* Hero section background matches overlay to prevent dark flash */
.hero-section {
    background: var(--hero-overlay-color, #1a1a1a);
}
.hero-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--color-gray-700) 0%, var(--color-gray-800) 100%);
    color: var(--color-gray-400);
    gap: var(--space-2);
}
.hero-placeholder i {
    font-size: 3rem;
    opacity: 0.5;
}
.hero-placeholder span {
    font-size: var(--text-sm);
    opacity: 0.7;
}
.hero-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
}
.hero-section .hero-content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    padding: var(--space-6);
    z-index: 2;
    max-width: 1400px;
    margin: 0 auto;
    left: 0;
    right: 0;
}
.hero-section .hero-title {
    margin-bottom: var(--space-4);
    line-height: 1.2;
}
.hero-section .hero-subtitle {
    font-size: clamp(1rem, 2.5vw, 1.5rem);
    opacity: 0.95;
    max-width: 700px;
    line-height: 1.5;
    margin-bottom: var(--space-6);
}

/* Hero Buttons */
.hero-buttons {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.hero-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: all 0.3s ease;
    cursor: pointer;
}
.hero-btn-small { padding: 10px 20px; font-size: 0.875rem; }
.hero-btn-medium { padding: 14px 28px; font-size: 1rem; }
.hero-btn-large { padding: 18px 36px; font-size: 1.125rem; }
.hero-btn-solid {
    background: var(--color-primary);
    color: #fff;
    border: 2px solid var(--color-primary);
}
.hero-btn-solid:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    transform: translateY(-2px);
}
.hero-btn-outline {
    background: transparent;
    color: #fff;
    border: 2px solid #fff;
}
.hero-btn-outline:hover {
    background: #fff;
    color: var(--color-gray-900);
}
.hero-btn-ghost {
    background: rgba(255,255,255,0.1);
    color: #fff;
    border: 2px solid transparent;
    backdrop-filter: blur(4px);
}
.hero-btn-ghost:hover {
    background: rgba(255,255,255,0.2);
}

/* Navigation Dots */
.hero-dots {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 3;
}
.hero-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255,255,255,0.4);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
}
.hero-dot.active, .hero-dot:hover {
    background: #fff;
    transform: scale(1.2);
}

/* Navigation Arrows */
.hero-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: transparent;
    color: rgba(255,255,255,0.8);
    border: none;
    cursor: pointer;
    z-index: 3;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    text-shadow: 0 2px 4px rgba(0,0,0,0.5);
}
.hero-arrow:hover, .hero-arrow:active {
    background: rgba(0,0,0,0.4);
    color: #fff;
}
.hero-arrow-prev { left: 20px; }
.hero-arrow-next { right: 20px; }

/* Arrow Styles */
.hero-arrows-circle .hero-arrow { background: rgba(0,0,0,0.5); border-radius: 50%; }
.hero-arrows-circle .hero-arrow:hover { background: rgba(0,0,0,0.7); }
.hero-arrows-square .hero-arrow { background: rgba(0,0,0,0.5); border-radius: 8px; }
.hero-arrows-square .hero-arrow:hover { background: rgba(0,0,0,0.7); }
.hero-arrows-pill .hero-arrow { background: rgba(0,0,0,0.5); border-radius: 25px; width: 60px; }
.hero-arrows-pill .hero-arrow:hover { background: rgba(0,0,0,0.7); }
.hero-arrows-outline .hero-arrow { background: transparent; border: 2px solid rgba(255,255,255,0.8); }
.hero-arrows-outline .hero-arrow:hover { background: rgba(255,255,255,0.2); border-color: #fff; }
.hero-arrows-glass .hero-arrow { background: rgba(255,255,255,0.15); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,0.2); }
.hero-arrows-glass .hero-arrow:hover { background: rgba(255,255,255,0.25); }
.hero-arrows-gradient .hero-arrow { background: linear-gradient(135deg, rgba(227,24,55,0.8) 0%, rgba(200,20,50,0.9) 100%); }
.hero-arrows-gradient .hero-arrow:hover { background: linear-gradient(135deg, rgba(227,24,55,1) 0%, rgba(200,20,50,1) 100%); transform: translateY(-50%) scale(1.1); }
.hero-arrows-shadow .hero-arrow { background: rgba(0,0,0,0.6); box-shadow: 0 4px 15px rgba(0,0,0,0.4), 0 2px 6px rgba(0,0,0,0.3); }
.hero-arrows-shadow .hero-arrow:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.5), 0 3px 10px rgba(0,0,0,0.4); transform: translateY(-50%) scale(1.05); }
.hero-arrows-neon .hero-arrow { background: transparent; border: 2px solid #00f0ff; color: #00f0ff; box-shadow: 0 0 10px rgba(0,240,255,0.5), inset 0 0 10px rgba(0,240,255,0.1); text-shadow: 0 0 10px rgba(0,240,255,0.8); }
.hero-arrows-neon .hero-arrow:hover { background: rgba(0,240,255,0.2); box-shadow: 0 0 20px rgba(0,240,255,0.8), inset 0 0 15px rgba(0,240,255,0.2); }
.hero-arrows-elegant .hero-arrow { background: transparent; border: 1px solid rgba(255,255,255,0.5); font-size: 1.2rem; }
.hero-arrows-elegant .hero-arrow:hover { border-color: #fff; background: rgba(255,255,255,0.1); }

/* Arrow Sizes */
.hero-arrows-small .hero-arrow { width: 32px; height: 32px; font-size: 1rem; }
.hero-arrows-medium .hero-arrow { width: 40px; height: 40px; font-size: 1.25rem; }
.hero-arrows-large .hero-arrow { width: 50px; height: 50px; font-size: 1.5rem; }
.hero-arrows-xlarge .hero-arrow { width: 60px; height: 60px; font-size: 1.75rem; }

/* Arrow Positions */
.hero-arrows-bottom .hero-arrow { top: auto; bottom: 80px; transform: none; }
.hero-arrows-bottom .hero-arrow-prev { left: calc(50% - 60px); }
.hero-arrows-bottom .hero-arrow-next { right: calc(50% - 60px); }
.hero-arrows-bottom-left .hero-arrow { top: auto; bottom: 30px; transform: none; }
.hero-arrows-bottom-left .hero-arrow-prev { left: 20px; }
.hero-arrows-bottom-left .hero-arrow-next { left: 80px; right: auto; }
.hero-arrows-bottom-right .hero-arrow { top: auto; bottom: 30px; transform: none; }
.hero-arrows-bottom-right .hero-arrow-prev { right: 80px; left: auto; }
.hero-arrows-bottom-right .hero-arrow-next { right: 20px; }
.hero-arrows-bottom-sides .hero-arrow { top: auto; bottom: 30px; transform: none; }
.hero-arrows-bottom-sides .hero-arrow-prev { left: 20px; }
.hero-arrows-bottom-sides .hero-arrow-next { right: 20px; }

/* Text Animations */
.hero-text-animation-fade-up .hero-title,
.hero-text-animation-fade-up .hero-subtitle,
.hero-text-animation-fade-up .hero-buttons {
    animation: heroFadeUp 0.8s ease-out forwards;
    opacity: 0;
}
.hero-text-animation-fade-up .hero-subtitle { animation-delay: 0.2s; }
.hero-text-animation-fade-up .hero-buttons { animation-delay: 0.4s; }

.hero-text-animation-fade-in .hero-title,
.hero-text-animation-fade-in .hero-subtitle,
.hero-text-animation-fade-in .hero-buttons {
    animation: heroFadeIn 0.8s ease-out forwards;
    opacity: 0;
}
.hero-text-animation-fade-in .hero-subtitle { animation-delay: 0.2s; }
.hero-text-animation-fade-in .hero-buttons { animation-delay: 0.4s; }

.hero-text-animation-slide-in .hero-title,
.hero-text-animation-slide-in .hero-subtitle,
.hero-text-animation-slide-in .hero-buttons {
    animation: heroSlideIn 0.8s ease-out forwards;
    opacity: 0;
}
.hero-text-animation-slide-in .hero-subtitle { animation-delay: 0.15s; }
.hero-text-animation-slide-in .hero-buttons { animation-delay: 0.3s; }

.hero-text-animation-zoom-in .hero-title,
.hero-text-animation-zoom-in .hero-subtitle,
.hero-text-animation-zoom-in .hero-buttons {
    animation: heroZoomIn 0.8s ease-out forwards;
    opacity: 0;
}
.hero-text-animation-zoom-in .hero-subtitle { animation-delay: 0.2s; }
.hero-text-animation-zoom-in .hero-buttons { animation-delay: 0.4s; }

@keyframes heroFadeUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}
@keyframes heroFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
@keyframes heroSlideIn {
    from { opacity: 0; transform: translateX(-30px); }
    to { opacity: 1; transform: translateX(0); }
}
@keyframes heroZoomIn {
    from { opacity: 0; transform: scale(0.9); }
    to { opacity: 1; transform: scale(1); }
}

/* Slide transition */
.hero-slider[data-transition="slide"] .hero-slide {
    transform: translateX(100%);
    opacity: 1;
    transition: transform 0.8s ease-in-out;
}
.hero-slider[data-transition="slide"] .hero-slide.active {
    transform: translateX(0);
}
.hero-slider[data-transition="slide"] .hero-slide.prev {
    transform: translateX(-100%);
}

/* Ken Burns Animation - Slow Zoom */
@keyframes kenburns-subtle { 0% { transform: scale(1); } 100% { transform: scale(1.05); } }
@keyframes kenburns-medium { 0% { transform: scale(1); } 100% { transform: scale(1.10); } }
@keyframes kenburns-strong { 0% { transform: scale(1); } 100% { transform: scale(1.15); } }
@keyframes kenburns-out-subtle { 0% { transform: scale(1.05); } 100% { transform: scale(1); } }
@keyframes kenburns-out-medium { 0% { transform: scale(1.10); } 100% { transform: scale(1); } }
@keyframes kenburns-out-strong { 0% { transform: scale(1.15); } 100% { transform: scale(1); } }

/* Ken Burns Alternating */
@keyframes kenburns-alt-subtle { 0% { transform: scale(1) translate(0, 0); } 100% { transform: scale(1.05) translate(-1%, -1%); } }
@keyframes kenburns-alt-medium { 0% { transform: scale(1) translate(0, 0); } 100% { transform: scale(1.10) translate(-2%, -1%); } }
@keyframes kenburns-alt-strong { 0% { transform: scale(1) translate(0, 0); } 100% { transform: scale(1.15) translate(-3%, -2%); } }

/* Pan Animation */
@keyframes pan-left-subtle { 0% { transform: scale(1.05) translateX(2%); } 100% { transform: scale(1.05) translateX(-2%); } }
@keyframes pan-left-medium { 0% { transform: scale(1.10) translateX(3%); } 100% { transform: scale(1.10) translateX(-3%); } }
@keyframes pan-left-strong { 0% { transform: scale(1.15) translateX(4%); } 100% { transform: scale(1.15) translateX(-4%); } }
@keyframes pan-right-subtle { 0% { transform: scale(1.05) translateX(-2%); } 100% { transform: scale(1.05) translateX(2%); } }
@keyframes pan-right-medium { 0% { transform: scale(1.10) translateX(-3%); } 100% { transform: scale(1.10) translateX(3%); } }
@keyframes pan-right-strong { 0% { transform: scale(1.15) translateX(-4%); } 100% { transform: scale(1.15) translateX(4%); } }

/* Animation Classes Applied by JS */
.hero-slide.kenburns-subtle img { animation: kenburns-subtle var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-medium img { animation: kenburns-medium var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-strong img { animation: kenburns-strong var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-out-subtle img { animation: kenburns-out-subtle var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-out-medium img { animation: kenburns-out-medium var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-out-strong img { animation: kenburns-out-strong var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-alt-subtle img { animation: kenburns-alt-subtle var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-alt-medium img { animation: kenburns-alt-medium var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.kenburns-alt-strong img { animation: kenburns-alt-strong var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.pan-left-subtle img { animation: pan-left-subtle var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.pan-left-medium img { animation: pan-left-medium var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.pan-left-strong img { animation: pan-left-strong var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.pan-right-subtle img { animation: pan-right-subtle var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.pan-right-medium img { animation: pan-right-medium var(--hero-speed, 5s) ease-out forwards; }
.hero-slide.pan-right-strong img { animation: pan-right-strong var(--hero-speed, 5s) ease-out forwards; }

/* Mobile Responsive */
@media (max-width: 768px) {
    .hero-section .hero-title {
        font-size: clamp(1.5rem, 6vw, 2rem) !important;
    }
    .hero-section .hero-subtitle {
        font-size: 0.95rem;
    }
    .hero-buttons {
        flex-direction: column;
        gap: var(--space-3);
        width: 100%;
        max-width: 280px;
    }
    .hero-btn {
        width: 100%;
        justify-content: center;
    }
    .hero-arrow {
        width: 40px;
        height: 40px;
    }
    .hero-arrow-prev { left: 10px; }
    .hero-arrow-next { right: 10px; }
    .hero-dots { bottom: 15px; }
    .hero-dot { width: 10px; height: 10px; }
}

/* BALLOON BANNER */
.balloon-banner { padding: var(--space-8) 0; background: var(--color-pure-white); text-align: center; }
.balloon-banner-title { font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 800; color: var(--color-accent-gold); text-transform: uppercase; letter-spacing: 6px; }

/* CATEGORY CARDS */
.category-cards-section { padding: var(--space-8) 0 var(--space-16); }
.category-cards-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-4); margin-bottom: var(--space-10); }
.category-card { text-align: center; transition: transform 0.2s ease; }
.category-card:hover { transform: translateY(-3px); }
.category-card-image { background: var(--color-card-blue); border-radius: var(--radius-lg); aspect-ratio: 1; display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-3); transition: all 0.2s; position: relative; overflow: hidden; }
.category-card:hover .category-card-image { background: var(--color-card-blue-hover); }
.category-card-image .placeholder-emoji { font-size: 3rem; }
.category-card-label { font-size: var(--text-sm); font-weight: 600; color: var(--color-gray-900); }
.category-card:hover .category-card-label { color: var(--color-primary); }

/* Category Card Image Crossfade Animation */
.crossfade-container {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}
.crossfade-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}
.crossfade-primary {
    opacity: 1;
    animation: crossfadePrimary 6.6s ease-in-out infinite;
}
.crossfade-secondary {
    opacity: 0;
    animation: crossfadeSecondary 6.6s ease-in-out infinite;
}
/* 2.7s display + 0.6s fade = 3.3s per image, total cycle = 6.6s */
@keyframes crossfadePrimary {
    0%, 40.9% { opacity: 1; } /* 0-2.7s visible (40.9% of 6.6s) */
    50% { opacity: 0; } /* 2.7s-3.3s fade out */
    50.1%, 90.9% { opacity: 0; } /* Hidden while secondary shows */
    100% { opacity: 1; } /* Fade back in */
}
@keyframes crossfadeSecondary {
    0%, 40.9% { opacity: 0; } /* Hidden while primary shows */
    50% { opacity: 1; } /* 2.7s-3.3s fade in */
    50.1%, 90.9% { opacity: 1; } /* 3.3s-6s visible */
    100% { opacity: 0; } /* Fade out */
}

/* Category Card 3D Effects (always visible, doesn't interfere with hover) */
.category-card.effect-3d-light .category-card-image {
    box-shadow: 0 2px 4px rgba(0,0,0,0.06), 0 4px 8px rgba(0,0,0,0.04);
}
.category-card.effect-3d-light:hover .category-card-image {
    box-shadow: 0 4px 8px rgba(0,0,0,0.08), 0 8px 16px rgba(0,0,0,0.06);
}
.category-card.effect-3d-moderate .category-card-image {
    box-shadow: 0 4px 6px rgba(0,0,0,0.07), 0 8px 15px rgba(0,0,0,0.05), 0 1px 3px rgba(0,0,0,0.1);
    transform: translateY(-2px);
}
.category-card.effect-3d-moderate:hover .category-card-image {
    box-shadow: 0 8px 12px rgba(0,0,0,0.1), 0 16px 24px rgba(0,0,0,0.08);
    transform: translateY(-4px);
}
.category-card.effect-3d-strong .category-card-image {
    box-shadow: 0 6px 12px rgba(0,0,0,0.1), 0 12px 24px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.12);
    transform: translateY(-3px);
}
.category-card.effect-3d-strong:hover .category-card-image {
    box-shadow: 0 12px 20px rgba(0,0,0,0.15), 0 20px 40px rgba(0,0,0,0.12);
    transform: translateY(-6px);
}

/* SECTIONS */
.section { padding: var(--space-16) 0; }
.section-header { text-align: center; margin-bottom: var(--space-8); }
.section-title { font-size: var(--text-2xl); font-weight: 700; margin-bottom: var(--space-2); }

/* POPULAR GRID */
.popular-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-4); }
.popular-item { text-align: center; transition: transform 0.2s ease; }
.popular-item:hover { transform: translateY(-3px); }
.popular-item-image { 
    background: var(--color-gray-100); 
    border-radius: var(--radius-lg); 
    aspect-ratio: 1; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    margin-bottom: var(--space-3);
    overflow: hidden;
    transition: all 0.2s;
}
.popular-item-image.has-image {
    background: transparent;
}
.popular-item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--radius-lg);
}
.popular-item-image .placeholder-emoji { font-size: 2.5rem; }
.popular-item:hover .popular-item-image img {
    transform: scale(1.05);
}
.popular-item-label { font-size: var(--text-sm); font-weight: 500; color: var(--color-gray-800); }

/* Popular Item 3D Effects (always visible, doesn't interfere with hover) */
.popular-item.effect-3d-light .popular-item-image {
    box-shadow: 0 2px 4px rgba(0,0,0,0.06), 0 4px 8px rgba(0,0,0,0.04);
}
.popular-item.effect-3d-light:hover .popular-item-image {
    box-shadow: 0 4px 8px rgba(0,0,0,0.08), 0 8px 16px rgba(0,0,0,0.06);
}
.popular-item.effect-3d-moderate .popular-item-image {
    box-shadow: 0 4px 6px rgba(0,0,0,0.07), 0 8px 15px rgba(0,0,0,0.05), 0 1px 3px rgba(0,0,0,0.1);
    transform: translateY(-2px);
}
.popular-item.effect-3d-moderate:hover .popular-item-image {
    box-shadow: 0 8px 12px rgba(0,0,0,0.1), 0 16px 24px rgba(0,0,0,0.08);
    transform: translateY(-4px);
}
.popular-item.effect-3d-strong .popular-item-image {
    box-shadow: 0 6px 12px rgba(0,0,0,0.1), 0 12px 24px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.12);
    transform: translateY(-3px);
}
.popular-item.effect-3d-strong:hover .popular-item-image {
    box-shadow: 0 12px 20px rgba(0,0,0,0.15), 0 20px 40px rgba(0,0,0,0.12);
    transform: translateY(-6px);
}

/* MENU PRODUCTS */
.menu-section { padding: var(--space-16) 0; background: var(--color-gray-50); }
.menu-box { padding: var(--space-6) 0; margin-bottom: var(--space-6); }
.menu-box:last-child { margin-bottom: 0; }
.menu-box-title { font-family: var(--font-display); font-size: var(--text-xl); font-style: italic; text-align: center; margin-bottom: var(--space-6); }
.menu-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-5); align-items: stretch; }
/* HOMEPAGE MENU ITEMS - Uses same style as product-card */
.menu-item { background: var(--color-pure-white); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm); transition: all 0.3s; display: flex; flex-direction: column; }
.menu-item:hover { box-shadow: var(--shadow-lg); transform: translateY(-5px); }
.menu-item-image { position: relative; aspect-ratio: 1; background: linear-gradient(135deg, #f5f7fa 0%, #e4e8ec 100%); display: flex; align-items: center; justify-content: center; font-size: 4rem; flex-shrink: 0; overflow: hidden; }
.menu-item-image img { width: 100%; height: 100%; object-fit: cover; }
.menu-item-name { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-1); font-family: var(--font-heading, inherit); }
.menu-item-desc { font-size: var(--text-sm); color: var(--color-gray-500); margin-bottom: var(--space-2); min-height: 40px; font-family: var(--font-body, inherit); }
.menu-item-price { font-size: var(--text-xl); font-weight: 800; color: var(--color-primary); margin-bottom: var(--space-3); font-family: var(--font-body, inherit); }
.menu-item-info { padding: var(--space-4); display: flex; flex-direction: column; flex: 1; text-align: center; }
.menu-item-qty { display: flex; align-items: center; justify-content: center; gap: var(--space-2); margin-bottom: var(--space-3); }
.menu-item-qty button { width: 32px; height: 32px; border: 1px solid var(--color-gray-300); border-radius: 50%; font-size: var(--text-sm); display: flex; align-items: center; justify-content: center; background: var(--color-pure-white); cursor: pointer; transition: all 0.2s; }
.menu-item-qty button:hover { border-color: var(--color-primary); color: var(--color-primary); }
.menu-item-qty span { font-weight: 700; min-width: 24px; text-align: center; }
.menu-item-add { padding: 0; }
.menu-item-add button { width: 100%; padding: 12px; font-size: var(--text-xs); font-weight: 600; background: var(--color-primary); color: var(--color-white); border-radius: var(--radius-md); text-transform: uppercase; white-space: nowrap; cursor: pointer; transition: all 0.2s; }
.menu-item-add button:hover { background: var(--color-primary-dark); }

/* PRODUCT CARDS */
.products-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-6); align-items: stretch; }
.product-card { background: var(--color-pure-white); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm); transition: all 0.3s; display: flex; flex-direction: column; }
.product-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-5px); }
.product-image { position: relative; aspect-ratio: 1; background: linear-gradient(135deg, #f5f7fa 0%, #e4e8ec 100%); display: flex; align-items: center; justify-content: center; font-size: 4rem; flex-shrink: 0; overflow: hidden; }
.product-image img { width: 100%; height: 100%; object-fit: cover; }
.product-badge { position: absolute; top: var(--space-3); left: var(--space-3); padding: 4px 10px; background: var(--color-primary); color: white; font-size: 11px; font-weight: 700; border-radius: var(--radius-full); text-transform: uppercase; }
.product-badge.gold { background: linear-gradient(135deg, #d4af37, #f9df7b); color: #333; }
.product-info { padding: var(--space-4); display: flex; flex-direction: column; flex: 1; }
.product-name { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-2); flex-shrink: 0; font-family: var(--font-heading, inherit); }
.product-desc { font-size: var(--text-sm); color: var(--color-gray-500); margin-bottom: var(--space-3); flex: 1; min-height: 40px; font-family: var(--font-body, inherit); }
.product-price { font-size: var(--text-xl); font-weight: 800; color: var(--color-primary); margin-bottom: var(--space-4); flex-shrink: 0; font-family: var(--font-body, inherit); }
.product-price .original { font-size: var(--text-sm); color: var(--color-gray-400); text-decoration: line-through; margin-left: var(--space-2); font-weight: 400; }
.product-card .btn { width: 100%; flex-shrink: 0; }

/* CTA SECTION */
.cta-section { background: var(--color-primary); padding: var(--space-12) 0; text-align: center; color: var(--color-white); }
.cta-section h2 { font-size: var(--text-2xl); font-weight: 800; margin-bottom: var(--space-3); color: var(--color-white); }
.cta-section p { font-size: var(--text-base); margin-bottom: var(--space-6); opacity: 0.9; }

/* CART PAGE - FIXED LAYOUT */
.cart-page { padding: var(--space-8) 0 var(--space-16); }
.cart-page .cart-header { margin-bottom: var(--space-6); }
.cart-page .cart-header h1 { font-size: var(--text-2xl); display: flex; align-items: center; gap: var(--space-3); }
.cart-layout { display: grid; grid-template-columns: 1fr 350px; gap: var(--space-6); align-items: start; }
.cart-items { background: var(--color-pure-white); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm); overflow: hidden; }
.cart-item { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-4); border-bottom: 1px solid var(--color-gray-100); position: relative; }
.cart-item:last-child { border-bottom: none; }
.cart-item-image { width: 70px; height: 70px; background: var(--color-gray-100); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.cart-item-image img { width: 100%; height: 100%; object-fit: cover; }
.cart-item-details { flex: 1; min-width: 0; }
.cart-item-details h3 { font-size: var(--text-sm); font-weight: 600; margin-bottom: 2px; }
.cart-item-details p { font-size: var(--text-xs); color: var(--color-gray-500); }
.cart-item-qty { display: flex; align-items: center; gap: 4px; }
.cart-item-qty button { width: 28px; height: 28px; border: 1px solid var(--color-gray-300); border-radius: 50%; font-size: var(--text-sm); display: flex; align-items: center; justify-content: center; background: var(--color-pure-white); }
.cart-item-qty button:hover { border-color: var(--color-primary); color: var(--color-primary); }
.cart-item-qty input { width: 36px; text-align: center; border: 1px solid var(--color-gray-200); border-radius: var(--radius-sm); padding: 4px; font-size: var(--text-sm); font-weight: 600; }
.cart-item-price { font-weight: 700; color: var(--color-primary); white-space: nowrap; }
.cart-item-remove { color: var(--color-gray-400); padding: var(--space-2); }
.cart-item-remove:hover { color: var(--color-error); }

/* CART SUMMARY - FIXED STYLING */
.cart-summary { 
    background: var(--color-pure-white); 
    border-radius: var(--radius-xl); 
    overflow: hidden; 
    position: sticky; 
    top: 80px;
    box-shadow: var(--shadow-sm);
}
.cart-summary > h3 { 
    padding: var(--space-4) var(--space-5); 
    background: var(--color-gray-900); 
    color: var(--color-white); 
    font-size: var(--text-base);
    font-weight: 700;
    margin: 0;
}
.summary-row { 
    display: flex; 
    justify-content: space-between; 
    padding: var(--space-3) var(--space-5); 
    font-size: var(--text-sm);
    border-bottom: 1px solid var(--color-gray-100);
}
.summary-row:last-of-type { border-bottom: none; }
.summary-row.total { 
    font-weight: 700; 
    font-size: var(--text-base);
    background: var(--color-gray-50);
    padding: var(--space-4) var(--space-5);
}
.summary-row.total .amount { color: var(--color-primary); }

/* DISCOUNT FORM - FIXED */
.discount-form { 
    display: flex; 
    gap: var(--space-2); 
    padding: var(--space-4) var(--space-5);
    border-top: 1px solid var(--color-gray-100);
}
.discount-form input { 
    flex: 1; 
    padding: var(--space-2) var(--space-3); 
    border: 1px solid var(--color-gray-300); 
    border-radius: var(--radius-sm); 
    font-size: var(--text-sm);
}
.discount-form button { 
    padding: var(--space-2) var(--space-4); 
    background: var(--color-gray-800); 
    color: var(--color-white); 
    border-radius: var(--radius-sm); 
    font-size: var(--text-sm);
    font-weight: 600;
}
.discount-form button:hover { background: var(--color-gray-900); }

/* CART SUMMARY BUTTONS - FIXED */
.cart-summary .btn-block {
    margin: var(--space-4) var(--space-5);
    width: calc(100% - var(--space-10));
}
.cart-summary .btn-block.btn-lg {
    padding: 12px 20px;
    font-size: var(--text-sm);
}
.cart-summary .btn-ghost {
    margin-top: 0 !important;
    padding: var(--space-3);
    font-size: var(--text-sm);
}

/* CART EMPTY */
.cart-empty { text-align: center; padding: var(--space-16) var(--space-4); }
.cart-empty i { font-size: 4rem; color: var(--color-gray-300); margin-bottom: var(--space-4); display: block; }
.cart-empty h2 { font-size: var(--text-xl); margin-bottom: var(--space-2); }
.cart-empty p { color: var(--color-gray-600); margin-bottom: var(--space-6); }

/* CHECKOUT */
.checkout-page { padding: var(--space-6) 0 var(--space-12); }
.checkout-layout { display: grid; grid-template-columns: 1fr 380px; gap: var(--space-6); align-items: start; }
.checkout-section { background: var(--color-pure-white); border-radius: var(--radius-xl); padding: var(--space-5); margin-bottom: var(--space-5); box-shadow: var(--shadow-sm); }
.checkout-section-title { 
    display: flex; 
    align-items: center; 
    gap: var(--space-3); 
    font-size: var(--text-lg); 
    margin-bottom: var(--space-5); 
    padding-bottom: var(--space-4); 
    border-bottom: 1px solid var(--color-gray-200); 
}
.step-number { 
    width: 28px; 
    height: 28px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    background: var(--color-primary); 
    color: white; 
    border-radius: 50%; 
    font-size: var(--text-sm); 
    font-weight: 700; 
}

/* UNIFIED METHOD OPTIONS - for Delivery & Payment */
.method-options { display: flex; flex-direction: column; gap: var(--space-4); }
.method-option { 
    display: flex; 
    align-items: center; 
    gap: var(--space-4); 
    padding: var(--space-4); 
    border: 2px solid var(--color-gray-200); 
    border-radius: var(--radius-lg); 
    cursor: pointer; 
    transition: all 0.2s;
    min-height: 76px;
}
.method-option:hover { border-color: var(--color-gray-400); }
.method-option.selected { 
    border-color: var(--color-primary); 
    background: rgba(227, 24, 55, 0.02); 
}
.method-option-radio { 
    width: 20px; 
    height: 20px; 
    border: 2px solid var(--color-gray-400); 
    border-radius: 50%; 
    position: relative; 
    flex-shrink: 0; 
}
.method-option.selected .method-option-radio { border-color: var(--color-primary); }
.method-option.selected .method-option-radio::after { 
    content: ''; 
    position: absolute; 
    top: 50%; 
    left: 50%; 
    transform: translate(-50%, -50%); 
    width: 10px; 
    height: 10px; 
    background: var(--color-primary); 
    border-radius: 50%; 
}
.method-option-icon { 
    width: 44px; 
    height: 44px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    background: var(--color-gray-100); 
    border-radius: var(--radius-md); 
    font-size: var(--text-lg); 
    color: var(--color-gray-600);
    flex-shrink: 0;
}
.method-option.selected .method-option-icon { 
    background: rgba(227, 24, 55, 0.1); 
    color: var(--color-primary); 
}
.method-option-details { flex: 1; min-width: 0; }
.method-option-name { font-weight: 600; font-size: var(--text-base); margin-bottom: 2px; }
.method-option-desc { font-size: var(--text-sm); color: var(--color-gray-500); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.method-option-price { 
    font-weight: 700; 
    color: var(--color-primary); 
    font-size: var(--text-base);
    white-space: nowrap;
}
.method-option-price.free { color: var(--color-success); }

/* Checkout Summary */
.checkout-summary { position: sticky; top: 80px; }
.summary-card { 
    background: var(--color-pure-white); 
    border-radius: var(--radius-xl); 
    overflow: hidden; 
    box-shadow: var(--shadow-sm); 
}
.summary-card > h3 { 
    padding: var(--space-4) var(--space-5); 
    background: var(--color-gray-900); 
    color: var(--color-white); 
    font-size: var(--text-base); 
    margin: 0;
}
.summary-items { 
    padding: var(--space-4) var(--space-5); 
    border-bottom: 1px solid var(--color-gray-100);
}
.summary-item { 
    display: flex; 
    justify-content: space-between; 
    font-size: var(--text-sm); 
    padding: var(--space-2) 0;
    color: var(--color-gray-700);
}
.summary-row { 
    display: flex; 
    justify-content: space-between; 
    padding: var(--space-3) var(--space-5); 
    font-size: var(--text-sm);
    border-bottom: 1px solid var(--color-gray-100);
}
.summary-row.total { 
    font-weight: 700; 
    font-size: var(--text-lg);
    background: var(--color-gray-50);
    border-bottom: none;
}
.summary-card .btn { margin: var(--space-4) var(--space-5); width: calc(100% - var(--space-10)); }
.secure-checkout { 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    gap: var(--space-2); 
    padding: var(--space-3); 
    font-size: var(--text-xs); 
    color: var(--color-gray-500);
    border-top: 1px solid var(--color-gray-100);
}

/* Info boxes */
.info-box { 
    display: flex; 
    gap: var(--space-3); 
    padding: var(--space-4); 
    background: var(--color-gray-50); 
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    color: var(--color-gray-700);
}
.info-box i { color: var(--color-secondary); font-size: var(--text-lg); flex-shrink: 0; }
.info-box p { margin: 0 0 var(--space-1) 0; }
.info-box p:last-child { margin-bottom: 0; }
.highlight-email { font-weight: 700; color: var(--color-primary); }

/* Error styles */
.checkout-errors { margin-bottom: var(--space-5); }
.error-box { 
    display: flex; 
    gap: var(--space-3); 
    padding: var(--space-4); 
    background: #FEE2E2; 
    border: 1px solid #FECACA;
    border-radius: var(--radius-lg);
    color: #DC2626;
}
.error-box i { font-size: var(--text-xl); }
.error-box ul { margin: var(--space-2) 0 0 var(--space-4); padding: 0; }
.error-box li { margin-bottom: var(--space-1); font-size: var(--text-sm); }
.field-error { display: block; font-size: var(--text-xs); color: #DC2626; margin-top: 4px; }
.form-input.error, .form-select.error { border-color: #DC2626; background: #FEF2F2; }

/* Contact Page Mobile Fix */
.contact-page { overflow-x: hidden; }
.contact-page .container { max-width: 100%; overflow-x: hidden; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
@media (max-width: 768px) {
    .contact-grid { grid-template-columns: 1fr; }
    .contact-page .checkout-layout { grid-template-columns: 1fr; }
}

/* FORMS */
.form-group { margin-bottom: var(--space-4); }
.form-label { display: block; font-size: var(--text-sm); font-weight: 600; color: var(--color-gray-700); margin-bottom: var(--space-2); }
.form-input, .form-select, .form-textarea { width: 100%; padding: var(--space-3); font-size: var(--text-sm); border: 1px solid var(--color-gray-300); border-radius: var(--radius-md); background: var(--color-pure-white); box-sizing: border-box; }
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--color-primary); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }

/* BUILDER */
.builder-progress { padding: var(--space-6) 0; background: var(--color-pure-white); border-bottom: 1px solid var(--color-gray-200); }
.progress-steps { display: flex; justify-content: center; gap: var(--space-2); }
.progress-step { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-4); color: var(--color-gray-400); font-size: var(--text-sm); font-weight: 500; }
.progress-step.active { color: var(--color-primary); }
.progress-step.completed { color: var(--color-success); }
.progress-step-icon { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border: 2px solid currentColor; border-radius: 50%; font-size: var(--text-xs); font-weight: 700; }
.progress-step.active .progress-step-icon, .progress-step.completed .progress-step-icon { background: currentColor; color: var(--color-white); }
.builder-layout { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-6); padding: var(--space-6) 0; align-items: start; }
.builder-main { background: var(--color-pure-white); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm); }
.builder-step-content { display: none; padding: var(--space-6); }
.builder-step-content.active { display: block; }
.builder-nav { display: flex; justify-content: space-between; padding: var(--space-4) var(--space-6); border-top: 1px solid var(--color-gray-200); background: var(--color-gray-50); }
.builder-preview-sidebar { background: var(--color-pure-white); border-radius: var(--radius-xl); overflow: hidden; position: sticky; top: 80px; box-shadow: var(--shadow-sm); }
.preview-header { padding: var(--space-4); background: var(--color-gray-900); color: white; text-align: center; font-weight: 600; }
.preview-visual { padding: var(--space-6); background: var(--color-card-blue); text-align: center; min-height: 120px; display: flex; align-items: center; justify-content: center; font-size: 4rem; }
.preview-items { padding: var(--space-4); max-height: 200px; overflow-y: auto; }
.preview-footer { padding: var(--space-4); border-top: 1px solid var(--color-gray-200); background: var(--color-gray-50); }
.preview-total { display: flex; justify-content: space-between; font-size: var(--text-lg); font-weight: 700; }
.balloon-grid, .addon-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--space-4); }
.balloon-option, .addon-option { border: 2px solid var(--color-gray-200); border-radius: var(--radius-lg); padding: var(--space-4); text-align: center; cursor: pointer; transition: all 0.2s; }
.balloon-option:hover, .addon-option:hover, .balloon-option.selected, .addon-option.selected { border-color: var(--color-primary); }
.balloon-option.selected, .addon-option.selected { background: rgba(227, 24, 55, 0.03); }
.balloon-image, .addon-image { width: 60px; height: 60px; margin: 0 auto var(--space-2); background: var(--color-gray-100); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.balloon-name, .addon-name { font-weight: 600; font-size: var(--text-sm); margin-bottom: var(--space-1); }
.balloon-price, .addon-price { font-weight: 700; color: var(--color-primary); font-size: var(--text-sm); margin-bottom: var(--space-2); }
.qty-controls { display: flex; align-items: center; justify-content: center; gap: var(--space-2); }
.qty-btn { width: 28px; height: 28px; border: 1px solid var(--color-gray-300); border-radius: 50%; font-size: var(--text-sm); display: flex; align-items: center; justify-content: center; background: var(--color-pure-white); }
.qty-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.qty-display { font-weight: 700; min-width: 24px; text-align: center; }

/* FOOTER */
.main-footer { background: var(--color-gray-900); color: var(--color-gray-400); padding: var(--space-12) 0 var(--space-6); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: var(--space-8); margin-bottom: var(--space-8); }
.footer-section h4 { color: var(--color-white); font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-4); }
.footer-links li { margin-bottom: var(--space-2); }
.footer-links a { font-size: var(--text-sm); }
.footer-links a:hover { color: var(--color-primary); }
.social-links { display: flex; gap: var(--space-3); }
.social-links a { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--color-gray-700); border-radius: 50%; }
.social-links a:hover { border-color: var(--color-primary); color: var(--color-primary); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: var(--space-4); text-align: center; font-size: var(--text-sm); }

/* SHOP PAGE */
.shop-page { padding: var(--space-6) 0 var(--space-12); }
.shop-header { text-align: center; margin-bottom: var(--space-6); }
.shop-header h1 { font-size: var(--text-2xl); margin-bottom: var(--space-2); }
.shop-filters { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: var(--space-4); margin-bottom: var(--space-6); padding-bottom: var(--space-4); border-bottom: 1px solid var(--color-gray-200); }
.filter-tabs { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.filter-tab { padding: 6px 14px; font-size: var(--text-sm); font-weight: 500; color: var(--color-gray-600); border: 1px solid var(--color-gray-200); border-radius: var(--radius-full); }
.filter-tab:hover { border-color: var(--color-primary); color: var(--color-primary); }
.filter-tab.active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.filter-sort { display: flex; align-items: center; gap: var(--space-2); }
.filter-sort label { font-size: var(--text-sm); color: var(--color-gray-600); }
.filter-sort select { padding: 6px 12px; font-size: var(--text-sm); border: 1px solid var(--color-gray-300); border-radius: var(--radius-sm); }
.builder-cta { background: var(--color-gray-900); color: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-8); text-align: center; margin-top: var(--space-10); }
.builder-cta h2 { color: var(--color-white); margin-bottom: var(--space-3); }
.builder-cta p { opacity: 0.8; margin-bottom: var(--space-5); }

/* ============================================
   MOBILE NAV - WITH ICONS & SMOOTH ANIMATION
   ============================================ */
.mobile-nav { 
    position: fixed; 
    top: 0; 
    left: 0; 
    width: 100%; 
    max-width: 320px;
    height: 100%; 
    background: var(--color-mobile-nav-bg, #FFFFFF); 
    transform: translateX(-100%); 
    transition: transform 0.3s ease; 
    z-index: 1000; 
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 4px 0 20px rgba(0,0,0,0.1);
}
.mobile-nav.active { transform: translateX(0); }

.mobile-nav-header { 
    display: flex; 
    align-items: center; 
    justify-content: space-between; 
    padding: var(--space-4); 
    border-bottom: 1px solid var(--color-gray-200);
    background: var(--color-mobile-nav-bg, #FFFFFF);
    min-height: 60px;
    flex-shrink: 0;
}
.mobile-nav-header button { 
    width: 40px; 
    height: 40px; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    font-size: var(--text-lg);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-mobile-nav-text, var(--color-gray-700));
    border-radius: var(--radius-full);
    transition: background 0.2s ease;
}
.mobile-nav-header button:hover { background: var(--color-gray-100); }
.mobile-nav-header button:active { background: var(--color-gray-200); }
.mobile-nav-back { color: var(--color-primary) !important; }
.mobile-nav-title { font-weight: 600; font-size: var(--text-base); color: var(--color-mobile-nav-text, var(--color-gray-800)); }

.mobile-menu-content { 
    flex: 1; 
    position: relative;
    overflow: hidden;
}

/* Main menu - with slide animation */
#mobileMainMenu {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    transform: translateX(0);
    transition: transform 0.3s ease;
}

#mobileMainMenu.slide-out {
    transform: translateX(-100%);
}

/* Submenus - with slide animation */
.mobile-submenu-page {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow-y: auto;
    background: var(--color-pure-white);
    transform: translateX(100%);
    transition: transform 0.3s ease;
}

.mobile-submenu-page.slide-in {
    transform: translateX(0);
}

.mobile-nav-list { 
    padding: 0; 
    margin: 0;
    list-style: none;
}
.mobile-nav-list li { 
    border-bottom: 1px solid var(--color-gray-100); 
}

/* Nav links with icons - FIXED ALIGNMENT */
.mobile-nav-list li a,
.mobile-nav-trigger { 
    display: flex !important; 
    align-items: center; 
    padding: 16px 20px; 
    font-size: var(--text-base); 
    font-weight: 500; 
    color: var(--color-mobile-nav-text, var(--color-gray-800));
    text-decoration: none;
    background: transparent;
    border: none;
    width: 100%;
    cursor: pointer;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
    outline: none;
    transition: background 0.15s ease;
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
}

/* Focus visible for accessibility */
.mobile-nav-list li a:focus-visible,
.mobile-nav-trigger:focus-visible {
    background: var(--color-gray-100);
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

/* Icon styling - red color, fixed width */
.mobile-nav-list li a .nav-icon,
.mobile-nav-trigger .nav-icon {
    display: inline-block;
    width: 24px;
    text-align: center;
    margin-right: 10px;
    color: var(--color-primary);
    font-size: 14px;
}

/* Text next to icon */
.mobile-nav-list li a > span,
.mobile-nav-trigger > span {
    display: flex;
    align-items: center;
    flex: 1;
}

/* Arrow icon on the right - pushed to end */
.mobile-nav-trigger .nav-arrow { 
    color: var(--color-gray-400); 
    font-size: 12px;
    margin-left: auto;
}

/* Hover state - only on devices that support hover (not touch) */
@media (hover: hover) and (pointer: fine) {
    .mobile-nav-list li a:hover,
    .mobile-nav-trigger:hover { 
        background: var(--color-mobile-nav-click, rgba(0, 0, 0, 0.04)) !important;
    }
}

/* Active/pressed state - works on all devices */
.mobile-nav-list li a:active,
.mobile-nav-trigger:active {
    background: var(--color-mobile-nav-click, rgba(0, 0, 0, 0.06)) !important;
}

/* Clicked class applied via JS for visual feedback */
.mobile-nav-list li a.clicked,
.mobile-nav-trigger.clicked {
    background: var(--color-mobile-nav-click, rgba(0, 0, 0, 0.06)) !important;
}

.mobile-nav-list li a.view-all { color: var(--color-primary); font-weight: 600; }

.mobile-submenu-title { 
    padding: var(--space-3) var(--space-5); 
    font-size: var(--text-sm); 
    font-weight: 600; 
    color: var(--color-gray-500); 
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--color-gray-50);
}

.mobile-nav-contact { 
    margin-top: auto;
    padding: var(--space-4); 
    border-top: 1px solid var(--color-gray-200);
    background: var(--color-gray-50);
}
.mobile-contact-link { 
    display: flex; 
    align-items: center; 
    gap: var(--space-3); 
    padding: var(--space-2) 0;
    color: var(--color-gray-700);
    text-decoration: none;
    font-size: var(--text-sm);
}
.mobile-contact-link i { 
    width: 20px; 
    color: var(--color-primary);
    text-align: center;
}
.mobile-contact-link:hover { color: var(--color-primary); }

.mobile-nav-overlay { 
    position: fixed; 
    inset: 0; 
    background: rgba(0,0,0,0.5); 
    opacity: 0; 
    visibility: hidden; 
    transition: all 0.3s; 
    z-index: 999;
}
.mobile-nav-overlay.active { opacity: 1; visibility: visible; }

/* TOAST */
.toast-container { position: fixed; bottom: var(--space-4); right: var(--space-4); z-index: 2000; }
.toast { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--color-pure-white); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); margin-top: var(--space-2); animation: toastIn 0.3s ease; }
@keyframes toastIn { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

/* UTILITIES */
.text-center { text-align: center; }
.hidden { display: none !important; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
    .category-cards-grid { grid-template-columns: repeat(3, 1fr); }
    .popular-grid { grid-template-columns: repeat(3, 1fr); }
    .builder-layout, .cart-layout, .checkout-layout { grid-template-columns: 1fr; }
    .builder-preview-sidebar, .cart-summary, .order-summary { position: static; margin-top: var(--space-6); }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .menu-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .container { padding: 0 var(--space-4); }
    .main-nav { display: none; }
    .mobile-menu-btn { display: flex; }
    .hero { padding: var(--space-10) 0; }
    .hero-buttons { flex-direction: column; }
    .hero-buttons .btn { width: 100%; }
    .category-cards-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
    .popular-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
    .menu-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
    .footer-grid { grid-template-columns: 1fr; text-align: center; }
    .social-links { justify-content: center; }
    .cart-item { flex-wrap: wrap; }
    .cart-item-details { flex: 1 1 100%; order: 1; margin-bottom: var(--space-2); }
    .cart-item-image { order: 0; }
    .cart-item-qty { order: 2; }
    .cart-item-price { order: 3; margin-left: auto; }
    .cart-item-remove { order: 4; }
    .form-row { grid-template-columns: 1fr; }
    .products-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
    .shop-filters { flex-direction: column; align-items: stretch; }
    .filter-tabs { justify-content: center; }
}

@media (max-width: 480px) {
    .category-cards-grid { grid-template-columns: repeat(2, 1fr); }
    .popular-grid { grid-template-columns: repeat(2, 1fr); }
    .menu-grid { grid-template-columns: repeat(2, 1fr); }
    .balloon-grid, .addon-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================
   MOBILE CHECKOUT OPTIMIZATION
   ============================================ */
@media (max-width: 768px) {
    /* Fix horizontal scroll */
    .checkout-page { padding: var(--space-4) 0 var(--space-8); }
    .checkout-page > .container { padding: 0 var(--space-4); }
    .checkout-layout { display: block; }
    .checkout-form { width: 100%; }
    
    .checkout-section { 
        padding: var(--space-4); 
        margin-bottom: var(--space-4); 
        border-radius: var(--radius-lg);
        overflow: hidden;
    }
    .checkout-section-title { font-size: var(--text-base); gap: var(--space-2); margin-bottom: var(--space-4); padding-bottom: var(--space-3); }
    .step-number { width: 24px; height: 24px; font-size: var(--text-xs); }
    
    /* Method options mobile */
    .method-options { gap: var(--space-3); }
    .method-option { 
        padding: var(--space-3); 
        gap: var(--space-2); 
        min-height: 64px;
    }
    .method-option-radio { width: 18px; height: 18px; }
    .method-option.selected .method-option-radio::after { width: 8px; height: 8px; }
    .method-option-icon { width: 36px; height: 36px; font-size: var(--text-sm); }
    .method-option-name { font-size: var(--text-sm); }
    .method-option-desc { font-size: var(--text-xs); }
    .method-option-price { font-size: var(--text-sm); }
    
    /* Form fields mobile */
    .form-group { margin-bottom: var(--space-3); }
    .form-label { font-size: var(--text-sm); margin-bottom: var(--space-1); }
    .form-input, .form-select, .form-textarea { 
        padding: var(--space-3); 
        font-size: 16px;
        border-radius: var(--radius-md);
        width: 100%;
        max-width: 100%;
    }
    .form-row { gap: var(--space-3); grid-template-columns: 1fr; }
    
    /* Calendar fix */
    .calendar-container { width: 100%; }
    
    /* Order summary mobile - centered, narrower */
    .checkout-summary { 
        width: 90%;
        max-width: 350px;
        margin: var(--space-4) auto 0;
    }
    
    /* Place order button */
    .btn-place-order { padding: var(--space-4); font-size: var(--text-base); }
}

/* CONTACT PAGE - MOBILE OPTIMIZED */
.contact-grid { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: var(--space-8); 
    max-width: 1000px; 
    margin: 0 auto; 
}
.contact-form-card { 
    background: var(--color-pure-white); 
    padding: var(--space-6); 
    border-radius: var(--radius-xl); 
    box-shadow: var(--shadow-md); 
}
.contact-form-card h3 { margin-bottom: var(--space-5); }
.contact-info-col { display: flex; flex-direction: column; gap: var(--space-5); }
.contact-info-card { 
    background: var(--color-gray-50); 
    padding: var(--space-6); 
    border-radius: var(--radius-xl); 
}
.contact-info-card h3 { margin-bottom: var(--space-5); }
.contact-info-items { display: flex; flex-direction: column; gap: var(--space-4); }
.contact-info-item { display: flex; align-items: flex-start; gap: var(--space-3); }
.contact-info-icon { 
    width: 44px; 
    height: 44px; 
    background: var(--color-primary); 
    border-radius: var(--radius-lg); 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: white; 
    flex-shrink: 0;
    font-size: var(--text-base);
}
.contact-info-item p { color: var(--color-gray-600); margin: var(--space-1) 0 0 0; font-size: var(--text-sm); }
.contact-info-item a { color: var(--color-gray-600); }
.contact-info-item a:hover { color: var(--color-primary); }
.contact-hours-card { 
    background: var(--color-pure-white); 
    padding: var(--space-6); 
    border-radius: var(--radius-xl); 
    box-shadow: var(--shadow-sm); 
}
.contact-hours-card h3 { margin-bottom: var(--space-4); }
.hours-list { display: flex; flex-direction: column; gap: var(--space-2); }
.hours-row { display: flex; justify-content: space-between; font-size: var(--text-sm); }
.hours-row span:last-child { font-weight: 600; }
.contact-social { margin-top: var(--space-2); }
.contact-social h4 { margin-bottom: var(--space-3); }

@media (max-width: 768px) {
    .contact-grid { grid-template-columns: 1fr; gap: var(--space-5); }
    .contact-form-card, .contact-info-card, .contact-hours-card { padding: var(--space-5); }
    .checkout-layout { grid-template-columns: 1fr; }
    .checkout-summary { position: static; margin-top: var(--space-5); }
}

/* ============================================
   PREMIUM LOADING ANIMATION - 3 BOUNCING DOTS
   ============================================ */
.loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}
.loading-overlay.active {
    opacity: 1;
    visibility: visible;
}
.loading-content {
    text-align: center;
}
.loading-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: var(--space-4);
}
.loading-dot {
    width: 14px;
    height: 14px;
    background: var(--color-primary);
    border-radius: 50%;
    animation: bounce 1.4s ease-in-out infinite;
}
.loading-dot:nth-child(1) { animation-delay: 0s; }
.loading-dot:nth-child(2) { animation-delay: 0.2s; }
.loading-dot:nth-child(3) { animation-delay: 0.4s; }

@keyframes bounce {
    0%, 80%, 100% {
        transform: scale(0.6);
        opacity: 0.5;
    }
    40% {
        transform: scale(1);
        opacity: 1;
    }
}

.loading-text {
    font-size: var(--text-sm);
    color: var(--color-gray-600);
    font-weight: 500;
}

/* Alternative: Pulse Ring Animation */
.loading-ring {
    width: 50px;
    height: 50px;
    border: 3px solid var(--color-gray-200);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto var(--space-4);
}
@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Premium Shimmer Effect for loading cards */
.shimmer {
    background: linear-gradient(
        90deg,
        var(--color-gray-100) 25%,
        var(--color-gray-50) 50%,
        var(--color-gray-100) 75%
    );
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}
@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ============================================
   DISABLE ZOOM ON FORM INPUTS (MOBILE)
   ============================================ */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="url"],
select,
textarea {
    font-size: 16px !important; /* Prevents iOS zoom */
}

/* ============================================
   CATEGORY CARDS WITH CUSTOM IMAGES
   ============================================ */
.category-card-image {
    background: var(--color-gray-100);
    border-radius: var(--radius-lg);
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-3);
    transition: all 0.2s;
    overflow: hidden;
    position: relative;
}
.category-card-image.has-image {
    background: transparent;
}
.category-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--radius-lg);
}
.category-card-image .placeholder-emoji {
    font-size: 3rem;
}
.category-card:hover .category-card-image {
    transform: scale(1.02);
}
.category-card:hover .category-card-image.has-image img {
    transform: scale(1.05);
}

/* Blue background category cards (like Balloons section) */
.category-card-image.blue-bg {
    background: var(--color-card-blue);
}
.category-card:hover .category-card-image.blue-bg {
    background: var(--color-card-blue-hover);
}

/* ============================================
   MINI CART SLIDE PANEL
   ============================================ */
.mini-cart-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.25);
    z-index: 998;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all 0.3s ease;
}
.mini-cart-overlay.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.mini-cart {
    position: fixed;
    top: 0;
    right: 0;
    width: 380px;
    max-width: 85vw;
    height: 100vh;
    height: 100dvh;
    background: var(--color-pure-white);
    box-shadow: -10px 0 40px rgba(0, 0, 0, 0.15);
    z-index: 999;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    pointer-events: none;
}
.mini-cart.active {
    transform: translateX(0);
    pointer-events: auto;
}

.mini-cart-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-5);
    border-bottom: 1px solid var(--color-gray-200);
    background: var(--color-gray-50);
}
.mini-cart-header h3 {
    font-size: var(--text-lg);
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-gray-900);
}
.mini-cart-header h3 i {
    color: var(--color-success);
}
.mini-cart-close {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: var(--color-gray-500);
    transition: all 0.2s;
}
.mini-cart-close:hover {
    background: var(--color-gray-200);
    color: var(--color-gray-800);
}

.mini-cart-items {
    max-height: 300px;
    overflow-y: auto;
}

.mini-cart-item {
    display: flex;
    gap: var(--space-4);
    padding: var(--space-4);
    border-bottom: 1px solid var(--color-gray-100);
}
.mini-cart-item:last-child {
    border-bottom: none;
}
.mini-cart-item-image {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, #f5f7fa 0%, #e4e8ec 100%);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    flex-shrink: 0;
    overflow: hidden;
}
.mini-cart-item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.mini-cart-item-details {
    flex: 1;
    min-width: 0;
}
.mini-cart-item-details h4 {
    font-size: var(--text-base);
    font-weight: 600;
    margin-bottom: var(--space-1);
    color: var(--color-gray-900);
}
.mini-cart-item-details p {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    margin-bottom: var(--space-2);
}
.mini-cart-item-price {
    font-size: var(--text-lg);
    font-weight: 800;
    color: var(--color-primary);
}

.mini-cart-summary {
    padding: var(--space-4) var(--space-5);
    background: var(--color-gray-50);
}
.mini-cart-summary-row {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-base);
    font-weight: 600;
}
.mini-cart-summary-row span:last-child {
    color: var(--color-gray-900);
}

.mini-cart-actions {
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-top: auto;
}
.mini-cart-actions .btn {
    padding: var(--space-4);
    font-size: var(--text-base);
    font-weight: 600;
}

@media (max-width: 480px) {
    .mini-cart {
        width: 75vw;
        max-width: 300px;
    }
    .mini-cart-header { padding: var(--space-3); }
    .mini-cart-header h3 { font-size: var(--text-sm); gap: var(--space-1); }
    .mini-cart-close { width: 32px; height: 32px; }
    .mini-cart-item { padding: var(--space-3); gap: var(--space-3); }
    .mini-cart-item-image { width: 50px; height: 50px; font-size: 1.5rem; }
    .mini-cart-item-details h4 { font-size: var(--text-sm); }
    .mini-cart-item-details p { font-size: var(--text-xs); margin-bottom: var(--space-1); }
    .mini-cart-item-price { font-size: var(--text-base); }
    .mini-cart-summary { padding: var(--space-3); }
    .mini-cart-summary-row { font-size: var(--text-sm); }
    .mini-cart-actions { padding: var(--space-3); gap: var(--space-2); }
    .mini-cart-actions .btn { padding: var(--space-3); font-size: var(--text-sm); }
}
