/* Window Configurator Pro — v3.1 | WordPress-isolated, theme-proof */

/* ── Google Fonts import ────────────────────────────── */
@import url("https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,300&family=DM+Serif+Display:ital@0;1&display=swap");

/* ── Design Tokens ──────────────────────────────────── */
#wcp-root {
  /* Backgrounds */
  --bg: #ffffff;
  --bg-surface: #f8f9fc;
  --bg-elevated: #ffffff;
  --bg-subtle: #f2f4f8;
  --bg-muted: #eef1f6;

  /* Borders */
  --border: #e2e6ee;
  --border-med: #cdd3df;
  --border-strong: #b0bac9;

  /* Accent — rich navy blue */
  --accent: #1b3b6f;
  --accent-mid: #2d5aa0;
  --accent-light: #ebf1fb;
  --accent-glow: rgba(27, 59, 111, 0.1);

  /* Highlight — warm amber */
  --hi: #d97706;
  --hi-light: #fef3c7;

  /* Text */
  --text-1: #0f1827;
  --text-2: #3d4f68;
  --text-3: #8494ab;
  --text-4: #b5bfd0;

  /* Status */
  --success: #059669;
  --success-light: #d1fae5;
  --error: #dc2626;
  --error-light: #fee2e2;

  /* Radius */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;
  --r-xl: 24px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.1), 0 4px 12px rgba(0,0,0,0.06);
  --shadow-accent: 0 4px 20px rgba(27,59,111,0.18);

  /* Transitions */
  --tr: all 0.18s cubic-bezier(0.4,0,0.2,1);
  --tr-slow: all 0.28s cubic-bezier(0.4,0,0.2,1);

  /* Typography */
  font-family: "DM Sans", system-ui, sans-serif !important;
  font-size: 15px !important;
  background: var(--bg-surface) !important;
  color: var(--text-1) !important;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

/* ── FULL ISOLATION: scope ALL resets inside #wcp-root ── */
/* This prevents the theme from bleeding in AND our rules from bleeding out */

#wcp-root *,
#wcp-root *::before,
#wcp-root *::after {
  box-sizing: border-box !important;
}

/* Typography reset within plugin */
#wcp-root p,
#wcp-root h1, #wcp-root h2, #wcp-root h3,
#wcp-root h4, #wcp-root h5, #wcp-root h6,
#wcp-root span, #wcp-root div, #wcp-root label,
#wcp-root strong, #wcp-root small, #wcp-root em {
  margin: 0 !important;
  padding: 0 !important;
  font-family: "DM Sans", system-ui, sans-serif !important;
  line-height: inherit;
  color: inherit;
}

/* Scoped button reset — no more global button rules */
#wcp-root button {
  cursor: pointer !important;
  border: none !important;
  background: none !important;
  font-family: "DM Sans", system-ui, sans-serif !important;
  font-size: inherit !important;
  padding: 0 !important;
  margin: 0 !important;
  color: inherit !important;
  line-height: inherit !important;
  display: inline-flex !important;
  align-items: center !important;
  text-decoration: none !important;
  /* Kill any theme box-shadows on buttons */
  box-shadow: none !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

/* Scoped input/textarea reset */
#wcp-root input,
#wcp-root textarea {
  font-family: "DM Sans", system-ui, sans-serif !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
}

/* Scoped anchor reset */
#wcp-root a {
  color: var(--accent) !important;
  text-decoration: none !important;
}

/* ── SVG FIX: Force SVG rendering independent of theme ── */
/* Many themes set svg { fill: currentColor } or override stroke/fill globally */
#wcp-root svg {
  fill: none !important;       /* default: no fill — matches our stroke-based icons */
  stroke: none !important;     /* reset stroke — each SVG element sets its own */
  display: block !important;
  overflow: visible !important;
}
/* SVG child elements: do NOT reset fill/stroke with unset here.
   Inline stroke/fill attributes on child elements have higher specificity
   than inherited CSS, so they work naturally once the parent svg reset stops
   theme inheritance. The rules below for specific icon wrappers handle
   currentColor-based icons that have no inline attributes. */

/* Preview SVGs (dim frame, sidebar, summary) use style="" attributes on child
   elements which sit in the author style layer — they beat any theme CSS rule.
   No additional CSS overrides needed here. */

/* Brand icon SVG — white strokes on dark bg */
#wcp-root .wcp-brand-icon svg {
  color: #fff !important;
}
#wcp-root .wcp-brand-icon svg line,
#wcp-root .wcp-brand-icon svg rect {
  stroke: currentColor !important;
}

/* Product card SVGs — use currentColor inherited from .wcp-product-svg */
#wcp-root .wcp-product-svg svg line,
#wcp-root .wcp-product-svg svg rect,
#wcp-root .wcp-product-svg svg path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Opening card SVGs */
#wcp-root .wcp-opening-svg svg line,
#wcp-root .wcp-opening-svg svg rect,
#wcp-root .wcp-opening-svg svg path,
#wcp-root .wcp-opening-svg svg circle {
  stroke: currentColor !important;
  fill: none !important;
}

