/* ============================================================
   CatchyDigits UI — Design System
   Applies dark/light theme over existing Bootstrap scaffold
   ============================================================ */

/* ---- THEME TOKENS ---- */
html[data-theme="dark"] {
  --bg:         oklch(0.16 0.008 260);
  --bg-2:       oklch(0.19 0.008 260);
  --bg-3:       oklch(0.22 0.008 260);
  --surface:    oklch(0.24 0.009 260);
  --hair:       oklch(0.30 0.008 260);
  --hair-2:     oklch(0.35 0.008 260);
  --mute:       oklch(0.62 0.008 260);
  --text-2:     oklch(0.78 0.008 260);
  --text:       oklch(0.96 0.005 90);
  --accent:     oklch(0.78 0.19 135);
  --accent-2:   oklch(0.68 0.18 135);
  --accent-ink: oklch(0.12 0.06 150);
  --warn:       oklch(0.78 0.16 50);
  --rose:       oklch(0.72 0.18 20);
  --shadow-ink: oklch(0 0 0 / 0.55);
  --watermark:  oklch(0.78 0.19 135 / 0.06);
  --link:       oklch(0.78 0.19 135);
}
html[data-theme="light"] {
  --bg:         oklch(0.99 0.003 90);
  --bg-2:       oklch(0.97 0.004 90);
  --bg-3:       oklch(0.94 0.005 90);
  --surface:    oklch(0.92 0.005 90);
  --hair:       oklch(0.88 0.005 90);
  --hair-2:     oklch(0.80 0.006 90);
  --mute:       oklch(0.52 0.008 260);
  --text-2:     oklch(0.34 0.008 260);
  --text:       oklch(0.17 0.010 260);
  --accent:     oklch(0.52 0.18 135);
  --accent-2:   oklch(0.44 0.17 135);
  --accent-ink: oklch(0.99 0.003 90);
  --warn:       oklch(0.55 0.16 50);
  --rose:       oklch(0.55 0.18 20);
  --shadow-ink: oklch(0.3 0.02 260 / 0.14);
  --watermark:  oklch(0.52 0.18 135 / 0.08);
  --link:       oklch(0.42 0.18 135);
}

:root {
  --r-sm: 8px;
  --r:    12px;
  --r-lg: 18px;
  --r-xl: 26px;
  --mono: 'JetBrains Mono', ui-monospace, 'Cascadia Code', Menlo, monospace;
  --sans: 'Inter', system-ui, -apple-system, sans-serif;
  --serif: 'Instrument Serif', 'Times New Roman', serif;
}

/* ---- RESET & BASE ---- */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  overflow-x: hidden;
}

body {
  background: var(--bg) !important;
  color: var(--text) !important;
  font-family: var(--sans) !important;
  font-feature-settings: "cv11","ss01","ss03";
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  transition: background-color .25s ease, color .25s ease;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(1100px 600px at 80% -10%, var(--accent) 0%, transparent 60%),
    radial-gradient(800px 500px at -10% 20%, oklch(0.55 0.12 260 / 0.07), transparent 60%);
  opacity: .07;
  pointer-events: none;
  z-index: 0;
}

#root, .main-wrapper { position: relative; z-index: 1; }

/* ---- TYPOGRAPHY ---- */
.mono { font-family: var(--mono) !important; font-variant-numeric: tabular-nums; }
.serif { font-family: var(--serif) !important; font-style: italic; font-weight: 400; }

h1, h2, h3, h4, h5, h6 { color: var(--text); font-family: var(--sans); }
p, span, label, li { color: var(--text-2); }
a { color: var(--link); transition: opacity .15s; }
a:hover { opacity: .8; text-decoration: none; }

::selection { background: var(--accent); color: var(--accent-ink); }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: var(--hair); border-radius: 8px; }
::-webkit-scrollbar-track { background: transparent; }

button, input, select, textarea { font-family: var(--sans) !important; color: var(--text) !important; }

/* ---- ANIMATIONS ---- */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes pulseDot {
  0%,100% { opacity: 1; transform: scale(1); }
  50%     { opacity: .4; transform: scale(.82); }
}
@keyframes cdTicker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes shimmer {
  from { background-position: -200% 0; }
  to   { background-position: 200% 0; }
}

.reveal { animation: fadeUp .45s ease-out both; }
.dot-live { animation: pulseDot 1.6s ease-in-out infinite; }

/* ---- PRELOADER ---- */
#preloader {
  background: var(--bg) !important;
}
.loader-icon {
  border-color: var(--hair) var(--accent) var(--hair) var(--hair) !important;
}

/* ---- PAGE SHELL ---- */
.page-shell { padding: 0 32px; }

/* ============================================================
   HEADER
   ============================================================ */
.cd-ticker {
  background: var(--bg-2);
  border-bottom: 1px solid var(--hair);
  height: 34px;
  overflow: hidden;
  display: flex;
  align-items: center;
}
.cd-ticker-track {
  display: flex;
  white-space: nowrap;
  animation: cdTicker 40s linear infinite;
}
.cd-ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 32px;
  font-size: 12px;
  color: var(--mute);
  letter-spacing: .03em;
}
.cd-ticker-item .dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

.cd-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bg-2);
  border-bottom: 1px solid var(--hair);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.cd-header-inner {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 32px;
  max-width: 1400px;
  margin: 0 auto;
}

.cd-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none !important;
}
.cd-logo img {
  height: 36px;
  width: auto;
}

.cd-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: 24px;
  flex: 1;
}
.cd-nav a {
  padding: 6px 12px;
  border-radius: var(--r-sm);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-2);
  text-decoration: none;
  transition: color .15s, background .15s;
  white-space: nowrap;
}
.cd-nav a:hover, .cd-nav a.active {
  color: var(--text);
  background: var(--bg-3);
}

/* Search pill in header */
.cd-search-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-3);
  border: 1px solid var(--hair);
  border-radius: 99px;
  padding: 7px 14px;
  cursor: text;
  transition: border-color .15s;
  min-width: 200px;
}
.cd-search-pill:focus-within {
  border-color: var(--accent);
}
.cd-search-pill input {
  border: none !important;
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
  font-size: 13px;
  color: var(--text) !important;
  width: 100%;
  padding: 0 !important;
  height: auto !important;
}
.cd-search-pill input::placeholder { color: var(--mute) !important; }
.cd-search-pill svg { color: var(--mute); flex-shrink: 0; }

/* Header right-side actions */
.cd-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.cd-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--r-sm);
  border: 1px solid var(--hair);
  background: var(--bg-3);
  color: var(--text-2);
  cursor: pointer;
  transition: color .15s, background .15s, border-color .15s;
  position: relative;
  text-decoration: none !important;
}
.cd-icon-btn:hover { color: var(--text); background: var(--surface); border-color: var(--hair-2); }
.cd-icon-btn svg { pointer-events: none; }

.cd-cart-badge {
  position: absolute;
  top: -5px; right: -5px;
  background: var(--accent);
  color: var(--accent-ink);
  font-size: 10px;
  font-weight: 700;
  font-family: var(--mono);
  width: 16px; height: 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.cd-auth-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none !important;
  transition: opacity .15s;
  white-space: nowrap;
}
.cd-auth-btn.primary {
  background: var(--accent);
  color: var(--accent-ink) !important;
  border: 1px solid transparent;
}
.cd-auth-btn.ghost {
  background: transparent;
  color: var(--text-2) !important;
  border: 1px solid var(--hair);
}
.cd-auth-btn:hover { opacity: .85; }

