/* ============================================================
   URBAN CLAVE — components.css
   UI Components: Buttons · Cards · Forms · Modals · Badges · etc.
   urbanclave.com
   ============================================================ */


/* ────────────────────────────────────────────────────────────
   1. BUTTONS
   ──────────────────────────────────────────────────────────── */

/* Base button */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-6);
  font-family: var(--font-primary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  line-height: 1;
  border-radius: var(--radius-md);
  border: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  text-align: center;
  transition:
    background-color var(--t-base),
    color var(--t-base),
    border-color var(--t-base),
    box-shadow var(--t-base),
    transform var(--t-fast),
    opacity var(--t-base);
  user-select: none;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}

.btn:active:not(:disabled) { transform: scale(0.97); }
.btn:disabled, .btn.is-disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Loading state */
.btn.is-loading {
  color: transparent !important;
  pointer-events: none;
}
.btn.is-loading::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

/* — Primary — */
.btn-primary {
  background-color: var(--clr-accent);
  color: var(--clr-white);
  border-color: var(--clr-accent);
}
.btn-primary:hover:not(:disabled) {
  background-color: var(--clr-accent-hover);
  border-color: var(--clr-accent-hover);
  box-shadow: var(--shadow-accent);
}

/* — Secondary — */
.btn-secondary {
  background-color: var(--clr-primary);
  color: var(--clr-white);
  border-color: var(--clr-primary);
}
.btn-secondary:hover:not(:disabled) {
  background-color: var(--clr-primary-light);
  border-color: var(--clr-primary-light);
}

/* — Outline — */
.btn-outline {
  background-color: transparent;
  color: var(--clr-accent);
  border-color: var(--clr-accent);
}
.btn-outline:hover:not(:disabled) {
  background-color: var(--clr-accent);
  color: var(--clr-white);
}

.btn-outline-dark {
  background-color: transparent;
  color: var(--clr-text);
  border-color: var(--clr-border-strong);
}
.btn-outline-dark:hover:not(:disabled) {
  border-color: var(--clr-text);
  background-color: var(--clr-gray-50);
}

/* — Ghost — */
.btn-ghost {
  background-color: transparent;
  color: var(--clr-text-secondary);
  border-color: transparent;
}
.btn-ghost:hover:not(:disabled) {
  background-color: var(--clr-gray-100);
  color: var(--clr-text);
}

/* — Success — */
.btn-success {
  background-color: var(--clr-success);
  color: var(--clr-white);
  border-color: var(--clr-success);
}

/* — White (on dark backgrounds) — */
.btn-white {
  background-color: var(--clr-white);
  color: var(--clr-accent);
  border-color: var(--clr-white);
}
.btn-white:hover:not(:disabled) {
  background-color: var(--clr-accent-light);
}

/* — Sizes — */
.btn-xs  { padding: var(--sp-1) var(--sp-3);  font-size: var(--fs-xs); border-radius: var(--radius-sm); }
.btn-sm  { padding: var(--sp-2) var(--sp-4);  font-size: var(--fs-sm); }
.btn-md  { padding: var(--sp-3) var(--sp-6);  font-size: var(--fs-sm); }      /* default */
.btn-lg  { padding: var(--sp-4) var(--sp-8);  font-size: var(--fs-md); }
.btn-xl  { padding: var(--sp-5) var(--sp-10); font-size: var(--fs-lg); }

/* Full width */
.btn-block { width: 100%; }

/* Icon-only button */
.btn-icon {
  padding: var(--sp-3);
  border-radius: var(--radius-full);
  min-width: 40px;
  height: 40px;
  font-size: 1rem;
}
.btn-icon.btn-sm { min-width: 32px; height: 32px; padding: var(--sp-2); font-size: 0.875rem; }
.btn-icon.btn-lg { min-width: 48px; height: 48px; padding: var(--sp-3); font-size: 1.2rem; }

/* Pill shape */
.btn-pill { border-radius: var(--radius-full); }

/* Buy Now / Add to Cart — special full-width CTA */
.btn-atc {
  background-color: var(--clr-accent);
  color: var(--clr-white);
  border-color: var(--clr-accent);
  padding: var(--sp-4) var(--sp-8);
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-lg);
  width: 100%;
  letter-spacing: var(--ls-wide);
}
.btn-atc:hover:not(:disabled) {
  background-color: var(--clr-accent-hover);
  box-shadow: var(--shadow-accent-lg);
  transform: translateY(-1px);
}
.btn-atc:active:not(:disabled) { transform: translateY(0) scale(0.98); }

.btn-buy-now {
  background-color: var(--clr-primary);
  color: var(--clr-white);
  border-color: var(--clr-primary);
  padding: var(--sp-4) var(--sp-8);
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-lg);
  width: 100%;
}
.btn-buy-now:hover:not(:disabled) {
  background-color: var(--clr-primary-light);
  box-shadow: var(--shadow-xl);
  transform: translateY(-1px);
}

/* Wishlist toggle */
.btn-wishlist {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background-color: var(--clr-white);
  border: 1px solid var(--clr-border);
  color: var(--clr-text-tertiary);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    color var(--t-base),
    border-color var(--t-base),
    background-color var(--t-base),
    transform var(--t-bounce);
  font-size: 0.9rem;
}
.btn-wishlist:hover,
.btn-wishlist.is-active {
  color: var(--clr-accent);
  border-color: var(--clr-accent);
  background-color: var(--clr-accent-light);
  transform: scale(1.1);
}