/* Glass icon SVGs */
#wcp-root .wcp-glass-icon svg line,
#wcp-root .wcp-glass-icon svg rect,
#wcp-root .wcp-glass-icon svg path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Checkmark SVG (filled circle + path) */
#wcp-root .wcp-product-check svg path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Nav arrow SVGs */
#wcp-root .wcp-nav-btn svg path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Cart button SVG */
#wcp-root .wcp-btn-cart svg path,
#wcp-root .wcp-btn-cart svg line {
  stroke: currentColor !important;
  fill: none !important;
}

/* Glass check svg */
#wcp-root .wcp-glass-check svg path {
  stroke: currentColor !important;
  fill: none !important;
}

/* Window preview SVGs in sidebar and dim frame */
#wcp-root .wcp-dim-frame svg rect,
#wcp-root .wcp-dim-frame svg line,
#wcp-root .wcp-dim-frame svg path {
  /* Keep their explicit stroke colors from PHP */
  stroke-width: inherit;
}

#wcp-root .wcp-sidebar-preview svg rect,
#wcp-root .wcp-sidebar-preview svg line,
#wcp-root .wcp-sidebar-preview svg path {
  stroke-width: inherit;
}

#wcp-root .wcp-summary-window svg rect,
#wcp-root .wcp-summary-window svg line,
#wcp-root .wcp-summary-window svg path {
  stroke-width: inherit;
}

/* ── Header & Progress Bar ──────────────────────────── */
#wcp-root .wcp-header {
  background: var(--bg-elevated) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 0 40px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 200 !important;
  box-shadow: 0 1px 0 var(--border), var(--shadow-sm) !important;
}

#wcp-root .wcp-header-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  max-width: 1160px !important;
  margin: 0 auto !important;
  height: 64px !important;
  gap: 24px !important;
}

#wcp-root .wcp-brand {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-shrink: 0 !important;
}
#wcp-root .wcp-brand-icon {
  width: 34px !important;
  height: 34px !important;
  background: var(--accent) !important;
  border-radius: var(--r-sm) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#wcp-root .wcp-brand-icon svg {
  width: 18px !important;
  height: 18px !important;
  color: #fff !important;
}
#wcp-root .wcp-brand-name {
  font-family: "DM Serif Display", serif !important;
  font-size: 16px !important;
  color: var(--text-1) !important;
  letter-spacing: -0.01em !important;
}
#wcp-root .wcp-brand-name span {
  color: var(--accent) !important;
}

#wcp-root .wcp-steps-bar {
  display: flex !important;
  align-items: center !important;
  flex: 1 !important;
  max-width: 640px !important;
  gap: 0 !important;
}

#wcp-root .wcp-step {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 5px !important;
  cursor: pointer !important;
  flex: 0 0 auto !important;
  transition: var(--tr) !important;
}

#wcp-root .wcp-step-dot {
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  border: 2px solid var(--border) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--text-3) !important;
  background: var(--bg) !important;
  transition: var(--tr) !important;
  position: relative !important;
}

#wcp-root .wcp-step-name {
  font-size: 10px !important;
  color: var(--text-4) !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  transition: var(--tr) !important;
  white-space: nowrap !important;
}

#wcp-root .wcp-step.active .wcp-step-dot {
  border-color: var(--accent) !important;
  background: var(--accent) !important;
  color: #fff !important;
  box-shadow: 0 0 0 4px var(--accent-light) !important;
}
#wcp-root .wcp-step.active .wcp-step-name {
  color: var(--accent) !important;
  font-weight: 600 !important;
}
#wcp-root .wcp-step.done .wcp-step-dot {
  border-color: var(--success) !important;
  background: var(--success-light) !important;
  color: var(--success) !important;
}
#wcp-root .wcp-step.done .wcp-step-name {
  color: var(--success) !important;
}
#wcp-root .wcp-step:hover:not(.active) .wcp-step-dot {
  border-color: var(--border-med) !important;
}

#wcp-root .wcp-step-line {
  flex: 1 !important;
  height: 1px !important;
  background: var(--border) !important;
  margin: 0 6px !important;
  margin-top: -14px !important;
  min-width: 12px !important;
}
#wcp-root .wcp-step-line.done {
  background: var(--success) !important;
}

/* ── Body Layout ─────────────────────────────────────── */
#wcp-root .wcp-body {
  display: grid !important;
  grid-template-columns: 1fr 296px !important;
  gap: 24px !important;
  max-width: 1160px !important;
  margin: 0 auto !important;
  padding: 32px 24px 60px !important;
  align-items: start !important;
}

/* ── Main Panel ──────────────────────────────────────── */
#wcp-root .wcp-main {
  min-width: 0 !important;
}

#wcp-root .wcp-panel {
  display: none !important;
  animation: wcp-fadeUp 0.22s ease !important;
}
#wcp-root .wcp-panel.active {
  display: block !important;
}

@keyframes wcp-fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

#wcp-root .wcp-panel-head {
  margin-bottom: 28px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid var(--border) !important;
}
#wcp-root .wcp-panel-head h2 {
  font-family: "DM Serif Display", serif !important;
  font-size: 26px !important;
  font-weight: 400 !important;
  color: var(--text-1) !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 6px !important;
}
#wcp-root .wcp-panel-head p {
  color: var(--text-3) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
}

