/* ============================================
   ShopMax Commerce — Premium E-Commerce Theme
   © 2026 ShopMax. All rights reserved.
   ============================================ */

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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --orange:#F97316;--orange-hover:#EA580C;--orange-light:#FFF7ED;--orange-100:#FFEDD5;
  --dark:#1F2937;--dark2:#374151;--dark3:#4B5563;
  --gray:#6B7280;--gray-light:#9CA3AF;--gray-200:#E5E7EB;--gray-100:#F3F4F6;--gray-50:#F9FAFB;
  --white:#FFFFFF;--bg:#FFFFFF;--bg2:#F9FAFB;
  --green:#10B981;--red:#EF4444;--blue:#3B82F6;--yellow:#F59E0B;--purple:#8B5CF6;
  --shadow:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.1);--shadow-lg:0 10px 30px rgba(0,0,0,.12);
  --radius:8px;--radius-lg:12px;--radius-xl:16px;
  --font:'Poppins',sans-serif;--font2:'Lato',sans-serif;
  --nav-h:64px;--top-bar-h:36px;
  --max-w:1280px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font2);color:var(--dark);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit;transition:color .2s}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:600;line-height:1.3}

/* ---------- Demo Banner ---------- */
.demo-banner{
  background:linear-gradient(135deg,#F97316,#FB923C);color:#fff;
  text-align:center;padding:8px 16px;font-size:13px;font-weight:500;
  position:relative;z-index:9999;font-family:var(--font);
}
.demo-banner a{color:#fff;text-decoration:underline;font-weight:700}

/* ---------- Utility Classes ---------- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}
.section{padding:60px 0}
.section-title{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--dark)}
.section-subtitle{font-size:15px;color:var(--gray);margin-bottom:32px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:var(--radius);font-family:var(--font);font-weight:600;font-size:14px;transition:all .25s;cursor:pointer;border:2px solid transparent}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:var(--orange-hover);border-color:var(--orange-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(249,115,22,.35)}
.btn-outline{border:2px solid var(--orange);color:var(--orange);background:transparent}
.btn-outline:hover{background:var(--orange);color:#fff}
.btn-dark{background:var(--dark);color:#fff}
.btn-dark:hover{background:var(--dark2)}
.btn-sm{padding:8px 18px;font-size:13px}
.btn-lg{padding:14px 36px;font-size:15px}
.btn-block{width:100%}
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}
.badge-sale{background:#FEE2E2;color:var(--red)}
.badge-new{background:#D1FAE5;color:var(--green)}
.badge-hot{background:#FFF7ED;color:var(--orange)}
.badge-processing{background:#FEF3C7;color:#D97706}
.badge-shipped{background:#DBEAFE;color:#2563EB}
.badge-delivered{background:#D1FAE5;color:#059669}
.text-orange{color:var(--orange)}
.bg-gray{background:var(--bg2)}

/* ---------- Top Utility Bar ---------- */
.top-bar{
  background:var(--dark);color:#fff;font-size:12px;
  height:var(--top-bar-h);display:flex;align-items:center;
}
.top-bar .container{display:flex;align-items:center;justify-content:space-between}
.top-bar-left{display:flex;align-items:center;gap:6px}
.top-bar-left i{color:var(--orange);font-size:14px}
.top-bar-right{display:flex;align-items:center;gap:20px}
.top-bar-right a{color:#D1D5DB;font-size:12px;transition:color .2s}
.top-bar-right a:hover{color:var(--orange)}
.top-bar-right select{background:transparent;color:#D1D5DB;border:none;font-size:12px;cursor:pointer}
.top-bar-right select option{background:var(--dark);color:#fff}

/* ---------- Main Header / Nav ---------- */
.main-header{
  background:var(--white);border-bottom:1px solid var(--gray-200);
  height:var(--nav-h);position:sticky;top:0;z-index:1000;
  box-shadow:var(--shadow);
}
.main-header .container{display:flex;align-items:center;height:100%;gap:24px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font);font-weight:800;font-size:22px;color:var(--dark);flex-shrink:0}
.logo i{font-size:28px;color:var(--orange)}
.logo span{color:var(--orange)}

/* Category Nav */
.cat-nav{display:flex;align-items:center;gap:0;margin-left:16px;height:100%}
.cat-nav-item{position:relative;height:100%;display:flex;align-items:center}
.cat-nav-item>a{padding:0 14px;font-size:14px;font-weight:500;color:var(--dark2);height:100%;display:flex;align-items:center;gap:4px;transition:color .2s;white-space:nowrap}
.cat-nav-item>a:hover,.cat-nav-item:hover>a{color:var(--orange)}
.cat-nav-item>a i.bi-chevron-down{font-size:10px;transition:transform .2s}
.cat-nav-item:hover>a i.bi-chevron-down{transform:rotate(180deg)}

/* Mega Menu */
.mega-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  background:var(--white);border:1px solid var(--gray-200);border-top:3px solid var(--orange);
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
  box-shadow:var(--shadow-lg);padding:24px 28px;min-width:520px;
  opacity:0;visibility:hidden;transition:all .25s;pointer-events:none;z-index:100;
}
.cat-nav-item:hover .mega-menu{opacity:1;visibility:visible;pointer-events:auto}
.mega-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mega-menu-col h4{font-size:13px;font-weight:700;text-transform:uppercase;color:var(--orange);margin-bottom:10px;letter-spacing:.5px}
.mega-menu-col a{display:block;padding:5px 0;font-size:13px;color:var(--dark3);transition:color .2s}
.mega-menu-col a:hover{color:var(--orange)}

/* Search Bar */
.search-bar{
  flex:1;max-width:460px;position:relative;margin:0 16px;
}
.search-bar input{
  width:100%;height:40px;border:2px solid var(--gray-200);border-radius:var(--radius);
  padding:0 44px 0 16px;font-size:14px;transition:border-color .2s;background:var(--gray-50);
}
.search-bar input:focus{outline:none;border-color:var(--orange);background:var(--white)}
.search-bar button{
  position:absolute;right:0;top:0;height:100%;width:44px;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray);font-size:18px;transition:color .2s;
}
.search-bar button:hover{color:var(--orange)}

/* Header Actions */
.header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.header-action{
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;font-size:20px;color:var(--dark2);transition:all .2s;position:relative;
}
.header-action:hover{background:var(--orange-light);color:var(--orange)}
.header-action .count-badge{
  position:absolute;top:2px;right:2px;background:var(--orange);color:#fff;
  font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* Mobile Menu Toggle */
.menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;font-size:24px;color:var(--dark)}

/* ---------- Hero Slider ---------- */
.hero-section{position:relative;overflow:hidden}
.hero-slide{
  position:relative;height:480px;display:flex;align-items:center;
  background-size:cover;background-position:center;
}
.hero-slide::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.2) 60%,transparent 100%);
}
.hero-content{position:relative;z-index:2;max-width:540px;padding:0 60px;color:#fff}
.hero-tag{display:inline-block;background:var(--orange);color:#fff;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;margin-bottom:16px;letter-spacing:1px}
.hero-content h1{font-size:44px;font-weight:800;line-height:1.15;margin-bottom:14px}
.hero-content p{font-size:16px;opacity:.9;margin-bottom:24px;line-height:1.7}
.hero-btns{display:flex;gap:12px}
.swiper-pagination-bullet{background:#fff!important;opacity:.5}
.swiper-pagination-bullet-active{opacity:1!important;background:var(--orange)!important}
.hero-section .swiper-button-next,.hero-section .swiper-button-prev{color:#fff;background:rgba(0,0,0,.3);width:44px;height:44px;border-radius:50%;--swiper-navigation-size:18px}
.hero-section .swiper-button-next:hover,.hero-section .swiper-button-prev:hover{background:var(--orange)}

/* ---------- Category Grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.cat-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  height:200px;cursor:pointer;
}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.cat-card:hover img{transform:scale(1.08)}
.cat-card .cat-overlay{
  position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65),transparent);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding:20px 12px;color:#fff;
}
.cat-overlay i{font-size:28px;margin-bottom:6px;opacity:.9}
.cat-overlay span{font-weight:700;font-size:14px;font-family:var(--font)}
.cat-overlay small{font-size:11px;opacity:.75;margin-top:2px}

/* ---------- Flash Deals ---------- */
.flash-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:28px}
.flash-left{display:flex;align-items:center;gap:16px}
.flash-left .section-title{margin-bottom:0}
.flash-icon{font-size:28px;color:var(--orange)}
.countdown{display:flex;gap:6px}
.countdown-box{
  background:var(--dark);color:#fff;border-radius:6px;
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;font-family:var(--font);
}
.countdown-sep{display:flex;align-items:center;font-size:18px;font-weight:700;color:var(--dark)}

/* ---------- Product Card ---------- */
.product-card{
  background:var(--white);border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--gray-200);transition:all .3s;position:relative;
}
.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:transparent}
.product-card .card-img{position:relative;overflow:hidden;aspect-ratio:1/1;background:var(--gray-50)}
.product-card .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.product-card:hover .card-img img{transform:scale(1.08)}
.card-badges{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px;z-index:2}
.card-badges .badge{font-size:11px;padding:4px 10px}
.card-wishlist{
  position:absolute;top:12px;right:12px;width:34px;height:34px;
  background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--gray);box-shadow:var(--shadow);z-index:2;
  transition:all .2s;cursor:pointer;border:none;
}
.card-wishlist:hover,.card-wishlist.active{color:var(--red);background:#FEE2E2}
.card-quick-view{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(249,115,22,.92);color:#fff;padding:10px;
  text-align:center;font-size:13px;font-weight:600;font-family:var(--font);
  transform:translateY(100%);transition:transform .3s;cursor:pointer;z-index:2;
}
.product-card:hover .card-quick-view{transform:translateY(0)}
.card-body{padding:14px 16px 16px}
.card-category{font-size:11px;color:var(--gray-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.card-title{font-family:var(--font);font-size:14px;font-weight:600;color:var(--dark);margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}
.card-title a:hover{color:var(--orange)}
.card-rating{display:flex;align-items:center;gap:3px;margin-bottom:8px}
.card-rating i{font-size:12px;color:var(--yellow)}
.card-rating i.empty{color:var(--gray-200)}
.card-rating span{font-size:11px;color:var(--gray-light);margin-left:4px}
.card-price{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.card-price .current{font-family:var(--font);font-size:18px;font-weight:700;color:var(--dark)}
.card-price .old{font-size:14px;color:var(--gray-light);text-decoration:line-through}
.card-price .discount{font-size:12px;color:var(--green);font-weight:600}
.card-actions{display:flex;gap:8px}
.card-actions .btn{flex:1;padding:8px 12px;font-size:13px}

/* Product Grid */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.products-grid-3{grid-template-columns:repeat(3,1fr)}
.products-grid-5{grid-template-columns:repeat(5,1fr)}

/* ---------- Newsletter ---------- */
.newsletter{
  background:linear-gradient(135deg,var(--orange),#EA580C);
  border-radius:var(--radius-xl);padding:48px;
  display:flex;align-items:center;justify-content:space-between;gap:40px;
  color:#fff;
}
.newsletter-text h3{font-size:26px;font-weight:700;margin-bottom:6px}
.newsletter-text p{opacity:.9;font-size:15px}
.newsletter-form{display:flex;gap:0;flex-shrink:0;width:420px;max-width:100%}
.newsletter-form input{
  flex:1;height:48px;border:none;border-radius:var(--radius) 0 0 var(--radius);
  padding:0 18px;font-size:14px;
}
.newsletter-form input:focus{outline:none}
.newsletter-form button{
  background:var(--dark);color:#fff;border:none;padding:0 28px;
  border-radius:0 var(--radius) var(--radius) 0;font-weight:600;font-size:14px;
  transition:background .2s;white-space:nowrap;
}
.newsletter-form button:hover{background:var(--dark2)}

/* ---------- Footer ---------- */
.footer{background:var(--dark);color:#D1D5DB;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-about .logo{color:#fff;margin-bottom:14px}
.footer-about p{font-size:13px;line-height:1.7;color:#9CA3AF;margin-bottom:16px}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:#9CA3AF;font-size:16px;transition:all .2s;
}
.footer-social a:hover{background:var(--orange);color:#fff}
.footer-col h4{font-family:var(--font);font-size:15px;font-weight:600;color:#fff;margin-bottom:16px}
.footer-col a{display:block;padding:4px 0;font-size:13px;color:#9CA3AF;transition:color .2s}
.footer-col a:hover{color:var(--orange)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding:20px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:12px;color:#6B7280}
.footer-payments{display:flex;gap:8px}
.footer-payments span{
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);padding:4px 10px;border-radius:4px;font-size:11px;font-weight:700;color:#9CA3AF;
}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs{padding:16px 0;font-size:13px;color:var(--gray);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.breadcrumbs a{color:var(--gray);transition:color .2s}
.breadcrumbs a:hover{color:var(--orange)}
.breadcrumbs i{font-size:10px;color:var(--gray-light)}
.breadcrumbs .current{color:var(--dark);font-weight:500}

/* ---------- Shop Page ---------- */
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:30px;align-items:start}
.shop-sidebar{position:sticky;top:calc(var(--nav-h) + 20px)}
.filter-group{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--gray-200)}
.filter-group:last-child{border-bottom:none}
.filter-group h4{font-size:14px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.filter-group h4 i{font-size:12px;transition:transform .2s}
.filter-check{display:flex;align-items:center;gap:8px;padding:5px 0;cursor:pointer;font-size:13px;color:var(--dark2)}
.filter-check input[type="checkbox"]{accent-color:var(--orange);width:16px;height:16px}
.filter-check span.count{margin-left:auto;font-size:11px;color:var(--gray-light)}
.price-range{padding:8px 0}
.price-range input[type="range"]{width:100%;accent-color:var(--orange)}
.price-inputs{display:flex;align-items:center;gap:8px;margin-top:8px}
.price-inputs input{width:80px;height:32px;border:1px solid var(--gray-200);border-radius:4px;padding:0 8px;font-size:13px;text-align:center}
.price-inputs span{color:var(--gray-light);font-size:13px}
.rating-filter{display:flex;flex-direction:column;gap:6px}
.rating-filter label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px}
.rating-filter label i{font-size:14px;color:var(--yellow)}
.rating-filter label i.empty{color:var(--gray-200)}
.color-swatches{display:flex;gap:8px;flex-wrap:wrap}
.color-swatch{
  width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;
  transition:all .2s;position:relative;
}
.color-swatch:hover,.color-swatch.active{border-color:var(--dark);transform:scale(1.15)}
.size-btns{display:flex;gap:6px;flex-wrap:wrap}
.size-btn{
  padding:6px 14px;border:1px solid var(--gray-200);border-radius:4px;
  font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;background:var(--white);
}
.size-btn:hover,.size-btn.active{border-color:var(--orange);background:var(--orange-light);color:var(--orange)}

/* Shop Toolbar */
.shop-toolbar{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding:12px 16px;background:var(--gray-50);border-radius:var(--radius);margin-bottom:24px;
}
.shop-toolbar .results{font-size:13px;color:var(--gray)}
.shop-toolbar .results b{color:var(--dark)}
.toolbar-right{display:flex;align-items:center;gap:12px}
.view-toggle{display:flex;gap:4px}
.view-toggle button{
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border-radius:4px;font-size:16px;color:var(--gray);border:1px solid var(--gray-200);transition:all .2s;
}
.view-toggle button.active,.view-toggle button:hover{background:var(--orange);color:#fff;border-color:var(--orange)}
.toolbar-select{height:34px;border:1px solid var(--gray-200);border-radius:4px;padding:0 10px;font-size:13px;color:var(--dark2);background:var(--white);cursor:pointer}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:32px}
.pagination a,.pagination span{
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius);font-size:14px;font-weight:500;transition:all .2s;
  border:1px solid var(--gray-200);color:var(--dark2);
}
.pagination a:hover{border-color:var(--orange);color:var(--orange)}
.pagination .active{background:var(--orange);color:#fff;border-color:var(--orange)}
.pagination .disabled{opacity:.4;pointer-events:none}

/* ---------- Product Detail ---------- */
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:24px 0 48px}
.pd-gallery{position:sticky;top:calc(var(--nav-h) + 20px)}
.pd-main-img{
  border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-50);
  aspect-ratio:1/1;margin-bottom:12px;cursor:zoom-in;
}
.pd-main-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.pd-main-img:hover img{transform:scale(1.05)}
.pd-thumbs{display:flex;gap:10px}
.pd-thumb{
  width:80px;height:80px;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  border:2px solid transparent;transition:border-color .2s;flex-shrink:0;
}
.pd-thumb.active,.pd-thumb:hover{border-color:var(--orange)}
.pd-thumb img{width:100%;height:100%;object-fit:cover}

.pd-info{}
.pd-brand{font-size:12px;color:var(--orange);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.pd-title{font-size:28px;font-weight:700;margin-bottom:10px}
.pd-rating{display:flex;align-items:center;gap:6px;margin-bottom:16px}
.pd-rating i{font-size:16px;color:var(--yellow)}
.pd-rating i.empty{color:var(--gray-200)}
.pd-rating .rating-text{font-size:14px;color:var(--gray)}
.pd-rating a{color:var(--orange);font-size:14px}
.pd-price-box{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:16px;background:var(--orange-light);border-radius:var(--radius)}
.pd-price{font-size:30px;font-weight:800;font-family:var(--font);color:var(--dark)}
.pd-old-price{font-size:18px;color:var(--gray-light);text-decoration:line-through}
.pd-save-badge{background:var(--green);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}
.pd-desc{font-size:14px;color:var(--dark3);line-height:1.7;margin-bottom:20px}
.pd-divider{height:1px;background:var(--gray-200);margin:20px 0}

/* Color Selector */
.pd-label{font-size:13px;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.pd-label span{font-weight:400;color:var(--gray)}
.pd-colors{display:flex;gap:10px;margin-bottom:20px}
.pd-color{
  width:36px;height:36px;border-radius:50%;cursor:pointer;border:3px solid transparent;
  transition:all .2s;position:relative;
}
.pd-color.active{border-color:var(--dark);box-shadow:0 0 0 2px var(--white),0 0 0 4px var(--dark)}
.pd-color:hover{transform:scale(1.1)}
.pd-sizes{display:flex;gap:8px;margin-bottom:20px}
.pd-size{
  padding:8px 18px;border:2px solid var(--gray-200);border-radius:var(--radius);
  font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;
}
.pd-size:hover,.pd-size.active{border-color:var(--orange);background:var(--orange-light);color:var(--orange)}

/* Quantity */
.qty-selector{
  display:inline-flex;align-items:center;border:2px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;
}
.qty-selector button{width:40px;height:40px;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--dark2);transition:all .2s}
.qty-selector button:hover{background:var(--gray-100);color:var(--orange)}
.qty-selector input{width:50px;height:40px;text-align:center;border:none;border-left:1px solid var(--gray-200);border-right:1px solid var(--gray-200);font-size:15px;font-weight:600}
.qty-selector input:focus{outline:none}

.pd-add-row{display:flex;gap:10px;margin-top:20px;align-items:center}
.pd-add-row .btn{padding:12px 32px}
.pd-wish-btn{
  width:46px;height:46px;border:2px solid var(--gray-200);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--gray);transition:all .2s;
}
.pd-wish-btn:hover{color:var(--red);border-color:var(--red);background:#FEE2E2}

/* Features */
.pd-features{margin-top:20px}
.pd-features li{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:14px;color:var(--dark2)}
.pd-features li i{color:var(--green);font-size:16px}

/* Product Tabs */
.pd-tabs{margin-top:48px}
.tab-nav{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:24px}
.tab-nav button{
  padding:12px 24px;font-size:14px;font-weight:600;font-family:var(--font);color:var(--gray);
  border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;
}
.tab-nav button.active,.tab-nav button:hover{color:var(--orange);border-bottom-color:var(--orange)}
.tab-content{display:none;animation:fadeTab .3s}
.tab-content.active{display:block}
@keyframes fadeTab{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.tab-content p{font-size:14px;color:var(--dark3);line-height:1.8;margin-bottom:14px}
.spec-table{width:100%;border-collapse:collapse}
.spec-table tr:nth-child(even){background:var(--gray-50)}
.spec-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--gray-200)}
.spec-table td:first-child{font-weight:600;color:var(--dark);width:200px}

/* Reviews */
.reviews-summary{display:flex;gap:40px;margin-bottom:32px;padding:24px;background:var(--gray-50);border-radius:var(--radius-lg)}
.reviews-avg{text-align:center;flex-shrink:0}
.reviews-avg .big-num{font-size:48px;font-weight:800;font-family:var(--font);color:var(--dark)}
.reviews-avg .stars{display:flex;gap:3px;justify-content:center;margin:6px 0}
.reviews-avg .stars i{font-size:18px;color:var(--yellow)}
.reviews-avg p{font-size:13px;color:var(--gray)}
.reviews-bars{flex:1}
.review-bar{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.review-bar span{font-size:13px;font-weight:500;white-space:nowrap;width:50px}
.review-bar .bar{flex:1;height:10px;background:var(--gray-200);border-radius:20px;overflow:hidden}
.review-bar .bar-fill{height:100%;background:var(--yellow);border-radius:20px}
.review-bar .count{font-size:12px;color:var(--gray);width:30px}

.review-item{padding:20px 0;border-bottom:1px solid var(--gray-200)}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.review-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--gray-200)}
.review-meta h5{font-size:14px;font-weight:600}
.review-meta span{font-size:12px;color:var(--gray)}
.review-stars{display:flex;gap:2px;margin-bottom:8px}
.review-stars i{font-size:14px;color:var(--yellow)}
.review-stars i.empty{color:var(--gray-200)}
.review-text{font-size:14px;color:var(--dark3);line-height:1.7}

/* ---------- Cart Page ---------- */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start;padding:24px 0 60px}
.cart-items{display:flex;flex-direction:column;gap:0}
.cart-item{
  display:grid;grid-template-columns:100px 1fr auto auto auto;align-items:center;gap:20px;
  padding:20px 0;border-bottom:1px solid var(--gray-200);
}
.cart-item-img{width:100px;height:100px;border-radius:var(--radius);overflow:hidden;background:var(--gray-50)}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info h4{font-size:15px;font-weight:600;margin-bottom:4px}
.cart-item-info p{font-size:12px;color:var(--gray)}
.cart-item-price{font-weight:700;font-family:var(--font);font-size:16px}
.cart-item-subtotal{font-weight:700;font-family:var(--font);font-size:16px;color:var(--orange)}
.cart-item-remove{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--gray);transition:all .2s;font-size:18px}
.cart-item-remove:hover{background:#FEE2E2;color:var(--red)}

.cart-coupon{display:flex;gap:8px;margin-top:20px}
.cart-coupon input{flex:1;height:42px;border:1px solid var(--gray-200);border-radius:var(--radius);padding:0 14px;font-size:14px}
.cart-coupon input:focus{outline:none;border-color:var(--orange)}

/* Order Summary */
.order-summary{
  background:var(--gray-50);border-radius:var(--radius-lg);padding:24px;
  border:1px solid var(--gray-200);position:sticky;top:calc(var(--nav-h) + 20px);
}
.order-summary h3{font-size:18px;font-weight:700;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--gray-200)}
.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:var(--dark2)}
.summary-row.total{font-size:18px;font-weight:700;color:var(--dark);border-top:2px solid var(--gray-200);padding-top:16px;margin-top:8px}
.summary-row .free{color:var(--green);font-weight:600}

/* ---------- Checkout Page ---------- */
.checkout-layout{display:grid;grid-template-columns:1fr 400px;gap:40px;align-items:start;padding:24px 0 60px}
.step-indicator{display:flex;align-items:center;gap:0;margin-bottom:32px}
.step{display:flex;align-items:center;gap:8px}
.step-num{
  width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;font-family:var(--font);
  background:var(--gray-200);color:var(--gray);
}
.step.active .step-num{background:var(--orange);color:#fff}
.step.done .step-num{background:var(--green);color:#fff}
.step-text{font-size:14px;font-weight:500;color:var(--gray)}
.step.active .step-text{color:var(--dark);font-weight:600}
.step-line{flex:1;height:2px;background:var(--gray-200);margin:0 12px}
.step-line.done{background:var(--green)}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:16px}
.form-group.full{grid-column:1/-1}
.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--dark2)}
.form-group input,.form-group select{
  width:100%;height:44px;border:1px solid var(--gray-200);border-radius:var(--radius);
  padding:0 14px;font-size:14px;transition:border-color .2s;
}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--orange)}
.form-section{margin-bottom:32px}
.form-section h3{font-size:18px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.form-section h3 i{color:var(--orange)}

.shipping-options{display:flex;flex-direction:column;gap:10px}
.shipping-option{
  display:flex;align-items:center;gap:14px;padding:14px 16px;
  border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .2s;
}
.shipping-option:hover,.shipping-option.active{border-color:var(--orange);background:var(--orange-light)}
.shipping-option input[type="radio"]{accent-color:var(--orange);width:18px;height:18px}
.shipping-option .ship-info{flex:1}
.shipping-option .ship-info h5{font-size:14px;font-weight:600}
.shipping-option .ship-info p{font-size:12px;color:var(--gray)}
.shipping-option .ship-price{font-weight:700;font-family:var(--font)}
.shipping-option .ship-price.free{color:var(--green)}

.payment-methods{display:flex;flex-direction:column;gap:10px}
.pay-method{
  display:flex;align-items:center;gap:14px;padding:14px 16px;
  border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .2s;
}
.pay-method:hover,.pay-method.active{border-color:var(--orange);background:var(--orange-light)}
.pay-method input[type="radio"]{accent-color:var(--orange);width:18px;height:18px}
.pay-method i{font-size:22px;color:var(--dark)}
.card-form{margin-top:16px;padding:16px;background:var(--gray-50);border-radius:var(--radius)}

/* Checkout Summary */
.checkout-summary{
  background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);
  padding:24px;position:sticky;top:calc(var(--nav-h) + 20px);
}
.checkout-summary h3{font-size:18px;font-weight:700;margin-bottom:20px}
.checkout-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-200)}
.checkout-item img{width:56px;height:56px;border-radius:6px;object-fit:cover;background:var(--gray-100)}
.checkout-item-info{flex:1}
.checkout-item-info h5{font-size:13px;font-weight:600}
.checkout-item-info p{font-size:11px;color:var(--gray)}
.checkout-item .item-price{font-weight:700;font-size:14px;font-family:var(--font)}