/* ────────────────────────────────────────────────────────────
   2. BADGES & TAGS
   ──────────────────────────────────────────────────────────── */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 2px var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-sm);
  line-height: 1.4;
  white-space: nowrap;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.badge-sale       { background-color: var(--clr-accent);        color: var(--clr-white); }
.badge-new        { background-color: var(--clr-info);          color: var(--clr-white); }
.badge-hot        { background-color: #FF6B35;                  color: var(--clr-white); }
.badge-flash      { background-color: var(--clr-secondary);     color: var(--clr-primary); }
.badge-out        { background-color: var(--clr-gray-500);      color: var(--clr-white); }
.badge-success    { background-color: var(--clr-success);       color: var(--clr-white); }
.badge-warning    { background-color: var(--clr-warning);       color: var(--clr-primary); }
.badge-pending    { background-color: var(--clr-info-light);    color: var(--clr-info); }
.badge-muted      { background-color: var(--clr-gray-100);      color: var(--clr-gray-600); }
.badge-bestseller { background-color: #FF6B35;                  color: var(--clr-white); }
.badge-featured   { background-color: var(--clr-success);       color: var(--clr-white); }

/* Discount percentage badge */
.badge-discount {
  background-color: var(--clr-accent);
  color: var(--clr-white);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  padding: 3px var(--sp-2);
  border-radius: var(--radius-sm);
}

/* Tag chip (clickable filter tag) */
.tag {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  background-color: var(--clr-gray-100);
  color: var(--clr-text-secondary);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  border-radius: var(--radius-full);
  border: 1px solid var(--clr-border);
  cursor: pointer;
  transition: all var(--t-base);
  white-space: nowrap;
}
.tag:hover {
  background-color: var(--clr-accent-light);
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}
.tag.is-active {
  background-color: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
}
.tag__remove {
  font-size: 0.7rem;
  opacity: 0.7;
  cursor: pointer;
  line-height: 1;
}
.tag__remove:hover { opacity: 1; }

/* Status dot */
.status-dot {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
}
.status-dot::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: currentColor;
  flex-shrink: 0;
}
.status-dot.success { color: var(--clr-success); }
.status-dot.warning { color: var(--clr-warning); }
.status-dot.error   { color: var(--clr-error); }
.status-dot.info    { color: var(--clr-info); }
.status-dot.muted   { color: var(--clr-text-tertiary); }


/* ────────────────────────────────────────────────────────────
   3. PRODUCT CARD
   ──────────────────────────────────────────────────────────── */

.product-card {
  background-color: var(--clr-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--clr-border);
  overflow: hidden;
  position: relative;
  transition:
    box-shadow var(--t-smooth),
    transform var(--t-smooth),
    border-color var(--t-smooth);
  display: flex;
  flex-direction: column;
}
.product-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-3px);
  border-color: var(--clr-border-strong);
}

/* Image container */
.product-card__img-wrap {
  position: relative;
  aspect-ratio: 1 / 1.1;
  overflow: hidden;
  background-color: var(--clr-gray-50);
  flex-shrink: 0;
}

.product-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--t-slow) ease;
}
.product-card:hover .product-card__img { transform: scale(1.05); }

/* Hover second image */
.product-card__img-hover {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity var(--t-smooth);
}
.product-card:hover .product-card__img-hover { opacity: 1; }

/* Badges on image */
.product-card__badges {
  position: absolute;
  top: var(--sp-2);
  left: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  z-index: 1;
}

/* Wishlist on image */
.product-card__wishlist {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  z-index: 1;
}

/* Quick add button — appears on hover */
.product-card__quick-add {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--clr-accent);
  color: var(--clr-white);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-align: center;
  padding: var(--sp-3);
  cursor: pointer;
  transform: translateY(100%);
  transition: transform var(--t-smooth);
  border: none;
  letter-spacing: var(--ls-wide);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
}
.product-card:hover .product-card__quick-add { transform: translateY(0); }
.product-card__quick-add:hover { background-color: var(--clr-accent-hover); }

/* Out of stock overlay */
.product-card__oos {
  position: absolute;
  inset: 0;
  background-color: rgba(255,255,255,0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}
.product-card__oos span {
  background-color: var(--clr-gray-700);
  color: var(--clr-white);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--radius-md);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
}

/* Card body */
.product-card__body {
  padding: var(--sp-3) var(--sp-4) var(--sp-4);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.product-card__brand {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-accent);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
}

.product-card__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  line-height: var(--lh-snug);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--t-base);
}
.product-card:hover .product-card__name { color: var(--clr-accent); }

.product-card__rating {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  margin-top: var(--sp-1);
}

.product-card__price {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: var(--sp-2);
}

.price-current {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  font-family: var(--font-secondary);
}
.price-mrp {
  font-size: var(--fs-sm);
  color: var(--clr-text-tertiary);
  text-decoration: line-through;
  font-family: var(--font-secondary);
}
.price-discount {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-success);
}


/* ────────────────────────────────────────────────────────────
   4. CATEGORY CARD
   ──────────────────────────────────────────────────────────── */

.category-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-4);
  background-color: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  cursor: pointer;
  text-align: center;
  transition:
    box-shadow var(--t-smooth),
    border-color var(--t-smooth),
    transform var(--t-smooth);
}
.category-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--clr-accent);
  transform: translateY(-4px);
}

.category-card__img {
  width: clamp(60px, 8vw, 90px);
  height: clamp(60px, 8vw, 90px);
  object-fit: contain;
  border-radius: var(--radius-full);
  background-color: var(--clr-gray-50);
  padding: var(--sp-2);
  transition: transform var(--t-smooth);
}
.category-card:hover .category-card__img { transform: scale(1.1); }