/* Mobile hamburger */
.cd-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px; height: 36px;
  cursor: pointer;
  background: var(--bg-3);
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  padding: 8px;
  flex-shrink: 0;
}
.cd-hamburger span {
  display: block;
  height: 2px;
  background: var(--text-2);
  border-radius: 2px;
  transition: all .2s;
}

/* Mobile drawer nav */
.cd-mobile-nav {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 200;
  display: none;
}
.cd-mobile-nav.open { display: flex; }
.cd-mobile-overlay {
  position: absolute;
  inset: 0;
  background: oklch(0 0 0 / 0.6);
}
.cd-mobile-panel {
  position: relative;
  background: var(--bg-2);
  width: 280px;
  height: 100%;
  overflow-y: auto;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  animation: slideInLeft .25s ease-out;
}
@keyframes slideInLeft {
  from { transform: translateX(-100%); }
  to   { transform: translateX(0); }
}
.cd-mobile-panel a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border-radius: var(--r-sm);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-2);
  text-decoration: none;
  transition: color .15s, background .15s;
}
.cd-mobile-panel a:hover { color: var(--text); background: var(--bg-3); }
.cd-mobile-close {
  align-self: flex-end;
  margin-bottom: 16px;
  background: var(--bg-3);
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  padding: 6px 10px;
  color: var(--text-2);
  cursor: pointer;
  font-size: 13px;
}

/* ============================================================
   HERO / SEARCH SECTION
   ============================================================ */
.cd-hero {
  padding: 48px 32px 36px;
  max-width: 1400px;
  margin: 0 auto;
}
.cd-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.cd-hero-eyebrow .dot-live {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  display: inline-block;
}
.cd-hero h1 {
  font-size: 62px;
  font-weight: 800;
  line-height: .96;
  letter-spacing: -.03em;
  color: var(--text);
  margin: 0 0 16px;
}
.cd-hero h1 em {
  font-style: normal;
  color: var(--accent);
}
.cd-hero-sub {
  font-size: 17px;
  color: var(--text-2);
  margin-bottom: 28px;
  max-width: 560px;
  line-height: 1.6;
}

/* Search box */
.cd-search-box {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  max-width: 760px;
}
.cd-search-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 18px;
  overflow-x: auto;
  scrollbar-width: none;
}
.cd-search-tabs::-webkit-scrollbar { display: none; }
.cd-tab-btn {
  padding: 7px 16px;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  background: transparent;
  color: var(--mute);
  transition: all .15s;
  flex-shrink: 0;
}
.cd-tab-btn:hover { color: var(--text-2); background: var(--bg-3); }
.cd-tab-btn.active {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: transparent;
}
.cd-tab-panel { display: none; }
.cd-tab-panel.active { display: block; }

.cd-search-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: end;
}
.cd-search-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 10px;
  align-items: end;
}
.cd-input-group label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.cd-input {
  width: 100%;
  background: var(--bg-2) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-sm) !important;
  padding: 9px 12px !important;
  font-size: 14px !important;
  color: var(--text) !important;
  outline: none !important;
  box-shadow: none !important;
  transition: border-color .15s !important;
  height: auto !important;
}
.cd-input:focus {
  border-color: var(--accent) !important;
}
.cd-input::placeholder { color: var(--mute) !important; }

.cd-search-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 20px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity .15s;
  text-decoration: none !important;
  height: 38px;
}
.cd-search-btn:hover { opacity: .85; color: var(--accent-ink) !important; }

/* Trust row */
.cd-trust-row {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 20px;
  flex-wrap: wrap;
}
.cd-trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: var(--mute);
  font-weight: 500;
}
.cd-trust-item svg { color: var(--accent); flex-shrink: 0; }

/* ============================================================
   LAYOUT — SIDEBAR + GRID
   ============================================================ */
.cd-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 24px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 32px 48px;
}

/* ---- SIDEBAR ---- */
.cd-sidebar {
  position: sticky;
  top: 80px;
  height: fit-content;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cd-sidebar-section {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 12px;
}
.cd-sidebar-title {
  padding: 12px 16px;
  font-size: 11px;
  font-weight: 700;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .08em;
  border-bottom: 1px solid var(--hair);
}
.cd-cat-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-2);
  text-decoration: none !important;
  border-bottom: 1px solid var(--hair);
  transition: background .12s, color .12s;
  cursor: pointer;
}
.cd-cat-item:last-child { border-bottom: none; }
.cd-cat-item:hover { background: var(--bg-3); color: var(--text); }
.cd-cat-item.active { background: var(--bg-3); color: var(--accent); }
.cd-cat-count {
  font-size: 11px;
  font-family: var(--mono);
  color: var(--mute);
  background: var(--bg-2);
  padding: 2px 7px;
  border-radius: 99px;
}

/* Price range */
.cd-price-range {
  padding: 16px;
}
.cd-price-labels {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  font-family: var(--mono);
  color: var(--mute);
  margin-top: 8px;
}
.cd-range-input {
  width: 100%;
  accent-color: var(--accent);
  cursor: pointer;
}

/* ---- GRID TOOLBAR ---- */
.cd-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 0 14px;
  border-bottom: 1px solid var(--hair);
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.cd-toolbar-left { flex: 1; }
.cd-result-count {
  font-size: 13px;
  color: var(--mute);
  font-family: var(--mono);
}
.cd-result-count strong {
  color: var(--text);
  font-weight: 700;
}

.cd-select {
  background: var(--bg-3) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-sm) !important;
  padding: 7px 12px !important;
  font-size: 13px !important;
  color: var(--text) !important;
  cursor: pointer;
  outline: none !important;
  box-shadow: none !important;
  height: auto !important;
}

/* View toggle */
.cd-view-toggle {
  display: flex;
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  overflow: hidden;
}
.cd-view-btn {
  padding: 7px 10px;
  background: transparent;
  border: none;
  color: var(--mute);
  cursor: pointer;
  transition: background .12s, color .12s;
}
.cd-view-btn.active { background: var(--bg-3); color: var(--text); }
.cd-view-btn + .cd-view-btn { border-left: 1px solid var(--hair); }

/* ============================================================
   NUMBER CARDS
   ============================================================ */
.cd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 14px;
}
.cd-grid.list-view {
  grid-template-columns: 1fr;
  gap: 8px;
}

/* Premium card */
.cd-card {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s;
  cursor: pointer;
  position: relative;
  text-decoration: none !important;
}
.cd-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px var(--shadow-ink);
  border-color: var(--hair-2);
}