/* ---------- Account Page ---------- */
.account-layout{display:grid;grid-template-columns:240px 1fr;gap:30px;padding:24px 0 60px}
.account-sidebar{
  background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);
  padding:8px;position:sticky;top:calc(var(--nav-h) + 20px);
}
.account-sidebar a{
  display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);
  font-size:14px;font-weight:500;color:var(--dark2);transition:all .2s;
}
.account-sidebar a:hover{background:var(--orange-light);color:var(--orange)}
.account-sidebar a.active{background:var(--orange);color:#fff}
.account-sidebar a i{font-size:18px}

.account-content h2{font-size:22px;font-weight:700;margin-bottom:24px}
.welcome-card{
  background:linear-gradient(135deg,var(--orange-light),#FFF7ED);
  border:1px solid var(--orange-100);border-radius:var(--radius-lg);
  padding:24px;margin-bottom:24px;display:flex;align-items:center;gap:20px;
}
.welcome-card h3{font-size:18px;font-weight:700;margin-bottom:4px}
.welcome-card p{font-size:13px;color:var(--gray)}
.orders-table{width:100%;border-collapse:collapse;font-size:14px}
.orders-table th{text-align:left;padding:12px 14px;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}
.orders-table td{padding:12px 14px;border-bottom:1px solid var(--gray-200)}

.address-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.address-card{border:1px solid var(--gray-200);border-radius:var(--radius);padding:16px}
.address-card h5{font-size:14px;font-weight:600;margin-bottom:6px}
.address-card p{font-size:13px;color:var(--gray);line-height:1.6}

/* ---------- Wishlist ---------- */
.wishlist-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.wishlist-header h2{font-size:22px;font-weight:700}

/* ---------- Vendor Page ---------- */
.vendor-banner{
  position:relative;height:240px;border-radius:var(--radius-xl);overflow:hidden;
  margin-bottom:-60px;
}
.vendor-banner img{width:100%;height:100%;object-fit:cover}
.vendor-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5),transparent)}
.vendor-profile{
  position:relative;z-index:2;display:flex;align-items:flex-end;gap:20px;
  padding:0 24px 24px;
}
.vendor-avatar{
  width:100px;height:100px;border-radius:50%;border:4px solid var(--white);
  overflow:hidden;box-shadow:var(--shadow-lg);flex-shrink:0;
}
.vendor-avatar img{width:100%;height:100%;object-fit:cover}
.vendor-info{padding-bottom:8px}
.vendor-info h1{font-size:24px;font-weight:700;color:#fff;margin-bottom:2px}
.vendor-info p{font-size:13px;color:rgba(255,255,255,.8)}
.vendor-stats{
  display:flex;gap:24px;padding:24px 0;margin-top:16px;border-bottom:1px solid var(--gray-200);
}
.vendor-stat{text-align:center}
.vendor-stat .num{font-size:22px;font-weight:800;font-family:var(--font);color:var(--dark)}
.vendor-stat .label{font-size:12px;color:var(--gray);margin-top:2px}

/* ---------- Swiper Overrides ---------- */
.swiper{width:100%}
.product-swiper .swiper-slide{width:auto}
.product-swiper .product-card{width:260px}
.swiper-button-next,.swiper-button-prev{
  color:var(--dark)!important;background:var(--white);width:40px!important;height:40px!important;
  border-radius:50%;box-shadow:var(--shadow-md);--swiper-navigation-size:16px;
}
.swiper-button-next:hover,.swiper-button-prev:hover{background:var(--orange);color:#fff!important}

/* ---------- Toast / Notifications ---------- */
.toast{
  position:fixed;bottom:24px;right:24px;background:var(--dark);color:#fff;
  padding:14px 24px;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;
  z-index:9999;transform:translateY(120%);transition:transform .3s;
}
.toast.show{transform:translateY(0)}
.toast i{font-size:18px;color:var(--green)}

/* ---------- Mobile Sidebar / Overlay ---------- */
.mobile-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1500;
  opacity:0;visibility:hidden;transition:all .3s;
}
.mobile-overlay.active{opacity:1;visibility:visible}
.mobile-sidebar{
  position:fixed;top:0;left:0;width:300px;height:100%;background:var(--white);
  z-index:1600;transform:translateX(-100%);transition:transform .3s;
  overflow-y:auto;padding:20px;
}
.mobile-sidebar.active{transform:translateX(0)}
.mobile-sidebar .close-btn{display:flex;align-items:center;justify-content:flex-end;margin-bottom:16px}
.mobile-sidebar .close-btn button{font-size:24px;color:var(--dark)}
.mobile-nav a{display:flex;align-items:center;gap:10px;padding:12px 0;font-size:15px;font-weight:500;border-bottom:1px solid var(--gray-100);color:var(--dark2)}
.mobile-nav a:hover{color:var(--orange)}

/* ---------- Animations ---------- */
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .5s ease-out}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.pulse{animation:pulse .3s}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .product-detail{grid-template-columns:1fr;gap:24px}
  .pd-gallery{position:static}
  .checkout-layout{grid-template-columns:1fr}
  .checkout-summary{position:static}
  .cart-layout{grid-template-columns:1fr}
  .order-summary{position:static}
  .shop-layout{grid-template-columns:1fr}
  .shop-sidebar{position:static}
  .account-layout{grid-template-columns:1fr}
  .account-sidebar{position:static;display:flex;flex-wrap:wrap;gap:4px;padding:4px}
  .account-sidebar a{padding:8px 12px;font-size:13px}
  .vendor-banner{height:180px}
}
@media(max-width:768px){
  .hero-slide{height:360px}
  .hero-content{padding:0 24px}
  .hero-content h1{font-size:28px}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cat-card{height:140px}
  .newsletter{flex-direction:column;padding:32px 24px;text-align:center}
  .newsletter-form{width:100%}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .footer-bottom{flex-direction:column;text-align:center}
  .cart-item{grid-template-columns:80px 1fr;gap:12px}
  .cart-item-price,.cart-item-subtotal{font-size:14px}
  .form-grid{grid-template-columns:1fr}
  .address-cards{grid-template-columns:1fr}
  .reviews-summary{flex-direction:column;gap:20px}
  .section{padding:40px 0}
  .section-title{font-size:22px}
  .vendor-stats{gap:16px;flex-wrap:wrap}
  .cat-nav{display:none}
  .search-bar{display:none}
  .menu-toggle{display:flex}
  .top-bar-left{font-size:11px}
  .top-bar-right{gap:12px}
}
@media(max-width:480px){
  .products-grid{grid-template-columns:1fr 1fr;gap:10px}
  .card-body{padding:10px 12px 14px}
  .card-price .current{font-size:15px}
  .hero-slide{height:280px}
  .hero-content h1{font-size:22px}
  .hero-btns{flex-direction:column;gap:8px}
  .flash-header{flex-direction:column;align-items:flex-start}
  .pd-add-row{flex-direction:column}
  .pd-add-row .btn{width:100%}
  .tab-nav{overflow-x:auto;gap:0}
  .tab-nav button{white-space:nowrap;padding:10px 14px;font-size:13px}
}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--gray-100)}
::-webkit-scrollbar-thumb{background:var(--gray-light);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gray)}

/* ---------- Selection ---------- */
::selection{background:var(--orange-light);color:var(--orange)}

/* ---------- Loading Skeleton ---------- */
.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

/* ---------- Star Rating Sizes ---------- */
.stars-sm i{font-size:12px}
.stars-md i{font-size:16px}
.stars-lg i{font-size:20px}

/* ---------- Empty State ---------- */
.empty-state{text-align:center;padding:60px 20px}
.empty-state i{font-size:64px;color:var(--gray-200);margin-bottom:16px}
.empty-state h3{font-size:20px;font-weight:600;margin-bottom:8px}
.empty-state p{font-size:14px;color:var(--gray);margin-bottom:24px}

/* ---------- Quick Extras ---------- */
.trust-bar{display:flex;justify-content:center;gap:48px;padding:32px 0;border-bottom:1px solid var(--gray-200)}
.trust-item{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;color:var(--dark2)}
.trust-item i{font-size:28px;color:var(--orange)}

/* Page title area */
.page-title-area{background:var(--bg2);padding:20px 0;border-bottom:1px solid var(--gray-200)}
.page-title-area h1{font-size:24px;font-weight:700}
