/* ══════════════════════════════════════════════════════════════════════
   QwikGlam — Part 2 World-Class Feature Styles
   Matches the Couture Luxe design language from customer.css
   File: assets/css/qg-features-part2.css
   ══════════════════════════════════════════════════════════════════════ */

/* ── Inherit design tokens from customer.css ── */
:root {
  --p2-baby-pink:    #FADADD;
  --p2-blush:        #F9C0CB;
  --p2-rose:         #F0839E;
  --p2-lavender:     #E8D5F5;
  --p2-violet:       #C4A0E8;
  --p2-deep-violet:  #8B5DB8;
  --p2-plum:         #3B1F5E;
  --p2-gold:         #C9A86C;
  --p2-gold-lt:      #EDD898;
  --p2-champagne:    #FAF0DC;
  --p2-ivory:        #FFFAF7;
  --p2-ink:          #2A1040;
  --p2-text:         #4A2B68;
  --p2-muted:        #9B7BB8;
  --p2-border:       rgba(200, 168, 220, 0.22);
  --p2-grad-aurora:  linear-gradient(135deg, #FADADD 0%, #E8D5F5 35%, #C4A0E8 65%, #EDD898 100%);
  --p2-grad-btn:     linear-gradient(135deg, #8B5DB8 0%, #C4A0E8 50%, #C9A86C 100%);
  --p2-shadow:       0 12px 48px rgba(59, 31, 94, 0.12);
  --p2-radius:       18px;
  --p2-font:         "DM Sans", sans-serif;
  --p2-font-serif:   "Playfair Display", serif;
}


/* ════════════════════════════════════════════════════════════
   FEATURE 1.1 — LIVE SOCIAL PROOF BAR
════════════════════════════════════════════════════════════ */
#qg-social-proof-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  padding: 10px 20px;
  background: linear-gradient(90deg, rgba(250,218,221,0.4), rgba(232,213,245,0.4));
  border-bottom: 1px solid var(--p2-border);
  font-family: var(--p2-font);
  font-size: 13px;
  color: var(--p2-plum);
  flex-wrap: wrap;
}

[data-sp-today] {
  font-weight: 700;
  font-size: 18px;
  color: var(--p2-deep-violet);
  min-width: 40px;
  display: inline-block;
}

#qg-social-ticker {
  font-size: 12.5px;
  color: var(--p2-text);
  opacity: 1;
  transition: opacity 0.3s ease;
  max-width: 280px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.qg-last-booked-badge {
  display: inline-block;
  font-family: var(--p2-font);
  font-size: 11px;
  font-weight: 600;
  color: var(--p2-rose);
  background: rgba(240, 131, 158, 0.1);
  border: 1px solid rgba(240, 131, 158, 0.25);
  border-radius: 100px;
  padding: 3px 10px;
  margin-top: 6px;
}


/* ════════════════════════════════════════════════════════════
   FEATURE 1.3 — PROTECTION GUARANTEE SEAL
════════════════════════════════════════════════════════════ */
#qg-protection-seal {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background: var(--p2-ivory);
  border: 1.5px solid var(--p2-border);
  border-radius: 14px;
  cursor: pointer;
  font-family: var(--p2-font);
  font-size: 13.5px;
  font-weight: 600;
  color: var(--p2-plum);
  transition: box-shadow 0.25s, border-color 0.25s;
  position: relative;
}

#qg-protection-seal:hover {
  box-shadow: var(--p2-shadow);
  border-color: var(--p2-violet);
}

#qg-protection-seal::before {
  content: '🛡️';
  font-size: 20px;
}

#qg-protection-seal.qg-seal--gold {
  background: linear-gradient(135deg, #FAF0DC 0%, #FFF8E7 100%);
  border-color: rgba(201, 168, 108, 0.5);
  color: #7A5C00;
}

#qg-protection-seal.qg-seal--gold::before { content: '✨'; }