/* Card header band */
.cd-card-header {
  background: var(--accent);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.cd-card-tag {
  background: oklch(from var(--accent-ink) l c h / 0.18);
  color: var(--accent-ink);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 99px;
  letter-spacing: .04em;
  white-space: nowrap;
}
html[data-theme="light"] .cd-card-tag {
  background: oklch(0 0 0 / 0.12);
}
.cd-card-hot {
  font-size: 10px;
  font-weight: 700;
  color: var(--accent-ink);
  background: var(--rose);
  padding: 3px 8px;
  border-radius: 99px;
  letter-spacing: .04em;
}
html[data-theme="dark"] .cd-card-hot { color: #fff; }

/* Card body */
.cd-card-body {
  padding: 16px 14px 12px;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.cd-number {
  font-family: var(--mono) !important;
  font-size: 24px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.5px;
  line-height: 1.2;
  margin: 6px 0 10px;
}
.cd-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: center;
  margin-bottom: 10px;
  min-height: 22px;
}
.cd-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 99px;
  border: 1px solid var(--hair);
  color: var(--mute);
  letter-spacing: .03em;
  background: var(--bg-2);
}

/* Price */
.cd-card-price {
  margin-top: auto;
  padding: 12px 14px;
  border-top: 1px solid var(--hair);
  width: 100%;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.cd-price-current {
  font-family: var(--mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--accent);
}
.cd-price-mrp {
  font-size: 12px;
  color: var(--mute);
  text-decoration: line-through;
  font-family: var(--mono);
}
.cd-price-save {
  font-size: 11px;
  font-weight: 700;
  color: var(--rose);
  margin-left: auto;
}

/* Card CTA button */
.cd-card-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 9px 13px;
  background: var(--accent);
  color: var(--accent-ink) !important;
  border: none;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  text-decoration: none !important;
  transition: opacity .15s;
  letter-spacing: .02em;
  white-space: nowrap;
  flex-shrink: 0;
}
.cd-card-btn:hover { opacity: .85; }

/* List view row */
.cd-list-row {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  display: grid;
  grid-template-columns: 1fr 120px 130px auto;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  transition: background .12s;
  text-decoration: none !important;
}
.cd-list-row:hover { background: var(--bg-3); }
.cd-list-number {
  font-family: var(--mono);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
}
.cd-list-tags { display: flex; gap: 4px; flex-wrap: wrap; }
.cd-list-price {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--accent);
}

/* ============================================================
   MOBILE FILTER DRAWER
   ============================================================ */
.cd-filter-bar {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--hair);
  background: var(--bg-2);
}
.cd-filter-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--bg-3);
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
  cursor: pointer;
  transition: border-color .15s;
}
.cd-filter-btn:hover { border-color: var(--accent); color: var(--text); }

.cd-filter-drawer {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 300;
  display: none;
}
.cd-filter-drawer.open { display: flex; }
.cd-filter-drawer-overlay {
  position: absolute;
  inset: 0;
  background: oklch(0 0 0 / 0.6);
}
.cd-filter-drawer-panel {
  position: relative;
  background: var(--bg-2);
  width: 300px;
  height: 100%;
  overflow-y: auto;
  padding: 20px;
  animation: slideInLeft .25s ease-out;
}
.cd-filter-drawer-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
.cd-filter-drawer-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.cd-filter-apply-btn {
  position: sticky;
  bottom: 0;
  width: 100%;
  padding: 12px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  border-radius: var(--r);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 20px;
  transition: opacity .15s;
}
.cd-filter-apply-btn:hover { opacity: .85; }

/* ============================================================
   CART PAGE
   ============================================================ */
.cd-page-header {
  background: var(--bg-2);
  border-bottom: 1px solid var(--hair);
  padding: 28px 32px;
}
.cd-page-header h1 {
  font-size: 28px;
  font-weight: 800;
  margin: 0 0 4px;
}
.cd-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--mute);
}
.cd-breadcrumb a { color: var(--mute); text-decoration: none; }
.cd-breadcrumb a:hover { color: var(--text); }
.cd-breadcrumb span { color: var(--text-2); }

.cd-cart-wrap {
  max-width: 1400px;
  margin: 0 auto;
  padding: 28px 32px 48px;
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 24px;
  align-items: start;
}

.cd-cart-table {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.cd-cart-table table {
  width: 100%;
  border-collapse: collapse;
}
.cd-cart-table thead th {
  padding: 14px 18px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--mute);
  border-bottom: 1px solid var(--hair);
  background: var(--bg-2);
}
.cd-cart-table tbody tr {
  border-bottom: 1px solid var(--hair);
  transition: background .12s;
}
.cd-cart-table tbody tr:last-child { border-bottom: none; }
.cd-cart-table tbody tr:hover { background: var(--bg-3); }
.cd-cart-table td {
  padding: 16px 18px;
  color: var(--text-2);
  font-size: 14px;
}
.cd-cart-number {
  font-family: var(--mono);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
}
.cd-cart-price {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 600;
  color: var(--accent);
}
.cd-cart-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: var(--r-sm);
  color: var(--mute);
  background: var(--bg-3);
  text-decoration: none !important;
  transition: background .12s, color .12s;
}
.cd-cart-remove:hover { background: var(--rose); color: #fff; }

/* Cart summary */
.cd-cart-summary {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  padding: 22px;
  position: sticky;
  top: 80px;
}
.cd-cart-summary h3 {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 18px;
  color: var(--text);
}
.cd-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--hair);
  font-size: 13.5px;
}
.cd-summary-row:last-of-type { border-bottom: none; }
.cd-summary-row.total {
  padding-top: 14px;
  font-weight: 700;
  font-size: 15px;
}
.cd-summary-row.total .val {
  font-family: var(--mono);
  color: var(--accent);
  font-size: 18px;
}
.cd-summary-row .key { color: var(--text-2); }
.cd-summary-row .val { font-family: var(--mono); color: var(--text); }

.cd-checkout-btn {
  display: block;
  width: 100%;
  padding: 13px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  border-radius: var(--r);
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  text-decoration: none !important;
  margin-top: 18px;
  transition: opacity .15s;
}
.cd-checkout-btn:hover { opacity: .85; color: var(--accent-ink) !important; }

.cd-ghost-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  background: var(--bg-3);
  color: var(--text-2);
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none !important;
  transition: border-color .15s, color .15s;
}
.cd-ghost-btn:hover { border-color: var(--hair-2); color: var(--text); }

/* Empty cart */
.cd-empty {
  padding: 80px 24px;
  text-align: center;
  color: var(--mute);
}
.cd-empty svg { margin-bottom: 18px; opacity: .4; }
.cd-empty h3 { font-size: 18px; font-weight: 700; color: var(--text-2); margin-bottom: 8px; }
.cd-empty p { font-size: 14px; color: var(--mute); margin-bottom: 20px; }

/* ============================================================
   PRODUCT DETAIL PAGE
   ============================================================ */
.cd-detail-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 32px 64px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 40px;
  align-items: start;
}
.cd-detail-hero {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-xl);
  padding: 40px 32px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cd-detail-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%, var(--accent) 0%, transparent 70%);
  opacity: .05;
  pointer-events: none;
}
.cd-detail-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 8px;
}
.cd-detail-number {
  font-family: var(--mono);
  font-size: 42px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -1px;
  line-height: 1.15;
  margin: 12px 0;
}
.cd-detail-number span {
  font-size: 18px;
  color: var(--mute);
  font-weight: 500;
}
.cd-detail-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin: 16px 0;
}