.category-card__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  line-height: var(--lh-snug);
}
.category-card__count {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
}


/* ────────────────────────────────────────────────────────────
   5. BRAND CARD
   ──────────────────────────────────────────────────────────── */

.brand-card {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-5);
  background-color: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  transition:
    box-shadow var(--t-base),
    border-color var(--t-base),
    transform var(--t-base);
  aspect-ratio: 3/2;
}
.brand-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-border-strong);
  transform: translateY(-2px);
}
.brand-card img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: grayscale(0.3);
  transition: filter var(--t-base);
}
.brand-card:hover img { filter: grayscale(0); }


/* ────────────────────────────────────────────────────────────
   6. RATING STARS
   ──────────────────────────────────────────────────────────── */

.stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--clr-gray-300);
  font-size: 0.85rem;
}
.stars .star-filled { color: var(--clr-secondary); }
.stars .star-half   { color: var(--clr-secondary); }

.rating-display {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.rating-display__score {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}
.rating-display__count {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
}

/* Interactive star rating (write review) */
.star-picker {
  display: flex;
  gap: var(--sp-1);
}
.star-picker__star {
  font-size: clamp(1.5rem, 3vw, 2rem);
  color: var(--clr-gray-200);
  cursor: pointer;
  transition: color var(--t-base), transform var(--t-base);
  line-height: 1;
}
.star-picker__star.is-active,
.star-picker__star:hover,
.star-picker__star:hover ~ .star-picker__star {
  color: var(--clr-secondary);
}
.star-picker__star:hover { transform: scale(1.2); }


/* ────────────────────────────────────────────────────────────
   7. FORMS
   ──────────────────────────────────────────────────────────── */

/* Form group */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

/* Label */
.form-label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
}
.form-label.required::after {
  content: ' *';
  color: var(--clr-accent);
}

/* Base input styles */
.form-input,
.form-textarea,
.form-select {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-family: var(--font-secondary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-regular);
  color: var(--clr-text);
  background-color: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-md);
  outline: none;
  transition:
    border-color var(--t-base),
    box-shadow var(--t-base),
    background-color var(--t-base);
  -webkit-appearance: none;
  appearance: none;
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--clr-text-tertiary);
  font-weight: var(--fw-regular);
}

.form-input:hover,
.form-textarea:hover,
.form-select:hover {
  border-color: var(--clr-border-strong);
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  border-color: var(--clr-border-focus);
  box-shadow: 0 0 0 3px rgba(232, 51, 60, 0.12);
}

/* Sizes */
.form-input-sm { padding: var(--sp-2) var(--sp-3); font-size: var(--fs-xs); }
.form-input-lg { padding: var(--sp-4) var(--sp-5); font-size: var(--fs-md); }

/* Textarea */
.form-textarea {
  resize: vertical;
  min-height: 100px;
  line-height: var(--lh-relaxed);
}

/* Select */
.form-select {
  cursor: pointer;
  padding-right: var(--sp-10);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%239CA3AF'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-3) center;
  background-size: 16px;
}

/* Input with icon */
.input-icon-wrap {
  position: relative;
}
.input-icon-wrap .form-input {
  padding-left: var(--sp-10);
}
.input-icon-wrap .input-icon {
  position: absolute;
  left: var(--sp-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--clr-text-tertiary);
  font-size: 1rem;
  pointer-events: none;
  transition: color var(--t-base);
}
.input-icon-wrap:focus-within .input-icon {
  color: var(--clr-accent);
}

/* Input with right action (password toggle) */
.input-action-wrap {
  position: relative;
}
.input-action-wrap .form-input { padding-right: var(--sp-12); }
.input-action {
  position: absolute;
  right: var(--sp-3);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--clr-text-tertiary);
  font-size: 1rem;
  padding: var(--sp-1);
  transition: color var(--t-base);
}
.input-action:hover { color: var(--clr-text); }

/* States */
.form-input.is-error,
.form-textarea.is-error,
.form-select.is-error {
  border-color: var(--clr-error);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}
.form-input.is-success,
.form-textarea.is-success {
  border-color: var(--clr-success);
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

/* Feedback messages */
.form-error {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-xs);
  color: var(--clr-error);
  animation: fadeInUp 0.2s ease;
}
.form-success-msg {
  font-size: var(--fs-xs);
  color: var(--clr-success);
}
.form-hint {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
}

/* Checkbox & Radio */
.form-check {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  user-select: none;
}
.form-check input[type="checkbox"],
.form-check input[type="radio"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  accent-color: var(--clr-accent);
  cursor: pointer;
}
.form-check__label {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  font-family: var(--font-secondary);
}

/* Custom checkbox (styled) */
.custom-check {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  cursor: pointer;
  user-select: none;
}
.custom-check input { display: none; }
.custom-check__box {
  width: 20px;
  height: 20px;
  border: 2px solid var(--clr-border-strong);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition:
    background-color var(--t-base),
    border-color var(--t-base);
  font-size: 0.65rem;
  color: transparent;
}
.custom-check input:checked + .custom-check__box {
  background-color: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
}
.custom-check input:checked + .custom-check__box::after {
  content: '✓';
}
.custom-check__label {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  line-height: var(--lh-snug);
}

/* Toggle switch */
.toggle-wrap {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.toggle {
  position: relative;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
  cursor: pointer;
}
.toggle input { display: none; }
.toggle__track {
  position: absolute;
  inset: 0;
  background-color: var(--clr-gray-300);
  border-radius: var(--radius-full);
  transition: background-color var(--t-smooth);
}
.toggle input:checked + .toggle__track { background-color: var(--clr-accent); }
.toggle__thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  background-color: var(--clr-white);
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-smooth);
}
.toggle input:checked ~ .toggle__thumb { transform: translateX(20px); }

