/* BharatMart - Stylish E-commerce Theme */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --primary: #F83758;
  --primary-dark: #E02B4C;
  --primary-light: rgba(248,55,88,0.08);
  --primary-gradient: linear-gradient(135deg, #F83758, #FF6B8A);
  --secondary: #FFA3B3;
  --black: #1D1E20;
  --white: #FFFFFF;
  --bg: #FAFAFA;
  --card: #FFFFFF;
  --border: #F0F0F0;
  --gray-50: #F9FAFB;
  --gray-100: #F3F4F6;
  --gray-200: #E8E8E8;
  --gray-300: #D1D5DB;
  --gray-400: #A0A0A0;
  --gray-500: #6B7280;
  --gray-600: #4B5563;
  --gray-700: #374151;
  --gray-900: #111827;
  --green: #10B981;
  --green-light: rgba(16,185,129,0.08);
  --orange: #F59E0B;
  --star: #EDB310;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow: 0 4px 16px rgba(0,0,0,0.06);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.1);
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --transition: all 0.25s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--black);padding-bottom:72px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* === HEADER === */
.main-header{background:var(--white);position:sticky;top:0;z-index:1000}
.header-inner{display:flex;align-items:center;gap:14px;padding:12px 20px;max-width:1400px;margin:0 auto}
.header-menu{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:none;font-size:20px;color:var(--black);cursor:pointer;border-radius:8px}
.header-menu:hover{background:var(--gray-100)}
.brand{display:flex;align-items:center;gap:8px;flex:1}
.brand-icon{width:36px;height:36px;background:var(--primary-gradient);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px}
.brand-name{font-size:18px;font-weight:800;color:var(--black)}
.brand-name span{color:var(--primary)}
.header-right{display:flex;align-items:center;gap:12px}
.header-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;overflow:hidden}
.header-avatar img{width:100%;height:100%;object-fit:cover}
.header-icon{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--gray-600);font-size:18px;border-radius:8px;transition:var(--transition)}
.header-icon:hover{background:var(--gray-100);color:var(--primary)}
.header-badge{position:absolute;top:2px;right:2px;background:var(--primary);color:#fff;font-size:9px;min-width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid #fff}

/* === SEARCH BAR === */
.search-wrap{padding:0 20px 14px;max-width:1400px;margin:0 auto}
.search-bar{display:flex;align-items:center;background:var(--white);border:1px solid var(--gray-200);border-radius:10px;padding:0 14px;transition:var(--transition)}
.search-bar:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}
.search-bar i{color:var(--gray-400);font-size:16px}
.search-bar input{flex:1;border:none;outline:none;padding:12px;font-size:14px;font-family:inherit;background:transparent}
.search-bar .voice-btn{color:var(--gray-400);background:none;border:none;font-size:18px;padding:4px}

/* === SECTION HEADER === */
.section-head{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 14px;max-width:1400px;margin:0 auto}
.section-head h2{font-size:20px;font-weight:800;color:var(--black)}
.section-head-actions{display:flex;align-items:center;gap:10px}
.sort-btn,.filter-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--gray-200);border-radius:6px;font-size:12px;font-weight:600;color:var(--gray-600);background:var(--white)}
.view-all-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 16px;border-radius:6px;font-size:12px;font-weight:700;background:var(--primary);color:#fff;border:1px solid var(--primary);transition:var(--transition)}
.view-all-btn:hover{background:var(--primary-dark)}