/* Numerology */
.cd-numerology {
  background: var(--bg-2);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  padding: 16px;
  margin-top: 20px;
  text-align: left;
}
.cd-numerology-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 12px;
}
.cd-numerology-row {
  display: flex;
  gap: 10px;
}
.cd-num-stat {
  flex: 1;
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  padding: 10px;
  text-align: center;
}
.cd-num-stat .label {
  font-size: 10px;
  font-weight: 600;
  color: var(--mute);
  text-transform: uppercase;
  margin-bottom: 4px;
  display: block;
}
.cd-num-stat .value {
  font-family: var(--mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--accent);
}

/* Detail actions panel */
.cd-detail-actions {
  position: sticky;
  top: 80px;
}
.cd-detail-price-card {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-xl);
  padding: 28px;
  margin-bottom: 16px;
}
.cd-detail-price {
  font-family: var(--mono);
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.5px;
}
.cd-detail-price-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  margin-bottom: 22px;
}
.cd-detail-mrp {
  font-family: var(--mono);
  font-size: 14px;
  color: var(--mute);
  text-decoration: line-through;
}
.cd-detail-save {
  font-size: 12px;
  font-weight: 700;
  color: var(--rose);
  background: oklch(from var(--rose) l c h / 0.12);
  padding: 2px 8px;
  border-radius: 99px;
}

.cd-add-btn {
  display: block;
  width: 100%;
  padding: 14px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  border-radius: var(--r);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none !important;
  text-align: center;
  transition: opacity .15s;
  margin-bottom: 10px;
}
.cd-add-btn:hover { opacity: .85; color: var(--accent-ink) !important; }

/* Steps */
.cd-steps {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  padding: 20px;
}
.cd-steps-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 14px;
}
.cd-step {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--hair);
}
.cd-step:last-child { border-bottom: none; }
.cd-step-num {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  width: 22px;
  flex-shrink: 0;
  padding-top: 1px;
}
.cd-step-text strong {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 2px;
}
.cd-step-text span {
  font-size: 12px;
  color: var(--mute);
}

/* ============================================================
   FORMS (login, register, contact, checkout)
   ============================================================ */
.cd-form-page {
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 16px;
}
.cd-form-card {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-xl);
  padding: 36px 32px;
  width: 100%;
  max-width: 480px;
}
.cd-form-card h2, .cd-form-card h3 {
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 6px;
  color: var(--text);
}
.cd-form-card .sub {
  font-size: 14px;
  color: var(--mute);
  margin-bottom: 28px;
}
.cd-form-group {
  margin-bottom: 16px;
}
.cd-form-group label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.cd-form-group input,
.cd-form-group textarea,
.cd-form-group select {
  width: 100%;
  background: var(--bg-2) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  color: var(--text) !important;
  outline: none !important;
  box-shadow: none !important;
  transition: border-color .15s !important;
  resize: vertical;
}
.cd-form-group input:focus,
.cd-form-group textarea:focus {
  border-color: var(--accent) !important;
}
.cd-form-group input::placeholder,
.cd-form-group textarea::placeholder {
  color: var(--mute) !important;
}
.cd-submit-btn {
  width: 100%;
  padding: 13px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  border-radius: var(--r);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s;
  margin-top: 8px;
}
.cd-submit-btn:hover { opacity: .85; }

/* Alert / flash messages */
.cd-alert {
  padding: 12px 16px;
  border-radius: var(--r-sm);
  font-size: 13.5px;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cd-alert.success {
  background: oklch(from var(--accent) l c h / 0.12);
  border: 1px solid oklch(from var(--accent) l c h / 0.3);
  color: var(--accent);
}
.cd-alert.danger {
  background: oklch(from var(--rose) l c h / 0.12);
  border: 1px solid oklch(from var(--rose) l c h / 0.3);
  color: var(--rose);
}
.cd-alert.info {
  background: oklch(0.60 0.14 240 / 0.1);
  border: 1px solid oklch(0.60 0.14 240 / 0.25);
  color: oklch(0.70 0.14 240);
}

/* ============================================================
   CHECKOUT PAGE
   ============================================================ */
.cd-checkout-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 32px 32px 64px;
}
.cd-checkout-card {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-xl);
  padding: 32px;
}
.cd-checkout-card h2 {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 24px;
  color: var(--text);
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.cd-contact-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 32px 32px 64px;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 32px;
  align-items: start;
}
.cd-contact-info {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-xl);
  padding: 28px;
}
.cd-contact-info h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 20px;
}
.cd-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--hair);
}
.cd-contact-item:last-child { border-bottom: none; }
.cd-contact-icon {
  width: 34px; height: 34px;
  background: oklch(from var(--accent) l c h / 0.12);
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--accent);
}
.cd-contact-item .label {
  font-size: 11px;
  font-weight: 600;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 3px;
}
.cd-contact-item .value { font-size: 13.5px; color: var(--text); }

/* ============================================================
   FAMILY PACK PAGE
   ============================================================ */
.cd-pack-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 18px;
  padding: 28px 32px 64px;
  max-width: 1400px;
  margin: 0 auto;
}
.cd-pack-card {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform .18s, box-shadow .18s;
}
.cd-pack-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px var(--shadow-ink);
}
.cd-pack-header {
  background: var(--accent);
  padding: 16px 20px;
}
.cd-pack-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--accent-ink);
  margin: 0;
}
.cd-pack-body { padding: 20px; }
.cd-pack-numbers {
  list-style: none;
  padding: 0; margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cd-pack-numbers li {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  padding: 8px 12px;
  background: var(--bg-2);
  border-radius: var(--r-sm);
  border: 1px solid var(--hair);
}
.cd-pack-price {
  font-family: var(--mono);
  font-size: 22px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 12px;
}

/* ============================================================
   POLICY / STATIC PAGES
   ============================================================ */
.cd-policy-wrap {
  max-width: 800px;
  margin: 0 auto;
  padding: 32px 32px 64px;
}
.cd-policy-card {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-xl);
  padding: 36px;
}
.cd-policy-card h1 {
  font-size: 26px;
  font-weight: 800;
  margin-bottom: 24px;
}
.cd-policy-card h2 { font-size: 17px; font-weight: 700; margin-top: 24px; }
.cd-policy-card p { font-size: 14px; line-height: 1.75; color: var(--text-2); }
.cd-policy-card ul li { font-size: 14px; color: var(--text-2); margin-bottom: 6px; }

/* ============================================================
   FOOTER
   ============================================================ */
.cd-footer {
  background: var(--bg-2);
  border-top: 1px solid var(--hair);
  padding: 48px 32px 0;
}
.cd-footer-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--hair);
}
.cd-footer-brand img { height: 38px; margin-bottom: 14px; }
.cd-footer-brand p {
  font-size: 13px;
  color: var(--mute);
  line-height: 1.65;
  margin-bottom: 16px;
}
.cd-footer-socials {
  display: flex;
  gap: 8px;
}
.cd-social-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px; height: 34px;
  border-radius: var(--r-sm);
  background: var(--bg-3);
  border: 1px solid var(--hair);
  color: var(--mute);
  text-decoration: none !important;
  transition: color .15s, border-color .15s;
  font-size: 14px;
}
.cd-social-btn:hover { color: var(--text); border-color: var(--hair-2); }