/* OTP inputs */
.otp-inputs {
  display: flex;
  gap: var(--sp-3);
  justify-content: center;
}
.otp-input {
  width: clamp(44px, 8vw, 56px);
  height: clamp(48px, 9vw, 60px);
  text-align: center;
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  border: 2px solid var(--clr-border);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--t-base), box-shadow var(--t-base);
  caret-color: var(--clr-accent);
}
.otp-input:focus {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(232, 51, 60, 0.12);
}
.otp-input.is-filled { background-color: var(--clr-accent-light); }

/* Search form */
.search-form {
  display: flex;
  align-items: center;
  gap: 0;
  background-color: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  transition: border-color var(--t-base), box-shadow var(--t-base);
}
.search-form:focus-within {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(232, 51, 60, 0.1);
}
.search-form input {
  flex: 1;
  border: none;
  background: transparent;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-sm);
  outline: none;
  color: var(--clr-text);
}
.search-form button {
  background-color: var(--clr-accent);
  color: var(--clr-white);
  border: none;
  padding: var(--sp-3) var(--sp-5);
  cursor: pointer;
  font-size: 1rem;
  transition: background-color var(--t-base);
}
.search-form button:hover { background-color: var(--clr-accent-hover); }

/* Quantity stepper */
.qty-stepper {
  display: inline-flex;
  align-items: center;
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: var(--clr-white);
}
.qty-stepper__btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  cursor: pointer;
  background: none;
  border: none;
  color: var(--clr-text-secondary);
  transition: background-color var(--t-base), color var(--t-base);
  user-select: none;
  flex-shrink: 0;
}
.qty-stepper__btn:hover { background-color: var(--clr-gray-50); color: var(--clr-text); }
.qty-stepper__btn:disabled { opacity: 0.4; cursor: not-allowed; }
.qty-stepper__input {
  width: 48px;
  height: 36px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--clr-border);
  border-right: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  outline: none;
  background: transparent;
  -moz-appearance: textfield;
}
.qty-stepper__input::-webkit-inner-spin-button,
.qty-stepper__input::-webkit-outer-spin-button { -webkit-appearance: none; }

/* Price range slider */
.price-slider-wrap { padding: var(--sp-4) 0; }
.price-slider-labels {
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  font-family: var(--font-secondary);
  margin-bottom: var(--sp-2);
}
input[type="range"] {
  -webkit-appearance: none;
  width: 100%;
  height: 4px;
  background: var(--clr-gray-200);
  border-radius: var(--radius-full);
  outline: none;
  accent-color: var(--clr-accent);
}
input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--clr-accent);
  cursor: pointer;
  box-shadow: 0 0 0 3px rgba(232, 51, 60, 0.2);
  transition: box-shadow var(--t-base);
}
input[type="range"]::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 5px rgba(232, 51, 60, 0.25);
}


/* ────────────────────────────────────────────────────────────
   8. MODAL
   ──────────────────────────────────────────────────────────── */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background-color: var(--clr-overlay);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-smooth);
  backdrop-filter: blur(3px);
}
.modal-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

.modal {
  background-color: var(--clr-white);
  border-radius: var(--radius-2xl);
  width: min(90vw, 560px);
  max-height: 90dvh;
  overflow-y: auto;
  box-shadow: var(--shadow-2xl);
  transform: scale(0.92);
  transition: transform var(--t-bounce);
  position: relative;
}
.modal-backdrop.is-open .modal { transform: scale(1); }

.modal-lg { width: min(95vw, 800px); }
.modal-xl { width: min(98vw, 1100px); }
.modal-sm { width: min(90vw, 420px); }

.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
  position: sticky;
  top: 0;
  background-color: var(--clr-white);
  z-index: 1;
  border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
}
.modal__title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}
.modal__close {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  color: var(--clr-text-tertiary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--t-base), color var(--t-base);
  font-size: 1.2rem;
  border: none;
  background: none;
}
.modal__close:hover { background-color: var(--clr-gray-100); color: var(--clr-text); }

.modal__body {
  padding: var(--sp-6);
}
.modal__footer {
  padding: var(--sp-5) var(--sp-6);
  border-top: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
}

/* Bottom sheet modal (mobile) */
@media (max-width: 640px) {
  .modal-backdrop {
    align-items: flex-end;
    padding: 0;
  }
  .modal, .modal-lg, .modal-xl {
    width: 100%;
    border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
    max-height: 92dvh;
    transform: translateY(100%);
  }
  .modal-backdrop.is-open .modal,
  .modal-backdrop.is-open .modal-lg,
  .modal-backdrop.is-open .modal-xl {
    transform: translateY(0);
  }

  /* Pull indicator */
  .modal__header::before {
    content: '';
    position: absolute;
    top: var(--sp-2);
    left: 50%;
    transform: translateX(-50%);
    width: 36px;
    height: 4px;
    background-color: var(--clr-gray-300);
    border-radius: var(--radius-full);
  }
}


/* ────────────────────────────────────────────────────────────
   9. TOAST NOTIFICATIONS
   ──────────────────────────────────────────────────────────── */

.toast-container {
  position: fixed;
  top: calc(var(--header-h) + var(--sp-4));
  right: var(--sp-4);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  pointer-events: none;
  width: min(90vw, 360px);
}