/* ── Card base ───────────────────────────────────────── */
#wcp-root .wcp-card {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-card:hover {
  border-color: var(--border-med) !important;
  box-shadow: var(--shadow-sm) !important;
}
#wcp-root .wcp-card.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
  box-shadow: 0 0 0 3px rgba(27,59,111,0.08) !important;
}

/* ── Step 1: Product Grid ────────────────────────────── */
#wcp-root .wcp-product-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 16px !important;
  margin-bottom: 32px !important;
}

#wcp-root .wcp-product-card {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  padding: 24px 20px 20px !important;
  cursor: pointer !important;
  transition: var(--tr-slow) !important;
  position: relative !important;
  overflow: hidden !important;
  /* Override any theme button/link hover transforms */
  text-decoration: none !important;
}
#wcp-root .wcp-product-card::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: var(--accent) !important;
  transform: scaleX(0) !important;
  transition: var(--tr) !important;
  transform-origin: left !important;
}
#wcp-root .wcp-product-card:hover {
  border-color: var(--border-med) !important;
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px) !important;
  background: var(--bg-elevated) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-product-card:hover::before {
  transform: scaleX(0.5) !important;
}
#wcp-root .wcp-product-card.selected {
  border-color: var(--accent) !important;
  background: #fff !important;
  box-shadow: var(--shadow-accent) !important;
}
#wcp-root .wcp-product-card.selected::before {
  transform: scaleX(1) !important;
}

#wcp-root .wcp-product-svg {
  color: var(--text-4) !important;
  transition: var(--tr) !important;
  margin-bottom: 18px !important;
}
#wcp-root .wcp-product-svg svg {
  width: 68px !important;
  height: 68px !important;
  display: block !important;
}
#wcp-root .wcp-product-card.selected .wcp-product-svg {
  color: var(--accent) !important;
}
#wcp-root .wcp-product-card:hover:not(.selected) .wcp-product-svg {
  color: var(--border-strong) !important;
}

#wcp-root .wcp-product-id {
  font-size: 10px !important;
  color: var(--text-4) !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  margin-bottom: 5px !important;
}
#wcp-root .wcp-product-name {
  font-family: "DM Serif Display", serif !important;
  font-size: 17px !important;
  font-weight: 400 !important;
  color: var(--text-1) !important;
  margin-bottom: 3px !important;
  letter-spacing: -0.01em !important;
}
#wcp-root .wcp-product-short {
  font-size: 11px !important;
  color: var(--accent-mid) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  margin-bottom: 10px !important;
}
#wcp-root .wcp-product-desc {
  font-size: 12.5px !important;
  color: var(--text-3) !important;
  line-height: 1.55 !important;
  margin-bottom: 16px !important;
}
#wcp-root .wcp-product-price {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--hi) !important;
  letter-spacing: -0.01em !important;
}
#wcp-root .wcp-product-check {
  position: absolute !important;
  top: 14px !important; right: 14px !important;
  width: 22px !important; height: 22px !important;
  background: var(--accent) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  opacity: 0 !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-product-check svg {
  width: 12px !important;
  height: 12px !important;
}
#wcp-root .wcp-product-card.selected .wcp-product-check {
  opacity: 1 !important;
}

/* ── Section Divider ─────────────────────────────────── */
#wcp-root .wcp-section-divider {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 28px 0 16px !important;
}
#wcp-root .wcp-section-divider::before,
#wcp-root .wcp-section-divider::after {
  content: "" !important;
  flex: 1 !important;
  height: 1px !important;
  background: var(--border) !important;
}
#wcp-root .wcp-section-divider span {
  font-size: 11px !important;
  color: var(--text-3) !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  font-weight: 600 !important;
}

/* ── Profile Pills ───────────────────────────────────── */
#wcp-root .wcp-inline-options {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
#wcp-root .wcp-opt-pill {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 12px 16px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
  flex: 1 !important;
  min-width: 140px !important;
}
#wcp-root .wcp-opt-pill:hover {
  border-color: var(--border-med) !important;
  background: var(--bg-surface) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-opt-pill.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
  box-shadow: 0 0 0 2px rgba(27,59,111,0.06) !important;
}
#wcp-root .wcp-opt-pill.hidden { display: none !important; }

#wcp-root .wcp-pill-label {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: var(--text-1) !important;
  display: block !important;
  margin-bottom: 3px !important;
}
#wcp-root .wcp-pill-sub {
  font-size: 11.5px !important;
  color: var(--text-3) !important;
}
#wcp-root .wcp-opt-pill.selected .wcp-pill-label {
  color: var(--accent) !important;
}

/* ── Step 2: Dimensions ──────────────────────────────── */
#wcp-root .wcp-dim-layout {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 36px !important;
  align-items: start !important;
}
#wcp-root .wcp-dim-canvas {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#wcp-root .wcp-dim-frame {
  position: relative !important;
  background: var(--bg-elevated) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 24px !important;
  width: 280px !important;
  height: 280px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#wcp-root .wcp-dim-frame svg {
  width: 100% !important;
  height: 100% !important;
}
#wcp-root .wcp-dim-badge {
  position: absolute !important;
  background: var(--accent) !important;
  color: #fff !important;
  border-radius: var(--r-sm) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  padding: 4px 10px !important;
  letter-spacing: 0.03em !important;
  box-shadow: var(--shadow-sm) !important;
}
#wcp-root .wcp-dim-w {
  bottom: 14px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
}
#wcp-root .wcp-dim-h {
  right: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) rotate(90deg) !important;
}