.cd-footer-col h4 {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 14px;
}
.cd-footer-col ul {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cd-footer-col ul li a {
  font-size: 13.5px;
  color: var(--mute);
  text-decoration: none;
  transition: color .12s;
}
.cd-footer-col ul li a:hover { color: var(--text); }

/* Newsletter in footer */
.cd-newsletter-form {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.cd-newsletter-form input {
  flex: 1;
  background: var(--bg-3) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-sm) !important;
  padding: 9px 12px !important;
  font-size: 13px !important;
  color: var(--text) !important;
  outline: none !important;
  box-shadow: none !important;
}
.cd-newsletter-form input:focus { border-color: var(--accent) !important; }
.cd-newsletter-form button {
  padding: 9px 14px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  transition: opacity .15s;
}
.cd-newsletter-form button:hover { opacity: .85; }

.cd-footer-bar {
  max-width: 1400px;
  margin: 0 auto;
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: var(--mute);
}

/* ============================================================
   WHATSAPP WIDGET
   ============================================================ */
.cd-whatsapp {
  position: fixed;
  bottom: 22px;
  right: 22px;
  z-index: 9998;
  cursor: pointer;
  transition: transform .2s;
}
.cd-whatsapp:hover { transform: scale(1.08); }
.cd-whatsapp-btn {
  width: 52px; height: 52px;
  background: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 18px rgba(37, 211, 102, 0.38);
  animation: pulseDot 2.4s ease-in-out infinite;
  text-decoration: none !important;
  font-size: 26px;
  color: #fff !important;
}

/* ============================================================
   PAGINATION (for AJAX-loaded content)
   ============================================================ */
.cd-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 24px 0;
  flex-wrap: wrap;
}
.cd-page-btn {
  min-width: 36px; height: 36px;
  padding: 0 10px;
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
  font-family: var(--mono);
}
.cd-page-btn:hover { background: var(--bg-3); color: var(--text); border-color: var(--hair-2); }
.cd-page-btn.active { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.cd-page-btn.disabled { opacity: .4; cursor: default; pointer-events: none; }

/* Old bootstrap pagination (from existing fetch files) */
.pagination { display: flex; justify-content: center; padding: 24px 0 !important; background: transparent !important; }
.pagination ul { display: flex; gap: 6px; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; }
.pagination li a {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 10px;
  background: var(--surface) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-sm) !important;
  font-size: 13px; font-weight: 600;
  color: var(--text-2) !important;
  text-decoration: none !important;
  transition: background .12s, color .12s;
  font-family: var(--mono);
}
.pagination li a:hover { background: var(--bg-3) !important; color: var(--text) !important; }
.pagination li.active a { background: var(--accent) !important; color: var(--accent-ink) !important; border-color: var(--accent) !important; }
.pagination li.disabled a { opacity: .4; pointer-events: none; }

/* ============================================================
   CARD OVERRIDES (for PHP-generated cards from fetch files)
   ============================================================ */
.card-custom {
  background: var(--surface) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-lg) !important;
  border-width: 1px !important;
  overflow: hidden !important;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s !important;
  max-width: none !important;
}
.card-custom:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 10px 32px var(--shadow-ink) !important;
  border-color: var(--hair-2) !important;
}
.sum-pills-header {
  background: var(--accent) !important;
  padding: 10px 14px !important;
}
.sum-pill {
  background: oklch(0 0 0 / 0.12) !important;
  color: var(--accent-ink) !important;
  border-radius: 99px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 10px !important;
}
html[data-theme="dark"] .sum-pill { background: oklch(1 0 0 / 0.18) !important; }
.card-body-content { padding: 14px 14px 10px !important; }
.number-display {
  font-family: var(--mono) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  letter-spacing: -0.5px !important;
  margin-bottom: 4px !important;
}
.offer-badge {
  font-size: 10px !important;
  color: var(--mute) !important;
  letter-spacing: .06em !important;
  margin-bottom: 6px !important;
}
.price-section {
  border-top: 1px solid var(--hair) !important;
  padding: 10px 14px !important;
  min-height: 56px !important;
  align-items: center !important;
}
.price-simple {
  color: var(--accent) !important;
  font-family: var(--mono) !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  text-align: center !important;
  width: 100% !important;
}
.price-original {
  color: var(--mute) !important;
  text-decoration: line-through !important;
  font-family: var(--mono) !important;
}
.save-text { color: var(--rose) !important; font-weight: 700 !important; }

/* Hide the deal badge image, show price cleanly */
.deal-badge-img { display: none !important; }
.deal-badge-container {
  width: auto !important; height: auto !important;
  left: 0 !important; position: static !important;
  flex-shrink: 0 !important;
}
.deal-badge-price {
  position: static !important;
  transform: none !important;
  font-family: var(--mono) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--accent) !important;
  text-shadow: none !important;
  rotate: none !important;
}
.deal-badge-price sup { color: var(--accent) !important; font-size: 12px !important; }
.price-info { margin-top: 0 !important; margin-left: 10px !important; }
.buy-button-container { padding: 0 14px 14px !important; }
.buy-now-btn-compact {
  background: var(--accent) !important;
  color: var(--accent-ink) !important;
  border-radius: var(--r-sm) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  padding: 10px !important;
  text-transform: none !important;
  letter-spacing: .02em !important;
  box-shadow: none !important;
}
.buy-now-btn-compact:hover {
  opacity: .85 !important;
  color: var(--accent-ink) !important;
  transform: none !important;
  background: var(--accent) !important;
  box-shadow: none !important;
}
.buy-now-btn-compact i { display: none !important; }

/* No results state */
.no-search-results {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  padding: 60px 24px !important;
}
.no-search-icon { color: var(--mute) !important; opacity: .4; }
.no-search-found-text { color: var(--mute) !important; font-size: 15px !important; }

