/* ════════════════════════════════════════════════════════
   KOKY SWEET — Candy Shop Theme 🍭🎂
   ════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800;900&display=swap');

:root {
    /* ── Candy Palette ── */
    --pink:           #FF6B9D;
    --pink-light:     #FFB3D1;
    --pink-pale:      #FFF0F7;
    --purple:         #9B5DE5;
    --purple-light:   #C9A8F5;
    --purple-pale:    #F3EEFF;
    --teal:           #00C9A7;
    --teal-light:     #7FFFD4;
    --yellow:         #F9C846;
    --orange:         #FF9F43;
    --blue:           #48CAE4;
    --white:          #FFFFFF;
    --gray-100:       #F8F9FA;
    --gray-200:       #F0E8F5;
    --gray-500:       #ADB5BD;
    --gray-600:       #6C757D;
    --gray-700:       #495057;
    --gray-800:       #343A40;
    --dark-text:      #2D1B4E;

    /* Bootstrap overrides */
    --bs-primary:     #FF6B9D;
    --bs-primary-rgb: 255, 107, 157;

    --border-radius:    16px;
    --border-radius-lg: 26px;
    --shadow-sm: 0 4px 20px rgba(155, 93, 229, .12);
    --shadow:    0 8px 32px rgba(255, 107, 157, .20);
    --shadow-lg: 0 16px 56px rgba(155, 93, 229, .25);
    --transition: all .3s cubic-bezier(.4,0,.2,1);
}

/* ── RTL ── */
[dir="rtl"] { text-align: right; }

*,*::before,*::after { box-sizing: border-box; }

body {
    font-family: 'Cairo', 'Segoe UI', sans-serif;
    background: var(--pink-pale);
    color: var(--dark-text);
    line-height: 1.7;
    overflow-x: hidden;
}

/* ════════════════════ TYPOGRAPHY ════════════════════ */
h1,h2,h3,h4,h5,h6 {
    font-family: 'Cairo', sans-serif;
    font-weight: 800;
    color: var(--purple);
    line-height: 1.3;
}

.text-chocolate { color: var(--pink) !important; }
.text-cream     { color: var(--pink-pale) !important; }
.bg-chocolate   { background-color: var(--pink) !important; }
.bg-cream       { background-color: var(--pink-pale) !important; }
.bg-cream-dark  { background-color: var(--pink-light) !important; }

/* ════════════════════ BUTTONS ════════════════════ */
.btn {
    border-radius: 50px;
    padding: .55rem 1.7rem;
    font-weight: 700;
    font-family: 'Cairo', sans-serif;
    transition: var(--transition);
    letter-spacing: .3px;
}

.btn-chocolate {
    background: linear-gradient(135deg, var(--pink), var(--purple));
    border: none;
    color: #fff;
    box-shadow: 0 4px 18px rgba(255,107,157,.40);
}
.btn-chocolate:hover {
    background: linear-gradient(135deg, #ff4d8d, #7b3dcc);
    color: #fff;
    transform: translateY(-3px);
    box-shadow: var(--shadow);
}

.btn-outline-chocolate {
    border: 2.5px solid var(--pink);
    color: var(--pink);
    background: transparent;
}
.btn-outline-chocolate:hover {
    background: var(--pink);
    color: #fff;
    transform: translateY(-2px);
}

.btn-pink {
    background: linear-gradient(135deg, var(--pink-light), var(--pink));
    color: #fff;
    border: none;
}
.btn-mint {
    background: linear-gradient(135deg, var(--teal-light), var(--teal));
    color: var(--dark-text);
    border: none;
}

/* ════════════════════ NAVBAR ════════════════════ */
.navbar {
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 2px 24px rgba(155,93,229,.10);
    padding: .75rem 0;
    border-bottom: 3px solid transparent;
    border-image: linear-gradient(90deg, var(--pink), var(--purple), var(--teal)) 1;
    transition: var(--transition);
}
.navbar-brand {
    font-size: 1.5rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--pink), var(--purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.navbar-brand img { height: 42px; margin-left: 8px; }

.nav-link {
    color: var(--gray-700);
    font-weight: 700;
    padding: .5rem 1rem !important;
    border-radius: 50px;
    transition: var(--transition);
    position: relative;
}
.nav-link:hover,
.nav-link.active {
    background: linear-gradient(135deg, var(--pink-pale), var(--purple-pale));
    color: var(--purple);
}

/* Cart badge */
.cart-badge {
    font-size: .6rem !important;
    min-width: 18px;
    min-height: 18px;
    background: var(--pink) !important;
    display: none;
}

/* ════════════════════ DROPDOWN ════════════════════ */
.dropdown-menu {
    border: none;
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-lg);
    padding: .5rem;
    background: #fff;
}
.dropdown-item {
    border-radius: 10px;
    font-weight: 600;
    transition: var(--transition);
}
.dropdown-item:hover {
    background: linear-gradient(135deg, var(--pink-pale), var(--purple-pale));
    color: var(--purple);
}

/* ════════════════════ CARDS ════════════════════ */
.card {
    border: none;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    background: #fff;
    overflow: hidden;
}
.card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-6px);
}