.toast {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background-color: var(--clr-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-2xl);
  border-left: 4px solid var(--clr-info);
  pointer-events: auto;
  animation: fadeInRight 0.35s ease forwards;
  transition: opacity var(--t-smooth), transform var(--t-smooth);
}
.toast.is-removing {
  opacity: 0;
  transform: translateX(120%);
}

.toast-success { border-left-color: var(--clr-success); }
.toast-error   { border-left-color: var(--clr-error); }
.toast-warning { border-left-color: var(--clr-warning); }

.toast__icon {
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 1px;
}
.toast-success .toast__icon { color: var(--clr-success); }
.toast-error   .toast__icon { color: var(--clr-error); }
.toast-warning .toast__icon { color: var(--clr-warning); }
.toast .toast__icon         { color: var(--clr-info); }

.toast__body { flex: 1; }
.toast__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  margin-bottom: 2px;
}
.toast__msg {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  font-family: var(--font-secondary);
  line-height: var(--lh-snug);
}
.toast__close {
  flex-shrink: 0;
  color: var(--clr-text-tertiary);
  cursor: pointer;
  font-size: 0.75rem;
  padding: 2px;
  transition: color var(--t-base);
  line-height: 1;
  background: none;
  border: none;
}
.toast__close:hover { color: var(--clr-text); }

/* Progress bar under toast */
.toast__progress {
  position: absolute;
  bottom: 0;
  left: 4px;
  right: 0;
  height: 3px;
  background-color: var(--clr-gray-200);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  overflow: hidden;
}
.toast__progress-bar {
  height: 100%;
  background-color: var(--clr-accent);
  transform-origin: left;
}


/* ────────────────────────────────────────────────────────────
   10. TABS
   ──────────────────────────────────────────────────────────── */

.tabs {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.tabs-nav {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--clr-border);
  overflow-x: auto;
  scrollbar-width: none;
}
.tabs-nav::-webkit-scrollbar { display: none; }

.tabs-nav__btn {
  padding: var(--sp-3) var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-secondary);
  border: none;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--t-base);
  position: relative;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.tabs-nav__btn::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background-color: var(--clr-accent);
  transform: scaleX(0);
  transition: transform var(--t-smooth);
}
.tabs-nav__btn:hover { color: var(--clr-text); }
.tabs-nav__btn.is-active {
  color: var(--clr-accent);
}
.tabs-nav__btn.is-active::after { transform: scaleX(1); }

.tabs-count {
  font-size: var(--fs-xs);
  background-color: var(--clr-gray-100);
  color: var(--clr-text-secondary);
  padding: 1px 6px;
  border-radius: var(--radius-full);
}
.tabs-nav__btn.is-active .tabs-count {
  background-color: var(--clr-accent-light);
  color: var(--clr-accent);
}

.tabs-panel { display: none; padding-top: var(--sp-5); }
.tabs-panel.is-active { display: block; animation: fadeIn var(--t-smooth) ease; }

/* Pill-style tabs */
.tabs-nav.tabs-pills {
  background-color: var(--clr-gray-100);
  border-radius: var(--radius-full);
  padding: 4px;
  border-bottom: none;
  display: inline-flex;
  gap: var(--sp-1);
}
.tabs-nav.tabs-pills .tabs-nav__btn {
  border-radius: var(--radius-full);
  padding: var(--sp-2) var(--sp-4);
}
.tabs-nav.tabs-pills .tabs-nav__btn::after { display: none; }
.tabs-nav.tabs-pills .tabs-nav__btn.is-active {
  background-color: var(--clr-white);
  color: var(--clr-text);
  box-shadow: var(--shadow-sm);
}


/* ────────────────────────────────────────────────────────────
   11. ACCORDION
   ──────────────────────────────────────────────────────────── */

.accordion { border: 1px solid var(--clr-border); border-radius: var(--radius-lg); overflow: hidden; }

.accordion__item { border-bottom: 1px solid var(--clr-border); }
.accordion__item:last-child { border-bottom: none; }

.accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  width: 100%;
  padding: var(--sp-4) var(--sp-5);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  transition: background-color var(--t-base);
}
.accordion__trigger:hover { background-color: var(--clr-gray-50); }
.accordion__trigger.is-open { color: var(--clr-accent); }

.accordion__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  border: 1.5px solid var(--clr-border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  color: var(--clr-text-secondary);
  transition: transform var(--t-smooth), background-color var(--t-base), border-color var(--t-base);
}
.accordion__trigger.is-open .accordion__icon {
  transform: rotate(180deg);
  background-color: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
}

.accordion__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--t-smooth) cubic-bezier(0, 1, 0, 1);
}
.accordion__body.is-open {
  max-height: 2000px;
  transition: max-height 0.5s ease-in-out;
}

.accordion__content {
  padding: 0 var(--sp-5) var(--sp-5);
  font-size: var(--fs-sm);
  font-family: var(--font-secondary);
  color: var(--clr-text-secondary);
  line-height: var(--lh-relaxed);
}


/* ────────────────────────────────────────────────────────────
   12. BREADCRUMB
   ──────────────────────────────────────────────────────────── */

.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-1);
  list-style: none;
}
.breadcrumb__item {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-xs);
  font-family: var(--font-secondary);
}
.breadcrumb__item:not(:last-child)::after {
  content: '/';
  color: var(--clr-text-tertiary);
  margin-left: var(--sp-1);
}
.breadcrumb__link {
  color: var(--clr-text-secondary);
  transition: color var(--t-base);
}
.breadcrumb__link:hover { color: var(--clr-accent); }
.breadcrumb__current {
  color: var(--clr-text);
  font-weight: var(--fw-medium);
}