/* Tabs (easy.responsive.tabs.js) styled to look like cd-search-box tabs */
.resp-tabs-list.hor_1 {
  display: flex !important;
  gap: 4px !important;
  list-style: none !important;
  padding: 0 !important;
  margin-bottom: 18px !important;
  overflow-x: auto;
  scrollbar-width: none;
  border: none !important;
}
.resp-tabs-list.hor_1::-webkit-scrollbar { display: none; }
.resp-tabs-list.hor_1 li {
  padding: 7px 16px !important;
  border-radius: var(--r-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border: 1px solid transparent !important;
  cursor: pointer !important;
  background: transparent !important;
  color: var(--mute) !important;
  transition: all .15s !important;
  white-space: nowrap !important;
  flex-shrink: 0;
}
.resp-tabs-list.hor_1 li:hover,
.resp-tabs-list.hor_1 li.resp-tab-active {
  color: var(--accent-ink) !important;
  background: var(--accent) !important;
}
.resp-tab-content { display: none !important; }
.resp-tab-content.resp-tab-content-active { display: block !important; }

/* Search section layout */
.search-section { background: transparent !important; padding: 0 0 32px !important; }
.searchbarbox {
  background: var(--surface) !important;
  border: 1px solid var(--hair) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: none !important;
  padding: 24px !important;
  height: auto !important;
  max-width: 800px !important;
}
.search-section .form-control { color: var(--text) !important; }
.search-section label { color: var(--mute) !important; font-size: 11px !important; font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: .06em !important; }
.search-section .btn-primary { background: var(--accent) !important; border-color: var(--accent) !important; color: var(--accent-ink) !important; }

/* Product grid from fetch files */
.product-grid { margin: 0 !important; }

/* ============================================================
   BOOTSTRAP OVERRIDES
   ============================================================ */
.container { max-width: 1400px !important; }
.btn-primary, .btn.theme, .butn.theme {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--accent-ink) !important;
  font-weight: 600;
  border-radius: var(--r-sm) !important;
}
.btn-primary:hover, .btn.theme:hover, .butn.theme:hover {
  opacity: .85 !important;
}
.btn-white {
  background: var(--bg-3) !important;
  border-color: var(--hair) !important;
  color: var(--text) !important;
}
.butn, .btn {
  font-family: var(--sans) !important;
}
.form-control {
  background: var(--bg-2) !important;
  border: 1px solid var(--hair) !important;
  color: var(--text) !important;
  border-radius: var(--r-sm) !important;
}
.form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 2px oklch(from var(--accent) l c h / 0.15) !important;
}
.alert-success {
  background: oklch(from var(--accent) l c h / 0.1) !important;
  border-color: oklch(from var(--accent) l c h / 0.3) !important;
  color: var(--accent) !important;
}
.alert-danger {
  background: oklch(from var(--rose) l c h / 0.1) !important;
  border-color: oklch(from var(--rose) l c h / 0.3) !important;
  color: var(--rose) !important;
}
.alert-info {
  background: oklch(0.60 0.14 240 / 0.08) !important;
  border-color: oklch(0.60 0.14 240 / 0.2) !important;
  color: oklch(0.72 0.14 240) !important;
}
/* Hide old structural elements that get replaced */
#top-bar, .navbar-default, .footer-top-bar, footer > .container > .row, .footer-bar,
.page-title-section, .page-title-section2 {
  display: none !important;
}
#preloader { z-index: 9999 !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .cd-layout { grid-template-columns: 210px 1fr; padding: 0 20px 40px; }
  .cd-hero { padding: 36px 20px 28px; }
  .cd-footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .cd-detail-wrap { grid-template-columns: 1fr; }
  .cd-cart-wrap { grid-template-columns: 1fr; }
  .cd-contact-wrap { grid-template-columns: 1fr; }
}

@media (max-width: 960px) {
  .cd-header-inner { padding: 12px 16px; }
  .cd-nav { display: none; }
  .cd-hamburger { display: flex; }
  .cd-search-pill { display: none; }
  .cd-layout { grid-template-columns: 1fr; padding: 0 16px 32px; }
  .cd-sidebar { display: none; }
  .cd-filter-bar { display: flex; }
  .cd-hero { padding: 28px 16px 20px; }
  .cd-hero h1 { font-size: 38px; }
  .cd-search-row-3 { grid-template-columns: 1fr 1fr; }
  .cd-page-header { padding: 20px 16px; }
  .cd-cart-wrap { padding: 20px 16px 40px; }
  .cd-pack-grid { padding: 20px 16px 40px; }
  .cd-policy-wrap { padding: 20px 16px 40px; }
  .cd-checkout-wrap { padding: 20px 16px 40px; }
  .cd-contact-wrap { padding: 20px 16px 40px; }
  .cd-footer { padding: 36px 16px 0; }
  .cd-footer-grid { grid-template-columns: 1fr 1fr; padding-bottom: 28px; }
  .cd-footer-bar { flex-direction: column; gap: 8px; text-align: center; padding: 14px 0; }
}

@media (max-width: 600px) {
  .cd-hero h1 { font-size: 30px; }
  .cd-footer-grid { grid-template-columns: 1fr; gap: 22px; }
  .cd-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .cd-number { font-size: 18px; }
  .cd-search-row { grid-template-columns: 1fr; }
  .cd-search-row-3 { grid-template-columns: 1fr; }
  .cd-detail-number { font-size: 30px; }
  .cd-cart-wrap { grid-template-columns: 1fr; }
  .cd-form-card { padding: 24px 18px; }
}

/* =============================================
   HERO SLIDER
   ============================================= */
.cd-hero-slider {
  position: relative;
  overflow: hidden;
  padding: 0;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cd-hero-slides {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.cd-hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s ease;
}

.cd-hero-slide.active {
  opacity: 1;
}

.cd-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    oklch(from var(--bg) l c h / 0.72) 0%,
    oklch(from var(--bg) l c h / 0.55) 50%,
    oklch(from var(--bg) l c h / 0.80) 100%
  );
  z-index: 1;
}

.cd-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 72px 24px 56px;
  max-width: 760px;
  margin: 0 auto;
  width: 100%;
}

.cd-hero-content h1 {
  font-size: 52px;
  font-weight: 800;
  line-height: 1.12;
  color: var(--text);
  margin: 12px 0 16px;
  letter-spacing: -0.02em;
}

.cd-hero-content .cd-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  background: oklch(from var(--accent) l c h / 0.12);
  border: 1px solid oklch(from var(--accent) l c h / 0.25);
  padding: 6px 14px;
  border-radius: 999px;
}

.cd-hero-content .cd-hero-sub {
  font-size: 15px;
  color: var(--text-2);
  max-width: 560px;
  margin: 0 auto 28px;
  line-height: 1.65;
}

.cd-hero-content .cd-trust-row {
  justify-content: center;
}

/* Slide dots */
.cd-hero-dots {
  position: absolute;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 8px;
}

.cd-hero-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: oklch(from var(--text) l c h / 0.3);
  cursor: pointer;
  transition: background .3s, transform .3s;
}

.cd-hero-dot.active {
  background: var(--accent);
  transform: scale(1.3);
}

/* =============================================
   FULL-WIDTH BANNER SLIDER
   ============================================= */
.cd-banner-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  line-height: 0;
}
.cd-banner-slides {
  position: relative;
  width: 100%;
}
.cd-banner-slide {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  opacity: 0;
  transition: opacity 0.8s ease;
  pointer-events: none;
}
.cd-banner-slide.active {
  position: relative;
  opacity: 1;
  pointer-events: auto;
}
.cd-banner-slide img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 520px;
  object-fit: cover;
  object-position: center;
}
.cd-banner-dots {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 7px;
  z-index: 10;
}
.cd-banner-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.45);
  cursor: pointer;
  transition: background .2s, transform .2s;
  border: none;
}
.cd-banner-dot.active {
  background: #fff;
  transform: scale(1.3);
}
@media (max-width: 767px) {
  .cd-banner-slide img { max-height: 220px; }
}

/* =============================================
   SEARCH SECTION (homepage tabs)
   ============================================= */
.cd-search-section {
  padding: 14px 18px;
  background: var(--bg);
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  position: sticky;
  top: 72px;
  z-index: 60;
}

.cd-search-section .cd-search-box {
  max-width: 1280px;
  margin: 0 auto;
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  overflow: hidden;
  padding: 0;
}

.cd-search-section .cd-search-tabs {
  display: flex;
  border-bottom: 1px solid var(--hair);
  padding: 0 4px;
  gap: 0;
  margin-bottom: 0;
  overflow-x: auto;
  scrollbar-width: none;
}

.cd-search-section .cd-search-tabs::-webkit-scrollbar { display: none; }