#wcp-root .wcp-dim-fields {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
}
#wcp-root .wcp-field label {
  display: block !important;
  font-size: 11.5px !important;
  color: var(--text-2) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  font-weight: 600 !important;
  margin-bottom: 8px !important;
}
#wcp-root .wcp-field label span {
  font-size: 10px !important;
  color: var(--text-3) !important;
  text-transform: none !important;
}
#wcp-root .wcp-num-wrap {
  display: flex !important;
  align-items: center !important;
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-num-wrap:focus-within {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-light) !important;
}
#wcp-root .wcp-num-btn {
  width: 42px !important;
  height: 44px !important;
  font-size: 18px !important;
  color: var(--text-3) !important;
  background: var(--bg-surface) !important;
  border-right: 1px solid var(--border) !important;
  transition: var(--tr) !important;
  flex-shrink: 0 !important;
  font-weight: 300 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#wcp-root .wcp-num-btn:last-child {
  border-right: none !important;
  border-left: 1px solid var(--border) !important;
}
#wcp-root .wcp-num-btn:hover {
  background: var(--bg-muted) !important;
  color: var(--text-2) !important;
  transform: none !important;
}
#wcp-root .wcp-num-btn:focus {
  background: var(--bg-muted) !important;
  color: var(--text-2) !important;
  outline: none !important;
}
#wcp-root .wcp-num-input {
  flex: 1 !important;
  height: 44px !important;
  background: none !important;
  border: none !important;
  outline: none !important;
  color: var(--text-1) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-align: center !important;
  box-shadow: none !important;
}
#wcp-root .wcp-num-input::-webkit-inner-spin-button { -webkit-appearance: none; }

#wcp-root .wcp-field-hint {
  font-size: 11px !important;
  color: var(--text-4) !important;
  margin-top: 5px !important;
}
#wcp-root .wcp-opt-label {
  color: var(--text-3) !important;
  font-weight: 400 !important;
}
#wcp-root .wcp-textarea {
  width: 100% !important;
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  color: var(--text-1) !important;
  font-size: 13.5px !important;
  padding: 10px 14px !important;
  resize: vertical !important;
  outline: none !important;
  transition: var(--tr) !important;
  line-height: 1.5 !important;
  box-shadow: none !important;
}
#wcp-root .wcp-textarea:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-light) !important;
}
#wcp-root .wcp-textarea::placeholder { color: var(--text-4) !important; }

#wcp-root .wcp-area-display {
  font-size: 13px !important;
  color: var(--text-2) !important;
  background: var(--bg-surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 10px 14px !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
#wcp-root .wcp-area-display strong {
  color: var(--hi) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
}

/* ── Step 3: Opening Grid ────────────────────────────── */
#wcp-root .wcp-opening-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(128px, 1fr)) !important;
  gap: 12px !important;
}
#wcp-root .wcp-opening-card {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 18px 12px 14px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
  text-align: center !important;
}
#wcp-root .wcp-opening-card:hover:not(.hidden) {
  border-color: var(--border-med) !important;
  box-shadow: var(--shadow-sm) !important;
  transform: translateY(-1px) !important;
  background: var(--bg-elevated) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-opening-card.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
  box-shadow: 0 0 0 2px rgba(27,59,111,0.06) !important;
}
#wcp-root .wcp-opening-card.hidden { display: none !important; }

#wcp-root .wcp-opening-svg {
  color: var(--text-4) !important;
  margin-bottom: 10px !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-opening-svg svg {
  width: 50px !important;
  height: 50px !important;
  display: block !important;
  margin: 0 auto !important;
}
#wcp-root .wcp-opening-card.selected .wcp-opening-svg { color: var(--accent) !important; }
#wcp-root .wcp-opening-card:hover:not(.selected) .wcp-opening-svg { color: var(--border-strong) !important; }

#wcp-root .wcp-opening-label {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--text-1) !important;
  margin-bottom: 4px !important;
}
#wcp-root .wcp-opening-price { font-size: 11px !important; color: var(--text-4) !important; }
#wcp-root .wcp-opening-card.selected .wcp-opening-price {
  color: var(--accent-mid) !important;
  font-weight: 600 !important;
}

/* ── Step 4: Color ───────────────────────────────────── */
#wcp-root .wcp-color-modes {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 10px !important;
  margin-bottom: 24px !important;
}
#wcp-root .wcp-color-mode {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 14px 16px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-color-mode:hover {
  border-color: var(--border-med) !important;
  background: var(--bg-elevated) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-color-mode.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
}
#wcp-root .wcp-mode-dot {
  width: 16px !important; height: 16px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  margin-top: 2px !important;
  border: 2px solid var(--border-med) !important;
  transition: var(--tr) !important;
  background: transparent !important;
}
#wcp-root .wcp-color-mode.selected .wcp-mode-dot {
  border-color: var(--accent) !important;
  background: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-light) !important;
}
#wcp-root .wcp-mode-body strong {
  display: block !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text-1) !important;
  margin-bottom: 3px !important;
}
#wcp-root .wcp-mode-body span { font-size: 11.5px !important; color: var(--text-3) !important; }
#wcp-root .wcp-color-mode.selected .wcp-mode-body strong { color: var(--accent) !important; }

