/* ============================================
   BONG CAFE - 3D STYLES
   A unique, immersive coffee experience
   ============================================ */

/* CSS Variables - Terracotta Studio Palette */
:root {
    --color-primary: #B5563E;
    --color-primary-light: #D4896A;
    --color-primary-dark: #8B3D2A;
    --color-secondary: #3D2B1F;
    --color-bg: #F2E6D9;
    --color-bg-dark: #E8D5C4;
    --color-text: #3D2B1F;
    --color-text-light: #6B5344;
    --color-white: #FFFFFF;
    --color-accent: #C9A87C;
    
    --font-display: 'Playfair Display', serif;
    --font-body: 'Outfit', sans-serif;
    
    --shadow-3d: 0 20px 40px rgba(61, 43, 31, 0.15);
    --shadow-3d-hover: 0 30px 60px rgba(61, 43, 31, 0.25);
    --shadow-inner: inset 0 2px 4px rgba(61, 43, 31, 0.1);
    
    --transition-smooth: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --transition-bounce: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* Reset & Base */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    font-family: var(--font-body);
    background: var(--color-bg);
    color: var(--color-text);
    line-height: 1.6;
    overflow-x: hidden;
    min-height: 100vh;
}

/* ============================================
   PARTICLES BACKGROUND
   ============================================ */
.particles-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.particle {
    position: absolute;
    width: 8px;
    height: 8px;
    background: var(--color-primary-light);
    border-radius: 50%;
    opacity: 0.3;
    animation: float-particle 15s infinite ease-in-out;
}

@keyframes float-particle {
    0%, 100% {
        transform: translateY(100vh) rotate(0deg);
        opacity: 0;
    }
    10% {
        opacity: 0.3;
    }
    90% {
        opacity: 0.3;
    }
    100% {
        transform: translateY(-100px) rotate(720deg);
        opacity: 0;
    }
}

/* ============================================
   NAVIGATION
   ============================================ */
.nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem 5%;
    background: rgba(242, 230, 217, 0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(181, 86, 62, 0.1);
    transition: var(--transition-smooth);
}

.nav.scrolled {
    padding: 1rem 5%;
    background: rgba(242, 230, 217, 0.98);
    box-shadow: 0 4px 30px rgba(61, 43, 31, 0.1);
}

.nav-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.logo-3d {
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 
        0 10px 30px rgba(181, 86, 62, 0.3),
        inset 0 2px 4px rgba(255, 255, 255, 0.3),
        inset 0 -2px 4px rgba(0, 0, 0, 0.2);
    transform: perspective(500px) rotateX(10deg) rotateY(-5deg);
    transition: var(--transition-bounce);
}

.logo-3d:hover {
    transform: perspective(500px) rotateX(0deg) rotateY(0deg) scale(1.1);
}

.logo-letter {
    color: var(--color-white);
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    text-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.logo-text {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--color-text);
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 2.5rem;
}

.nav-link {
    text-decoration: none;
    color: var(--color-text);
    font-weight: 500;
    font-size: 0.95rem;
    position: relative;
    padding: 0.5rem 0;
    transition: var(--transition-smooth);
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color-primary);
    transition: var(--transition-smooth);
}

.nav-link:hover {
    color: var(--color-primary);
}

.nav-link:hover::after {
    width: 100%;
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 5px;
}

.nav-toggle span {
    width: 25px;
    height: 2px;
    background: var(--color-text);
    transition: var(--transition-smooth);
}

/* ============================================
   HERO SECTION - REDESIGNED
   ============================================ */
.hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 8rem 5% 4rem;
    position: relative;
    overflow: hidden;
}

.hero-bg-pattern {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: 
        radial-gradient(circle at 20% 80%, rgba(181, 86, 62, 0.08) 0%, transparent 50%),\n        radial-gradient(circle at 80% 20%, rgba(201, 168, 124, 0.1) 0%, transparent 50%);\n    pointer-events: none;\n    z-index: 0;\n}

.hero-content {
    display: grid;\n    grid-template-columns: 1fr 1fr;\n    gap: 4rem;\n    align-items: center;\n    max-width: 1400px;\n    width: 100%;\n    position: relative;\n    z-index: 1;\n}

.hero-text {\n    animation: fade-in-up 1s ease-out;\n}

@keyframes fade-in-up {\n    from {\n        opacity: 0;\n        transform: translateY(30px);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0);\n    }\n}

/* Hero Badge */\n.hero-badge {\n    display: inline-flex;\n    align-items: center;\n    gap: 0.5rem;\n    padding: 0.5rem 1rem;\n    background: rgba(181, 86, 62, 0.1);\n    border: 1px solid rgba(181, 86, 62, 0.2);\n    border-radius: 50px;\n    font-size: 0.85rem;\n    font-weight: 600;\n    color: var(--color-primary);\n    margin-bottom: 1.5rem;\n    animation: fade-in-up 0.8s ease-out 0.2s both;\n}

.badge-icon {\n    width: 18px;\n    height: 18px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n}

.badge-icon svg {\n    width: 100%;\n    height: 100%;\n    stroke: var(--color-primary);\n}

.hero-title {\n    font-family: var(--font-display);\n    font-size: clamp(2.5rem, 5vw, 4.5rem);\n    font-weight: 700;\n    line-height: 1.1;\n    margin-bottom: 1.5rem;\n}