.cd-search-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 14px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--mute);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color .2s, border-color .2s;
  margin-bottom: -1px;
  flex-shrink: 0;
}

.cd-search-tab:hover { color: var(--text); }

.cd-search-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.cd-search-panel {
  display: none;
  padding: 20px 24px;
}

.cd-search-panel.active { display: block; }

.cd-search-panel-grid {
  display: grid;
  gap: 14px;
  align-items: end;
}

.cd-search-panel-basic {
  grid-template-columns: 1fr auto;
}

.cd-search-panel-advanced {
  grid-template-columns: repeat(4, 1fr);
}

.cd-search-field label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 6px;
}

/* ---- responsive ---- */
@media (max-width: 767px) {
  .cd-hero-slider { min-height: 320px; }
  .cd-hero-content { padding: 52px 16px 44px; }
  .cd-hero-content h1 { font-size: 32px; }
  .cd-search-panel-basic { grid-template-columns: 1fr; }
  .cd-search-panel-advanced { grid-template-columns: 1fr 1fr; }
  .cd-search-section { padding: 12px 12px; top: 62px; }
}

@media (max-width: 480px) {
  .cd-hero-content h1 { font-size: 26px; }
  .cd-search-panel-advanced { grid-template-columns: 1fr; }
}

/* =============================================
   PRODUCT CARDS — premium trading-card style
   ============================================= */

/* Grid wrapper */
.cd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  padding: 12px 0 6px;
  align-items: start;
}

/* Card shell */
.cd-card {
  background: var(--bg-2);
  border: 1px solid var(--hair);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .22s cubic-bezier(.2,.8,.2,1),
              box-shadow .22s cubic-bezier(.2,.8,.2,1),
              border-color .22s;
}

.cd-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 48px -20px oklch(0 0 0 / 0.6), 0 0 0 1px var(--hair-2);
  border-color: var(--hair-2);
}

/* Top metadata row */
.cd-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 14px 10px;
  border-bottom: 1px solid var(--hair);
  background: var(--bg);
  flex-wrap: wrap;
}

.cd-card-sum {
  font-size: 11px;
  color: var(--mute);
  white-space: nowrap;
}

.cd-card-sum-val {
  font-family: var(--mono);
  font-weight: 700;
  color: var(--text-2);
}

.cd-card-offer {
  margin-left: auto;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--accent);
  background: oklch(from var(--accent) l c h / 0.12);
  border: 1px solid oklch(from var(--accent) l c h / 0.25);
  padding: 2px 8px;
  border-radius: 999px;
  white-space: nowrap;
}

/* Number display */
.cd-card-number {
  padding: 22px 14px 18px;
  text-align: center;
}

.cd-num-mono {
  font-family: var(--mono);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--text);
  transition: all .3s;
}

.cd-card:hover .cd-num-mono {
  background: linear-gradient(135deg, var(--text), var(--accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Price + CTA strip */
.cd-card-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-top: 1px solid var(--hair);
  background: var(--bg-3);
}

.cd-card-price-wrap {
  flex: 1;
  min-width: 0;
}

.cd-card-price {
  font-family: var(--mono);
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
  white-space: nowrap;
}

.cd-card-mrp {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 2px;
}

.cd-card-mrp-val {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--mute);
  text-decoration: line-through;
}

.cd-card-save {
  font-size: 10px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: .02em;
}

/* Add button */
.cd-card-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 9px 13px;
  background: var(--text);
  color: var(--bg);
  border: none;
  border-radius: var(--r-sm);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: .01em;
  transition: background .15s, color .15s;
  white-space: nowrap;
  flex-shrink: 0;
}

.cd-card:hover .cd-card-btn {
  background: var(--accent);
  color: var(--accent-ink);
}

/* Deal badge row (discount cards) */
.cd-card-deal-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px 10px;
  background: var(--bg-3);
  border-top: 1px solid var(--hair);
}
.cd-deal-badge-wrap {
  position: relative;
  width: 80px;
  height: 80px;
  flex-shrink: 0;
}
.cd-deal-badge-img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  display: block;
}
.cd-deal-badge-price {
  position: absolute;
  top: 56%;
  left: 50%;
  transform: translate(-45%, -40%);
  font-size: 10px;
  font-weight: 800;
  color: #fff;
  text-align: center;
  line-height: 1.2;
  white-space: nowrap;
  text-shadow: 0 1px 3px rgba(0,0,0,.5);
  pointer-events: none;
}
.cd-deal-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  justify-content: center;
}
.cd-deal-original {
  font-size: 13px;
  color: var(--mute);
  text-decoration: line-through;
  font-family: var(--mono);
}
.cd-deal-save-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--rose);
}
.cd-deal-save-amount {
  font-size: 14px;
  font-weight: 700;
  color: var(--rose);
  font-family: var(--mono);
}
.cd-card-footer-deal {
  border-top: none !important;
  padding-top: 8px !important;
  background: var(--bg-3);
}

/* Empty state */
.cd-empty-state {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 64px 24px;
  text-align: center;
}

/* Pagination */
.cd-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 32px 0 8px;
  flex-wrap: wrap;
}

.cd-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
  background: var(--bg-2);
  border: 1px solid var(--hair);
  cursor: pointer;
  text-decoration: none;
  transition: all .15s;
}

.cd-page-btn:hover {
  background: var(--bg-3);
  border-color: var(--hair-2);
  color: var(--text);
}