#wcp-root .wcp-section-label {
  font-size: 11px !important;
  color: var(--text-3) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.09em !important;
  font-weight: 600 !important;
  margin-bottom: 14px !important;
}
#wcp-root .wcp-color-panel { margin-bottom: 20px !important; }
#wcp-root .wcp-swatch-row { display: flex !important; flex-wrap: wrap !important; gap: 10px !important; }
#wcp-root .wcp-swatch {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 10px 14px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-swatch:hover {
  border-color: var(--border-med) !important;
  box-shadow: var(--shadow-sm) !important;
  background: var(--bg-elevated) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-swatch.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
}
#wcp-root .wcp-swatch.hidden { display: none !important; }
#wcp-root .wcp-swatch-circle {
  width: 28px !important; height: 28px !important;
  border-radius: 50% !important;
  background: var(--sw-color) !important;
  flex-shrink: 0 !important;
  border: 2px solid rgba(0,0,0,0.08) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
}
#wcp-root .wcp-swatch-info span { display: block !important; font-size: 13px !important; font-weight: 600 !important; color: var(--text-1) !important; }
#wcp-root .wcp-swatch-info small { font-size: 10.5px !important; color: var(--text-3) !important; }
#wcp-root .wcp-swatch.selected .wcp-swatch-info span { color: var(--accent) !important; }

#wcp-root .wcp-ral-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(66px, 1fr)) !important;
  gap: 10px !important;
}
#wcp-root .wcp-ral-swatch {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 6px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
  border-radius: var(--r-md) !important;
  padding: 8px !important;
  border: 1.5px solid transparent !important;
}
#wcp-root .wcp-ral-swatch:hover {
  border-color: var(--border-med) !important;
  background: var(--bg-surface) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-ral-swatch.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
}
#wcp-root .wcp-ral-swatch.hidden { display: none !important; }
#wcp-root .wcp-ral-circle {
  width: 40px !important; height: 40px !important;
  border-radius: 50% !important;
  background: var(--sw-color) !important;
  border: 2px solid rgba(0,0,0,0.07) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.12) !important;
}
#wcp-root .wcp-ral-swatch span { font-size: 10.5px !important; color: var(--text-2) !important; font-weight: 600 !important; }
#wcp-root .wcp-ral-swatch.selected span { color: var(--accent) !important; }

/* ── Step 5: Glass ───────────────────────────────────── */
#wcp-root .wcp-glass-tabs {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-bottom: 18px !important;
}
#wcp-root .wcp-glass-tab {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 20px !important;
  padding: 6px 16px !important;
  font-size: 13px !important;
  color: var(--text-2) !important;
  font-weight: 500 !important;
  transition: var(--tr) !important;
  cursor: pointer !important;
}
#wcp-root .wcp-glass-tab:hover,
#wcp-root .wcp-glass-tab:focus,
#wcp-root .wcp-glass-tab.active {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  background: var(--accent-light) !important;
  font-weight: 600 !important;
}

#wcp-root .wcp-glass-list { display: flex !important; flex-direction: column !important; gap: 8px !important; }
#wcp-root .wcp-glass-row {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 14px 16px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-glass-row:hover {
  border-color: var(--border-med) !important;
  box-shadow: var(--shadow-sm) !important;
  background: var(--bg-elevated) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-glass-row.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
}
#wcp-root .wcp-glass-row.hidden { display: none !important; }
#wcp-root .wcp-glass-icon { color: var(--text-4) !important; flex-shrink: 0 !important; transition: var(--tr) !important; }
#wcp-root .wcp-glass-icon svg { width: 32px !important; height: 32px !important; }
#wcp-root .wcp-glass-row.selected .wcp-glass-icon { color: var(--accent) !important; }
#wcp-root .wcp-glass-info { flex: 1 !important; }
#wcp-root .wcp-glass-info strong { display: block !important; font-size: 14px !important; font-weight: 600 !important; color: var(--text-1) !important; }
#wcp-root .wcp-glass-info span { font-size: 12px !important; color: var(--text-3) !important; }
#wcp-root .wcp-glass-row.selected .wcp-glass-info strong { color: var(--accent) !important; }
#wcp-root .wcp-glass-price-tag { font-size: 12.5px !important; font-weight: 700 !important; color: var(--text-3) !important; white-space: nowrap !important; }
#wcp-root .wcp-glass-row.selected .wcp-glass-price-tag { color: var(--hi) !important; }
#wcp-root .wcp-glass-check { color: var(--accent) !important; opacity: 0 !important; transition: var(--tr) !important; flex-shrink: 0 !important; }
#wcp-root .wcp-glass-check svg { width: 20px !important; height: 20px !important; }
#wcp-root .wcp-glass-row.selected .wcp-glass-check { opacity: 1 !important; }