.title-line {\n    display: block;\n    opacity: 0;\n    transform: translateY(30px);\n    animation: title-reveal 0.8s ease-out forwards;\n}

.title-line:nth-child(1) { animation-delay: 0.3s; }\n.title-line:nth-child(2) { animation-delay: 0.5s; }\n.title-line:nth-child(3) { animation-delay: 0.7s; }

@keyframes title-reveal {\n    to {\n        opacity: 1;\n        transform: translateY(0);\n    }\n}

.title-accent {\n    color: var(--color-primary);\n    position: relative;\n    display: inline-block;\n}

.title-accent::after {\n    content: '';\n    position: absolute;\n    bottom: 8px;\n    left: -5px;\n    right: -5px;\n    height: 12px;\n    background: var(--color-accent);\n    opacity: 0.3;\n    z-index: -1;\n    border-radius: 4px;\n}

.hero-subtitle {\n    font-size: 1.25rem;\n    color: var(--color-text-light);\n    margin-bottom: 2.5rem;\n    max-width: 500px;\n    opacity: 0;\n    animation: fade-in-up 0.8s ease-out 0.9s forwards;\n}

.hero-cta {\n    display: flex;\n    gap: 1rem;\n    flex-wrap: wrap;\n    opacity: 0;\n    animation: fade-in-up 0.8s ease-out 1.1s forwards;\n    margin-bottom: 3rem;\n}

/* Buttons */\n.btn {\n    display: inline-flex;\n    align-items: center;\n    justify-content: center;\n    gap: 0.5rem;\n    padding: 1rem 2.5rem;\n    font-family: var(--font-body);\n    font-size: 1rem;\n    font-weight: 600;\n    text-decoration: none;\n    border: none;\n    border-radius: 50px;\n    cursor: pointer;\n    transition: var(--transition-smooth);\n    position: relative;\n    overflow: hidden;\n}

.btn::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);\n    transition: 0.5s;\n}

.btn:hover::before {\n    left: 100%;\n}

.btn-icon {\n    width: 20px;\n    height: 20px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n}

.btn-icon svg {\n    width: 100%;\n    height: 100%;\n}

.btn-primary {\n    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);\n    color: var(--color-white);\n    box-shadow: 0 10px 30px rgba(181, 86, 62, 0.3);\n}

.btn-primary:hover {\n    transform: translateY(-3px);\n    box-shadow: 0 15px 40px rgba(181, 86, 62, 0.4);\n}

.btn-secondary {\n    background: transparent;\n    color: var(--color-text);\n    border: 2px solid var(--color-text);\n}

.btn-secondary:hover {\n    background: var(--color-text);\n    color: var(--color-bg);\n}

.btn-small {\n    padding: 0.75rem 1.5rem;\n    font-size: 0.9rem;\n}

.btn-full {\n    width: 100%;\n}

/* Hero Stats */\n.hero-stats {\n    display: flex;\n    align-items: center;\n    gap: 2rem;\n    opacity: 0;\n    animation: fade-in-up 0.8s ease-out 1.3s forwards;\n}

.stat {\n    text-align: center;\n}

.stat-value {\n    display: block;\n    font-family: var(--font-display);\n    font-size: 2rem;\n    font-weight: 700;\n    color: var(--color-primary);\n    line-height: 1;\n}

.stat-label {\n    font-size: 0.85rem;\n    color: var(--color-text-light);\n    text-transform: uppercase;\n    letter-spacing: 1px;\n}

.stat-divider {\n    width: 1px;\n    height: 40px;\n    background: rgba(61, 43, 31, 0.2);\n}

/* ============================================
   3D COFFEE CUP\n   ============================================ */\n.hero-visual {\n    position: relative;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    min-height: 500px;\n}

.coffee-cup-3d {\n    position: relative;\n    width: 220px;\n    height: 220px;\n    animation: cup-float 4s ease-in-out infinite;\n}

@keyframes cup-float {\n    0%, 100% { transform: translateY(0) rotateY(0deg); }\n    50% { transform: translateY(-20px) rotateY(5deg); }\n}