/* ────────────────────────────────────────────────────────────
   13. PAGINATION
   ──────────────────────────────────────────────────────────── */

.pagination {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  flex-wrap: wrap;
}

.page-btn {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  cursor: pointer;
  transition:
    background-color var(--t-base),
    color var(--t-base);
  border: 1px solid var(--clr-border);
  background-color: var(--clr-white);
  text-decoration: none;
}
.page-btn:hover:not(.is-disabled) {
  background-color: var(--clr-gray-100);
  color: var(--clr-text);
}
.page-btn.is-active {
  background-color: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
  font-weight: var(--fw-bold);
}
.page-btn.is-disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.page-ellipsis {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-text-tertiary);
  font-size: var(--fs-sm);
}


/* ────────────────────────────────────────────────────────────
   14. LOADER / SPINNER
   ──────────────────────────────────────────────────────────── */

.spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--clr-gray-200);
  border-top-color: var(--clr-accent);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  flex-shrink: 0;
}
.spinner-sm { width: 20px; height: 20px; border-width: 2px; }
.spinner-lg { width: 48px; height: 48px; border-width: 4px; }
.spinner-white { border-color: rgba(255,255,255,0.3); border-top-color: #fff; }

/* Page-level loading */
.page-loader {
  position: fixed;
  inset: 0;
  background-color: var(--clr-white);
  z-index: var(--z-top);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--sp-4);
}
.page-loader.is-hidden {
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-smooth);
}


/* ────────────────────────────────────────────────────────────
   15. SKELETON LOADERS
   ──────────────────────────────────────────────────────────── */

.skeleton {
  background: linear-gradient(
    90deg,
    var(--clr-gray-100) 25%,
    var(--clr-gray-200) 50%,
    var(--clr-gray-100) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-sm);
  display: block;
}

/* Specific skeleton shapes */
.skeleton-text   { height: 1em; margin-bottom: var(--sp-2); border-radius: var(--radius-sm); }
.skeleton-text-sm { height: 0.75em; width: 60%; margin-bottom: var(--sp-1); }
.skeleton-circle { border-radius: 50%; }
.skeleton-img    { aspect-ratio: 1; border-radius: var(--radius-lg); width: 100%; }
.skeleton-btn    { height: 40px; border-radius: var(--radius-md); width: 120px; }

/* Product card skeleton */
.skeleton-product-card {
  background-color: var(--clr-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--clr-border);
  overflow: hidden;
}
.skeleton-product-card .skeleton-img {
  aspect-ratio: 1 / 1.1;
  border-radius: 0;
}
.skeleton-product-card__body {
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}


/* ────────────────────────────────────────────────────────────
   16. PROGRESS BAR
   ──────────────────────────────────────────────────────────── */