/* ── Step 6: Extra Options ───────────────────────────── */
#wcp-root .wcp-option-group { margin-bottom: 28px !important; }
#wcp-root .wcp-option-group.hidden { display: none !important; }
#wcp-root .wcp-option-group-head h3 {
  font-size: 11px !important;
  color: var(--text-3) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.09em !important;
  font-weight: 600 !important;
  margin-bottom: 12px !important;
  padding-left: 2px !important;
}
#wcp-root .wcp-opt-card-row { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; }
#wcp-root .wcp-opt-card {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  padding: 12px 16px !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
  flex: 1 !important;
  min-width: 100px !important;
}
#wcp-root .wcp-opt-card:hover {
  border-color: var(--border-med) !important;
  background: var(--bg-surface) !important;
  color: var(--text-1) !important;
}
#wcp-root .wcp-opt-card.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
}
#wcp-root .wcp-opt-card.hidden { display: none !important; }
#wcp-root .wcp-opt-name { font-size: 13px !important; font-weight: 600 !important; color: var(--text-1) !important; }
#wcp-root .wcp-opt-sub { font-size: 11px !important; color: var(--text-3) !important; margin-top: 2px !important; }
#wcp-root .wcp-opt-card.selected .wcp-opt-name { color: var(--accent) !important; }

/* Toggles */
#wcp-root .wcp-toggles-grid { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
#wcp-root .wcp-toggle-group.hidden { display: none !important; }
#wcp-root .wcp-toggle-label { font-size: 11px !important; color: var(--text-3) !important; font-weight: 600 !important; margin-bottom: 8px !important; text-transform: uppercase !important; letter-spacing: 0.07em !important; }
#wcp-root .wcp-toggle-row { display: flex !important; gap: 6px !important; }
#wcp-root .wcp-toggle {
  flex: 1 !important;
  padding: 9px 12px !important;
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-sm) !important;
  font-size: 12.5px !important;
  color: var(--text-2) !important;
  font-weight: 500 !important;
  transition: var(--tr) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#wcp-root .wcp-toggle:hover,
#wcp-root .wcp-toggle:focus,
#wcp-root .wcp-toggle.selected {
  border-color: var(--accent) !important;
  background: var(--accent-light) !important;
  color: var(--accent) !important;
  font-weight: 600 !important;
}
#wcp-root .wcp-toggle em { font-style: normal !important; color: var(--hi) !important; font-size: 11px !important; }
#wcp-root .wcp-toggle.hidden { display: none !important; }

/* ── Step 7: Summary ─────────────────────────────────── */
#wcp-root .wcp-summary-layout { display: grid !important; grid-template-columns: 1fr 300px !important; gap: 28px !important; }
#wcp-root .wcp-summary-window {
  background: var(--bg-elevated) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  padding: 28px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 200px !important;
  margin-bottom: 20px !important;
  box-shadow: var(--shadow-sm) !important;
}
#wcp-root .wcp-summary-window svg { width: 100% !important; max-width: 220px !important; height: auto !important; }
#wcp-root .wcp-summary-table { display: flex !important; flex-direction: column !important; }
#wcp-root .wcp-sum-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  font-size: 13px !important;
}
#wcp-root .wcp-sum-row:last-child { border-bottom: none !important; }
#wcp-root .wcp-sum-row span { color: var(--text-3) !important; }
#wcp-root .wcp-sum-row strong { color: var(--text-1) !important; font-weight: 600 !important; text-align: right !important; max-width: 60% !important; }

/* Price card */
#wcp-root .wcp-price-card {
  background: var(--bg-elevated) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  padding: 24px !important;
  position: sticky !important;
  top: 84px !important;
  box-shadow: var(--shadow-md) !important;
}
#wcp-root .wcp-price-label { font-size: 10.5px !important; color: var(--text-3) !important; text-transform: uppercase !important; letter-spacing: 0.1em !important; font-weight: 600 !important; margin-bottom: 14px !important; }
#wcp-root .wcp-price-breakdown { margin-bottom: 16px !important; }
#wcp-root .wcp-pb-row {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 12.5px !important;
  color: var(--text-2) !important;
  padding: 5px 0 !important;
  border-bottom: 1px dashed var(--border) !important;
}
#wcp-root .wcp-pb-row:last-child { border-bottom: none !important; }
#wcp-root .wcp-pb-row span:last-child { color: var(--text-1) !important; font-weight: 600 !important; }
#wcp-root .wcp-price-total-ex {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 12px 0 !important;
  border-top: 2px solid var(--border) !important;
  margin-top: 6px !important;
}
#wcp-root .wcp-price-total-ex span { font-size: 13px !important; color: var(--text-2) !important; }
#wcp-root .wcp-price-total-ex strong { font-family: "DM Serif Display", serif !important; font-size: 22px !important; color: var(--text-1) !important; font-weight: 400 !important; }
#wcp-root .wcp-price-total-inc {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  margin-bottom: 18px !important;
}
#wcp-root .wcp-price-total-inc span { font-size: 12px !important; color: var(--text-3) !important; }
#wcp-root .wcp-price-total-inc strong { font-size: 13px !important; color: var(--text-3) !important; }
#wcp-root .wcp-qty-row { display: flex !important; align-items: center !important; justify-content: space-between !important; margin-bottom: 16px !important; }
#wcp-root .wcp-qty-row span { font-size: 13px !important; color: var(--text-2) !important; font-weight: 500 !important; }
#wcp-root .wcp-qty-ctrl {
  display: flex !important;
  align-items: center !important;
  background: var(--bg-surface) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-sm) !important;
  overflow: hidden !important;
}
#wcp-root .wcp-qty-btn {
  width: 32px !important; height: 32px !important;
  font-size: 16px !important;
  color: var(--text-2) !important;
  transition: var(--tr) !important;
  font-weight: 300 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#wcp-root .wcp-qty-btn:hover,