.qg-seal-tooltip {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 999;
  background: var(--p2-plum);
  border-radius: 14px;
  padding: 16px 20px;
  min-width: 260px;
  box-shadow: 0 24px 64px rgba(59, 31, 94, 0.25);
}

.qg-seal-benefit {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--p2-font);
  font-size: 13px;
  color: #fff;
  padding: 5px 0;
}

.qg-seal-benefit span:first-child { font-size: 16px; flex-shrink: 0; }


/* ════════════════════════════════════════════════════════════
   FEATURE 2.4 — PRICE ANCHORING
════════════════════════════════════════════════════════════ */
.qg-price-anchor {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}

.qg-salon-price {
  font-family: var(--p2-font);
  font-size: 13px;
  color: var(--p2-muted);
  text-decoration: line-through;
}

.qg-our-price {
  font-family: var(--p2-font-serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--p2-plum);
}

.qg-savings-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 100px;
  background: rgba(60, 150, 80, 0.12);
  border: 1px solid rgba(60, 150, 80, 0.25);
  font-family: var(--p2-font);
  font-size: 11.5px;
  font-weight: 700;
  color: #2A7A2A;
}

#qg-cart-savings {
  display: none;
  padding: 10px 16px;
  background: rgba(60, 150, 80, 0.08);
  border: 1px solid rgba(60, 150, 80, 0.2);
  border-radius: 12px;
  font-family: var(--p2-font);
  font-size: 13.5px;
  font-weight: 600;
  color: #2A7A2A;
  margin: 12px 0;
}


/* ════════════════════════════════════════════════════════════
   FEATURE 3.1 — COMBO RECOMMENDATIONS
════════════════════════════════════════════════════════════ */
#qg-combo-recs {
  margin: 24px 0;
}

.qg-combos-heading {
  font-family: var(--p2-font-serif);
  font-size: 18px;
  font-weight: 700;
  color: var(--p2-plum);
  margin: 0 0 16px;
}

.qg-combos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}

.qg-combo-card {
  background: var(--p2-ivory);
  border: 1.5px solid var(--p2-border);
  border-radius: 16px;
  overflow: hidden;
  transition: transform 0.25s, box-shadow 0.25s;
  display: flex;
  flex-direction: column;
}

.qg-combo-card:hover,
.qg-combo-card.qg-combo-adding {
  transform: translateY(-2px);
  box-shadow: var(--p2-shadow);
  border-color: var(--p2-violet);
}

.qg-combo-img {
  width: 100%;
  height: 100px;
  object-fit: cover;
  display: block;
}

.qg-combo-info {
  padding: 10px 12px 4px;
  flex: 1;
}

.qg-combo-name {
  display: block;
  font-family: var(--p2-font);
  font-size: 13px;
  font-weight: 600;
  color: var(--p2-plum);
  margin-bottom: 2px;
}

.qg-combo-price {
  display: block;
  font-family: var(--p2-font);
  font-size: 14px;
  font-weight: 700;
  color: var(--p2-deep-violet);
}

.qg-combo-pct {
  display: block;
  font-size: 11px;
  color: var(--p2-muted);
  margin-top: 3px;
}

.qg-combo-add {
  margin: 8px 12px 12px;
  padding: 8px;
  background: var(--p2-grad-btn);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--p2-font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.2s;
}

.qg-combo-add:hover:not(:disabled) { opacity: 0.9; transform: scale(1.02); }
.qg-combo-add.qg-combo-added {
  background: linear-gradient(135deg, #3a8a50, #5cb87a);
  cursor: default;
}


/* ════════════════════════════════════════════════════════════
   FEATURE 3.2 — EXPRESS 1-TAP REBOOK CARD
════════════════════════════════════════════════════════════ */
#qg-rebook-card {
  background: linear-gradient(135deg, #FFF0F3 0%, #F5E8FF 100%);
  border: 1.5px solid rgba(196, 160, 232, 0.35);
  border-radius: 20px;
  padding: 0;
  margin: 0 0 20px;
  overflow: hidden;
}

.qg-rebook-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
}