/* === CATEGORIES ROW === */
.cat-scroll{padding:0 20px;overflow-x:auto;scrollbar-width:none;max-width:1400px;margin:0 auto}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-row{display:flex;gap:20px;padding-bottom:6px}
.cat-item{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:64px;cursor:pointer}
.cat-avatar{width:56px;height:56px;border-radius:50%;overflow:hidden;border:2px solid var(--gray-200);background:var(--gray-100);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.cat-avatar i{font-size:22px;color:var(--gray-500)}
.cat-item:hover .cat-avatar{border-color:var(--primary);transform:scale(1.08)}
.cat-label{font-size:11px;font-weight:600;color:var(--gray-600);text-align:center;white-space:nowrap}

/* === PROMO BANNER === */
.promo-banner{margin:18px 20px;border-radius:var(--radius);overflow:hidden;position:relative;background:var(--primary-gradient);padding:24px;color:#fff;min-height:140px;display:flex;align-items:center;max-width:1400px}
.promo-banner-text{position:relative;z-index:2;max-width:55%}
.promo-banner-text .promo-off{font-size:28px;font-weight:900;margin-bottom:4px}
.promo-banner-text .promo-sub{font-size:13px;opacity:.85;margin-bottom:4px}
.promo-banner-text .promo-desc{font-size:12px;opacity:.7;margin-bottom:16px}
.promo-shop-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(0,0,0,0.15);backdrop-filter:blur(8px);color:#fff;font-size:12px;font-weight:700;padding:8px 16px;border-radius:6px;border:1px solid rgba(255,255,255,0.25);transition:var(--transition)}
.promo-shop-btn:hover{background:rgba(0,0,0,0.3)}
.promo-img{position:absolute;right:0;bottom:0;height:100%;width:45%;object-fit:contain;object-position:right bottom;z-index:1}
.promo-dots{display:flex;gap:6px;justify-content:center;margin-top:12px}
.promo-dot{width:8px;height:8px;border-radius:50%;background:var(--primary)}
.promo-dot.muted{background:var(--gray-300)}

/* === DEAL SECTION === */
.deal-header{background:linear-gradient(135deg,#4392F1,#2D7DD2);margin:0 20px;border-radius:var(--radius) var(--radius) 0 0;padding:14px 18px;display:flex;justify-content:space-between;align-items:center;max-width:1400px}
.deal-header h3{color:#fff;font-size:16px;font-weight:800}
.deal-timer{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,0.9);font-size:12px;font-weight:600}
.deal-timer i{font-size:14px}

/* === PRODUCT CARD === */
.product-scroll{padding:0 20px;overflow-x:auto;scrollbar-width:none;max-width:1400px;margin:0 auto}
.product-scroll::-webkit-scrollbar{display:none}
.product-row{display:flex;gap:14px;padding-bottom:8px}
.product-card{background:var(--white);border-radius:var(--radius);overflow:hidden;transition:var(--transition);position:relative;min-width:160px;max-width:180px;flex-shrink:0;border:1px solid var(--border)}
.product-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.pc-img-wrap{position:relative;overflow:hidden;background:var(--gray-100);aspect-ratio:1}
.pc-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.product-card:hover .pc-img{transform:scale(1.05)}
.pc-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--gray-300)}
.pc-badge{position:absolute;top:8px;left:8px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px}
.pc-wish{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-400);font-size:13px;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition)}
.pc-wish:hover{color:var(--primary)}
.pc-body{padding:12px}
.pc-title{font-size:13px;font-weight:600;color:var(--black);margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.pc-desc{font-size:11px;color:var(--gray-400);margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.pc-price{font-size:15px;font-weight:800;color:var(--black)}
.pc-old-price{font-size:12px;color:var(--gray-400);text-decoration:line-through;margin-left:6px}
.pc-discount{font-size:11px;color:var(--primary);font-weight:700;margin-left:6px}
.pc-rating{display:flex;align-items:center;gap:4px;margin-top:6px}
.pc-stars{color:var(--star);font-size:11px;display:flex;gap:1px}
.pc-reviews{font-size:10px;color:var(--gray-400)}

/* === PRODUCTS GRID (Listing Page) === */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;padding:0 20px;max-width:1400px;margin:0 auto}

/* === SPECIAL OFFER BAR === */
.offer-bar{display:flex;align-items:center;gap:14px;margin:10px 20px;padding:14px 18px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border)}
.offer-icon{width:50px;height:50px;flex-shrink:0}
.offer-icon img{width:100%;height:100%;object-fit:contain}
.offer-icon i{font-size:28px;color:var(--primary)}
.offer-text h4{font-size:15px;font-weight:700;color:var(--black);display:flex;align-items:center;gap:6px}
.offer-text p{font-size:12px;color:var(--gray-500)}