#wcp-root .wcp-qty-btn:focus {
  background: var(--bg-muted) !important;
  color: var(--text-1) !important;
}
#wcp-root #qtyInput {
  width: 40px !important; height: 32px !important;
  background: none !important;
  border: none !important;
  border-left: 1px solid var(--border) !important;
  border-right: 1px solid var(--border) !important;
  outline: none !important;
  color: var(--text-1) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-align: center !important;
  box-shadow: none !important;
}
#wcp-root #qtyInput::-webkit-inner-spin-button { -webkit-appearance: none; }

#wcp-root .wcp-cart-msg { padding: 10px 14px !important; border-radius: var(--r-sm) !important; font-size: 13px !important; font-weight: 500 !important; margin-bottom: 14px !important; }
#wcp-root .wcp-cart-msg.success { background: var(--success-light) !important; color: var(--success) !important; border: 1px solid rgba(5,150,105,0.25) !important; }
#wcp-root .wcp-cart-msg.error { background: var(--error-light) !important; color: var(--error) !important; border: 1px solid rgba(220,38,38,0.2) !important; }

/* ── Buttons ─────────────────────────────────────────── */
#wcp-root .wcp-btn-cart {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
  width: 100% !important;
  padding: 14px 20px !important;
  background: var(--accent) !important;
  color: #fff !important;
  border-radius: var(--r-md) !important;
  font-size: 14.5px !important;
  font-weight: 700 !important;
  font-family: "DM Sans", sans-serif !important;
  letter-spacing: -0.01em !important;
  transition: var(--tr-slow) !important;
  cursor: pointer !important;
  border: none !important;
  box-shadow: var(--shadow-accent) !important;
  margin-bottom: 10px !important;
  text-decoration: none !important;
}
#wcp-root .wcp-btn-cart:hover:not(:disabled) {
  background: var(--accent-mid) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 28px rgba(27,59,111,0.28) !important;
  color: #fff !important;
}
#wcp-root .wcp-btn-cart:focus {
  background: var(--accent) !important;
  color: #fff !important;
}
#wcp-root .wcp-btn-cart:active { transform: translateY(0) !important; }
#wcp-root .wcp-btn-cart:disabled { opacity: 0.65 !important; cursor: not-allowed !important; }
#wcp-root .wcp-btn-cart svg { width: 17px !important; height: 17px !important; }
#wcp-root .wcp-btn-cart.sidebar-cart { padding: 11px 16px !important; font-size: 13px !important; }

#wcp-root .wcp-btn-ghost {
  width: 100% !important;
  padding: 10px !important;
  background: none !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  color: var(--text-2) !important;
  font-size: 13px !important;
  transition: var(--tr) !important;
  cursor: pointer !important;
  font-family: inherit !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}
#wcp-root .wcp-btn-ghost:hover,
#wcp-root .wcp-btn-ghost:focus {
  border-color: var(--border-med) !important;
  color: #fff !important;
  background: var(--accent) !important;
}

#wcp-root .wcp-btn-reset {
  width: 100% !important;
  padding: 8px !important;
  background: none !important;
  color: var(--text-1) !important;
  font-size: 12px !important;
  transition: var(--tr) !important;
  margin-top: 8px !important;
  font-family: inherit !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  border: none !important;
}
#wcp-root .wcp-btn-reset:hover,
#wcp-root .wcp-btn-reset:focus {
  background: rgba(220,38,38,0.08) !important;
  color: var(--error) !important;
}

/* ── Navigation Bar ──────────────────────────────────── */
#wcp-root .wcp-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 24px 0 0 !important;
  border-top: 1px solid var(--border) !important;
  margin-top: 36px !important;
}
#wcp-root .wcp-nav-btn {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 11px 22px !important;
  border-radius: var(--r-md) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  transition: var(--tr) !important;
  cursor: pointer !important;
  font-family: inherit !important;
}
#wcp-root .wcp-btn-prev {
  background: var(--bg-elevated) !important;
  border: 1.5px solid var(--border) !important;
  color: var(--text-2) !important;
}
#wcp-root .wcp-btn-prev:hover,
#wcp-root .wcp-btn-prev:focus {
  border-color: var(--border-med) !important;
  color: var(--text-1) !important;
  background: var(--bg-surface) !important;
}
#wcp-root .wcp-btn-next {
  background: var(--accent) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: var(--shadow-accent) !important;
}
#wcp-root .wcp-btn-next:hover,
#wcp-root .wcp-btn-next:focus {
  background: var(--accent-mid) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 24px rgba(27,59,111,0.28) !important;
  color: #fff !important;
}
#wcp-root .wcp-nav-btn svg { width: 16px !important; height: 16px !important; }