.qg-rebook-badge {
  display: inline-block;
  font-family: var(--p2-font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--p2-deep-violet);
  background: rgba(196, 160, 232, 0.2);
  padding: 3px 10px;
  border-radius: 100px;
  margin-bottom: 6px;
}

.qg-rebook-services {
  font-family: var(--p2-font);
  font-size: 15px;
  font-weight: 600;
  color: var(--p2-plum);
  margin: 0 0 4px;
}

.qg-rebook-artist {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--p2-font);
  font-size: 13px;
  color: var(--p2-text);
  margin: 0 0 4px;
}

.qg-rebook-artist-photo {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
  border: 1.5px solid var(--p2-border);
}

.qg-avail-dot { color: #3a8a50; font-size: 10px; }

.qg-rebook-nudge {
  font-family: var(--p2-font);
  font-size: 12px;
  color: var(--p2-muted);
  font-style: italic;
  margin: 0;
}

.qg-rebook-btn {
  flex-shrink: 0;
  padding: 12px 20px;
  background: var(--p2-grad-btn);
  color: #fff;
  border: none;
  border-radius: 14px;
  font-family: var(--p2-font);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: transform 0.2s, box-shadow 0.2s;
}

.qg-rebook-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(139, 93, 184, 0.35);
}

@media (max-width: 480px) {
  .qg-rebook-inner { flex-direction: column; align-items: flex-start; }
  .qg-rebook-btn   { width: 100%; }
}


/* ════════════════════════════════════════════════════════════
   FEATURE 3.4 — SMART TIME SLOT INTELLIGENCE
════════════════════════════════════════════════════════════ */
.qg-slot-badge,
.qg-slot-warning {
  display: block;
  font-family: var(--p2-font);
  font-size: 10.5px;
  font-weight: 600;
  border-radius: 100px;
  padding: 2px 8px;
  margin-top: 4px;
  white-space: nowrap;
}

.qg-slot-badge {
  color: var(--p2-deep-violet);
  background: rgba(196, 160, 232, 0.18);
}

.qg-slot-warning {
  color: #B85000;
  background: rgba(255, 150, 50, 0.12);
}

.qg-time-chip.qg-slot-best,
[data-slot-hour].qg-slot-best {
  border-color: var(--p2-gold) !important;
  background: linear-gradient(135deg, #FFF8E7, #FAF0DC) !important;
  box-shadow: 0 0 0 2px rgba(201, 168, 108, 0.3);
}


/* ════════════════════════════════════════════════════════════
   FEATURE 4.1 — DEDICATED ARTIST PROMPT
════════════════════════════════════════════════════════════ */
#qg-dedicated-prompt {
  background: linear-gradient(135deg, #FFF0F3, #F5E8FF);
  border: 1.5px solid rgba(196, 160, 232, 0.4);
  border-radius: 18px;
  padding: 20px;
  margin: 16px 0;
  text-align: center;
}

#qg-dedicated-prompt p {
  font-family: var(--p2-font-serif);
  font-size: 16px;
  color: var(--p2-plum);
  margin: 0 0 14px;
}

#qgSetDedicated {
  padding: 11px 24px;
  background: var(--p2-grad-btn);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-family: var(--p2-font);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  margin-right: 8px;
}

#qgDismissPrompt {
  padding: 11px 20px;
  background: transparent;
  border: 1.5px solid var(--p2-border);
  border-radius: 12px;
  font-family: var(--p2-font);
  font-size: 14px;
  color: var(--p2-muted);
  cursor: pointer;
}

.qg-dedicated-confirmed {
  color: #2A7A2A !important;
  font-family: var(--p2-font) !important;
  font-size: 15px !important;
}