.cd-page-btn.active {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.cd-page-ellipsis {
  font-size: 13px;
  color: var(--mute);
  padding: 0 4px;
}

/* Responsive grid columns */
@media (min-width: 1400px) { .cd-grid { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 1100px) and (max-width: 1399px) { .cd-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 768px)  and (max-width: 1099px) { .cd-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .cd-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }
@media (max-width: 360px)  { .cd-grid { grid-template-columns: 1fr; } }

/* ── Quick action buttons ─────────────────────────────────────── */
.cd-quick-actions {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 16px;
  background: var(--bg);
}
.cd-quick-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: var(--r-lg);
  border: 2px solid var(--accent);
  background: var(--bg-2);
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.cd-quick-btn:hover { background: var(--accent); color: #fff; text-decoration: none; }
.cd-quick-btn svg { flex-shrink: 0; }
@media (max-width: 575px) { .cd-quick-btn { padding: 10px 18px; font-size: 13px; } }

/* ── Sticky mini quick filters ───────────────────────────────── */
.cd-mini-filter-wrap {
  position: sticky;
  top: 132px;
  z-index: 58;
  background: var(--bg);
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.cd-mini-filter-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  white-space: nowrap;
}
.cd-mini-filter-inner-price {
  border-top: 1px dashed var(--hair);
}
.cd-mini-filter-inner::-webkit-scrollbar { display: none; }
.cd-mini-filter-label {
  font-size: 11px;
  font-weight: 800;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-right: 4px;
}
.cd-mini-chip,
.cd-mini-chip-price {
  border: 1px solid var(--hair);
  background: var(--bg-2);
  color: var(--text);
  border-radius: 999px;
  padding: 6px 11px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: all .15s;
}
.cd-mini-chip:hover,
.cd-mini-chip-price:hover {
  border-color: var(--hair-2);
  background: var(--bg-3);
}
.cd-mini-chip.active,
.cd-mini-chip-price.active {
  background: #f3cf4a;
  color: #2d1b69;
  border-color: #f3cf4a;
}
@media (max-width: 991px) {
  .cd-mini-filter-wrap { top: 122px; }
}
@media (max-width: 767px) {
  .cd-mini-filter-wrap { top: 112px; }
}

/* ── Category banner sections ─────────────────────────────────── */
.cd-banner-section { padding: 16px 16px 4px; }
.cd-banner-section-inner { max-width: 1400px; margin: 0 auto; }
.cd-banner-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.cd-banner-section-head h2 { font-size: 18px; font-weight: 800; color: var(--text); margin: 0; }
.cd-banner-more {
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  text-decoration: none;
}
.cd-banner-more:hover { text-decoration: underline; }
.cd-banner-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.cd-banner-card {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--bcard-bg, #1a6b3a);
  aspect-ratio: 16/7;
  display: flex;
  align-items: flex-end;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.cd-banner-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.2); }
.cd-banner-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cd-banner-card-label {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 10px 14px;
  background: rgba(0,0,0,.5);
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  text-align: center;
  letter-spacing: .3px;
  /* visible even without image since card bg is colored */
}
@media (max-width: 767px) {
  .cd-banner-row { grid-template-columns: repeat(2, 1fr); }
  .cd-banner-section { padding: 20px 16px 4px; }
}
@media (max-width: 480px) { .cd-banner-row { grid-template-columns: 1fr; } }

/* ── Pattern showcase grid ────────────────────────────────────── */
.cd-patterns-section { padding: 14px 16px 8px; }
.cd-patterns-inner { max-width: 1400px; margin: 0 auto; }
.cd-patterns-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.cd-pattern-card {
  position: relative;
  border-radius: var(--r-lg);
  padding: 22px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  overflow: hidden;
}
.cd-pattern-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.18); text-decoration: none; }
.cd-pat-dark  { background: #2c1a6e; }
.cd-pat-gold  { background: #b87d00; }
.cd-pat-green { background: #1e5c2e; }
.cd-pat-num {
  font-size: 26px;
  font-weight: 900;
  color: #f5c842;
  font-family: var(--mono);
  line-height: 1.1;
}
.cd-pat-num small { font-size: 16px; display: block; color: rgba(245,200,66,.7); }
.cd-pat-label { font-size: 13px; font-weight: 700; color: rgba(255,255,255,.9); flex: 1; }
.cd-pat-arrow {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #fff;
  font-weight: 700;
}
@media (max-width: 991px)  { .cd-patterns-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .cd-patterns-grid { grid-template-columns: repeat(2, 1fr); } .cd-patterns-section { padding: 24px 16px 8px; } }
@media (max-width: 400px)  { .cd-pat-num { font-size: 20px; } }

/* ── Delivery process section ─────────────────────────────────── */
.cd-delivery-section { background: var(--accent); padding: 24px 16px; margin: 12px 0; }
.cd-delivery-inner { max-width: 1100px; margin: 0 auto; }
.cd-delivery-steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}
.cd-delivery-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 160px;
  padding: 0 8px;
}
.cd-delivery-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  border: 2px solid rgba(255,255,255,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  margin-bottom: 12px;
  flex-shrink: 0;
}
.cd-delivery-step h3 { font-size: 14px; font-weight: 800; color: #fff; margin-bottom: 6px; }
.cd-delivery-step p  { font-size: 12px; color: rgba(255,255,255,.85); line-height: 1.5; margin: 0; }
.cd-delivery-arrow {
  font-size: 28px;
  color: rgba(255,255,255,.6);
  margin-top: 20px;
  flex-shrink: 0;
  padding: 0 4px;
}
@media (max-width: 767px) { .cd-delivery-arrow { display: none; } .cd-delivery-steps { gap: 20px; } .cd-delivery-section { padding: 32px 16px; } }

/* ── Category top strip (auto-scroll ticker) ──────────────────── */
.cd-cat-top-strip {
  background: var(--bg-2);
  border-bottom: 1px solid var(--hair);
  overflow: hidden;
  position: relative;
}
.cd-cat-top-strip:hover .cd-cat-top-inner { animation-play-state: paused; }
.cd-cat-top-inner {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 0;
  white-space: nowrap;
  width: max-content;
  animation: cd-cat-scroll 30s linear infinite;
}
@keyframes cd-cat-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.cd-cat-top-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  border: 1.5px solid var(--hair);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.cd-cat-top-chip:hover { background: var(--bg-3); border-color: var(--hair-2); }
.cd-cat-top-chip.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ── Trust bar ────────────────────────────────────────────────── */
.cd-trust-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
  padding: 10px 16px;
  background: var(--accent);
}
.cd-trust-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #fff;
  line-height: 1.3;
}
.cd-trust-stat span {
  color: #fff !important;
}
.cd-trust-num {
  font-size: 16px;
  font-weight: 800;
  font-family: var(--mono);
}
.cd-trust-stat span:last-child {
  font-size: 10px;
  opacity: .85;
  text-align: center;
}
@media (max-width: 575px) {
  .cd-trust-bar { gap: 20px; padding: 12px 16px; }
  .cd-trust-num { font-size: 17px; }
}

/* ── Shared section title ─────────────────────────────────────── */
.cd-section-title {
  text-align: center;
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 28px;
  color: var(--text);
}

/* ── Why Choose Us ────────────────────────────────────────────── */
.cd-why-section { padding: 24px 16px 18px; }
.cd-why-section .cd-section-title,
.cd-why-section .cd-why-grid {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}
.cd-why-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 20px;
}
.cd-why-card {
  background: var(--bg-2);
  border: 1px solid var(--hair);
  border-top: 3px solid var(--accent);
  border-radius: var(--r-lg);
  padding: 28px 20px;
  text-align: center;
  box-shadow: 0 2px 12px var(--shadow-ink);
  transition: box-shadow .2s, transform .2s;
}
.cd-why-card:hover { box-shadow: 0 8px 28px var(--shadow-ink); transform: translateY(-3px); }
.cd-why-icon { font-size: 34px; display: block; margin-bottom: 12px; }
.cd-why-card h3 { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.cd-why-card p { font-size: 13px; color: var(--mute); line-height: 1.55; margin: 0; }

/* ── How It Works ─────────────────────────────────────────────── */
.cd-hiw-section {
  padding: 22px 16px 24px;
  background: var(--bg-2);
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.cd-hiw-section > .cd-section-title,
.cd-hiw-section .cd-hiw-steps {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}
.cd-hiw-steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}
.cd-hiw-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 160px;
  padding: 0 8px;
}
.cd-hiw-num {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(134,188,66,.35);
}
.cd-hiw-step h3 { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.cd-hiw-step p  { font-size: 12px; color: var(--mute); line-height: 1.5; margin: 0; }
.cd-hiw-connector {
  flex: 1;
  min-width: 24px;
  height: 2px;
  background: var(--hair);
  margin-top: 24px;
}
@media (max-width: 767px) {
  .cd-hiw-connector { display: none; }
  .cd-hiw-steps { gap: 20px; }
}
@media (max-width: 575px) {
  .cd-why-section, .cd-hiw-section { padding-left: 16px; padding-right: 16px; }
}
