@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Cairo:wght@400;600;700;800;900&display=swap');

/*
 * DZP Product Options Wizard v8
 * Dark editorial aesthetic — designed for fashion/streetwear brands
 * All colors from dashboard CSS vars — fully customizable
 */

.dzp-pf {
  /* ── Pull dashboard vars, fall back to dark streetwear theme ── */
  --w-bg:     var(--SRF,  #111111);
  --w-bg2:    var(--SRF2, #1a1a1a);
  --w-border: var(--BR,   #2a2a2a);
  --w-ink:    var(--TX,   #f0f0f0);
  --w-ink2:   var(--MU,   #888888);
  --w-ink3:   #555555;
  --w-accent: var(--P,    #c9a84c);  /* gold */
  --w-btn:    var(--BTN,  #c9a84c);
  --w-btnt:   var(--BTNT, #000000);
  --w-card:   var(--BG,   #0d0d0d);
  --w-r:      var(--RI,   10px);
  --w-font:   var(--FB,   'Cairo', sans-serif);
  --w-head:   var(--pf_head_bg,  #0d0d0d);
  --w-done:   var(--pf_head_done,#1a4a2a);
  --w-dot:    var(--pf_dot_color,var(--P, #c9a84c));

  font-family: var(--w-font);
  direction: rtl;
  max-width: 540px;
  background: var(--w-bg);
  border: 1px solid var(--w-border);
  border-radius: 16px;
  overflow: hidden;
  margin: 20px 0;
  box-shadow: 0 20px 60px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.3);
}

/* ══ Header progress bar ══ */
.dzp-wiz-head {
  background: var(--w-head);
  padding: 18px 20px 0;
  border-bottom: 1px solid var(--w-border);
  transition: background .6s ease;
}
.dzp-wiz-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}
.dzp-wiz-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--w-ink2);
}
.dzp-wiz-count {
  font-family: 'Syne', sans-serif;
  font-size: 12px;
  font-weight: 800;
  color: var(--w-dot);
  letter-spacing: .05em;
  direction: ltr;
}
.dzp-wiz-dots {
  display: flex;
  gap: 4px;
  padding-bottom: 0;
  margin-bottom: -1px;
}
.dzp-wiz-dot {
  flex: 1;
  height: 2px;
  background: var(--w-border);
  border-radius: 2px;
  transition: background .4s ease;
  position: relative;
  overflow: hidden;
}
.dzp-wiz-dot.done   { background: var(--w-dot); }
.dzp-wiz-dot.active { background: var(--w-border); }
.dzp-wiz-dot.active::after {
  content: '';
  position: absolute; top: 0; bottom: 0; left: -40%; width: 40%;
  background: var(--w-dot);
  animation: dzpPulse 1.6s ease-in-out infinite;
}
@keyframes dzpPulse { to { left: 140%; } }

/* ══ Answered step row ══ */
.dzp-done-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--w-border);
  background: var(--w-bg2);
  animation: dzpIn .2s ease both;
}
@keyframes dzpIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dzp-done-num {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--w-dot);
  color: #000;
  font-family: 'Syne', sans-serif;
  font-size: 9px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; letter-spacing: 0;
}
.dzp-done-q {
  font-size: 10px; font-weight: 700;
  color: var(--w-ink2);
  text-transform: uppercase; letter-spacing: .06em;
  flex-shrink: 0; max-width: 90px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.dzp-done-a {
  flex: 1;
  font-size: 12px; font-weight: 700;
  color: var(--w-ink);
  text-align: right;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.dzp-done-edit {
  background: transparent;
  border: 1px solid var(--w-border);
  border-radius: 6px;
  padding: 3px 9px;
  font-family: var(--w-font);
  font-size: 10px; font-weight: 700;
  color: var(--w-ink2);
  cursor: pointer;
  transition: all .15s;
  flex-shrink: 0;
  letter-spacing: .04em;
}
.dzp-done-edit:hover { color: var(--w-ink); border-color: var(--w-ink2); }

/* ══ Active step card ══ */
.dzp-step-card {
  padding: 22px 20px 18px;
  border-bottom: 1px solid var(--w-border);
  background: var(--w-bg);
  animation: dzpUp .3s cubic-bezier(.22,.68,0,1.1) both;
}
@keyframes dzpUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.dzp-q-lbl {
  font-family: 'Syne', sans-serif;
  font-size: 15px; font-weight: 800;
  color: var(--w-ink);
  margin-bottom: 18px;
  line-height: 1.3;
  letter-spacing: -.01em;
  display: flex; align-items: flex-start;
  justify-content: flex-end; gap: 6px;
  direction: rtl;
}
.dzp-q-lbl .req { color: var(--w-dot); font-size: 20px; line-height: 1; }

.dzp-err-msg {
  font-size: 11px; font-weight: 700;
  color: #e05555;
  margin-top: 10px; display: none;
  letter-spacing: .02em;
}
.dzp-step-card.has-err { animation: dzpShake .3s ease; }
.dzp-step-card.has-err .dzp-err-msg { display: block; }
@keyframes dzpShake {
  0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)}
}

.dzp-step-nav { display: flex; gap: 8px; margin-top: 18px; }
.dzp-btn-next {
  padding: 12px 24px;
  background: var(--w-btn); color: var(--w-btnt);
  border: none; border-radius: var(--w-r);
  font-family: var(--w-font); font-size: 13px; font-weight: 800;
  cursor: pointer; letter-spacing: .02em;
  display: flex; align-items: center; gap: 6px;
  transition: all .2s ease;
}
.dzp-btn-next:hover { filter: brightness(1.15); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(0,0,0,.4); }
.dzp-btn-next:active { transform: scale(.97); }
.dzp-btn-skip {
  padding: 12px 16px;
  background: transparent; color: var(--w-ink2);
  border: 1px solid var(--w-border);
  border-radius: var(--w-r);
  font-family: var(--w-font); font-size: 12px; font-weight: 700;
  cursor: pointer; transition: all .15s;
}
.dzp-btn-skip:hover { color: var(--w-ink); border-color: var(--w-ink2); }

/* ══ WIDGETS ══ */

.dzp-btns { display: grid; gap: 8px; }
.dzp-opt-btn {
  padding: 13px 16px;
  border: 1px solid var(--w-border);
  border-radius: var(--w-r);
  background: var(--w-bg2);
  font-family: var(--w-font); font-size: 14px; font-weight: 700;
  color: var(--w-ink);
  cursor: pointer; text-align: center; line-height: 1.3;
  transition: all .18s ease;
}
.dzp-opt-btn:hover { border-color: var(--w-ink2); transform: translateY(-1px); }
.dzp-opt-btn.sel { background: var(--w-btn); border-color: var(--w-btn); color: var(--w-btnt); box-shadow: 0 4px 16px rgba(0,0,0,.4); transform: translateY(-1px); }
.dzp-opt-sub { display: block; font-size: 10px; font-weight: 500; opacity: .55; margin-top: 3px; }
.dzp-price-badge { font-size: 10px; font-weight: 700; color: var(--w-dot); margin-right: 4px; font-family: 'Syne', sans-serif; }

.dzp-swatches { display: flex; flex-wrap: wrap; gap: 8px; }
.dzp-swatch {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border: 1px solid var(--w-border);
  border-radius: var(--w-r); background: var(--w-bg2);
  font-family: var(--w-font); font-size: 13px; font-weight: 700; color: var(--w-ink);
  cursor: pointer; transition: all .15s;
}
.dzp-swatch .clr-dot { width: 18px; height: 18px; border-radius: 50%; border: 2px solid rgba(255,255,255,.15); flex-shrink: 0; }
.dzp-swatch:hover { border-color: var(--w-ink2); transform: translateY(-1px); }
.dzp-swatch.sel { border-color: var(--w-dot); box-shadow: 0 0 0 2px var(--w-dot); }

.dzp-select {
  width: 100%; padding: 13px 16px 13px 40px;
  border: 1px solid var(--w-border); border-radius: var(--w-r);
  background: var(--w-bg2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E") no-repeat left 14px center;
  font-family: var(--w-font); font-size: 14px; font-weight: 600; color: var(--w-ink);
  appearance: none; direction: rtl; cursor: pointer; outline: none;
  transition: border-color .15s;
}
.dzp-select:focus { border-color: var(--w-btn); box-shadow: 0 0 0 3px rgba(201,168,76,.15); }

.dzp-radios { display: flex; flex-direction: column; gap: 8px; }
.dzp-radio-row {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px; border: 1px solid var(--w-border);
  border-radius: var(--w-r); cursor: pointer;
  background: var(--w-bg2); transition: all .15s;
}
.dzp-radio-row:hover { border-color: var(--w-ink2); transform: translateX(-2px); }
.dzp-radio-row.sel { border-color: var(--w-dot); background: var(--w-bg); box-shadow: inset 0 0 0 1px var(--w-dot); }
.dzp-radio-ring { width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--w-border); flex-shrink: 0; position: relative; transition: all .15s; }
.dzp-radio-row.sel .dzp-radio-ring { border-color: var(--w-dot); }
.dzp-radio-row.sel .dzp-radio-ring::after { content:''; position:absolute; inset:3px; border-radius:50%; background:var(--w-dot); }
.dzp-radio-info { flex: 1; text-align: right; }
.dzp-radio-title { font-size: 13px; font-weight: 700; color: var(--w-ink); }
.dzp-radio-desc  { font-size: 11px; color: var(--w-ink2); margin-top: 2px; }

.dzp-checks { display: flex; flex-direction: column; gap: 8px; }
.dzp-check-row {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px; border: 1px solid var(--w-border);
  border-radius: var(--w-r); cursor: pointer;
  background: var(--w-bg2); transition: all .15s; user-select: none;
}
.dzp-check-row:hover { border-color: var(--w-ink2); }
.dzp-check-row.sel { border-color: var(--w-dot); box-shadow: inset 0 0 0 1px var(--w-dot); }
.dzp-check-box { width: 18px; height: 18px; border-radius: 5px; border: 2px solid var(--w-border); flex-shrink: 0; position: relative; transition: all .15s; }
.dzp-check-row.sel .dzp-check-box { background: var(--w-dot); border-color: var(--w-dot); }
.dzp-check-row.sel .dzp-check-box::after { content:''; position:absolute; left:4px; top:1px; width:6px; height:10px; border-right:2px solid #000; border-bottom:2px solid #000; transform:rotate(45deg); }
.dzp-check-row input[type=checkbox] { display:none; }
.dzp-check-ico { font-size: 18px; flex-shrink: 0; }
.dzp-check-info { flex: 1; text-align: right; }
.dzp-check-title { font-size: 13px; font-weight: 700; color: var(--w-ink); }
.dzp-check-desc  { font-size: 11px; color: var(--w-ink2); margin-top: 2px; }

.dzp-stepper { display: flex; height: 52px; border: 1px solid var(--w-border); border-radius: var(--w-r); overflow: hidden; background: var(--w-bg2); }
.dzp-qty-btn { width: 52px; background: transparent; border: none; font-size: 22px; font-weight: 300; color: var(--w-ink2); cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all .12s; font-family: 'Syne', sans-serif; }
.dzp-qty-btn:hover { background: var(--w-border); color: var(--w-ink); }
.dzp-qty-val { flex: 1; border: none; border-right: 1px solid var(--w-border); border-left: 1px solid var(--w-border); text-align: center; font-family: 'Syne', sans-serif; font-size: 20px; font-weight: 700; color: var(--w-ink); background: var(--w-bg2); outline: none; }
.dzp-tier-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.dzp-tier-chip { font-size: 11px; padding: 4px 11px; border-radius: 20px; border: 1px solid var(--w-border); background: transparent; color: var(--w-ink2); font-weight: 600; font-family: 'Syne', sans-serif; transition: all .15s; letter-spacing: .02em; }
.dzp-tier-chip.on { background: rgba(201,168,76,.12); color: var(--w-dot); border-color: var(--w-dot); font-weight: 700; }

.dzp-input, .dzp-textarea, .dzp-input-num, .dzp-input-url {
  width: 100%; padding: 13px 16px;
  border: 1px solid var(--w-border); border-radius: var(--w-r);
  font-family: var(--w-font); font-size: 14px; color: var(--w-ink);
  background: var(--w-bg2); direction: rtl;
  transition: border-color .15s; outline: none; box-sizing: border-box;
}
.dzp-input-url { direction: ltr; }
.dzp-textarea { resize: vertical; min-height: 86px; line-height: 1.6; }
.dzp-input:focus, .dzp-textarea:focus, .dzp-input-num:focus, .dzp-input-url:focus {
  border-color: var(--w-btn);
  box-shadow: 0 0 0 3px rgba(201,168,76,.12);
}
.dzp-input::placeholder, .dzp-textarea::placeholder, .dzp-input-url::placeholder { color: var(--w-ink3); }

/* ══ NFC Free Platform Picker ══ */
.dzp-nfc-hint {
  font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: var(--w-ink2); text-align: right; margin-bottom: 14px;
}

.dzp-plat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}
.dzp-plat-tile {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 12px 4px 10px;
  border: 1px solid var(--w-border);
  border-radius: var(--w-r);
  background: var(--w-bg2);
  cursor: pointer;
  transition: all .2s ease;
  position: relative;
  overflow: hidden;
}
.dzp-plat-tile::before {
  content: '';
  position: absolute; inset: 0;
  background: var(--_c, transparent);
  opacity: 0;
  transition: opacity .2s;
}
.dzp-plat-tile:hover::before { opacity: .06; }
.dzp-plat-tile.on::before    { opacity: .1; }
.dzp-plat-tile:hover { border-color: var(--w-ink2); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,.3); }
.dzp-plat-tile.on    { border-color: var(--w-dot); box-shadow: 0 0 0 1.5px var(--w-dot), 0 6px 16px rgba(0,0,0,.3); transform: translateY(-2px); }
.dzp-plat-tile.on::after {
  content: '✓';
  position: absolute; top: 5px; left: 5px;
  width: 14px; height: 14px;
  background: var(--w-dot); color: #000;
  border-radius: 50%; font-size: 8px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  line-height: 14px; text-align: center; z-index: 1;
}
.dzp-plat-icon {
  width: 34px; height: 34px;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  background: var(--w-border);
}
.dzp-plat-icon svg { width: 18px; height: 18px; }
.dzp-plat-name {
  font-size: 9px; font-weight: 800;
  color: var(--w-ink2); text-align: center; line-height: 1.2;
  letter-spacing: .04em; text-transform: uppercase;
  font-family: 'Syne', sans-serif;
}
.dzp-plat-tile.on .dzp-plat-name { color: var(--w-ink); }

.dzp-nfc-fields { display: flex; flex-direction: column; gap: 6px; }
.dzp-nfc-entry {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--w-border); border-radius: var(--w-r);
  background: var(--w-bg2); transition: border-color .15s;
  animation: dzpIn .2s ease both;
}
.dzp-nfc-entry:focus-within { border-color: var(--w-btn); box-shadow: 0 0 0 3px rgba(201,168,76,.1); }
.dzp-nfc-icon { width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.dzp-nfc-icon svg { width: 15px; height: 15px; }
.dzp-nfc-name { font-size: 10px; font-weight: 800; color: var(--w-ink2); min-width: 52px; text-align: right; flex-shrink: 0; letter-spacing: .04em; text-transform: uppercase; font-family: 'Syne', sans-serif; }
.dzp-nfc-url { flex: 1; border: none; background: transparent; font-size: 12px; color: var(--w-ink); direction: ltr; outline: none; font-family: monospace; }
.dzp-nfc-url::placeholder { color: var(--w-ink3); font-size: 11px; }

/* Upload */
.dzp-upload-zone { border: 2px dashed var(--w-border); border-radius: var(--w-r); padding: 28px 16px; text-align: center; cursor: pointer; background: var(--w-bg2); position: relative; transition: all .18s; }
.dzp-upload-zone:hover { border-color: var(--w-ink2); }
.dzp-upload-zone input { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.dzp-upload-icon { font-size: 28px; color: var(--w-ink2); margin-bottom: 8px; display: block; }
.dzp-upload-text { font-size: 13px; color: var(--w-ink2); font-weight: 600; }
.dzp-upload-text strong { color: var(--w-ink); }
.dzp-file-done { display:flex; align-items:center; gap:8px; padding:9px 12px; background:rgba(30,74,42,.3); border:1px solid #2d5a3a; border-radius:var(--w-r); font-size:12px; color:#6fcf97; }
.dzp-file-done span { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-weight:700; }
.dzp-file-done button { background:none; border:none; color:#e05555; cursor:pointer; font-size:15px; }

.dzp-cta-btn { display:block; width:100%; padding:15px; border-radius:var(--w-r); font-family:var(--w-font); font-size:15px; font-weight:800; cursor:pointer; text-align:center; transition:all .2s ease; letter-spacing:.02em; border:2px solid; }
.dzp-cta-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.4); }

/* ══ Bottom: price + cart ══ */
.dzp-price-box {
  padding: 20px 20px 4px;
  background: var(--w-bg);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  direction: rtl;
}
.dzp-price-lbl { font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--w-ink2); margin-bottom: 4px; }
.dzp-price-sub { font-size: 10px; color: var(--w-ink2); font-family: monospace; }
.dzp-price-val { display: flex; align-items: baseline; gap: 5px; direction: ltr; }
.dzp-price-val span:first-child { font-family: 'Syne', sans-serif; font-size: 34px; font-weight: 800; color: var(--w-ink); line-height: 1; }
.dzp-price-cur { font-size: 14px; font-weight: 700; color: var(--w-ink2); font-family: var(--w-font); }

.dzp-atc {
  display: block; width: calc(100% - 40px); margin: 12px 20px 8px;
  padding: 15px 20px;
  background: var(--w-btn); color: var(--w-btnt);
  border: none; border-radius: var(--w-r);
  font-family: var(--w-font); font-size: 15px; font-weight: 800;
  cursor: pointer;
  transition: all .2s ease;
  letter-spacing: .02em;
  box-shadow: 0 4px 20px rgba(0,0,0,.3);
}
.dzp-atc:hover { filter: brightness(1.1); transform: translateY(-1px); box-shadow: 0 8px 30px rgba(0,0,0,.4); }
.dzp-atc:active { transform: scale(.99); }
.dzp-atc:disabled { opacity: .4; cursor: not-allowed; transform: none; filter: none; }

.dzp-now {
  display: block; width: calc(100% - 40px); margin: 0 20px 20px;
  padding: 13px 20px;
  background: transparent; color: var(--w-ink2);
  border: 1px solid var(--w-border); border-radius: var(--w-r);
  font-family: var(--w-font); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .15s;
}
.dzp-now:hover { color: var(--w-ink); border-color: var(--w-ink2); }