.progress {
  width: 100%;
  height: 8px;
  background-color: var(--clr-gray-100);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.progress-sm { height: 4px; }
.progress-lg { height: 12px; }

.progress__bar {
  height: 100%;
  background-color: var(--clr-accent);
  border-radius: var(--radius-full);
  transition: width 0.6s ease;
  position: relative;
}
.progress__bar.success { background-color: var(--clr-success); }
.progress__bar.warning { background-color: var(--clr-warning); }

/* Rating bar (review breakdown) */
.rating-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.rating-bar__label {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  width: 24px;
  flex-shrink: 0;
}
.rating-bar__track {
  flex: 1;
  height: 8px;
  background-color: var(--clr-gray-100);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.rating-bar__fill {
  height: 100%;
  background-color: var(--clr-secondary);
  border-radius: var(--radius-full);
  transition: width 0.6s ease;
}
.rating-bar__count {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
  width: 28px;
  text-align: right;
  flex-shrink: 0;
}


/* ────────────────────────────────────────────────────────────
   17. ALERT / NOTICE
   ──────────────────────────────────────────────────────────── */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-size: var(--fs-sm);
  font-family: var(--font-secondary);
  line-height: var(--lh-snug);
}
.alert-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.alert-body { flex: 1; }
.alert-title { font-weight: var(--fw-semibold); font-family: var(--font-primary); margin-bottom: var(--sp-1); }
.alert-dismiss { cursor: pointer; color: inherit; opacity: 0.6; background: none; border: none; font-size: 0.75rem; transition: opacity var(--t-base); }
.alert-dismiss:hover { opacity: 1; }

.alert-success { background-color: var(--clr-success-light); border-color: var(--clr-success); color: #065F46; }
.alert-error   { background-color: var(--clr-error-light);   border-color: var(--clr-error);   color: #991B1B; }
.alert-warning { background-color: var(--clr-warning-light); border-color: var(--clr-warning); color: #92400E; }
.alert-info    { background-color: var(--clr-info-light);    border-color: var(--clr-info);    color: #1E40AF; }


/* ────────────────────────────────────────────────────────────
   18. MINI CART DROPDOWN
   ──────────────────────────────────────────────────────────── */

.mini-cart {
  position: absolute;
  top: calc(100% + var(--sp-2));
  right: 0;
  width: min(90vw, 380px);
  background-color: var(--clr-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  border: 1px solid var(--clr-border);
  z-index: var(--z-dropdown);
  display: none;
  animation: fadeInDown var(--t-smooth) ease;
  overflow: hidden;
}
.mini-cart.is-open { display: flex; flex-direction: column; }

.mini-cart__header {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mini-cart__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}
.mini-cart__count {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
}

.mini-cart__items {
  max-height: 320px;
  overflow-y: auto;
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.mini-cart-item {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: var(--sp-3);
  align-items: center;
}
.mini-cart-item__img {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: var(--radius-md);
  background-color: var(--clr-gray-50);
  flex-shrink: 0;
}
.mini-cart-item__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: var(--lh-snug);
  margin-bottom: var(--sp-1);
}
.mini-cart-item__meta {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
}
.mini-cart-item__price {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  text-align: right;
  white-space: nowrap;
}
.mini-cart-item__remove {
  font-size: 0.75rem;
  color: var(--clr-error);
  cursor: pointer;
  transition: opacity var(--t-base);
  background: none;
  border: none;
  padding: var(--sp-1);
}

.mini-cart__footer {
  padding: var(--sp-4) var(--sp-5);
  border-top: 1px solid var(--clr-border);
  background-color: var(--clr-gray-50);
}
.mini-cart__total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--sp-4);
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}
.mini-cart__total-amount { color: var(--clr-accent); }


/* ────────────────────────────────────────────────────────────
   19. IMAGE GALLERY (Product Detail)
   ──────────────────────────────────────────────────────────── */

.product-gallery {
  display: flex;
  gap: var(--sp-3);
  flex-direction: row-reverse;
}

.product-gallery__thumbs {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  width: clamp(60px, 8vw, 80px);
  flex-shrink: 0;
  overflow-y: auto;
  max-height: 480px;
  scrollbar-width: thin;
}

.product-gallery__thumb {
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: var(--radius-sm);
  border: 2px solid var(--clr-border);
  cursor: pointer;
  transition:
    border-color var(--t-base),
    opacity var(--t-base);
  opacity: 0.65;
  width: 100%;
}
.product-gallery__thumb:hover,
.product-gallery__thumb.is-active {
  border-color: var(--clr-accent);
  opacity: 1;
}

.product-gallery__main {
  flex: 1;
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background-color: var(--clr-gray-50);
  cursor: zoom-in;
}

.product-gallery__main-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform var(--t-slow) ease;
}
.product-gallery__main:hover .product-gallery__main-img {
  transform: scale(1.06);
}

/* Mobile: horizontal thumb strip */
@media (max-width: 640px) {
  .product-gallery { flex-direction: column; }
  .product-gallery__thumbs {
    flex-direction: row;
    width: auto;
    max-height: unset;
    overflow-x: auto;
    overflow-y: visible;
    height: clamp(56px, 10vw, 72px);
  }
  .product-gallery__thumb {
    width: clamp(56px, 10vw, 72px);
    height: 100%;
    flex-shrink: 0;
  }
}


/* ────────────────────────────────────────────────────────────
   20. COUNTDOWN TIMER
   ──────────────────────────────────────────────────────────── */

.countdown {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background-color: var(--clr-primary);
  border-radius: var(--radius-md);
  padding: var(--sp-2) var(--sp-4);
}

.countdown__unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  min-width: 44px;
  background-color: rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
  padding: var(--sp-2) var(--sp-3);
}
.countdown__num {
  font-size: var(--fs-xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  animation: countdownPulse 1s ease infinite;
}
.countdown__label {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
}
.countdown__sep {
  font-size: var(--fs-xl);
  font-weight: var(--fw-black);
  color: rgba(255,255,255,0.4);
  margin-bottom: 12px;
}


/* ────────────────────────────────────────────────────────────
   21. ORDER TRACKING STEPPER
   ──────────────────────────────────────────────────────────── */

.order-stepper {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}

.order-step {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  position: relative;
  padding-bottom: var(--sp-6);
}
.order-step:last-child { padding-bottom: 0; }
.order-step:last-child .order-step__line { display: none; }

.order-step__indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}
.order-step__dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background-color: var(--clr-gray-200);
  border: 2px solid var(--clr-gray-200);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: var(--clr-gray-400);
  transition: all var(--t-smooth);
  z-index: 1;
}
.order-step.is-done .order-step__dot {
  background-color: var(--clr-success);
  border-color: var(--clr-success);
  color: var(--clr-white);
}
.order-step.is-current .order-step__dot {
  background-color: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
  box-shadow: var(--shadow-accent);
  animation: pulse 2s ease infinite;
}

.order-step__line {
  width: 2px;
  flex: 1;
  min-height: var(--sp-6);
  background-color: var(--clr-gray-200);
  margin-top: 4px;
}
.order-step.is-done + .order-step .order-step__line,
.order-step.is-done .order-step__line {
  background-color: var(--clr-success);
}

.order-step__content { padding-top: 6px; flex: 1; }
.order-step__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
}
.order-step.is-current .order-step__title { color: var(--clr-accent); }
.order-step__time {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  font-family: var(--font-secondary);
  margin-top: var(--sp-1);
}
.order-step__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  font-family: var(--font-secondary);
  margin-top: var(--sp-1);
  line-height: var(--lh-snug);
}


/* ────────────────────────────────────────────────────────────
   22. SUPPORT TICKET CHAT
   ──────────────────────────────────────────────────────────── */

.chat-thread {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding: var(--sp-4);
  background-color: var(--clr-gray-50);
  border-radius: var(--radius-xl);
  border: 1px solid var(--clr-border);
}

.chat-bubble-wrap {
  display: flex;
  gap: var(--sp-3);
  max-width: 80%;
}
.chat-bubble-wrap.user-msg { margin-left: auto; flex-direction: row-reverse; }

.chat-bubble-wrap .avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: var(--clr-accent);
  color: var(--clr-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  flex-shrink: 0;
}
.chat-bubble-wrap.user-msg .avatar { background-color: var(--clr-primary); }