/* ════════════════════════════════════════════════════════════
   FEATURE 5.4 — REFER & EARN WIDGET
════════════════════════════════════════════════════════════ */
#qg-referral-widget {
  background: var(--p2-grad-aurora);
  border-radius: 20px;
  padding: 24px;
  margin: 20px 0;
}

#qg-referral-widget h3 {
  font-family: var(--p2-font-serif);
  font-size: 20px;
  font-weight: 700;
  color: var(--p2-plum);
  margin: 0 0 6px;
}

[data-referral-label] {
  font-family: var(--p2-font);
  font-size: 13.5px;
  color: var(--p2-text);
  margin: 0 0 18px;
  display: block;
}

.qg-referral-code-box {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255, 255, 255, 0.7);
  border: 1.5px solid var(--p2-border);
  border-radius: 14px;
  padding: 12px 16px;
  margin-bottom: 14px;
}

[data-referral-code] {
  font-family: 'Courier New', monospace;
  font-size: 17px;
  font-weight: 700;
  color: var(--p2-plum);
  letter-spacing: 0.12em;
  flex: 1;
}

[data-copy-code] {
  padding: 8px 16px;
  background: var(--p2-plum);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--p2-font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
}

[data-copy-code]:hover { background: var(--p2-deep-violet); }

[data-share-whatsapp] {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: #25D366;
  color: #fff;
  border: none;
  border-radius: 12px;
  font-family: var(--p2-font);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.2s;
}

[data-share-whatsapp]::before { content: '💬'; }
[data-share-whatsapp]:hover   { opacity: 0.9; }

.qg-referral-stats {
  display: flex;
  gap: 20px;
  margin-top: 16px;
}

.qg-ref-stat {
  text-align: center;
}

.qg-ref-stat-num {
  font-family: var(--p2-font-serif);
  font-size: 24px;
  font-weight: 700;
  color: var(--p2-plum);
  display: block;
}

.qg-ref-stat-label {
  font-family: var(--p2-font);
  font-size: 11px;
  color: var(--p2-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}


/* ════════════════════════════════════════════════════════════
   MEMBERSHIP TIER BADGE
════════════════════════════════════════════════════════════ */
.qg-tier-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: 100px;
  font-family: var(--p2-font);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.qg-tier-bronze   { background: rgba(205, 127, 50, 0.12); color: #7A4000; border: 1px solid rgba(205,127,50,0.3); }
.qg-tier-silver   { background: rgba(150, 150, 160, 0.12); color: #4A4A60; border: 1px solid rgba(150,150,160,0.3); }
.qg-tier-gold     { background: rgba(201, 168, 108, 0.2); color: #7A5C00; border: 1px solid rgba(201,168,108,0.4); }
.qg-tier-platinum { background: var(--p2-grad-aurora); color: var(--p2-plum); border: 1px solid rgba(196,160,232,0.5); }
.qg-tier-luminary { background: linear-gradient(135deg, #3B1F5E, #8B5DB8); color: #fff; border: none; box-shadow: 0 4px 20px rgba(139,93,184,0.4); }


/* ════════════════════════════════════════════════════════════
   BEAUTY PASSPORT CARD (artist brief view)
════════════════════════════════════════════════════════════ */
.qg-client-brief {
  background: var(--p2-ivory);
  border: 1.5px solid var(--p2-border);
  border-radius: 18px;
  padding: 20px;
}

.qg-brief-section {
  margin-bottom: 16px;
}

.qg-brief-label {
  font-family: var(--p2-font);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--p2-muted);
  margin-bottom: 6px;
}

.qg-allergy-alert {
  background: #FFF0F3;
  border: 1.5px solid #F9C0CB;
  border-radius: 12px;
  padding: 12px 16px;
  font-family: var(--p2-font);
  font-size: 13.5px;
  color: #C05080;
  font-weight: 600;
}

.qg-allergy-alert::before { content: '⚠️ Allergy Alert: '; }