/* === CATEGORY BANNER === */
.cat-banner{margin:10px 20px;border-radius:var(--radius);overflow:hidden;background:var(--gray-100);display:flex;align-items:center;padding:16px 20px;border:1px solid var(--border);gap:16px}
.cat-banner-img{width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--gray-200)}
.cat-banner-text{flex:1}
.cat-banner-text h3{font-size:16px;font-weight:800;color:var(--black);margin-bottom:4px}
.cat-banner-text p{font-size:12px;color:var(--gray-500)}
.visit-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 16px;border-radius:6px;font-size:12px;font-weight:700;background:var(--primary);color:#fff;border:none;transition:var(--transition)}

/* === TRENDING HEADER === */
.trending-header{background:var(--primary-gradient);margin:0 20px;border-radius:var(--radius) var(--radius) 0 0;padding:14px 18px;display:flex;justify-content:space-between;align-items:center}
.trending-header h3{color:#fff;font-size:16px;font-weight:800}
.trending-header .sub{font-size:11px;color:rgba(255,255,255,0.8);display:flex;align-items:center;gap:4px;margin-top:2px}

/* === NEW ARRIVALS BANNER === */
.arrival-banner{margin:14px 20px;border-radius:var(--radius);overflow:hidden;position:relative;min-height:140px;background:linear-gradient(135deg,#FFE8D6,#FFD5C2);display:flex;align-items:center;padding:24px}
.arrival-banner-text{z-index:1}
.arrival-banner-text h3{font-size:20px;font-weight:900;color:var(--black);margin-bottom:4px}
.arrival-banner-text p{font-size:13px;color:var(--gray-600);margin-bottom:14px}

/* === SPONSORED === */
.sponsored-section{padding:20px}
.sponsored-section h3{font-size:18px;font-weight:800;color:var(--black);margin-bottom:14px}
.sponsored-card{border-radius:var(--radius);overflow:hidden;position:relative;background:var(--gray-100);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}
.sponsored-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.3);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}
.sponsored-overlay .up-to{font-size:14px;font-weight:600;letter-spacing:2px;opacity:.9}
.sponsored-overlay .big-off{font-size:48px;font-weight:900;letter-spacing:-1px}

/* === BOTTOM NAV === */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--border);display:flex;z-index:999;padding:6px 0 env(safe-area-inset-bottom,0)}
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;font-size:10px;font-weight:600;color:var(--gray-400);transition:var(--transition);cursor:pointer}
.bnav-item i{font-size:20px;transition:var(--transition)}
.bnav-item.active{color:var(--primary)}
.bnav-item:hover{color:var(--primary)}

/* === FLASH === */
.alert-toast{position:fixed;top:70px;right:16px;z-index:9999;padding:12px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);animation:slideIn .35s ease;max-width:340px}
.alert-success{background:var(--green);color:#fff}
.alert-danger{background:var(--primary);color:#fff}
@keyframes slideIn{from{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}

/* === CONTAINER === */
.main-content{min-height:calc(100vh - 140px)}
.container{max-width:1400px;margin:0 auto;padding:0 20px}

/* === CARD (general) === */
.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;transition:var(--transition)}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);border:none;font-family:inherit}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);box-shadow:0 6px 20px rgba(248,55,88,0.3)}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}
.btn-outline:hover{background:var(--primary-light)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#059669;box-shadow:0 6px 20px rgba(16,185,129,0.3)}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-full{width:100%;justify-content:center}
.btn-cart{width:100%;padding:9px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px}
.btn-cart:hover{background:var(--primary-dark);box-shadow:0 4px 16px rgba(248,55,88,0.25)}

/* === FORMS === */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-control{width:100%;padding:11px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;transition:var(--transition);outline:none;background:var(--white)}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}

