/* ===== PawStore - Complete Fixed Stylesheet ===== */

/* ====== ANIMATIONS ====== */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bounceIn{0%{transform:scale(0.8);opacity:0}60%{transform:scale(1.05)}100%{transform:scale(1);opacity:1}}

/* ====== CSS VARIABLES ====== */
:root{
  --primary:#69b3d4;
  --primary-light:#2E7D32;
  --primary-ultra:#E8F5E9;
  --primary-dark:#145214;
  --secondary:#FF8F00;
  --secondary-light:#FFF3E0;
  --secondary-dark:#E65100;
  --dark:#1A1A2E;
  --gray:#6B7280;
  --light:#F8FAFC;
  --border:#E5E7EB;
  --white:#fff;
  --radius:12px;
  --radius-lg:20px;
  --shadow:0 4px 24px rgba(0,0,0,.08);
  --shadow-lg:0 12px 48px rgba(0,0,0,.14);
  --shadow-xl:0 24px 64px rgba(0,0,0,.18);
  --transition:.25s ease;
}

/* ====== RESET & BASE ====== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--dark);background:#fff;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* ====== BUTTONS ====== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .25s ease;font-family:inherit;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0);transition:.25s}
.btn:hover::after{background:rgba(255,255,255,.12)}
.btn-primary{background:#52a8ef;color:#fff;box-shadow:0 4px 16px rgba(46,125,50,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(46,125,50,.45)}
.btn-secondary{background:linear-gradient(135deg,var(--secondary),var(--secondary-dark));color:#fff;box-shadow:0 4px 16px rgba(255,143,0,.3)}
.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,143,0,.45)}
.btn-outline{background:transparent;border:2px solid #aedaff;color:#aedaff}
.btn-outline:hover{background:#aedaff;color:#fff;transform:translateY(-2px)}
.btn-sm{padding:8px 18px;font-size:13.5px}
.btn-block{width:100%;justify-content:center}

/* ====== TOPBAR ====== */
.topbar{background:#aedaff;padding:8px 0;font-size:13px}
.topbar .container{display:flex;align-items:center;justify-content:space-between}
.topbar-left span{margin-right:20px;display:inline-flex;align-items:center;gap:6px}
.topbar-right a{color:rgba(255,255,255,.8);margin-left:14px;display:inline-flex;align-items:center;gap:5px;transition:var(--transition)}
.topbar-right a:hover{color:#fff}

/* ====== HEADER ====== */
.main-header{background:#fff;padding:14px 0;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:500;box-shadow:0 2px 16px rgba(0,0,0,.07);transition:box-shadow .3s}
.main-header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.14)}
.header-inner{display:flex;align-items:center;gap:20px}
.logo{display:flex;align-items:center;gap:12px;font-weight:700;transition:var(--transition)}
.logo:hover{opacity:.85}
.logo-icon{font-size:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}
.logo-icon img{width:70px;height:auto;object-fit:contain;display:block;border-radius:50%}
.logo strong{font-size:1.35rem;color:#aedaff;line-height:1.2;display:block}
.logo small{font-size:11px;color:var(--gray);display:block;font-weight:400;line-height:1}
.header-search{flex:1;max-width:500px;position:relative}
.header-search input{width:100%;padding:11px 50px 11px 20px;border:2px solid var(--border);border-radius:50px;font-size:14px;font-family:inherit;outline:none;transition:var(--transition);background:var(--light)}
.header-search input:focus{border-color:var(--primary-light);background:#fff;box-shadow:0 0 0 4px rgba(46,125,50,.1)}
.header-search button{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;background:#aedaff;color:#fff;border:none;cursor:pointer;font-size:14px;transition:var(--transition)}
.header-search button:hover{transform:translateY(-50%) scale(1.08)}
.header-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.icon-btn{width:44px;height:44px;border-radius:12px;background:var(--light);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--dark);cursor:pointer;position:relative;transition:var(--transition)}
.icon-btn:hover{background:var(--primary-ultra);border-color:var(--primary-light);color:#aedaff;transform:translateY(-1px)}
.icon-btn .badge{position:absolute;top:-5px;right:-5px;background:var(--secondary);color:#fff;border-radius:50%;width:20px;height:20px;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid #fff;animation:bounceIn .3s ease}

/* ====== NAV - DESKTOP ====== */
/* z-index stacking: header=500, nav=600, dropdown=700, nav-overlay=800, mobile-nav=900, cart=1000 */
.main-nav{background:#aedaff;padding:0;position:relative;z-index:600}
.main-nav .container{display:flex;align-items:center}
.nav-list{display:flex;flex-wrap:wrap;list-style:none;gap:0;background:#aedaff}
.nav-list li{position:relative}
.nav-list>li>a{display:block;padding:14px 18px;color:#000;font-size:14px;font-weight:500;transition:var(--transition);position:relative}
.nav-list>li>a::after{content:'';position:absolute;bottom:0;left:18px;right:18px;height:2px;background:#fff;border-radius:2px;transform:scaleX(0);transition:.25s}
.nav-list>li>a:hover::after,.nav-list>li>a.active::after{transform:scaleX(1)}
.nav-list>li>a:hover,.nav-list>li>a.active{color:#fff}
.nav-close{display:none}
.menu-toggle{display:none;background:#2E7D32;border:none;color:#fff;font-size:18px;cursor:pointer;padding:10px 13px;border-radius:8px;transition:var(--transition);box-shadow:0 2px 8px rgba(0,0,0,.15);margin-left:auto}
.menu-toggle:hover{background:#1b5e20}

/* ====== DROPDOWN - DESKTOP ====== */
.nav-list li .dropdown{
  display:none;
  position:absolute;
  top:100%;
  left:0;
  background:#fff;
  min-width:230px;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-xl);
  padding:10px 0px 10px 30px;
  z-index:700;
  border:1px solid var(--border);
  animation:fadeUp .2s ease;
}
.nav-list li:hover>.dropdown{display:block}
.dropdown li{position:relative}
.dropdown li a{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:13.5px;color:var(--dark);transition:var(--transition);border-radius:10px}
.dropdown li a:hover{background:var(--primary-ultra);color:#aedaff;padding-left:20px}
/* 2nd level submenu */
.dropdown li .dropdown{display:none;position:absolute;top:0;left:100%;min-width:220px}
.dropdown li:hover>.dropdown{display:block}

/* ====== NAV OVERLAY (mobile backdrop) ====== */
.nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:800;opacity:0;pointer-events:none;transition:.3s;backdrop-filter:blur(3px)}
.nav-overlay.open{opacity:1;pointer-events:all}

/* ====== HERO SLIDER ====== */
.hero-slider{position:relative;overflow:hidden;min-height:520px;background:linear-gradient(135deg,var(--primary-dark) 0%,#aedaff 50%,#388E3C 100%)}
.hero-slider::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.hero-slide{display:none;min-height:520px;align-items:center;padding:70px 0;position:relative}
.hero-slide.active{display:flex;animation:fadeUp .5s ease}
.hero-content{max-width:600px;color:#fff}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,143,0,.9);color:#fff;padding:7px 18px;border-radius:50px;font-size:13px;font-weight:700;margin-bottom:20px;letter-spacing:.5px;box-shadow:0 4px 12px rgba(255,143,0,.4)}
.hero-content h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;line-height:1.15;margin-bottom:18px;font-family:'Playfair Display',serif;text-shadow:0 2px 8px rgba(0,0,0,.2)}
.hero-content p{font-size:1.1rem;opacity:.92;margin-bottom:32px;line-height:1.75}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-slider-nav{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.slider-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;border:none;transition:all .3s}
.slider-dot.active{background:#fff;width:30px;border-radius:10px}
.slider-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 24px;z-index:10;pointer-events:none}
.slider-arrow{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;border:2px solid rgba(255,255,255,.3);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition);pointer-events:all;backdrop-filter:blur(4px)}
.slider-arrow:hover{background:rgba(255,255,255,.35);transform:scale(1.08)}

/* ====== STATS BAR ====== */
.stats-bar{background:#aedaff;color:#fff;padding:36px 0;position:relative;overflow:hidden}
.stats-bar::after{content:'';position:absolute;right:-100px;top:-60px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.04)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center;position:relative}
.stat-item{padding:8px;transition:var(--transition)}
.stat-item:hover{transform:translateY(-3px)}
.stat-item i{font-size:28px;margin-bottom:10px;color:var(--secondary)}
.stat-item .stat-num{font-size:2.1rem;font-weight:800;font-family:'Playfair Display',serif;color:#fff;line-height:1}
.stat-item .stat-label{font-size:13px;opacity:.8;margin-top:6px;font-weight:500}

/* ====== SECTIONS ====== */
.section{padding:75px 0}
.section-alt{background:var(--light)}
.section-header{text-align:center;margin-bottom:52px}
.section-label{display:inline-block;background:var(--primary-ultra);color:#aedaff;font-size:12.5px;font-weight:700;padding:6px 18px;border-radius:50px;letter-spacing:.8px;margin-bottom:14px;text-transform:uppercase}
.section-title{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:800;font-family:'Playfair Display',serif;color:var(--dark);margin-bottom:12px}
.section-subtitle{color:var(--gray);font-size:1rem;max-width:560px;margin:0 auto}

/* ====== CATEGORIES ====== */
.categories-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.cat-card{background:#fff;border-radius:var(--radius-lg);padding:28px 16px;text-align:center;border:2px solid var(--border);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;display:block}
.cat-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-ultra),var(--secondary-light));opacity:0;transition:.3s}
.cat-card:hover{border-color:var(--primary-light);transform:translateY(-6px);box-shadow:0 12px 36px rgba(46,125,50,.18)}
.cat-card:hover::before{opacity:1}
.cat-card img,.cat-card .cat-emoji{width:64px;height:64px;object-fit:cover;border-radius:50%;margin:0 auto 14px;position:relative;font-size:34px;display:flex;align-items:center;justify-content:center;background:var(--primary-ultra);transition:.3s}
.cat-card:hover img,.cat-card:hover .cat-emoji{transform:scale(1.12) rotate(-5deg)}
.cat-card h4{font-size:13.5px;font-weight:700;color:var(--dark);position:relative;line-height:1.3}
.cat-card .count{font-size:11.5px;color:var(--gray);margin-top:5px;position:relative}

/* ====== PRODUCTS ====== */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.product-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;transition:all .3s ease;position:relative}
.product-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.14);transform:translateY(-5px)}
.product-img{position:relative;height:230px;overflow:hidden;background:linear-gradient(135deg,#f9f9f9,var(--light));display:block}
.product-img img{width:100%;height:100%;object-fit:cover;transition:.45s ease}
.product-card:hover .product-img img{transform:scale(1.08)}
.product-img .no-img{height:100%;display:flex;align-items:center;justify-content:center;font-size:72px;opacity:.6}
.product-badge{position:absolute;top:12px;left:12px;background:linear-gradient(135deg,var(--secondary),var(--secondary-dark));color:#fff;font-size:11px;font-weight:800;padding:5px 12px;border-radius:50px;z-index:2;box-shadow:0 2px 8px rgba(255,143,0,.4)}
.product-badge.new{background:#aedaff}
.product-actions{position:absolute;right:12px;top:12px;display:flex;flex-direction:column;gap:7px;opacity:0;transform:translateX(12px);transition:.3s;z-index:2}
.product-card:hover .product-actions{opacity:1;transform:translateX(0)}
.product-action-btn{width:36px;height:36px;border-radius:10px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--dark);transition:var(--transition);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.product-action-btn:hover{background:#aedaff;color:#fff;border-color:#aedaff;transform:scale(1.08)}
.product-info{padding:18px}
.product-brand{font-size:11px;color:#aedaff;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.product-name{font-size:14.5px;font-weight:700;color:var(--dark);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45}
.price-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.sale-price{font-size:1.2rem;font-weight:800;color:#aedaff}
.original-price{font-size:13px;color:var(--gray);text-decoration:line-through}
.discount-pct{font-size:11px;font-weight:800;color:var(--secondary-dark);background:var(--secondary-light);padding:3px 8px;border-radius:6px}
.product-info .btn{width:100%;justify-content:center;padding:11px;font-size:13.5px}

/* ====== PRODUCTS PAGE - LAYOUT WITH SIDEBAR ====== */
.products-layout{display:grid;grid-template-columns:240px 1fr;gap:28px;align-items:start}
.products-sidebar{position:sticky;top:90px}

/* ====== WHY CHOOSE US ====== */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.feature-card{background:#fff;border-radius:var(--radius-lg);padding:32px;border:1px solid var(--border);text-align:center;transition:all .3s ease;position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#aedaff,var(--secondary));transform:scaleX(0);transition:.3s;transform-origin:left}
.feature-card:hover::before{transform:scaleX(1)}
.feature-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.feature-icon{width:68px;height:68px;background:var(--primary-ultra);border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#aedaff;margin:0 auto 18px;transition:var(--transition)}
.feature-card:hover .feature-icon{background:linear-gradient(135deg,#aedaff,var(--primary-light));color:#fff;transform:scale(1.1) rotate(-5deg)}
.feature-card h3{font-size:1.05rem;font-weight:700;color:var(--dark);margin-bottom:8px}
.feature-card p{font-size:13.5px;color:var(--gray);line-height:1.75}

/* ====== TESTIMONIALS ====== */
.testimonials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.testimonial-card{background:#fff;border-radius:var(--radius-lg);padding:26px;border:1px solid var(--border);transition:all .3s ease;position:relative}
.testimonial-card::before{content:'"';position:absolute;top:16px;right:20px;font-size:80px;font-family:'Playfair Display',serif;color:var(--primary-ultra);line-height:1;pointer-events:none}
.testimonial-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary-light);transform:translateY(-3px)}
.stars{color:var(--secondary);font-size:15px;margin-bottom:14px;letter-spacing:1px}
.testimonial-text{font-size:14px;color:var(--gray);line-height:1.8;margin-bottom:18px;font-style:italic;position:relative}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#aedaff,var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0;box-shadow:0 4px 12px rgba(46,125,50,.3)}
.author-name{font-weight:700;font-size:14px;color:var(--dark)}
.author-role{font-size:12px;color:var(--gray)}

/* ====== CTA BANNER ====== */
.cta-banner{padding:80px 0;color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='40' fill='none' stroke='%23ffffff' stroke-width='0.5' opacity='0.15'/%3E%3C/svg%3E");opacity:.5}
.cta-banner h2{font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:800;font-family:'Playfair Display',serif;margin-bottom:16px;position:relative}
.cta-banner p{font-size:1.05rem;opacity:.92;margin-bottom:34px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.75;position:relative}
.cta-banner .btn{padding:15px 40px;font-size:16px;position:relative}

/* ====== NEWSLETTER ====== */
.newsletter{background:linear-gradient(135deg,var(--dark),#69b3d4);padding:75px 0;text-align:center;color:#fff;position:relative;overflow:hidden}
.newsletter::before{content:'';position:absolute;top:-100px;left:-100px;width:400px;height:400px;border-radius:50%;background:rgba(255,143,0,.06)}
.newsletter::after{content:'';position:absolute;bottom:-80px;right:-80px;width:300px;height:300px;border-radius:50%;background:rgba(46,125,50,.08)}
.newsletter h2{font-size:1.9rem;font-weight:800;margin-bottom:12px;position:relative}
.newsletter p{opacity:.8;margin-bottom:30px;position:relative;max-width:500px;margin-left:auto;margin-right:auto}
.newsletter-form{display:flex;gap:10px;max-width:500px;margin:0 auto;position:relative}
.newsletter-form input{flex:1;padding:15px 22px;border-radius:50px;border:2px solid rgba(255,255,255,.15);font-size:15px;font-family:inherit;outline:none;background:rgba(255,255,255,.1);color:#fff;transition:var(--transition)}
.newsletter-form input::placeholder{color:rgba(255,255,255,.5)}
.newsletter-form input:focus{border-color:var(--secondary);background:rgba(255,255,255,.15)}
.newsletter-form .btn{flex-shrink:0;border-radius:50px;padding:15px 28px;background:linear-gradient(135deg,var(--secondary),var(--secondary-dark))}

/* ====== CART SIDEBAR ====== */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;opacity:0;pointer-events:none;transition:.3s;backdrop-filter:blur(3px)}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-sidebar{position:fixed;right:-440px;top:0;height:100%;width:420px;background:#fff;z-index:1001;transition:.35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}
.cart-sidebar.open{right:0}
.cart-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--primary-ultra),#fff)}
.cart-header h3{font-size:1.1rem;font-weight:800;color:var(--dark)}
.cart-close{background:var(--light);border:1px solid var(--border);width:36px;height:36px;border-radius:10px;font-size:18px;cursor:pointer;color:var(--gray);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.cart-close:hover{background:#aedaff;color:#fff;border-color:#aedaff}
.cart-items{flex:1;overflow-y:auto;padding:16px 20px;-webkit-overflow-scrolling:touch}
.cart-items::-webkit-scrollbar{width:4px}
.cart-items::-webkit-scrollbar-track{background:var(--light)}
.cart-items::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.cart-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border);transition:.25s}
.cart-item:hover{background:var(--light);margin:0 -8px;padding:16px 8px;border-radius:var(--radius)}
.cart-item-img{width:72px;height:72px;border-radius:12px;object-fit:cover;background:var(--light);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:30px;overflow:hidden;border:1px solid var(--border)}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:14px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-variation{font-size:11.5px;color:var(--gray);margin-bottom:4px}
.cart-item-price{font-size:14px;color:#aedaff;font-weight:800}
.cart-qty{display:flex;align-items:center;gap:10px;margin-top:8px}
.qty-btn{width:28px;height:28px;border-radius:8px;background:var(--light);border:1px solid var(--border);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-weight:700}
.qty-btn:hover{background:#aedaff;color:#fff;border-color:#aedaff}
.qty-num{font-weight:700;min-width:24px;text-align:center}
.cart-item-remove{background:none;border:none;cursor:pointer;color:#ccc;font-size:15px;padding:4px;transition:var(--transition);border-radius:6px;line-height:1}
.cart-item-remove:hover{color:#e53935;background:#fff0f0}
.cart-footer{padding:20px 24px;border-top:1px solid var(--border);background:var(--light)}
.cart-total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:800;margin-bottom:16px;padding:14px 16px;background:#fff;border-radius:var(--radius);border:1px solid var(--border)}
.cart-empty-msg{text-align:center;padding:50px 20px;color:var(--gray)}
.cart-empty-msg .empty-icon{font-size:64px;margin-bottom:16px;opacity:.6}

/* ====== ALERTS ====== */
.alert{padding:14px 18px;border-radius:var(--radius);margin-bottom:18px;font-size:14px;display:flex;align-items:center;gap:10px;animation:fadeUp .3s ease}
.alert-success{background:#E8F5E9;color:#69b3d4;border-left:4px solid #aedaff}
.alert-error{background:#FFEBEE;color:#c62828;border-left:4px solid #e53935}
.alert-info{background:#E3F2FD;color:#0d47a1;border-left:4px solid #1565c0}

/* ====== BREADCRUMB ====== */
.breadcrumb{background:var(--light);padding:14px 0;border-bottom:1px solid var(--border)}
.breadcrumb-inner{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--gray)}
.breadcrumb-inner a{color:#aedaff;font-weight:500;transition:var(--transition)}
.breadcrumb-inner a:hover{color:var(--primary-dark)}
.breadcrumb-inner span:last-child{color:var(--dark);font-weight:600}
.breadcrumb-inner i{font-size:10px;color:var(--border)}

/* ====== FORMS ====== */
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:13.5px;font-weight:600;color:var(--dark);margin-bottom:7px}
.form-control{width:100%;padding:13px 18px;border:2px solid var(--border);border-radius:var(--radius);font-size:14.5px;font-family:inherit;outline:none;transition:var(--transition);background:#fff}
.form-control:focus{border-color:var(--primary-light);box-shadow:0 0 0 4px rgba(46,125,50,.1);background:#fff}
textarea.form-control{resize:vertical;min-height:130px}
.form-control::placeholder{color:#adb5bd}

/* ====== PAGE HERO ====== */
.page-hero{background:linear-gradient(135deg,var(--primary-dark),var(--primary-light));color:#fff;padding:75px 0;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.page-hero h1{font-size:2.5rem;font-weight:800;font-family:'Playfair Display',serif;margin-bottom:14px;position:relative}
.page-hero p{font-size:1.05rem;opacity:.88;max-width:560px;margin:0 auto;position:relative;line-height:1.7}
.page-content{padding:65px 0}
.page-content h2{font-size:1.65rem;font-weight:800;color:var(--dark);margin:32px 0 14px;font-family:'Playfair Display',serif}
.page-content h3{font-size:1.2rem;font-weight:700;color:var(--dark);margin:22px 0 10px}
.page-content p{color:var(--gray);margin-bottom:14px;line-height:1.85}
.page-content ul{margin:10px 0 14px 24px;color:var(--gray);line-height:2.1}
.page-content .info-box{background:var(--primary-ultra);border-left:4px solid #aedaff;padding:18px 22px;border-radius:0 var(--radius) var(--radius) 0;margin:20px 0}

/* ====== CONTACT PAGE ====== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-info-card{background:#aedaff;color:#fff;border-radius:var(--radius-lg);padding:36px}
.contact-info-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:26px}
.contact-info-icon{width:46px;height:46px;background:rgba(255,255,255,.15);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}

/* ====== ABOUT PAGE ====== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.team-card{text-align:center;background:#fff;border-radius:var(--radius-lg);padding:30px;border:1px solid var(--border);transition:var(--transition)}
.team-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.team-avatar{width:82px;height:82px;border-radius:50%;background:linear-gradient(135deg,#aedaff,var(--secondary));color:#fff;font-size:30px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 6px 20px rgba(46,125,50,.3)}
.team-name{font-weight:700;font-size:1.05rem;margin-bottom:5px}
.team-role{font-size:13px;color:#aedaff;font-weight:700;margin-bottom:9px}
.team-bio{font-size:13px;color:var(--gray);line-height:1.7}

/* ====== FOOTER ====== */
.site-footer{background:var(--dark);color:rgba(255,255,255,.72);padding:65px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.footer-col h4{font-size:15px;font-weight:700;color:#fff;margin-bottom:20px;position:relative;padding-bottom:12px}
.footer-col h4::after{content:'';position:absolute;bottom:0;left:0;width:32px;height:2px;background:var(--secondary);border-radius:2px}
.footer-col p{font-size:13.5px;line-height:1.85;margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:13.5px;color:rgba(255,255,255,.62);transition:var(--transition);display:inline-flex;align-items:center;gap:6px}
.footer-col ul li a:hover{color:#fff;padding-left:6px}
.footer-col ul li i{width:16px;color:var(--secondary);font-size:12px}
.social-links{display:flex;gap:10px;margin-top:18px}
.social-links a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:14px}
.social-links a:hover{background:var(--primary-light);color:#fff;transform:translateY(-2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;display:flex;justify-content:space-between;align-items:center;font-size:13px}

/* ====== WHATSAPP + SCROLL TOP ====== */
.wa-float{position:fixed;bottom:26px;right:26px;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#25D366,#128C7E);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;z-index:999;box-shadow:0 6px 24px rgba(37,211,102,.5);transition:var(--transition)}
.wa-float:hover{transform:scale(1.12);box-shadow:0 8px 32px rgba(37,211,102,.6)}
.wa-float::before{content:'';position:absolute;inset:0;border-radius:50%;background:rgba(37,211,102,.3);animation:pulse 2s infinite}
#scrollTopBtn{position:fixed;bottom:96px;right:26px;width:44px;height:44px;border-radius:50%;background:#aedaff;color:#fff;border:none;cursor:pointer;font-size:16px;display:none;align-items:center;justify-content:center;z-index:999;box-shadow:0 4px 16px rgba(46,125,50,.4);transition:var(--transition)}
#scrollTopBtn:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(46,125,50,.5)}

/* ====== PRODUCT DETAIL ====== */
.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;padding:44px 0}
.product-gallery-main{border-radius:var(--radius-lg);overflow:hidden;background:var(--light);height:440px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}
.product-gallery-main img{width:100%;height:100%;object-fit:contain;transition:.4s}
.product-title{font-size:1.9rem;font-weight:800;font-family:'Playfair Display',serif;margin-bottom:12px;line-height:1.25}
.product-price-section{margin:20px 0;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.product-price{font-size:2.1rem;font-weight:800;color:#aedaff}
.product-old-price{font-size:1.15rem;color:var(--gray);text-decoration:line-through}
.product-save{background:var(--secondary-light);color:var(--secondary-dark);font-weight:800;padding:5px 14px;border-radius:50px;font-size:13px}
.variation-group{margin:18px 0}
.variation-label{font-size:13px;font-weight:700;color:var(--dark);margin-bottom:10px}
.variation-opts{display:flex;gap:8px;flex-wrap:wrap}
.var-btn{padding:9px 20px;border-radius:10px;border:2px solid var(--border);font-size:13.5px;font-weight:600;cursor:pointer;background:#fff;transition:var(--transition)}
.var-btn.active,.var-btn:hover{border-color:#aedaff;background:var(--primary-ultra);color:#aedaff}
.qty-selector{display:flex;align-items:center;gap:16px;margin:22px 0}
.qty-controls{display:flex;align-items:center;border:2px solid var(--border);border-radius:var(--radius);overflow:hidden}
.qty-controls button{width:42px;height:46px;background:var(--light);border:none;cursor:pointer;font-size:20px;font-weight:700;transition:var(--transition)}
.qty-controls button:hover{background:#aedaff;color:#fff}
.qty-controls input{width:54px;height:46px;text-align:center;border:none;border-left:2px solid var(--border);border-right:2px solid var(--border);font-size:16px;font-weight:800;font-family:inherit}
.action-buttons{display:flex;gap:12px;margin-top:10px}
.action-buttons .btn{flex:1;justify-content:center;padding:15px}

/* ====== CART & CHECKOUT ====== */
.cart-page-grid{display:grid;grid-template-columns:1fr 360px;gap:30px;padding:34px 0}
.cart-table{width:100%;border-collapse:collapse}
.cart-table th{padding:14px 18px;background:var(--light);font-size:12.5px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.6px;text-align:left;border-bottom:2px solid var(--border)}
.cart-table td{padding:18px;border-bottom:1px solid var(--border);vertical-align:middle}
.order-summary{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:26px;position:sticky;top:100px;box-shadow:var(--shadow)}
.summary-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px dashed var(--border);font-size:14px}
.summary-total{font-size:1.2rem;font-weight:800;border-bottom:none;margin-top:10px;color:#aedaff}
.checkout-grid{display:grid;grid-template-columns:1fr 390px;gap:30px;align-items:start;padding:34px 0}
.checkout-box{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;margin-bottom:22px}
.checkout-box h3{font-size:1rem;font-weight:800;margin-bottom:22px;display:flex;align-items:center;gap:10px;color:var(--dark)}
.payment-opt{display:flex;align-items:center;gap:16px;padding:16px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:10px;transition:var(--transition)}
.payment-opt:has(input:checked){border-color:#aedaff;background:var(--primary-ultra)}
.payment-opt input{accent-color:#aedaff}
.payment-icon{font-size:24px;width:38px;text-align:center}

/* ====== USER ACCOUNT ====== */
.account-layout{display:grid;grid-template-columns:250px 1fr;gap:30px;padding:34px 0}
.account-sidebar{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:22px;height:fit-content;position:sticky;top:100px}
.account-user{text-align:center;padding-bottom:22px;border-bottom:1px solid var(--border);margin-bottom:16px}
.account-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#aedaff,var(--secondary));color:#fff;font-size:26px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:0 6px 20px rgba(46,125,50,.3)}
.account-nav a{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);font-size:14px;color:var(--gray);font-weight:500;margin-bottom:4px;transition:var(--transition)}
.account-nav a.active,.account-nav a:hover{background:var(--primary-ultra);color:#aedaff;font-weight:700}
.account-content{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:30px}

/* ====== POLICY SECTION ====== */
.policy-section{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:30px;margin-bottom:22px}
.policy-section h3{font-size:1.15rem;font-weight:700;color:var(--dark);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--primary-ultra)}

/* ====== LOADING SKELETON ====== */
.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}

/* ====== NO RESULTS ====== */
.no-results{text-align:center;padding:60px 20px;color:var(--gray)}
.no-results i{font-size:56px;margin-bottom:16px;opacity:.3;display:block}

/* ====== FEATURED BG SECTION ====== */
.featured-bg{background:url('https://gvhealthcare.org/petstore/assets/7fb4cfd51f08188a02d8debd2a0365a7.jpg') center/cover no-repeat;position:relative;padding:80px 0}
.featured-bg::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.45)}
.featured-bg .container{position:relative;z-index:2}
.featured-bg .section-title,.featured-bg .section-label{color:#fff}

/* ====== ADMIN FORM EDIT ====== */
.a-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:var(--transition)}
.a-btn-primary{background:#2E7D32;color:#fff}
.a-btn-primary:hover{background:#1b5e20}
.a-btn-icon{width:36px;height:36px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;border:none;transition:var(--transition);flex-shrink:0}
.a-btn-icon.edit{background:#E8F5E9;color:#2E7D32;border:1px solid #c8e6c9}
.a-btn-icon.edit:hover{background:#2E7D32;color:#fff}
.a-btn-icon.del{background:#FFEBEE;color:#c62828;border:1px solid #ffcdd2}
.a-btn-icon.del:hover{background:#c62828;color:#fff}
.a-form-control{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13.5px;font-family:inherit;outline:none}
.a-form-control:focus{border-color:#2E7D32}

/* ====================================================
   RESPONSIVE BREAKPOINTS
   z-index map:
   header        = 500
   main-nav      = 600
   dropdown      = 700
   nav-overlay   = 800
   mobile nav    = 900
   cart overlay  = 1000
   cart sidebar  = 1001
   ==================================================== */

/* ---- 1100px: Large tablet ---- */
@media(max-width:1100px){
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .categories-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
}

/* ---- 900px: Tablet ---- */
@media(max-width:900px){
  .header-search{display:none}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .categories-grid{grid-template-columns:repeat(3,1fr)}
  .features-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .cart-page-grid,.checkout-grid{grid-template-columns:1fr}
  .account-layout{grid-template-columns:1fr}
  .product-detail-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  /* Products page sidebar hide */
  .products-sidebar{display:none}
  .products-layout{grid-template-columns:1fr}
}

/* ---- 860px: Mobile nav kicks in ---- */
@media(max-width:860px){
  /* Show hamburger */
  .menu-toggle{display:flex}

  /* Mobile nav drawer */
  .nav-list{
    display:none;
    flex-direction:column;
    position:fixed;
    top:0;left:0;
    width:82%;max-width:320px;
    height:100%;
    background:linear-gradient(180deg,#1b5e20 0%,#2e7d32 100%);
    z-index:900;
    padding:0;
    overflow-y:auto;
    gap:0;
    box-shadow:4px 0 24px rgba(0,0,0,.3);
    list-style:none;
    -webkit-overflow-scrolling:touch;
  }
  .nav-list.open{
    display:flex;
    animation:slideIn .28s ease;
  }

  /* Close button inside drawer */
  .nav-close{
    display:flex;
    align-items:center;
    justify-content:space-between;
    background:rgba(0,0,0,.2);
    border:none;
    color:#fff;
    font-size:15px;
    font-weight:600;
    cursor:pointer;
    padding:16px 24px;
    border-bottom:1px solid rgba(255,255,255,.1);
    width:100%;
  }
  .nav-close:hover{background:rgba(0,0,0,.3)}

  /* Nav links in drawer */
  .nav-list>li>a{
    display:block;
    padding:15px 24px;
    font-size:15px;
    color:#fff;
    border-bottom:1px solid rgba(255,255,255,.08);
    font-weight:500;
  }
  .nav-list>li>a:hover,.nav-list>li>a.active{
    background:rgba(255,255,255,.12);
    color:#fff;
  }
  .nav-list>li>a::after{display:none}

  /* Dropdown in mobile - always visible as sub-list */
  .nav-list li .dropdown{
    position:static;
    display:block;
    background:rgba(0,0,0,.18);
    box-shadow:none;
    border:none;
    border-radius:0;
    padding:4px 0;
    animation:none;
    min-width:unset;
  }
  .nav-list li:hover>.dropdown{display:block}
  .dropdown li a{
    padding:11px 40px;
    color:rgba(255,255,255,.85);
    font-size:13.5px;
    border-radius:0;
  }
  .dropdown li a:hover{
    background:rgba(255,255,255,.12);
    color:#fff;
    padding-left:48px;
  }

  /* Other layout fixes at 860 */
  .categories-grid{grid-template-columns:repeat(2,1fr)}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .features-grid,.team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-slide{padding:50px 0}
  .hero-content h1{font-size:1.8rem}
  .newsletter-form{flex-direction:column}
  .action-buttons{flex-direction:column}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .stat-item .stat-num{font-size:1.6rem}
}

/* ---- 600px: Small mobile ---- */
@media(max-width:600px){
  .topbar{display:none}
  .main-header{padding:10px 0}
  .section{padding:44px 0}
  .page-content{padding:36px 0}
  .page-hero{padding:44px 0}
  .page-hero h1{font-size:1.7rem}
  .page-hero p{font-size:.95rem}

  /* Always 2 columns for products & categories */
  .products-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .categories-grid{grid-template-columns:repeat(2,1fr);gap:10px}

  /* Smaller product cards */
  .product-img{height:155px}
  .product-info{padding:12px}
  .product-name{font-size:12.5px}
  .sale-price{font-size:.95rem}
  .product-info .btn{padding:9px 10px;font-size:12px;gap:5px}

  /* Smaller category cards */
  .cat-card{padding:16px 8px}
  .cat-card img,.cat-card .cat-emoji{width:46px;height:46px;font-size:24px}
  .cat-card h4{font-size:12px}
  .cat-card .count{font-size:11px}

  /* Hero */
  .hero-content h1{font-size:1.5rem}
  .hero-content p{font-size:.95rem}
  .hero-badge{font-size:11.5px;padding:5px 14px}
  .hero-slide{padding:40px 0;min-height:380px}
  .hero-slider{min-height:380px}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-item .stat-num{font-size:1.4rem}
  .stat-item i{font-size:22px}

  /* Cart full width on mobile */
  .cart-sidebar{width:100%;right:-100%}
  .cart-sidebar.open{right:0}

  /* Buttons */
  .btn{padding:11px 20px;font-size:14px}

  /* Breadcrumb */
  .breadcrumb{padding:10px 0}
  .breadcrumb-inner{font-size:12px}

  /* Footer */
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .footer-grid{grid-template-columns:1fr}

  /* Checkout / Cart page */
  .checkout-box{padding:18px}
  .cart-table th,.cart-table td{padding:12px 10px}

  /* Account */
  .account-layout{gap:16px}
  .account-content{padding:20px}

  /* Newsletter */
  .newsletter{padding:44px 0}
  .newsletter h2{font-size:1.5rem}

  /* Featured bg */
  .featured-bg{padding:44px 0}

  /* Testimonials 1 col */
  .testimonials-grid{grid-template-columns:1fr}

  /* Turn off hover transforms on touch */
  .product-card:hover{transform:none;box-shadow:var(--shadow)}
  .cat-card:hover{transform:none;box-shadow:none}
  .feature-card:hover{transform:none}
  .team-card:hover{transform:none}
}

/* ---- 380px: Very small phones ---- */
@media(max-width:380px){
  .container{padding:0 14px}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .product-img{height:130px}
  .product-info{padding:10px}
  .product-name{font-size:12px}
  .product-info .btn{font-size:11px;padding:8px 6px}
  .icon-btn{width:40px;height:40px;font-size:15px}
  .hero-content h1{font-size:1.3rem}
  .stat-num{font-size:1.2rem !important}
}

nav.main-nav {
    z-index: 9999;
}