/* ================================================================
   home-v3.css — New Sections Stylesheet
   How We Pop · Loyalty · Subscription · Reviews · Instagram
   Chatbot · Newsletter Popup · Language Toggle
================================================================ */

/* ── Variables (extend main style.css) ────────────────────────── */
:root {
  --card-bg: #0d0d0d;
  --card-inner: #141418;
}

/* ── Hero extras ───────────────────────────────────────────────── */
.hero-product-card {
  width: 240px; height: 320px; border-radius: 24px;
  background: linear-gradient(135deg, #1a0500, #3a1000);
  border: 2px solid rgba(255,87,34,.3);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px;
  box-shadow: 0 40px 80px rgba(0,0,0,.8), 0 0 60px rgba(255,87,34,.1);
  padding: 24px; text-align: center;
}
.hero-product-card-name { font-family: var(--font-display); font-size: 1.4rem; letter-spacing: .1em; }
.hero-product-card-sub  { font-size: .72rem; letter-spacing: .15em; color: rgba(255,255,255,.45); text-transform: uppercase; }
.hero-social-proof {
  display: flex; align-items: center; gap: 10px;
  margin-top: 24px; font-size: .82rem; color: rgba(255,255,255,.5);
}
.hero-social-proof span:first-child { color: #FFD700; letter-spacing: 1px; }

/* ── Product extras ────────────────────────────────────────────── */
.product-save-pct {
  display: inline-block; background: rgba(0,200,83,.12);
  color: #00C853; border-radius: 99px; padding: 1px 8px;
  font-size: .68rem; font-weight: 800; letter-spacing: .06em;
  margin-left: 6px;
}
.stock-low-badge { background: #FF9800 !important; top: 52px !important; }
.stock-out-badge { background: #444 !important; top: 52px !important; }
.btn-sold-out    { opacity: .4 !important; cursor: not-allowed !important; }
.product-placeholder {
  width: 180px; height: 240px; border-radius: 20px;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; position: relative; z-index: 1;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  transition: transform var(--transition);
}
.product-card:hover .product-placeholder { transform: translateY(-12px) scale(1.04); }

/* ── Empty product state ───────────────────────────────────────── */
.empty-products {
  text-align: center; padding: 80px 20px;
  max-width: 480px; margin: 0 auto;
}
.ep-icon  { font-size: 4rem; margin-bottom: 16px; }
.ep-title { font-family: var(--font-display); font-size: 1.8rem; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 10px; }
.ep-desc  { color: rgba(255,255,255,.5); line-height: 1.7; }

/* ── Section helpers ───────────────────────────────────────────── */
.section-center { text-align: center; max-width: 600px; margin: 0 auto 52px; padding: 0 5vw; }
.section-sub    { color: rgba(255,255,255,.5); line-height: 1.7; margin-top: 14px; font-size: 1rem; }

/* ── How We Pop ────────────────────────────────────────────────── */
#how-we-pop { padding: 100px 5vw; background: var(--grey); }
.process-grid {
  display: flex; align-items: center; justify-content: center;
  gap: 0; max-width: 1100px; margin: 0 auto;
  flex-wrap: wrap; gap: 16px;
}
.process-step {
  flex: 1; min-width: 180px; max-width: 220px;
  background: var(--black); border-radius: var(--radius);
  padding: 32px 20px; text-align: center;
  border: 1px solid rgba(255,255,255,.05);
  position: relative; overflow: hidden;
  transition: transform var(--transition), border-color var(--transition);
}
.process-step:hover { transform: translateY(-6px); border-color: rgba(232,0,28,.3); }
.ps-num {
  position: absolute; top: 12px; right: 14px;
  font-family: var(--font-display); font-size: 2.5rem;
  color: rgba(255,255,255,.04); letter-spacing: .02em; line-height: 1;
}
.ps-icon  { font-size: 2.4rem; margin-bottom: 14px; }
.ps-title { font-family: var(--font-display); font-size: 1.1rem; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 10px; }
.ps-desc  { font-size: .82rem; line-height: 1.6; color: rgba(255,255,255,.5); }
.process-arrow { font-size: 1.5rem; color: rgba(232,0,28,.4); flex-shrink: 0; padding: 0 4px; }
@media (max-width:768px) { .process-arrow { display:none; } .process-grid { gap: 12px; } .process-step { min-width: 140px; } }

/* ── Pincode Widget ────────────────────────────────────────────── */
.pincode-widget {
  margin-top: 28px; background: var(--card-bg);
  border-radius: var(--radius); padding: 18px 20px;
  border: 1px solid rgba(255,255,255,.06);
}
.pw-label { font-size: .82rem; font-weight: 700; color: rgba(255,255,255,.6); margin-bottom: 10px; }
.pw-row   { display: flex; gap: 8px; }
.pw-row input {
  flex: 1; background: var(--grey); border: 1.5px solid rgba(255,255,255,.08);
  border-radius: 10px; padding: 10px 14px; color: var(--white);
  font-family: var(--font-body); font-size: .9rem;
  transition: border-color var(--transition);
}
.pw-row input:focus { outline: none; border-color: var(--red); }
.pw-row button {
  background: var(--red); border: none; color: white;
  padding: 10px 18px; border-radius: 10px; font-family: var(--font-body);
  font-size: .85rem; font-weight: 700; cursor: pointer;
  transition: all var(--transition);
}
.pw-row button:hover { background: var(--white); color: var(--black); }
#pincodeResult { margin-top: 8px; font-size: .82rem; font-weight: 600; }
.pin-ok       { color: #00C853; }
.pin-error    { color: #ff6b6b; }
.pin-checking { color: rgba(255,255,255,.4); }

/* ── Loyalty ────────────────────────────────────────────────────── */
#loyalty { padding: 100px 5vw; background: linear-gradient(180deg,#050505 0%,#0a0000 50%,#050505 100%); }
.loyalty-wrap {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center; max-width: 1100px; margin: 0 auto;
}
.loyalty-tiers { margin: 28px 0; display: flex; flex-direction: column; gap: 16px; }
.lt-item { display: flex; align-items: center; gap: 14px; }
.lt-icon { font-size: 1.6rem; width: 40px; text-align: center; flex-shrink: 0; }
.lt-name { font-weight: 800; font-size: .9rem; margin-bottom: 2px; }
.lt-desc { font-size: .78rem; color: rgba(255,255,255,.45); }

.loyalty-card {
  background: linear-gradient(135deg, #1a0000, #0d0d0d);
  border-radius: 20px; padding: 28px;
  border: 1px solid rgba(232,0,28,.2);
  box-shadow: 0 24px 60px rgba(0,0,0,.5);
  position: relative; overflow: hidden;
}
.loyalty-card::before { content:''; position:absolute; top:-40px; right:-40px; width:120px; height:120px; background:radial-gradient(circle,rgba(232,0,28,.1),transparent); border-radius:50%; }
.lc-header  { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.lc-badge   { background: rgba(232,0,28,.12); border: 1px solid rgba(232,0,28,.25); border-radius: 99px; padding: 4px 12px; font-size: .7rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--red); }
.lc-pts-label { font-size: .68rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 6px; }
.lc-pts     { font-family: var(--font-display); font-size: 3rem; letter-spacing: .04em; margin-bottom: 20px; }
.lc-how     { display: flex; gap: 0; background: rgba(255,255,255,.04); border-radius: 12px; overflow: hidden; margin-bottom: 20px; }
.lc-hi      { flex: 1; padding: 14px; text-align: center; }
.lc-div     { width: 1px; background: rgba(255,255,255,.06); }
.lc-n       { display: block; font-family: var(--font-display); font-size: 1.4rem; color: var(--red); }
.lc-t       { font-size: .72rem; color: rgba(255,255,255,.4); margin-top: 4px; }
.lc-cta     { display: block; text-align: center; background: rgba(255,255,255,.06); border-radius: 10px; padding: 10px; font-size: .85rem; font-weight: 700; transition: all var(--transition); }
.lc-cta:hover { background: var(--red); color: white; }

/* ── Subscription ──────────────────────────────────────────────── */
#subscription {
  padding: 100px 5vw; position: relative;
  background: var(--grey); overflow: hidden;
}
.sub-glow {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(232,0,28,.06) 0%, transparent 70%);
  pointer-events: none;
}
.sub-wrap {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center; max-width: 1100px; margin: 0 auto; position: relative;
}
.sub-perks { margin: 20px 0; display: flex; flex-direction: column; gap: 10px; }
.sp-item   { display: flex; align-items: center; gap: 10px; font-size: .9rem; color: rgba(255,255,255,.7); }
.sp-check  { color: #00C853; font-weight: 800; font-size: 1rem; flex-shrink: 0; }
.sub-plans { display: flex; gap: 12px; margin-top: 20px; flex-wrap: wrap; }
.sp-plan   {
  flex: 1; min-width: 120px; background: var(--black);
  border: 2px solid rgba(255,255,255,.08); border-radius: 14px;
  padding: 16px; text-align: center; cursor: pointer;
  transition: all var(--transition);
}
.sp-plan:hover  { border-color: rgba(232,0,28,.3); }
.sp-plan.active { border-color: var(--red); background: rgba(232,0,28,.06); }
.sp-pname  { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 6px; }
.sp-pprice { font-family: var(--font-display); font-size: 1.4rem; margin-bottom: 4px; }
.sp-pnote  { font-size: .7rem; color: #00C853; font-weight: 700; }

/* Subscription box visual */
.sub-box-visual { display: flex; justify-content: center; align-items: center; position: relative; }
.sbv-box {
  width: 220px; position: relative;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,.6));
  animation: floatChip 4s ease-in-out infinite;
}
.sbv-lid {
  height: 30px; background: linear-gradient(135deg,#e8001c,#8B0010);
  border-radius: 12px 12px 0 0; margin: 0 8px;
}
.sbv-body {
  background: linear-gradient(135deg,#1a0000,#0d0d0d);
  border-radius: 0 0 16px 16px; border: 2px solid rgba(232,0,28,.2);
  border-top: none; padding: 24px; text-align: center;
}
.sbv-chip { font-size: 2rem; margin: 4px; display: inline-block; }
.sbv-badge {
  position: absolute; top: 0; right: -10px;
  background: var(--red); color: white; border-radius: 50%;
  width: 56px; height: 56px; display: flex; align-items: center;
  justify-content: center; font-family: var(--font-display);
  font-size: .85rem; font-weight: 700; box-shadow: 0 8px 24px rgba(232,0,28,.4);
}

/* ── Review Photo Grid ─────────────────────────────────────────── */
#reviews-section { padding: 100px 5vw; overflow: hidden; }
.review-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px,1fr));
  gap: 12px; max-width: 1100px; margin: 0 auto 40px;
}
.rpg-card {
  aspect-ratio: 1; border-radius: 16px; overflow: hidden;
  position: relative; cursor: pointer;
}
.rpg-card img { width:100%; height:100%; object-fit:cover; transition: transform .4s; }
.rpg-card:hover img { transform: scale(1.06); }
.rpg-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 50%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 16px; opacity: 0; transition: opacity .3s;
}
.rpg-card:hover .rpg-overlay { opacity: 1; }
.rpg-stars { color: #FFD700; font-size: .9rem; letter-spacing: 1px; margin-bottom: 4px; }
.rpg-text  { font-size: .78rem; color: rgba(255,255,255,.85); line-height: 1.4; margin-bottom: 6px; }
.rpg-name  { font-size: .7rem; font-weight: 700; color: rgba(255,255,255,.6); }

.review-cta-strip {
  display: flex; align-items: center; gap: 28px;
  background: linear-gradient(135deg, rgba(232,0,28,.08), rgba(232,0,28,.02));
  border: 1px solid rgba(232,0,28,.18); border-radius: 20px;
  padding: 24px 32px; max-width: 900px; margin: 40px auto 0;
  flex-wrap: wrap;
}
.rcs-left  { display: flex; align-items: center; gap: 16px; flex: 1; min-width: 220px; }
.rcs-icon  { font-size: 2.4rem; flex-shrink: 0; }
.rcs-title { font-family: var(--font-display); font-size: 1.1rem; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 4px; }
.rcs-sub   { font-size: .85rem; color: rgba(255,255,255,.55); line-height: 1.5; }

/* ── Instagram ─────────────────────────────────────────────────── */
#instagram { padding: 80px 5vw; background: var(--grey); }
.ig-handle-link {
  display: inline-block; margin-top: 10px; font-size: .9rem;
  color: rgba(255,255,255,.45); transition: color var(--transition);
}
.ig-handle-link:hover { color: var(--red); }
.insta-grid {
  display: grid; grid-template-columns: repeat(6,1fr);
  gap: 4px; max-width: 1100px; margin: 32px auto 0;
}
.insta-item {
  aspect-ratio: 1; border-radius: 8px; overflow: hidden;
  position: relative; cursor: pointer; display: block;
  background: var(--black);
}
.insta-overlay {
  position: absolute; inset: 0; background: rgba(232,0,28,.65);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity var(--transition);
}
.insta-item:hover .insta-overlay { opacity: 1; }
.insta-heart { font-size: 2rem; color: white; }
.insta-placeholder {
  width:100%; height:100%; min-height:80px;
  background: linear-gradient(135deg,#1a1a1a,#252525);
  display:flex; align-items:center; justify-content:center;
  font-size:2.2rem;
}

/* ── Newsletter Popup ──────────────────────────────────────────── */
#newsletter-popup {
  position: fixed; inset: 0; z-index: 5000;
  display: none; align-items: center; justify-content: center;
  padding: 20px;
}
#newsletter-popup.show { display: flex; }
.np-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.8); backdrop-filter: blur(6px);
}
.np-box {
  position: relative; z-index: 1;
  background: #0d0d0d; border-radius: 24px;
  padding: 44px 36px; max-width: 420px; width: 100%;
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 40px 80px rgba(0,0,0,.7);
  text-align: center; animation: fadeUp .4s ease;
}
.np-close {
  position: absolute; top: 14px; right: 14px;
  background: rgba(255,255,255,.06); border: none;
  color: rgba(255,255,255,.5); width: 32px; height: 32px;
  border-radius: 50%; cursor: pointer; font-size: 1rem;
  transition: all var(--transition);
}
.np-close:hover { background: var(--red); color: white; }
.np-emoji { font-size: 3rem; margin-bottom: 14px; }
.np-title { font-family: var(--font-display); font-size: 1.6rem; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 10px; }
.np-desc  { color: rgba(255,255,255,.5); font-size: .88rem; line-height: 1.6; margin-bottom: 20px; }
.np-form  { display: flex; gap: 8px; flex-wrap: wrap; }
.np-form input { flex: 1; min-width: 180px; background: var(--grey); border: 1.5px solid rgba(255,255,255,.08); border-radius: 10px; padding: 11px 14px; color: white; font-family: var(--font-body); }

/* ── Language Toggle ───────────────────────────────────────────── */
.lang-toggle {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.7); padding: 7px 14px; border-radius: 99px;
  font-family: var(--font-body); font-size: .78rem; font-weight: 700;
  cursor: pointer; transition: all var(--transition);
}
.lang-toggle:hover { background: rgba(255,255,255,.12); color: white; }

/* ── AI Chatbot ────────────────────────────────────────────────── */
#chatbot-widget {
  position: fixed; bottom: 28px; right: 28px; z-index: 3000;
}
.chatbot-toggle {
  width: 58px; height: 58px; border-radius: 50%;
  background: var(--red); border: none; cursor: pointer;
  font-size: 1.5rem; box-shadow: 0 8px 32px rgba(232,0,28,.5);
  transition: all var(--transition); position: relative;
  display: flex; align-items: center; justify-content: center;
}
.chatbot-toggle:hover { transform: scale(1.1); box-shadow: 0 12px 40px rgba(232,0,28,.6); }
.chatbot-badge {
  position: absolute; top: -4px; right: -4px;
  background: white; color: var(--red); border-radius: 50%;
  width: 20px; height: 20px; font-size: .7rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.chatbot-window {
  display: none; position: absolute; bottom: 72px; right: 0;
  width: 340px; background: #0d0d0d; border-radius: 20px;
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 24px 60px rgba(0,0,0,.7);
  flex-direction: column; overflow: hidden;
  animation: fadeUp .3s ease;
}
.chatbot-window.open { display: flex; }
.chatbot-header {
  background: var(--red); padding: 14px 16px;
  display: flex; align-items: center; justify-content: space-between;
}
.chatbot-avatar { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.chatbot-name   { font-weight:800; font-size:.9rem; }
.chatbot-status { font-size:.7rem; color:rgba(255,255,255,.7); }
.chatbot-messages {
  flex: 1; overflow-y: auto; padding: 16px;
  display: flex; flex-direction: column; gap: 10px;
  max-height: 280px;
}
.chat-msg { display: flex; }
.bot-msg  { justify-content: flex-start; }
.user-msg { justify-content: flex-end; }
.chat-bubble {
  max-width: 78%; padding: 10px 14px; border-radius: 16px;
  font-size: .85rem; line-height: 1.5;
}
.bot-msg  .chat-bubble { background: rgba(255,255,255,.07); border-radius: 4px 16px 16px 16px; }
.user-msg .chat-bubble { background: var(--red); color: white; border-radius: 16px 4px 16px 16px; }
.chat-typing { display: flex; gap: 4px; align-items: center; padding: 10px 14px; }
.chat-dot { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.3); animation: dotBounce .8s ease-in-out infinite; }
.chat-dot:nth-child(2) { animation-delay:.15s; }
.chat-dot:nth-child(3) { animation-delay:.3s; }
@keyframes dotBounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
.chatbot-quick { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 12px 10px; }
.chatbot-quick button {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.7); border-radius: 99px; padding: 5px 12px;
  font-size: .72rem; font-weight: 700; cursor: pointer;
  transition: all var(--transition);
}
.chatbot-quick button:hover { background: var(--red); border-color: var(--red); color: white; }
.chatbot-input-row {
  display: flex; gap: 8px; padding: 10px 12px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.chatbot-input-row input {
  flex: 1; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1); border-radius: 10px;
  padding: 9px 12px; color: white; font-family: var(--font-body); font-size: .85rem;
}
.chatbot-input-row input:focus { outline: none; border-color: var(--red); }
.chatbot-input-row button {
  background: var(--red); border: none; color: white;
  width: 36px; height: 36px; border-radius: 10px;
  cursor: pointer; font-size: 1rem; transition: all var(--transition);
}
.chatbot-input-row button:hover { background: var(--white); color: var(--black); }

/* ── Responsive ────────────────────────────────────────────────── */
@media(max-width:1024px) {
  .loyalty-wrap, .sub-wrap { grid-template-columns:1fr; gap:48px; }
  .sub-right, .loyalty-right { display:flex; justify-content:center; }
  .insta-grid { grid-template-columns:repeat(3,1fr); }
}
@media(max-width:768px) {
  #how-we-pop, #loyalty, #subscription, #reviews-section, #instagram { padding:60px 5vw; }
  .review-photo-grid { grid-template-columns:repeat(2,1fr); }
  .insta-grid { grid-template-columns:repeat(2,1fr); }
  .review-cta-strip { flex-direction:column; text-align:center; }
  .rcs-left { flex-direction:column; text-align:center; }
  .chatbot-window { width: calc(100vw - 56px); right: -14px; }
}
@media(max-width:480px) {
  .process-grid { gap:10px; }
  .sbv-box { width:160px; }
  .review-photo-grid { grid-template-columns:1fr 1fr; }
}