.chat-bubble {
  background-color: var(--clr-white);
  border-radius: var(--radius-lg) var(--radius-lg) var(--radius-lg) 4px;
  padding: var(--sp-3) var(--sp-4);
  box-shadow: var(--shadow-xs);
  border: 1px solid var(--clr-border);
}
.chat-bubble-wrap.user-msg .chat-bubble {
  background-color: var(--clr-primary);
  color: var(--clr-white);
  border-color: var(--clr-primary);
  border-radius: var(--radius-lg) var(--radius-lg) 4px var(--radius-lg);
}

.chat-bubble__text {
  font-size: var(--fs-sm);
  font-family: var(--font-secondary);
  line-height: var(--lh-relaxed);
}
.chat-bubble-wrap.user-msg .chat-bubble__text { color: rgba(255,255,255,0.9); }

.chat-bubble__time {
  font-size: var(--fs-xs);
  color: var(--clr-text-tertiary);
  margin-top: var(--sp-1);
  text-align: right;
}
.chat-bubble-wrap.user-msg .chat-bubble__time { color: rgba(255,255,255,0.5); }


/* ────────────────────────────────────────────────────────────
   23. MISC COMPONENTS
   ──────────────────────────────────────────────────────────── */

/* Divider with text */
.divider-text {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  color: var(--clr-text-tertiary);
  font-size: var(--fs-xs);
  font-family: var(--font-secondary);
}
.divider-text::before,
.divider-text::after {
  content: '';
  flex: 1;
  height: 1px;
  background-color: var(--clr-border);
}

/* Card wrapper (generic) */
.card {
  background-color: var(--clr-white);
  border-radius: var(--radius-xl);
  border: 1px solid var(--clr-border);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.card-body { padding: var(--sp-5) var(--sp-6); }
.card-header {
  padding: var(--sp-4) var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
  color: var(--clr-text);
}
.card-footer {
  padding: var(--sp-4) var(--sp-6);
  border-top: 1px solid var(--clr-border);
  background-color: var(--clr-gray-50);
}

/* Avatar */
.avatar {
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background-color: var(--clr-gray-200);
}
.avatar-xs  { width: 24px; height: 24px; }
.avatar-sm  { width: 32px; height: 32px; }
.avatar-md  { width: 40px; height: 40px; }
.avatar-lg  { width: 56px; height: 56px; }
.avatar-xl  { width: 80px; height: 80px; }
.avatar-2xl { width: 112px; height: 112px; }

/* Coupon card */
.coupon-card {
  border: 2px dashed var(--clr-accent);
  border-radius: var(--radius-lg);
  padding: var(--sp-4) var(--sp-5);
  background-color: var(--clr-accent-light);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  justify-content: space-between;
}
.coupon-card__code {
  font-size: var(--fs-lg);
  font-weight: var(--fw-black);
  color: var(--clr-accent);
  letter-spacing: var(--ls-wider);
  font-family: var(--font-mono);
}
.coupon-card__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  font-family: var(--font-secondary);
  margin-top: var(--sp-1);
}
.coupon-card__copy {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-accent);
  cursor: pointer;
  transition: opacity var(--t-base);
  white-space: nowrap;
  background: none;
  border: none;
}
.coupon-card__copy:hover { opacity: 0.7; }

/* Loyalty points badge */
.points-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  background-color: var(--clr-secondary-light);
  border: 1px solid rgba(245, 158, 11, 0.3);
  color: #92400E;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  padding: 2px var(--sp-2);
  border-radius: var(--radius-full);
}
.points-badge__icon { color: var(--clr-secondary); }


/* ────────────────────────────────────────────────────────────
   24. USER DROPDOWN (header)
   ──────────────────────────────────────────────────────────── */

.user-dropdown {
  position: absolute;
  top: calc(100% + var(--sp-2));
  right: 0;
  width: min(88vw, 280px);
  background-color: var(--clr-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  border: 1px solid var(--clr-border);
  z-index: var(--z-dropdown);
  overflow: hidden;
  display: none;
  animation: fadeInDown var(--t-smooth) ease;
}
.user-dropdown.is-open { display: block; }

.user-dropdown__header {
  padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(135deg, var(--clr-primary), var(--clr-primary-light));
}
.user-dropdown__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-white);
  margin-bottom: 2px;
}
.user-dropdown__email {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.5);
  font-family: var(--font-secondary);
  word-break: break-all;
}

.user-dropdown__links {
  padding: var(--sp-2) 0;
}
.user-dropdown__link {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-5);
  font-size: var(--fs-sm);
  font-family: var(--font-secondary);
  color: var(--clr-text-secondary);
  transition: background-color var(--t-base), color var(--t-base);
  text-decoration: none;
}
.user-dropdown__link:hover {
  background-color: var(--clr-gray-50);
  color: var(--clr-text);
}
.user-dropdown__link svg { flex-shrink: 0; color: var(--clr-text-tertiary); }
.user-dropdown__badge {
  margin-left: auto;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  background-color: var(--clr-accent-light);
  color: var(--clr-accent);
  padding: 2px var(--sp-2);
  border-radius: var(--radius-full);
}

.user-dropdown__footer {
  border-top: 1px solid var(--clr-border);
  padding: var(--sp-3) var(--sp-4);
}
.user-dropdown__logout {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  width: 100%;
  padding: var(--sp-2) var(--sp-2);
  font-size: var(--fs-sm);
  font-family: var(--font-secondary);
  color: var(--clr-error);
  background: none;
  border: none;
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: background-color var(--t-base);
}
.user-dropdown__logout:hover { background-color: var(--clr-error-light); }