/* === AUTH === */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg)}
.auth-card{background:var(--white);border-radius:var(--radius-lg);padding:36px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo .logo-icon{width:56px;height:56px;background:var(--primary-gradient);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;margin:0 auto 12px}
.auth-logo h1{font-size:22px;font-weight:800;color:var(--black)}
.auth-logo p{color:var(--gray-500);font-size:13px;margin-top:4px}

/* === BADGES === */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;gap:4px}
.badge-success{background:var(--green-light);color:var(--green)}
.badge-warning{background:rgba(245,158,11,0.1);color:#D97706}
.badge-danger{background:var(--primary-light);color:var(--primary)}
.badge-info{background:rgba(59,130,246,0.1);color:#2563EB}

/* === CART === */
.cart-item{display:flex;gap:14px;padding:16px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:12px}
.cart-item-img{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}
.cart-item-name{font-weight:600;font-size:14px;margin-bottom:4px}
.cart-item-price{font-size:16px;font-weight:800;color:var(--black)}
.qty-control{display:inline-flex;align-items:center;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);overflow:hidden}
.qty-btn{width:32px;height:32px;border:none;background:var(--gray-50);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.qty-btn:hover{background:var(--primary-light);color:var(--primary)}
.qty-val{width:40px;text-align:center;font-weight:700;font-size:14px}

/* === TIMELINE === */
.order-timeline{position:relative;padding-left:28px}
.order-timeline::before{content:'';position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:var(--gray-200)}
.timeline-dot{position:absolute;left:-28px;width:18px;height:18px;border-radius:50%;background:var(--gray-200);border:3px solid var(--white);box-shadow:0 0 0 2px var(--gray-200)}
.timeline-dot.active{background:var(--green);box-shadow:0 0 0 2px var(--green-light)}
.timeline-dot.current{background:var(--primary);box-shadow:0 0 0 2px var(--primary-light);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 2px var(--primary-light)}50%{box-shadow:0 0 0 8px transparent}}

/* === SIDEBAR (Mobile Drawer) === */
.sidebar-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(4px);
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
}
.sidebar-overlay.active {
  opacity: 1;
  visibility: visible;
}
.sidebar-drawer {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 280px;
  background: var(--white);
  z-index: 2001;
  transform: translateX(-100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  box-shadow: 10px 0 30px rgba(0,0,0,0.1);
}
.sidebar-drawer.active {
  transform: translateX(0);
}
.sidebar-header {
  padding: 24px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 18px;
  font-weight: 800;
}
.sidebar-brand span {
  color: var(--primary);
}
.sidebar-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-50);
  border: none;
  font-size: 16px;
  color: var(--gray-500);
}
.sidebar-content {
  flex: 1;
  padding: 20px 0;
  overflow-y: auto;
}
.sidebar-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 24px;
  font-size: 14px;
  font-weight: 600;
  color: var(--gray-700);
  transition: var(--transition);
}
.sidebar-item:hover, .sidebar-item.active {
  background: var(--primary-light);
  color: var(--primary);
}
.sidebar-item i {
  font-size: 18px;
  width: 24px;
  text-align: center;
}
.sidebar-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 20px 24px 10px;
}
.sidebar-footer {
  padding: 20px 24px;
  border-top: 1px solid var(--border);
}
.sidebar-user {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.sidebar-user-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--primary-gradient);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
}
.sidebar-user-name {
  font-size: 14px;
  font-weight: 700;
}
.sidebar-user-email {
  font-size: 11px;
  color: var(--gray-500);
}

/* === RESPONSIVE === */
@media(max-width:768px){
  .products-grid{grid-template-columns:repeat(2,1fr);gap:10px}
}
@media(max-width:480px){
  .products-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:0 14px}
  .section-head{padding:16px 14px 12px}
  .search-wrap{padding:0 14px 10px}
  .header-inner{padding:10px 14px}
}
@media(min-width:769px){
  .bottom-nav{display:none}
  body{padding-bottom:0}
}