#wcp-root .wcp-nav-info { text-align: center !important; }
#wcp-root #navStepLabel { display: block !important; font-size: 11.5px !important; color: var(--text-3) !important; margin-bottom: 8px !important; font-weight: 500 !important; }
#wcp-root .wcp-nav-dots { display: flex !important; gap: 5px !important; justify-content: center !important; }
#wcp-root .wcp-nav-dot {
  width: 6px !important; height: 6px !important;
  border-radius: 50% !important;
  background: var(--border-med) !important;
  cursor: pointer !important;
  transition: var(--tr) !important;
}
#wcp-root .wcp-nav-dot.active { background: var(--accent) !important; width: 22px !important; border-radius: 3px !important; }
#wcp-root .wcp-nav-dot.done { background: var(--success) !important; }

/* ── Sidebar ─────────────────────────────────────────── */
#wcp-root .wcp-sidebar { padding-left: 0 !important; }
#wcp-root .wcp-sidebar-sticky {
  position: sticky !important;
  top: 80px !important;
  background: var(--bg-elevated) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-xl) !important;
  padding: 20px !important;
  box-shadow: var(--shadow-md) !important;
}
#wcp-root .wcp-sidebar-preview {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  padding: 20px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 18px !important;
  min-height: 160px !important;
  justify-content: center !important;
}
#wcp-root .wcp-sidebar-preview svg { width: 130px !important; height: 130px !important; }
#wcp-root .wcp-sidebar-product-badge {
  font-size: 10.5px !important;
  color: var(--text-3) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.09em !important;
  background: var(--bg-muted) !important;
  border: 1px solid var(--border) !important;
  border-radius: 20px !important;
  padding: 4px 10px !important;
}
#wcp-root .wcp-sidebar-dim { font-size: 12px !important; color: var(--accent-mid) !important; font-weight: 600 !important; letter-spacing: 0.02em !important; }
#wcp-root .wcp-sidebar-config { margin-bottom: 16px !important; }
#wcp-root .wcp-sc-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  font-size: 12px !important;
}
#wcp-root .wcp-sc-row:last-child { border-bottom: none !important; }
#wcp-root .wcp-sc-row span { color: var(--text-3) !important; font-size: 11px !important; text-transform: uppercase !important; letter-spacing: 0.06em !important; font-weight: 600 !important; }
#wcp-root .wcp-sc-row strong { color: var(--text-1) !important; font-weight: 600 !important; text-align: right !important; max-width: 60% !important; overflow: hidden !important; text-overflow: ellipsis !important; white-space: nowrap !important; font-size: 12px !important; }
#wcp-root .wcp-sidebar-price {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-mid) 100%) !important;
  border-radius: var(--r-md) !important;
  padding: 16px !important;
  margin-bottom: 14px !important;
  text-align: center !important;
  box-shadow: var(--shadow-accent) !important;
}
#wcp-root .wcp-sidebar-price-label { font-size: 10px !important; color: rgba(255,255,255,0.65) !important; text-transform: uppercase !important; letter-spacing: 0.1em !important; margin-bottom: 6px !important; font-weight: 500 !important; }
#wcp-root .wcp-sidebar-price-val { font-family: "DM Serif Display", serif !important; font-size: 28px !important; font-weight: 400 !important; color: #fff !important; line-height: 1.1 !important; }
#wcp-root .wcp-sidebar-price-vat { font-size: 11px !important; color: rgba(255,255,255,0.55) !important; margin-top: 5px !important; }

/* ── Loading Spinner ─────────────────────────────────── */
#wcp-root .wcp-spinner {
  display: inline-block !important;
  width: 13px !important; height: 13px !important;
  border: 2px solid rgba(255,255,255,0.3) !important;
  border-top-color: #fff !important;
  border-radius: 50% !important;
  animation: wcp-spin 0.6s linear infinite !important;
  margin-left: 8px !important;
  vertical-align: middle !important;
}
@keyframes wcp-spin {
  to { transform: rotate(360deg); }
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 960px) {
  #wcp-root .wcp-body { grid-template-columns: 1fr !important; padding: 20px 16px !important; gap: 20px !important; }
  #wcp-root .wcp-sidebar { padding-left: 0 !important; }
  #wcp-root .wcp-sidebar-sticky { position: static !important; }
  #wcp-root .wcp-product-grid { grid-template-columns: 1fr !important; }
  #wcp-root .wcp-dim-layout { grid-template-columns: 1fr !important; }
  #wcp-root .wcp-summary-layout { grid-template-columns: 1fr !important; }
  #wcp-root .wcp-color-modes { grid-template-columns: 1fr !important; }
  #wcp-root .wcp-toggles-grid { grid-template-columns: 1fr !important; }
  #wcp-root .wcp-header-inner { gap: 12px !important; }
  #wcp-root .wcp-brand-name { display: none !important; }
}
@media (max-width: 680px) {
  #wcp-root .wcp-header { padding: 0 16px !important; }
  #wcp-root .wcp-step-name { display: none !important; }
  #wcp-root .wcp-steps-bar { justify-content: space-between !important; }
  #wcp-root .wcp-panel-head h2 { font-size: 22px !important; }
  #wcp-root .wcp-opening-grid { grid-template-columns: repeat(2, 1fr) !important; }
  #wcp-root .wcp-product-grid { grid-template-columns: 1fr !important; }
}