.cup-body {\n    position: relative;\n    width: 180px;\n    height: 160px;\n    background: linear-gradient(135deg, #f8f8f8 0%, #e8e8e8 50%, #d8d8d8 100%);\n    border-radius: 0 0 90px 90px;\n    box-shadow: \n        inset -15px 0 30px rgba(0,0,0,0.08),\n        inset 15px 0 30px rgba(255,255,255,0.9),\n        0 25px 50px rgba(0,0,0,0.15);\n    transform: perspective(500px) rotateX(10deg);\n    margin: 0 auto;\n}

.cup-rim {\n    position: absolute;\n    top: -18px;\n    left: 5px;\n    right: 5px;\n    height: 35px;\n    background: linear-gradient(180deg, #ffffff 0%, #f0f0f0 100%);\n    border-radius: 50%;\n    box-shadow: \n        inset 0 2px 5px rgba(0,0,0,0.08),\n        0 3px 8px rgba(0,0,0,0.1);\n}

.cup-handle {\n    position: absolute;\n    right: -45px;\n    top: 35px;\n    width: 55px;\n    height: 80px;\n    border: 18px solid #e0e0e0;\n    border-left: none;\n    border-radius: 0 40px 40px 0;\n    box-shadow: \n        inset -5px 0 10px rgba(0,0,0,0.08),\n        5px 5px 15px rgba(0,0,0,0.1);\n}

.coffee-liquid {\n    position: absolute;\n    top: 5px;\n    left: 18px;\n    right: 18px;\n    height: 22px;\n    background: linear-gradient(180deg, #6B4423 0%, #4A2C17 100%);\n    border-radius: 50%;\n    overflow: hidden;\n}

.latte-art {\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%, -50%);\n    width: 30px;\n    height: 30px;\n    background: radial-gradient(circle, #D4A574 30%, transparent 70%);\n    border-radius: 50%;\n    opacity: 0.8;\n}

.latte-art::before {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%, -50%);\n    width: 20px;\n    height: 20px;\n    background: radial-gradient(circle, #E8D5C4 40%, transparent 70%);\n    border-radius: 50%;\n}

.steam-container {\n    position: absolute;\n    top: -60px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 100px;\n    height: 80px;\n}

.steam {\n    position: absolute;\n    width: 10px;\n    height: 40px;\n    background: linear-gradient(180deg, rgba(181, 86, 62, 0.3) 0%, transparent 100%);\n    border-radius: 50%;\n    filter: blur(6px);\n    animation: steam-rise 3s ease-out infinite;\n}

.steam-1 { left: 30%; animation-delay: 0s; }\n.steam-2 { left: 50%; animation-delay: 1s; height: 50px; }\n.steam-3 { left: 70%; animation-delay: 2s; }

@keyframes steam-rise {\n    0% {\n        transform: translateY(0) scaleX(1);\n        opacity: 0.6;\n    }\n    100% {\n        transform: translateY(-70px) scaleX(2);\n        opacity: 0;\n    }\n}

.shadow-3d {\n    position: absolute;\n    bottom: -40px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 160px;\n    height: 35px;\n    background: radial-gradient(ellipse, rgba(0,0,0,0.15) 0%, transparent 70%);\n    border-radius: 50%;\n    animation: shadow-pulse 4s ease-in-out infinite;\n}

@keyframes shadow-pulse {\n    0%, 100% { transform: translateX(-50%) scale(1); opacity: 0.3; }\n    50% { transform: translateX(-50%) scale(0.8); opacity: 0.2; }\n}

/* ============================================
   FLOATING 3D ICONS\n   ============================================ */\n.floating-icons {\n    position: absolute;\n    width: 100%;\n    height: 100%;\n    pointer-events: none;\n}

.float-icon {\n    position: absolute;\n    animation: float-around 8s ease-in-out infinite;\n}

.float-1 { top: 5%; left: 5%; animation-delay: 0s; }\n.float-2 { top: 50%; right: 5%; animation-delay: 2s; }\n.float-3 { bottom: 15%; left: 15%; animation-delay: 4s; }

@keyframes float-around {\n    0%, 100% { transform: translate(0, 0) rotate(0deg); }\n    25% { transform: translate(25px, -25px) rotate(10deg); }\n    50% { transform: translate(0, -50px) rotate(0deg); }\n    75% { transform: translate(-25px, -25px) rotate(-10deg); }\n}

.icon-3d {\n    width: 60px;\n    height: 60px;\n    background: linear-gradient(135deg, var(--color-white) 0%, var(--color-bg) 100%);\n    border-radius: 16px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    box-shadow: \n        0 15px 35px rgba(61, 43, 31, 0.15),\n        inset 0 2px 4px rgba(255,255,255,0.8);\n    transform: perspective(500px) rotateX(15deg) rotateY(-15deg);\n    transition: var(--transition-smooth);\n}

.icon-3d:hover {\n    transform: perspective(500px) rotateX(0deg) rotateY(0deg) scale(1.1);\n}

.icon-3d svg {\n    width: 28px;\n    height: 28px;\n    fill: var(--color-primary);\n}

/* Coffee Bean Icon */\n.icon-bean {\n    position: relative;\n}

.bean-shape {\n    width: 35px;\n    height: 50px;\n    background: linear-gradient(135deg, #6B4423 0%, #4A2C17 100%);\n    border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;\n    position: relative;\n    transform: rotate(45deg);\n    box-shadow: inset -3px -3px 8px rgba(0,0,0,0.3);\n}

.bean-shape::before {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%, -50%);\n    width: 3px;\n    height: 70%;\n    background: rgba(255,255,255,0.2);\n    border-radius: 2px;\n}

/* Croissant Icon */\n.icon-croissant {\n    position: relative;\n}

.croissant-shape {\n    width: 50px;\n    height: 35px;\n    background: linear-gradient(135deg, #D4A574 0%, #C9956B 50%, #B8834F 100%);\n    border-radius: 50%;\n    position: relative;\n    box-shadow: \n        inset -2px -2px 6px rgba(0,0,0,0.1),\n        0 4px 8px rgba(0,0,0,0.1);\n}

.croissant-shape::before,\n.croissant-shape::after {\n    content: '';\n    position: absolute;\n    background: linear-gradient(135deg, #D4A574 0%, #C9956B 100%);\n    border-radius: 50%;\n}

.croissant-shape::before {\n    width: 20px;\n    height: 30px;\n    left: -5px;\n    top: 2px;\n    transform: rotate(-20deg);\n}

.croissant-shape::after {\n    width: 20px;\n    height: 30px;\n    right: -5px;\n    top: 2px;\n    transform: rotate(20deg);\n}

/* Decorative Circles */\n.deco-circle {\n    position: absolute;\n    border-radius: 50%;\n    opacity: 0.1;\n}

.deco-1 {\n    width: 300px;\n    height: 300px;\n    background: var(--color-primary);\n    top: -100px;\n    right: -50px;\n    animation: pulse 6s ease-in-out infinite;\n}

.deco-2 {\n    width: 200px;\n    height: 200px;\n    background: var(--color-accent);\n    bottom: 50px;\n    left: -50px;\n    animation: pulse 8s ease-in-out infinite 1s;\n}

.deco-3 {\n    width: 150px;\n    height: 150px;\n    background: var(--color-primary-light);\n    top: 50%;\n    right: 20%;\n    animation: pulse 7s ease-in-out infinite 2s;\n}

@keyframes pulse {\n    0%, 100% { transform: scale(1); opacity: 0.1; }\n    50% { transform: scale(1.1); opacity: 0.15; }\n}

/* ============================================
   HERO IMAGES GALLERY\n   ============================================ */\n.hero-images {\n    display: flex;\n    justify-content: center;\n    gap: 1.5rem;\n    margin-top: 4rem;\n    position: relative;\n    z-index: 1;\n    flex-wrap: wrap;\n}

.hero-img-card {\n    width: 200px;\n    height: 140px;\n    background: var(--color-white);\n    border-radius: 16px;\n    overflow: hidden;\n    box-shadow: var(--shadow-3d);\n    transition: var(--transition-smooth);\n    transform: perspective(1000px) rotateX(5deg);\n}

.hero-img-card:hover {\n    transform: perspective(1000px) rotateX(0deg) translateY(-10px);\n    box-shadow: var(--shadow-3d-hover);\n}

.hero-img-card.card-1 { transform: perspective(1000px) rotateX(5deg) rotateY(-5deg); }\n.hero-img-card.card-2 { transform: perspective(1000px) rotateX(5deg); margin-top: -20px; }\n.hero-img-card.card-3 { transform: perspective(1000px) rotateX(5deg) rotateY(5deg); }

.hero-img-card.card-1:hover { transform: perspective(1000px) rotateX(0deg) rotateY(0deg) translateY(-10px); }\n.hero-img-card.card-2:hover { transform: perspective(1000px) rotateX(0deg) translateY(-10px); }\n.hero-img-card.card-3:hover { transform: perspective(1000px) rotateX(0deg) rotateY(0deg) translateY(-10px); }

/* Image Placeholder */\n.img-placeholder {\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-dark) 100%);\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n    gap: 0.5rem;\n    border: 2px dashed rgba(181, 86, 62, 0.3);\n    border-radius: 16px;\n    padding: 1rem;\n    text-align: center;\n}

.placeholder-icon {\n    width: 40px;\n    height: 40px;\n    color: var(--color-primary);\n    opacity: 0.6;\n}

.placeholder-icon svg {\n    width: 100%;\n    height: 100%;\n    stroke: currentColor;\n}

.placeholder-text {\n    font-size: 0.9rem;\n    font-weight: 600;\n    color: var(--color-text);\n}

.placeholder-hint {\n    font-size: 0.7rem;\n    color: var(--color-text-light);\n    opacity: 0.7;\n}

/* Scroll Indicator */\n.scroll-indicator {\n    position: absolute;\n    bottom: 2rem;\n    left: 50%;\n    transform: translateX(-50%);\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    gap: 0.5rem;\n    opacity: 0.6;\n    animation: bounce 2s infinite;\n}

.mouse {\n    width: 26px;\n    height: 40px;\n    border: 2px solid var(--color-text);\n    border-radius: 13px;\n    display: flex;\n    justify-content: center;\n    padding-top: 8px;\n}

.wheel {\n    width: 4px;\n    height: 8px;\n    background: var(--color-text);\n    border-radius: 2px;\n    animation: scroll-wheel 2s infinite;\n}

@keyframes scroll-wheel {\n    0% { transform: translateY(0); opacity: 1; }\n    100% { transform: translateY(12px); opacity: 0; }\n}

@keyframes bounce {\n    0%, 100% { transform: translateX(-50%) translateY(0); }\n    50% { transform: translateX(-50%) translateY(-10px); }\n}

.scroll-indicator span {\n    font-size: 0.8rem;\n    text-transform: uppercase;\n    letter-spacing: 2px;\n}

/* ============================================
   SECTION STYLES\n   ============================================ */\nsection {\n    padding: 6rem 5%;\n    position: relative;\n}

.section-header {\n    text-align: center;\n    margin-bottom: 4rem;\n}

.section-tag {\n    display: inline-block;\n    padding: 0.5rem 1.5rem;\n    background: var(--color-primary-light);\n    color: var(--color-white);\n    font-size: 0.85rem;\n    font-weight: 600;\n    text-transform: uppercase;\n    letter-spacing: 2px;\n    border-radius: 50px;\n    margin-bottom: 1rem;\n}

.section-title {\n    font-family: var(--font-display);\n    font-size: clamp(2rem, 4vw, 3.5rem);\n    font-weight: 700;\n    margin-bottom: 1rem;\n    color: var(--color-text);\n}

.section-desc {\n    font-size: 1.1rem;\n    color: var(--color-text-light);\n    max-width: 600px;\n    margin: 0 auto;\n}

/* ============================================
   MENU SECTION\n   ============================================ */\n.menu {\n    background: var(--color-bg-dark);\n}

.menu-grid {\n    display: grid;\n    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));\n    gap: 2rem;\n    max-width: 1200px;\n    margin: 0 auto;\n    perspective: 1000px;\n}

.menu-card {\n    height: 350px;\n    perspective: 1000px;\n    cursor: pointer;\n}

.card-3d {\n    position: relative;\n    width: 100%;\n    height: 100%;\n    transform-style: preserve-3d;\n    transition: transform 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275);\n}

.menu-card:hover .card-3d {\n    transform: rotateY(180deg);\n}

.card-front,\n.card-back {\n    position: absolute;\n    width: 100%;\n    height: 100%;\n    backface-visibility: hidden;\n    border-radius: 24px;\n    padding: 2rem;\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n    text-align: center;\n    box-shadow: var(--shadow-3d);\n}

.card-front {\n    background: linear-gradient(135deg, var(--color-white) 0%, var(--color-bg) 100%);\n    border: 1px solid rgba(181, 86, 62, 0.1);\n}

.card-back {\n    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);\n    color: var(--color-white);\n    transform: rotateY(180deg);\n}

.card-icon {\n    margin-bottom: 1rem;\n}

.icon-3d-small {\n    width: 70px;\n    height: 70px;\n    background: linear-gradient(135deg, var(--color-white) 0%, var(--color-bg) 100%);\n    border-radius: 20px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    box-shadow: 0 10px 25px rgba(181, 86, 62, 0.15);\n}

.card-back .icon-3d-small {\n    background: rgba(255,255,255,0.2);\n    box-shadow: 0 10px 25px rgba(0,0,0,0.1);\n}

/* Menu Icons */\n.icon-coffee-cup {\n    width: 35px;\n    height: 35px;\n    background: linear-gradient(135deg, #6B4423 0%, #4A2C17 100%);\n    border-radius: 0 0 50% 50%;\n    position: relative;\n}

.icon-coffee-cup::before {\n    content: '';\n    position: absolute;\n    top: -8px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 40px;\n    height: 15px;\n    background: linear-gradient(180deg, #f0f0f0 0%, #e0e0e0 100%);\n    border-radius: 50%;\n}

.icon-coffee-cup::after {\n    content: '';\n    position: absolute;\n    right: -12px;\n    top: 5px;\n    width: 15px;\n    height: 20px;\n    border: 4px solid #e0e0e0;\n    border-left: none;\n    border-radius: 0 50% 50% 0;\n}

.icon-cappuccino {\n    width: 35px;\n    height: 35px;\n    background: linear-gradient(135deg, #D4A574 0%, #C9956B 100%);\n    border-radius: 0 0 50% 50%;\n    position: relative;\n}

.icon-cappuccino::before {\n    content: '';\n    position: absolute;\n    top: -5px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 45px;\n    height: 20px;\n    background: linear-gradient(180deg, #ffffff 0%, #f5f5f5 100%);\n    border-radius: 50%;\n}

.icon-cold-brew {\n    width: 30px;\n    height: 40px;\n    background: linear-gradient(180deg, #4A6670 0%, #2F3640 100%);\n    border-radius: 5px;\n    position: relative;\n}

.icon-cold-brew::before {\n    content: '';\n    position: absolute;\n    top: -5px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 20px;\n    height: 10px;\n    background: #6B8E9F;\n    border-radius: 2px;\n}

.icon-matcha {\n    width: 35px;\n    height: 35px;\n    background: linear-gradient(135deg, #7A9E7E 0%, #5A7A5E 100%);\n    border-radius: 0 0 50% 50%;\n    position: relative;\n}

.icon-matcha::before {\n    content: '';\n    position: absolute;\n    top: -8px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 40px;\n    height: 15px;\n    background: linear-gradient(180deg, #f0f0f0 0%, #e0e0e0 100%);\n    border-radius: 50%;\n}

.icon-croissant-small {\n    width: 40px;\n    height: 25px;\n    background: linear-gradient(135deg, #D4A574 0%, #C9956B 50%, #B8834F 100%);\n    border-radius: 50%;\n    position: relative;\n}

.icon-croissant-small::before,\n.icon-croissant-small::after {\n    content: '';\n    position: absolute;\n    background: inherit;\n    border-radius: 50%;\n}

.icon-croissant-small::before {\n    width: 15px;\n    height: 22px;\n    left: -3px;\n    top: 1px;\n    transform: rotate(-15deg);\n}

.icon-croissant-small::after {\n    width: 15px;\n    height: 22px;\n    right: -3px;\n    top: 1px;\n    transform: rotate(15deg);\n}

.icon-cake {\n    width: 35px;\n    height: 30px;\n    background: linear-gradient(180deg, #D4A574 0%, #C9956B 50%, #8B6914 100%);\n    border-radius: 5px 5px 0 0;\n    position: relative;\n}

.icon-cake::before {\n    content: '';\n    position: absolute;\n    top: -8px;\n    left: 50%;\n    transform: translateX(-50%);\n    width: 8px;\n    height: 15px;\n    background: #4A2C17;\n    border-radius: 2px;\n}

.card-front h3 {\n    font-family: var(--font-display);\n    font-size: 1.75rem;\n    margin-bottom: 0.5rem;\n}

.price {\n    font-size: 1.5rem;\n    font-weight: 600;\n    color: var(--color-primary);\n}

.card-back p {\n    margin-bottom: 1.5rem;\n    line-height: 1.7;\n}

/* ============================================
   ABOUT SECTION\n   ============================================ */\n.about {\n    background: var(--color-bg);\n}

.about-container {\n    display: grid;\n    grid-template-columns: 1fr 1fr;\n    gap: 4rem;\n    align-items: center;\n    max-width: 1200px;\n    margin: 0 auto;\n}

.about-visual {\n    display: flex;\n    justify-content: center;\n}

.about-image-3d {\n    position: relative;\n    width: 350px;\n    height: 450px;\n}

.image-frame {\n    position: relative;\n    width: 100%;\n    height: 100%;\n    transform-style: preserve-3d;\n    transform: perspective(1000px) rotateY(-15deg) rotateX(5deg);\n    transition: var(--transition-smooth);\n}

.about-image-3d:hover .image-frame {\n    transform: perspective(1000px) rotateY(0deg) rotateX(0deg);\n}

.frame-depth {\n    position: absolute;\n    border-radius: 20px;\n    box-shadow: var(--shadow-3d);\n}

.frame-1 {\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background: var(--color-primary);\n    transform: translateZ(0);\n}

.frame-2 {\n    top: 10px;\n    left: 10px;\n    width: calc(100% - 20px);\n    height: calc(100% - 20px);\n    background: var(--color-primary-light);\n    transform: translateZ(20px);\n}

.frame-3 {\n    top: 20px;\n    left: 20px;\n    width: calc(100% - 40px);\n    height: calc(100% - 40px);\n    background: var(--color-bg);\n    transform: translateZ(40px);\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    overflow: hidden;\n}

.about-placeholder {\n    border: none;\n    background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-bg) 100%);\n}

.about-content {\n    padding: 2rem;\n}

.about-text {\n    font-size: 1.1rem;\n    color: var(--color-text-light);\n    margin-bottom: 1.5rem;\n    line-height: 1.8;\n}

.stats-grid {\n    display: grid;\n    grid-template-columns: repeat(3, 1fr);\n    gap: 2rem;\n    margin-top: 3rem;\n}

.stat-item {\n    text-align: center;\n}

.stat-number {\n    display: block;\n    font-family: var(--font-display);\n    font-size: 3rem;\n    font-weight: 700;\n    color: var(--color-primary);\n    line-height: 1;\n}

.stat-label {\n    font-size: 0.9rem;\n    color: var(--color-text-light);\n    text-transform: uppercase;\n    letter-spacing: 1px;\n}

/* ============================================
   GALLERY SECTION\n   ============================================ */\n.gallery {\n    background: var(--color-bg-dark);\n    overflow: hidden;\n}

.gallery-3d {\n    display: flex;\n    justify-content: center;\n    gap: 2rem;\n    flex-wrap: wrap;\n    perspective: 1000px;\n    padding: 2rem 0;\n}

.gallery-item {\n    transform-style: preserve-3d;\n    transition: var(--transition-smooth);\n}

.gallery-item:nth-child(1) { transform: translateZ(20px); }\n.gallery-item:nth-child(2) { transform: translateZ(40px); }\n.gallery-item:nth-child(3) { transform: translateZ(30px); }\n.gallery-item:nth-child(4) { transform: translateZ(50px); }

.gallery-card {\n    position: relative;\n    width: 220px;\n    height: 280px;\n    background: linear-gradient(135deg, var(--color-white) 0%, var(--color-bg) 100%);\n    border-radius: 24px;\n    padding: 2rem;\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    justify-content: center;\n    text-align: center;\n    box-shadow: var(--shadow-3d);\n    transition: var(--transition-smooth);\n    overflow: hidden;\n}

.gallery-card:hover {\n    transform: translateY(-20px) rotateX(10deg);\n    box-shadow: var(--shadow-3d-hover);\n}

.card-glow {\n    position: absolute;\n    top: -50%;\n    left: -50%;\n    width: 200%;\n    height: 200%;\n    background: radial-gradient(circle, rgba(181, 86, 62, 0.1) 0%, transparent 70%);\n    opacity: 0;\n    transition: var(--transition-smooth);\n}

.gallery-card:hover .card-glow {\n    opacity: 1;\n}

.gallery-icon {\n    margin-bottom: 1rem;\n}

.gallery-card h4 {\n    font-family: var(--font-display);\n    font-size: 1.25rem;\n    color: var(--color-text);\n}

/* Gallery Icons */\n.icon-brewing {\n    width: 40px;\n    height: 40px;\n    background: linear-gradient(135deg, #6B4423 0%, #4A2C17 100%);\n    border-radius: 50%;\n    position: relative;\n}

.icon-brewing::before {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%, -50%);\n    width: 20px;\n    height: 20px;\n    background: rgba(255,255,255,0.3);\n    border-radius: 50%;\n}

.icon-creative {\n    width: 40px;\n    height: 40px;\n    background: linear-gradient(135deg, #D4896A 0%, #B5563E 100%);\n    border-radius: 8px;\n    position: relative;\n}

.icon-creative::before {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%, -50%);\n    width: 20px;\n    height: 20px;\n    border: 3px solid rgba(255,255,255,0.5);\n    border-radius: 50%;\n}

.icon-plant {\n    width: 40px;\n    height: 40px;\n    background: linear-gradient(135deg, #7A9E7E 0%, #5A7A5E 100%);\n    border-radius: 50% 50% 50% 5px;\n    position: relative;\n    transform: rotate(-45deg);\n}

.icon-atmosphere {\n    width: 40px;\n    height: 40px;\n    background: linear-gradient(135deg, #C9A87C 0%, #A08060 100%);\n    border-radius: 50%;\n    position: relative;\n    box-shadow: 0 5px 15px rgba(201, 168, 124, 0.4);\n}

/* ============================================
   CONTACT SECTION\n   ============================================ */\n.contact {\n    background: var(--color-bg);\n}

.contact-container {\n    display: grid;\n    grid-template-columns: 1fr 1fr;\n    gap: 4rem;\n    max-width: 1200px;\n    margin: 0 auto;\n}

.contact-info {\n    padding: 2rem;\n}

.contact-details {\n    margin-top: 3rem;\n}

.contact-item {\n    display: flex;\n    gap: 1.5rem;\n    margin-bottom: 2rem;\n    padding: 1.5rem;\n    background: var(--color-white);\n    border-radius: 16px;\n    box-shadow: var(--shadow-3d);\n    transition: var(--transition-smooth);\n}

.contact-item:hover {\n    transform: translateX(10px);\n    box-shadow: var(--shadow-3d-hover);\n}

.contact-icon {\n    flex-shrink: 0;\n}

/* Contact Icons */\n.icon-location {\n    width: 30px;\n    height: 30px;\n    background: linear-gradient(135deg, #B5563E 0%, #8B3D2A 100%);\n    border-radius: 50% 50% 50% 5px;\n    transform: rotate(-45deg);\n}

.icon-clock {\n    width: 30px;\n    height: 30px;\n    border: 3px solid var(--color-primary);\n    border-radius: 50%;\n    position: relative;\n}

.icon-clock::before {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    width: 2px;\n    height: 10px;\n    background: var(--color-primary);\n    transform: translate(-50%, -100%);\n}

.icon-clock::after {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    width: 8px;\n    height: 2px;\n    background: var(--color-primary);\n    transform: translate(-50%, -50%);\n}

.icon-phone {\n    width: 30px;\n    height: 30px;\n    background: var(--color-primary);\n    border-radius: 8px;\n    position: relative;\n}

.icon-phone::before {\n    content: '';\n    position: absolute;\n    top: 50%;\n    left: 50%;\n    transform: translate(-50%, -50%);\n    width: 15px;\n    height: 20px;\n    border: 2px solid white;\n    border-radius: 3px;\n}

.contact-item h4 {\n    font-family: var(--font-display);\n    font-size: 1.25rem;\n    margin-bottom: 0.5rem;\n}

.contact-item p {\n    color: var(--color-text-light);\n    line-height: 1.6;\n}

/* Contact Form */\n.contact-form-wrapper {\n    padding: 2rem;\n}

.contact-form {\n    background: var(--color-white);\n    padding: 3rem;\n    border-radius: 24px;\n    box-shadow: var(--shadow-3d);\n}

.form-group {\n    position: relative;\n    margin-bottom: 2rem;\n}

.form-group input,\n.form-group textarea {\n    width: 100%;\n    padding: 1rem 0;\n    font-family: var(--font-body);\n    font-size: 1rem;\n    border: none;\n    border-bottom: 2px solid var(--color-bg-dark);\n    background: transparent;\n    outline: none;\n    transition: var(--transition-smooth);\n}

.form-group label {\n    position: absolute;\n    left: 0;\n    top: 1rem;\n    font-size: 1rem;\n    color: var(--color-text-light);\n    pointer-events: none;\n    transition: var(--transition-smooth);\n}

.form-group input:focus,\n.form-group textarea:focus,\n.form-group input:not(:placeholder-shown),\n.form-group textarea:not(:placeholder-shown) {\n    border-bottom-color: var(--color-primary);\n}

.form-group input:focus + label,\n.form-group textarea:focus + label,\n.form-group input:not(:placeholder-shown) + label,\n.form-group textarea:not(:placeholder-shown) + label {\n    top: -0.5rem;\n    font-size: 0.85rem;\n    color: var(--color-primary);\n}

.input-line {\n    position: absolute;\n    bottom: 0;\n    left: 0;\n    width: 0;\n    height: 2px;\n    background: var(--color-primary);\n    transition: var(--transition-smooth);\n}

.form-group input:focus ~ .input-line,\n.form-group textarea:focus ~ .input-line {\n    width: 100%;\n}

/* ============================================
   FOOTER\n   ============================================ */\n.footer {\n    background: var(--color-secondary);\n    color: var(--color-white);\n    padding: 4rem 5%;\n    text-align: center;\n}

.footer-content {\n    max-width: 800px;\n    margin: 0 auto;\n}

.footer-brand {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    gap: 0.75rem;\n    margin-bottom: 2rem;\n}

.footer-brand .logo-3d {\n    background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-primary) 100%);\n}

.footer-brand .logo-text {\n    color: var(--color-white);\n}

.footer-social {\n    display: flex;\n    justify-content: center;\n    gap: 1.5rem;\n    margin-bottom: 2rem;\n}

.social-link {\n    width: 50px;\n    height: 50px;\n    background: rgba(255, 255, 255, 0.1);\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    text-decoration: none;\n    transition: var(--transition-smooth);\n}

.social-link svg {\n    width: 24px;\n    height: 24px;\n    fill: var(--color-white);\n}

.social-link:hover {\n    background: var(--color-primary);\n    transform: translateY(-5px);\n}

.footer-copy {\n    color: rgba(255, 255, 255, 0.6);\n    font-size: 0.9rem;\n}

/* ============================================
   RESPONSIVE DESIGN\n   ============================================ */\n@media (max-width: 1024px) {\n    .hero-content {\n        grid-template-columns: 1fr;\n        text-align: center;\n    }\n    \n    .hero-text {\n        order: 1;\n    }\n    \n    .hero-visual {\n        order: 0;\n        min-height: 400px;\n    }\n    \n    .hero-subtitle {\n        margin-left: auto;\n        margin-right: auto;\n    }\n    \n    .hero-cta {\n        justify-content: center;\n    }\n    \n    .hero-stats {\n        justify-content: center;\n    }\n    \n    .about-container,\n    .contact-container {\n        grid-template-columns: 1fr;\n    }\n    \n    .about-visual {\n        order: 0;\n    }\n    \n    .about-content {\n        order: 1;\n    }\n}

@media (max-width: 768px) {\n    .nav-menu {\n        position: fixed;\n        top: 0;\n        right: -100%;\n        width: 80%;\n        max-width: 300px;\n        height: 100vh;\n        background: var(--color-bg);\n        flex-direction: column;\n        padding: 6rem 2rem 2rem;\n        gap: 1.5rem;\n        transition: var(--transition-smooth);\n        box-shadow: -10px 0 30px rgba(0,0,0,0.1);\n    }\n    \n    .nav-menu.active {\n        right: 0;\n    }\n    \n    .nav-toggle {\n        display: flex;\n        z-index: 1001;\n    }\n    \n    .nav-toggle.active span:nth-child(1) {\n        transform: rotate(45deg) translate(5px, 5px);\n    }\n    \n    .nav-toggle.active span:nth-child(2) {\n        opacity: 0;\n    }\n    \n    .nav-toggle.active span:nth-child(3) {\n        transform: rotate(-45deg) translate(5px, -5px);\n    }\n    \n    .hero-title {\n        font-size: 2.5rem;\n    }\n    \n    .hero-images {\n        flex-direction: column;\n        align-items: center;\n    }\n    \n    .hero-img-card {\n        width: 280px;\n        height: 180px;\n    }\n    \n    .hero-img-card.card-2 {\n        margin-top: 0;\n    }\n    \n    .menu-grid {\n        grid-template-columns: 1fr;\n    }\n    \n    .stats-grid {\n        grid-template-columns: 1fr;\n        gap: 1.5rem;\n    }\n    \n    .gallery-3d {\n        flex-direction: column;\n        align-items: center;\n    }\n    \n    .gallery-item {\n        transform: none !important;\n    }\n    \n    .contact-form {\n        padding: 2rem;\n    }\n}

@media (max-width: 480px) {\n    .hero {\n        padding: 7rem 1.5rem 3rem;\n    }\n    \n    section {\n        padding: 4rem 1.5rem;\n    }\n    \n    .btn {\n        padding: 0.875rem 2rem;\n        font-size: 0.9rem;\n    }\n    \n    .coffee-cup-3d {\n        transform: scale(0.8);\n    }\n    \n    .about-image-3d {\n        width: 280px;\n        height: 360px;\n    }\n    \n    .contact-item {\n        flex-direction: column;\n        text-align: center;\n    }\n    \n    .hero-stats {\n        flex-direction: column;\n        gap: 1rem;\n    }\n    \n    .stat-divider {\n        width: 60px;\n        height: 1px;\n    }\n}

/* ============================================
   ANIMATIONS & EFFECTS\n   ============================================ */\n.reveal {\n    opacity: 0;\n    transform: translateY(30px);\n    transition: all 0.8s ease-out;\n}

.reveal.active {\n    opacity: 1;\n    transform: translateY(0);\n}

/* Smooth scroll for anchor links */\nhtml {\n    scroll-behavior: smooth;\n}

/* Selection color */\n::selection {\n    background: var(--color-primary);\n    color: var(--color-white);\n}

/* Focus styles for accessibility */\n:focus-visible {\n    outline: 2px solid var(--color-primary);\n    outline-offset: 4px;\n}

/* Reduced motion preference */\n@media (prefers-reduced-motion: reduce) {\n    *,\n    *::before,\n    *::after {\n        animation-duration: 0.01ms !important;\n        animation-iteration-count: 1 !important;\n        transition-duration: 0.01ms !important;\n    }\n}