/* Product cards */
.card-product .card-img-wrapper {
    position: relative;
    overflow: hidden;
    height: 220px;
}
.card-product .card-img-top {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.card-product:hover .card-img-top    { transform: scale(1.08); }
.card-product .badge-wrapper {
    position: absolute;
    top: 10px; right: 10px;
    display: flex; flex-direction: column; gap: 5px;
}
.card-product .product-actions {
    position: absolute;
    bottom: -60px; left: 0; right: 0;
    display: flex; justify-content: center; gap: 10px;
    padding: 12px;
    background: linear-gradient(to top, rgba(155,93,229,.65), transparent);
    transition: var(--transition);
}
.card-product:hover .product-actions { bottom: 0; }
.card-product .product-actions .btn {
    width: 42px; height: 42px;
    border-radius: 50%; padding: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
}

.cart-item-image {
    width: 80px; height: 80px;
    object-fit: cover;
    border-radius: var(--border-radius);
    border: 2px solid var(--pink-light);
}

/* ════════════════════ BADGES ════════════════════ */
.badge { border-radius: 50px; padding: .4em .9em; font-weight: 700; }
.badge-chocolate { background: linear-gradient(135deg,var(--pink),var(--purple)); color:#fff; }
.badge-pink      { background: var(--pink-light); color: var(--dark-text); }
.badge-mint      { background: var(--teal-light); color: var(--dark-text); }

/* ════════════════════ FORMS ════════════════════ */
.form-control,.form-select {
    border-radius: var(--border-radius);
    border: 2px solid var(--gray-200);
    padding: .65rem 1rem;
    font-family: 'Cairo', sans-serif;
    transition: var(--transition);
    background: rgba(255,255,255,.9);
}
.form-control:focus,.form-select:focus {
    border-color: var(--pink);
    box-shadow: 0 0 0 3px rgba(255,107,157,.18);
}
.form-label { color: var(--purple); font-weight: 700; margin-bottom: .4rem; }

/* Input group text */
.input-group-text {
    border-radius: var(--border-radius) 0 0 var(--border-radius);
    background: linear-gradient(135deg, var(--pink-pale), var(--purple-pale));
    border: 2px solid var(--gray-200);
    color: var(--purple);
}

/* ════════════════════ HERO ════════════════════ */
.hero-section {
    background: linear-gradient(135deg, #fff0f7 0%, #f3eeff 50%, #e8faff 100%);
    padding: 90px 0 80px;
    position: relative;
    overflow: hidden;
}
.hero-section::before {
    content:'';
    position:absolute;
    width:600px; height:600px;
    top:-150px; right:-150px;
    background: radial-gradient(circle, rgba(255,107,157,.18) 0%, transparent 70%);
    border-radius:50%;
    animation: floatBlob1 7s ease-in-out infinite;
}
.hero-section::after {
    content:'';
    position:absolute;
    width:400px; height:400px;
    bottom:-100px; left:-100px;
    background: radial-gradient(circle, rgba(0,201,167,.15) 0%, transparent 70%);
    border-radius:50%;
    animation: floatBlob2 9s ease-in-out infinite;
}

@keyframes floatBlob1 {
    0%,100% { transform:translate(0,0) scale(1); }
    50%      { transform:translate(30px,-30px) scale(1.08); }
}
@keyframes floatBlob2 {
    0%,100% { transform:translate(0,0) scale(1); }
    50%      { transform:translate(-20px,20px) scale(1.05); }
}

.hero-title {
    font-size: 3.2rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--pink), var(--purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1.2;
}
.hero-subtitle { font-size: 1.15rem; color: var(--gray-600); margin-bottom: 2rem; }

/* ════════════════════ SECTION TITLE ════════════════════ */
.section-title {
    position: relative;
    display: inline-block;
    margin-bottom: 2rem;
}
.section-title::after {
    content: '';
    position: absolute;
    bottom: -10px; left:50%;
    transform: translateX(-50%);
    width: 70px; height: 4px;
    background: linear-gradient(90deg, var(--pink), var(--purple), var(--teal));
    border-radius: 2px;
}

/* ════════════════════ CATEGORY CARDS ════════════════════ */
.category-card {
    text-align: center;
    padding: 1.8rem 1rem;
    border-radius: var(--border-radius-lg);
    background: #fff;
    transition: var(--transition);
    cursor: pointer;
    border: 2.5px solid transparent;
}
.category-card:nth-child(1) { border-color: rgba(255,107,157,.3); }
.category-card:nth-child(2) { border-color: rgba(72,202,228,.3); }
.category-card:nth-child(3) { border-color: rgba(249,200,70,.4); }
.category-card:nth-child(4) { border-color: rgba(155,93,229,.3); }

.category-card:hover {
    transform: translateY(-10px) rotate(2deg);
    box-shadow: var(--shadow-lg);
    border-color: var(--pink);
    background: linear-gradient(135deg, var(--pink-pale), var(--purple-pale));
}
.category-card img {
    width: 90px; height: 90px;
    object-fit: cover;
    border-radius: 50%;
    margin-bottom: .9rem;
    border: 3px solid var(--pink-light);
    transition: var(--transition);
}
.category-card:hover img { border-color: var(--purple); transform: scale(1.1) rotate(-2deg); }
.category-card h5 { color: var(--purple); margin-bottom: .3rem; font-size: 1rem; }

/* ════════════════════ SHADOW SOFT ════════════════════ */
.shadow-soft { box-shadow: var(--shadow-sm); }

/* ════════════════════ FOOTER ════════════════════ */
.footer {
    background: linear-gradient(160deg, #2D1B4E 0%, #4A1E6B 60%, #1a3a5c 100%);
    color: var(--pink-pale);
    padding: 64px 0 22px;
    position: relative;
    overflow: hidden;
}
.footer::before {
    content:'';
    position:absolute;
    top:0; left:0; right:0;
    height:5px;
    background: linear-gradient(90deg, var(--pink), var(--purple), var(--teal), var(--yellow));
}
.footer h5      { color: var(--pink-light); margin-bottom: 1.3rem; font-size: 1.05rem; }
.footer p,.footer li { color: rgba(255,210,230,.75); }
.footer a { color: rgba(255,210,230,.8); text-decoration:none; transition:var(--transition); }
.footer a:hover { color: var(--teal-light); padding-right:4px; }

.footer .social-links a {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: rgba(255,107,157,.2);
    margin-left: 8px;
    transition: var(--transition);
    font-size: 1.2rem;
}
.footer .social-links a:hover {
    background: linear-gradient(135deg, var(--pink), var(--purple));
    color: #fff; padding-right:0;
    transform: translateY(-4px) scale(1.1);
}

/* ════════════════════ CART ════════════════════ */
.cart-item {
    display:flex; align-items:center;
    padding:1rem; gap:1rem;
    border-bottom: 1px solid var(--gray-200);
    transition:var(--transition);
}
.cart-item:hover { background: var(--pink-pale); border-radius:var(--border-radius); }
.cart-item-title { font-weight:700; color:var(--purple); }
.cart-item-price { color:var(--pink); font-weight:800; }

.quantity-control { display:flex; align-items:center; gap:.5rem; }
.quantity-control button {
    width:34px; height:34px; border-radius:50%;
    border: 2px solid var(--pink-light);
    background:#fff; display:flex; align-items:center; justify-content:center;
    transition:var(--transition); cursor:pointer;
}
.quantity-control button:hover { background:var(--pink); color:#fff; border-color:var(--pink); }
.quantity-control input {
    width:52px; text-align:center;
    border: 2px solid var(--gray-200);
    border-radius:var(--border-radius); padding:.25rem;
}

/* ════════════════════ ORDER STATUS ════════════════════ */
.order-status         { display:inline-flex; align-items:center; gap:.5rem; padding:.45rem 1rem; border-radius:50px; font-weight:600; }
.order-status-pending    { background:#FFF3CD; color:#856404; }
.order-status-preparing  { background:#D1ECF1; color:#0C5460; }
.order-status-delivering { background: linear-gradient(135deg,var(--blue),var(--teal)); color:#fff; }
.order-status-completed  { background: linear-gradient(135deg,var(--teal),#00b894); color:#fff; }
.order-status-cancelled  { background:#F8D7DA; color:#721C24; }

/* ════════════════════ ADMIN ════════════════════ */
.admin-dashboard   { background:var(--gray-100); min-height:100vh; }
.admin-sidebar     { background:#fff; min-height:100vh; box-shadow:2px 0 16px rgba(0,0,0,.06); }
.admin-sidebar .nav-link   { padding:.8rem 1.5rem !important; border-radius:0; border-right:3px solid transparent; }
.admin-sidebar .nav-link:hover,
.admin-sidebar .nav-link.active { background:var(--pink-pale); border-right-color:var(--pink); color:var(--purple); }

.stat-card { padding:1.6rem; border-radius:var(--border-radius-lg); background:#fff; box-shadow:var(--shadow-sm); transition:var(--transition); }
.stat-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.stat-card .icon { width:52px; height:52px; border-radius:var(--border-radius); display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:.85rem; }
.stat-card .stat-value { font-size:1.8rem; font-weight:800; color:var(--purple); line-height:1.1; }
.stat-card .stat-label { color:var(--gray-600); font-size:.85rem; margin-top:.2rem; }

/* ════════════════════ ANIMATIONS ════════════════════ */
@keyframes fadeInUp {
    from { opacity:0; transform:translateY(28px); }
    to   { opacity:1; transform:translateY(0); }
}
.fade-in { animation: fadeInUp .55s ease both; }

@keyframes flipText {
    0% { transform: rotateX(90deg); opacity: 0; }
    100% { transform: rotateX(0deg); opacity: 1; }
}
.flip-animate {
    display: inline-block;
    animation: flipText 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

@keyframes floatSlow {
    0%,100% { transform:translateY(0); }
    50%      { transform:translateY(-12px); }
}
.float-slow { animation: floatSlow 4s ease-in-out infinite; }


/* ════════════════════ SCROLLBAR ════════════════════ */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--pink-pale); }
::-webkit-scrollbar-thumb { background: linear-gradient(var(--pink), var(--purple)); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background: var(--purple); }

/* ════════════════════ TOAST ════════════════════ */
.toast-container { position:fixed; top:20px; left:50%; transform:translateX(-50%); z-index:9999; }

/* ════════════════════ PWA INSTALL CARD ════════════════════ */
.pwa-install-card {
    position: fixed;
    bottom: 24px; left: 50%;
    transform: translateX(-50%);
    z-index: 9990;
    width: min(420px, calc(100vw - 32px));
    background: linear-gradient(135deg,#fff0f7,#f3eeff);
    border-radius: 20px;
    box-shadow: 0 8px 40px rgba(155,93,229,.25);
    border: 2px solid rgba(255,107,157,.3);
    animation: slideUpCard .4s cubic-bezier(.4,0,.2,1) both;
}
@keyframes slideUpCard {
    from { opacity:0; transform:translateX(-50%) translateY(30px); }
    to   { opacity:1; transform:translateX(-50%) translateY(0);    }
}
.pwa-install-inner  { display:flex; align-items:center; gap:12px; padding:14px 16px; flex-wrap:wrap; }
.pwa-install-logo   { width:48px; height:48px; border-radius:12px; object-fit:contain; flex-shrink:0; }
.pwa-install-text   { flex:1; display:flex; flex-direction:column; }
.pwa-install-text strong { font-size:.95rem; color:var(--purple); }
.pwa-install-text small  { font-size:.8rem; color:var(--gray-600); }
.pwa-install-actions { display:flex; gap:8px; align-items:center; }

/* ════════════════════ RESPONSIVE ════════════════════ */
@media (max-width: 991.98px) {
    /* Admin dashboard mobile */
    .stat-card { padding: .85rem; }
    .stat-card .stat-value { font-size: 1.4rem; }
    .stat-card .stat-label { font-size: .75rem; }
    .stat-card .icon { width: 40px; height: 40px; font-size: 1.2rem; margin-bottom: .5rem; }
    .admin-sidebar { min-height: auto; }
    /* Cards hover disabled on mobile for performance */
    .card:hover { transform: none; }
}
@media (max-width: 768px) {
    .hero-title { font-size: 2.1rem; }
    .hero-section { padding: 50px 0 40px; }
    .card-product .card-img-wrapper { height: 175px; }
    .stat-card .stat-value { font-size: 1.3rem; }
    .stat-card .icon { width: 36px; height: 36px; font-size: 1rem; }
}
@media (max-width: 576px) {
    .hero-title { font-size: 1.7rem; }
    .card-product .card-img-wrapper { height: 150px; }
    .card-product .card-body { padding: .75rem; }
    .card-product .card-title { font-size: .9rem; }
    .btn { font-size: .9rem; padding: .45rem 1.2rem; }
    .navbar-brand span { display: none !important; }
    .footer .row > div { text-align: center; }
    .footer .social-links { justify-content:center; display:flex; }
    .stat-card { padding: .7rem; }
    .stat-card .stat-value { font-size: 1.15rem; }
    .stat-card .stat-label { font-size: .7rem; }
    .stat-card .icon { width: 32px; height: 32px; font-size: .9rem; margin-bottom: .35rem; }
}

/* ════════════════════ PRINT ════════════════════ */
@media print {
    .navbar,.footer,.btn { display:none !important; }
    .card { box-shadow:none; border:1px solid var(--gray-200); }
}

/* ════════════════════════════════════════════════════════
   🎲 KOKY SWEET — 3D EFFECTS SYSTEM
   ════════════════════════════════════════════════════════ */

/* ── Global 3D perspective layer ── */
.hero-section,
.category-card,
.card-product,
.stat-card,
.feature-icon-3d,
.glass-card,
.card-3d {
    transform-style: preserve-3d;
}

/* ════════════════════ GLASSMORPHISM 3D ════════════════════ */
.glass-card, .stat-card {
    background: rgba(255, 255, 255, 0.65) !important;
    backdrop-filter: blur(16px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(16px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.8) !important;
    box-shadow: 0 16px 40px rgba(155, 93, 229, 0.15), 
                inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
    border-radius: var(--border-radius-lg);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    transform-style: preserve-3d;
    position: relative;
    overflow: visible !important;
}
.glass-card:hover, .stat-card:hover {
    box-shadow: 0 25px 50px rgba(155, 93, 229, 0.25), 
                inset 0 1px 0 rgba(255, 255, 255, 1) !important;
    transform: translateY(-8px) scale(1.02);
}

.pop-3d {
    transform: translateZ(30px) !important;
    text-shadow: 0 4px 10px rgba(0,0,0,0.1);
    transition: transform 0.3s;
}
.glass-card:hover .pop-3d, .stat-card:hover .pop-3d, .stat-card:hover .stat-value, .stat-card:hover .icon {
    transform: translateZ(50px) scale(1.05) !important;
}

/* Form selects & inputs 3D */
.form-3d {
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 107, 157, 0.3) !important;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.02),
                0 4px 10px rgba(155, 93, 229, 0.05) !important;
    transform: translateZ(10px);
    transition: all 0.3s ease;
}
.form-3d:focus {
    transform: translateZ(15px) scale(1.02);
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.02),
                0 10px 20px rgba(255, 107, 157, 0.15) !important;
    border-color: var(--pink) !important;
}

/* Floating animated background mesh */
.mesh-bg {
    position: relative;
}
.mesh-bg::before {
    content: '';
    position: absolute;
    top: -50px; left: -50px;
    width: 250px; height: 250px;
    background: radial-gradient(circle, rgba(255,107,157,0.15) 0%, transparent 70%);
    border-radius: 50%;
    animation: floatBlob1 8s ease-in-out infinite;
    z-index: -1;
    pointer-events: none;
}
.mesh-bg::after {
    content: '';
    position: absolute;
    bottom: -50px; right: -50px;
    width: 250px; height: 250px;
    background: radial-gradient(circle, rgba(155,93,229,0.15) 0%, transparent 70%);
    border-radius: 50%;
    animation: floatBlob2 10s ease-in-out infinite reverse;
    z-index: -1;
    pointer-events: none;
}

/* ════════════════════ HERO 3D ════════════════════ */
#hero-canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;
    opacity: 0.7;
}
.hero-section {
    position: relative;
    overflow: hidden;
}
.hero-section .container {
    position: relative;
    z-index: 1;
}

/* Hero image 3D float */
.hero-img-3d {
    animation: heroFloat3D 6s ease-in-out infinite;
    filter: drop-shadow(0 30px 40px rgba(255,107,157,0.35));
    transform-origin: center bottom;
}
@keyframes heroFloat3D {
    0%   { transform: translateY(0)   rotateY(-5deg) rotateX(3deg) scale(1); }
    33%  { transform: translateY(-18px) rotateY(5deg)  rotateX(-2deg) scale(1.03); }
    66%  { transform: translateY(-10px) rotateY(-3deg) rotateX(5deg) scale(1.01); }
    100% { transform: translateY(0)   rotateY(-5deg) rotateX(3deg) scale(1); }
}

/* Hero text depth */
.hero-title {
    text-shadow: 0 2px 0 rgba(155,93,229,.15),
                 0 4px 0 rgba(155,93,229,.10),
                 0 8px 20px rgba(155,93,229,.20);
    transform: translateZ(20px);
}

/* ════════════════════ BUTTONS 3D ════════════════════ */
.btn-chocolate,
.btn-outline-chocolate {
    position: relative;
    transform: translateZ(0) translateY(0);
    transition: transform .18s cubic-bezier(.4,0,.2,1),
                box-shadow .18s ease;
}
.btn-chocolate::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    box-shadow: 0 6px 0 rgba(139,0,70,.35);
    transition: all .18s ease;
}
.btn-chocolate:hover {
    transform: translateY(-4px) translateZ(8px);
}
.btn-chocolate:hover::after {
    box-shadow: 0 10px 0 rgba(139,0,70,.2);
}
.btn-chocolate:active {
    transform: translateY(2px) translateZ(0);
}
.btn-chocolate:active::after {
    box-shadow: 0 2px 0 rgba(139,0,70,.4);
}

/* ════════════════════ PRODUCT CARD 3D ════════════════════ */
.card-product {
    transition: transform .35s cubic-bezier(.4,0,.2,1),
                box-shadow .35s ease;
    transform-style: preserve-3d;
    will-change: transform;
}

/* VanillaTilt glare overlay */
.card-product .js-tilt-glare {
    border-radius: var(--border-radius-lg) !important;
}

/* Image 3D zoom */
.card-product .card-img-wrapper {
    transform-style: preserve-3d;
    overflow: hidden;
}
.card-product .card-img-top {
    transition: transform .5s ease;
    will-change: transform;
}
.card-product:hover .card-img-top {
    transform: scale(1.08) translateZ(10px);
}

/* Badge 3D pop */
.card-product .badge-wrapper .badge {
    transform: translateZ(15px);
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
}

/* ════════════════════ CATEGORY CARD 3D ════════════════════ */
.category-card {
    transition: transform .35s cubic-bezier(.4,0,.2,1),
                box-shadow .35s ease,
                background .35s ease;
    cursor: pointer;
    position: relative;
}
.category-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--border-radius-lg);
    background: linear-gradient(135deg, rgba(255,107,157,.0), rgba(155,93,229,.0));
    transition: background .35s ease;
    z-index: 0;
    pointer-events: none;
}
.category-card:hover {
    transform: translateY(-14px) rotateX(8deg) rotateY(-4deg) scale(1.04);
    box-shadow: 0 30px 60px rgba(255,107,157,.25),
                0 0 0 1px rgba(255,107,157,.15);
}
.category-card:hover::before {
    background: linear-gradient(135deg, rgba(255,107,157,.08), rgba(155,93,229,.08));
}
.category-card:hover .icon {
    transform: translateZ(20px) scale(1.15) rotate(-5deg);
    transition: transform .35s ease;
}
.category-card .icon {
    transition: transform .35s ease;
    display: inline-block;
}

/* ════════════════════ FEATURE SECTION 3D ════════════════════ */
.feature-icon-3d {
    transition: transform .4s ease, color .4s ease;
    display: inline-block;
    transform-origin: center;
    filter: drop-shadow(0 8px 16px rgba(255,107,157,.3));
}
.feature-box:hover .feature-icon-3d {
    transform: rotateY(360deg) translateZ(15px);
    color: var(--purple) !important;
}
.feature-box {
    transition: transform .35s ease, box-shadow .35s ease;
    border-radius: var(--border-radius-lg);
    padding: 1.5rem;
    background: rgba(255,255,255,0.6);
    backdrop-filter: blur(10px);
}
.feature-box:hover {
    transform: translateY(-8px) rotateX(5deg);
    box-shadow: 0 20px 40px rgba(155,93,229,.15);
    background: #fff;
}

/* ════════════════════ NAVBAR 3D GLASS ════════════════════ */
.navbar {
    background: rgba(255,255,255,0.85) !important;
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    box-shadow: 0 4px 30px rgba(155,93,229,.12),
                0 1px 0 rgba(255,255,255,.8) inset;
    border-bottom: 1px solid rgba(255,255,255,.6);
}
.navbar-brand {
    text-shadow: 0 2px 8px rgba(155,93,229,.2);
    transition: transform .3s ease;
}
.navbar-brand:hover {
    transform: scale(1.05) translateZ(5px);
}

/* ════════════════════ STAT CARD 3D (Admin) ════════════════════ */
.stat-card {
    transform-style: preserve-3d;
    will-change: transform;
}
.stat-card .js-tilt-glare {
    border-radius: var(--border-radius-lg) !important;
}
.stat-card .stat-value {
    text-shadow: 0 2px 8px rgba(155,93,229,.2);
    transition: transform .3s;
}
.stat-card .icon {
    transition: transform .3s ease;
}

/* ════════════════════ CTA CARD 3D ════════════════════ */
.cta-card-3d {
    transform-style: preserve-3d;
    transition: transform .5s ease, box-shadow .5s ease;
    position: relative;
    overflow: hidden;
}
.cta-card-3d::after {
    content: '';
    position: absolute;
    top: -50%;
    right: -50%;
    width: 200%;
    height: 200%;
    background: conic-gradient(from 0deg, transparent, rgba(255,107,157,.08), transparent 120deg);
    animation: ctaSpin 8s linear infinite;
    pointer-events: none;
}
@keyframes ctaSpin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}
.cta-card-3d:hover {
    transform: perspective(1000px) rotateX(2deg) rotateY(-2deg) scale(1.02);
    box-shadow: 0 30px 60px rgba(255,107,157,.2);
}

/* ════════════════════ FOOTER 3D DEPTH ════════════════════ */
.footer {
    position: relative;
    overflow: hidden;
}
.footer::after {
    content: '';
    position: absolute;
    bottom: -80px;
    right: -80px;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(255,107,157,.08) 0%, transparent 70%);
    border-radius: 50%;
    animation: floatBlob1 10s ease-in-out infinite;
    pointer-events: none;
}

/* ════════════════════ SECTION HEADING 3D ════════════════════ */
.section-title-3d {
    position: relative;
    display: inline-block;
}
.section-title-3d span {
    position: relative;
    z-index: 1;
}
.section-title-3d::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--pink), var(--purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: blur(8px);
    opacity: 0.35;
    transform: translateY(4px) translateZ(-10px);
    z-index: 0;
}

/* ════════════════════ CARD GENERAL 3D ════════════════════ */
.card {
    transition: transform .35s cubic-bezier(.4,0,.2,1),
                box-shadow .35s ease !important;
}
.card:hover {
    transform: translateY(-6px) rotateX(1deg);
    box-shadow: 0 20px 50px rgba(155,93,229,.18) !important;
}

/* ════════════════════ FLOATING SPARKLES ════════════════════ */
.sparkle {
    position: absolute;
    pointer-events: none;
    border-radius: 50%;
    animation: sparkleAnim linear infinite;
}
@keyframes sparkleAnim {
    0%   { opacity: 0; transform: scale(0) translateY(0); }
    20%  { opacity: 1; }
    80%  { opacity: 1; }
    100% { opacity: 0; transform: scale(1.5) translateY(-60px); }
}

/* ════════════════════ 3D SCROLL REVEAL ════════════════════ */
.reveal-3d {
    opacity: 0;
    transform: perspective(800px) rotateX(25deg) translateY(50px);
    transition: opacity .7s ease, transform .7s cubic-bezier(.4,0,.2,1);
}
.reveal-3d.visible {
    opacity: 1;
    transform: perspective(800px) rotateX(0deg) translateY(0);
}

/* ════════════════════ DISABLE ON MOBILE ════════════════════ */
@media (pointer: coarse), (max-width: 767px) {
    /* Disable heavy 3D on touch/mobile */
    .category-card:hover,
    .card:hover,
    .card-product:hover,
    .feature-box:hover,
    .cta-card-3d:hover {
        transform: translateY(-4px) !important;
    }
    .hero-img-3d {
        animation: floatSlow 4s ease-in-out infinite;
    }
    .btn-chocolate:hover {
        transform: translateY(-2px) !important;
    }
}