/* ==========================================================
 *  ShopForge · 1-Click Provision Wizard
 *  Master admin · stopmetzoeken.store/admin/provision
 *  © Pinky Creative Studio
 * ========================================================== */

:root {
  --pv-bg: #07081a;
  --pv-bg-2: #0d1030;
  --pv-surface: #11143a;
  --pv-border: #1f2350;
  --pv-ink: #f0f0ff;
  --pv-muted: #9aa0d8;
  --pv-accent: #1B4BFF;
  --pv-accent-2: #a78bfa;
  --pv-forge: #D4151D;
  --pv-success: #10b981;
  --pv-warn: #f59e0b;
  --pv-danger: #ef4444;
}

* { box-sizing: border-box; }

.provision-body {
  margin: 0;
  background: var(--pv-bg);
  color: var(--pv-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Inter", "SF Pro Text", sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
  max-width: 100vw;
  width: 100%;
}

.aurora {
  position: fixed; inset: 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(212, 21, 29, .18), transparent 40%),
    radial-gradient(circle at 85% 70%, rgba(167, 139, 250, .18), transparent 40%),
    radial-gradient(circle at 50% 50%, rgba(27, 75, 255, .12), transparent 50%);
  z-index: -1;
  pointer-events: none;
}

.auth-gate {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh; padding: 1rem;
}
.login-card {
  background: var(--pv-surface); border: 1px solid var(--pv-border);
  border-radius: 14px; padding: 2rem;
  max-width: 420px; width: 100%; text-align: center;
}
.login-icon { font-size: 3rem; margin-bottom: 1rem; }
.login-card h1 { margin: 0 0 .5rem; font-size: 1.4rem; }
.login-card .muted { color: var(--pv-muted); margin-bottom: 1.5rem; }
.login-card a { color: var(--pv-accent); }

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5rem;
  padding: .65rem 1.2rem; border-radius: 10px;
  border: 1px solid var(--pv-border);
  background: var(--pv-surface); color: var(--pv-ink);
  font-weight: 600; font-size: .92rem; cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
  text-decoration: none;
}
.btn:hover { transform: translateY(-1px); border-color: var(--pv-accent); }
.btn-primary { background: var(--pv-accent); border-color: var(--pv-accent); }
.btn-primary:hover { background: #2a5cff; }
.btn-success { background: var(--pv-success); border-color: var(--pv-success); }
.btn-success:hover { background: #14c98c; }
.btn-ghost { background: transparent; }
.btn-block { width: 100%; }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

.pv-shell {
  display: flex; flex-direction: column;
  min-height: 100vh;
  max-width: 1280px; margin: 0 auto;
  padding: 1rem;
}

/* topbar */
.pv-topbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding-bottom: 1rem;
  border-bottom: 1px solid var(--pv-border);
}
.pv-top-left, .pv-top-right { display: flex; align-items: center; gap: .75rem; }
.pv-back {
  color: var(--pv-muted); text-decoration: none; font-size: 1.4rem;
}
.pv-back:hover { color: var(--pv-ink); }
.pv-brand { display: flex; align-items: center; gap: .5rem; }
.pv-brand-mark { font-size: 1.4rem; }
.pv-brand-text { font-weight: 700; font-size: 1.05rem; }
.pv-pill {
  padding: .15rem .65rem; border-radius: 999px;
  background: var(--pv-bg-2); color: var(--pv-accent-2);
  font-size: .72rem; text-transform: uppercase; letter-spacing: .5px;
}
.pv-pill.running { background: var(--pv-warn); color: #000; }
.pv-pill.done { background: var(--pv-success); color: #000; }
.pv-pill.fail { background: var(--pv-danger); color: #fff; }

.pv-lang {
  background: var(--pv-bg-2); color: var(--pv-ink);
  border: 1px solid var(--pv-border); border-radius: 8px;
  padding: .35rem .55rem; font-size: .85rem;
}

/* progress bar */
.pv-progress {
  display: flex; align-items: center; justify-content: center;
  gap: .25rem; margin: 1.5rem 0;
  flex-wrap: wrap;
}
.pv-step-dot {
  display: flex; flex-direction: column; align-items: center;
  gap: .35rem; min-width: 80px;
  opacity: .45;
  transition: opacity .2s ease;
}
.pv-step-dot.active { opacity: 1; }
.pv-step-dot.done { opacity: 1; }
.pv-step-dot.done .pv-dot-num {
  background: var(--pv-success); color: #000;
  border-color: var(--pv-success);
}
.pv-step-dot.active .pv-dot-num {
  background: var(--pv-accent); color: #fff;
  border-color: var(--pv-accent);
}
.pv-dot-num {
  width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center;
  border: 2px solid var(--pv-border);
  background: var(--pv-bg-2); color: var(--pv-muted);
  font-weight: 700;
}
.pv-dot-label {
  font-size: .72rem; color: var(--pv-muted);
  text-align: center; max-width: 96px;
}
.pv-step-line {
  flex: 0 0 36px; height: 2px;
  background: var(--pv-border);
  margin: 0 .25rem;
}

/* main */
.pv-main {
  background: var(--pv-surface);
  border: 1px solid var(--pv-border);
  border-radius: 14px;
  padding: 1.5rem;
  flex: 1;
}

.pv-step h2 { margin: 0 0 .35rem; font-size: 1.3rem; }
.pv-step .muted { color: var(--pv-muted); margin: 0 0 1.5rem; }

.pv-form {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.pv-field {
  display: flex; flex-direction: column; gap: .35rem;
}
.pv-field > span {
  font-size: .82rem; color: var(--pv-muted); font-weight: 600;
}
.pv-field input,
.pv-field select {
  background: var(--pv-bg-2); color: var(--pv-ink);
  border: 1px solid var(--pv-border); border-radius: 10px;
  padding: .65rem .85rem; font-size: .95rem;
  font-family: inherit;
}
.pv-field input:focus, .pv-field select:focus {
  outline: none; border-color: var(--pv-accent);
  box-shadow: 0 0 0 3px rgba(27, 75, 255, .2);
}
.pv-field small { font-size: .72rem; color: var(--pv-muted); }

.pv-input-suffix {
  display: flex; align-items: stretch;
  border: 1px solid var(--pv-border); border-radius: 10px;
  background: var(--pv-bg-2); overflow: hidden;
}
.pv-input-suffix input {
  flex: 1; border: none; background: transparent; outline: none;
  padding: .65rem .85rem;
}
.pv-suffix {
  display: grid; place-items: center;
  padding: 0 .85rem;
  background: var(--pv-bg);
  color: var(--pv-muted); font-size: .85rem;
  border-left: 1px solid var(--pv-border);
}

/* tier grid */
.pv-tier-grid {
  display: grid; gap: 1rem; margin-bottom: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.pv-tier input { display: none; }
.pv-tier-card {
  border: 2px solid var(--pv-border); border-radius: 12px;
  padding: 1rem; cursor: pointer;
  background: var(--pv-bg-2);
  transition: border-color .15s ease, transform .15s ease;
}
.pv-tier input:checked + .pv-tier-card {
  border-color: var(--pv-forge);
  background: linear-gradient(135deg, rgba(212, 21, 29, .15), transparent);
}
.pv-tier-card:hover { transform: translateY(-2px); }
.pv-tier-name { font-weight: 700; font-size: 1.1rem; margin-bottom: .35rem; }
.pv-tier-price { color: var(--pv-accent-2); font-size: 1.4rem; font-weight: 700; }
.pv-tier-meta { color: var(--pv-muted); font-size: .82rem; margin-top: .35rem; }

.pv-mode-row {
  display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem;
  padding: 1rem; background: var(--pv-bg-2);
  border: 1px solid var(--pv-border); border-radius: 10px;
}
.pv-radio {
  display: flex; align-items: center; gap: .5rem; cursor: pointer;
  font-size: .92rem;
}
.pv-radio input { accent-color: var(--pv-accent); }

.pv-domain {
  display: grid; gap: 1rem;
  grid-template-columns: 1fr auto 1fr;
  align-items: end;
}
.pv-or {
  text-align: center; color: var(--pv-muted);
  padding-bottom: .65rem;
  text-transform: uppercase; font-size: .75rem; letter-spacing: 1px;
}
@media (max-width: 640px) {
  .pv-domain { grid-template-columns: 1fr; }
}

/* domain check */
.pv-check-list {
  display: grid; gap: .75rem;
}
.pv-check-item {
  display: flex; justify-content: space-between; align-items: center;
  background: var(--pv-bg-2); border: 1px solid var(--pv-border);
  border-radius: 10px; padding: 1rem;
}
.pv-check-item.ok { border-color: var(--pv-success); }
.pv-check-item.fail { border-color: var(--pv-danger); }
.pv-check-name { font-weight: 600; }
.pv-check-status { color: var(--pv-muted); font-size: .92rem; }

/* themes */
.pv-theme-grid {
  display: grid; gap: 1rem; margin-bottom: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.pv-theme input { display: none; }
.pv-theme-card {
  border: 2px solid var(--pv-border); border-radius: 12px;
  padding: 1.5rem 1rem; cursor: pointer;
  min-height: 120px;
  transition: border-color .15s ease, transform .15s ease;
}
.pv-theme-card:hover { transform: translateY(-2px); }
.pv-theme input:checked + .pv-theme-card { border-color: var(--pv-forge); }
.pv-theme-name { font-weight: 700; font-size: 1.05rem; margin-bottom: .35rem; }
.pv-theme-meta { color: var(--pv-muted); font-size: .82rem; }
.pv-theme-dark { background: linear-gradient(135deg, #0a0a0a, #1a0506); color: #fff; }
.pv-theme-light { background: linear-gradient(135deg, #fafaf8, #fff); color: #1a1a1a; }
.pv-theme-light .pv-theme-meta { color: #666; }
.pv-theme-b2b { background: linear-gradient(135deg, #0b1d4a, #1b4bff); color: #fff; }

/* summary */
.pv-summary {
  display: grid; gap: .65rem;
  background: var(--pv-bg-2); border: 1px solid var(--pv-border);
  border-radius: 10px; padding: 1rem;
  margin-bottom: 1.5rem;
}
.pv-summary-row {
  display: grid; grid-template-columns: 140px 1fr;
  gap: 1rem; align-items: center;
  font-size: .92rem;
}
.pv-summary-row b { color: var(--pv-muted); font-weight: 600; font-size: .82rem; }
.pv-summary-row span { font-weight: 500; }

/* progress log */
.pv-progress-log {
  background: var(--pv-bg-2); border: 1px solid var(--pv-border);
  border-radius: 10px; padding: 1rem;
  margin-bottom: 1.5rem;
}
.pv-progress-log h3 { margin: 0 0 .75rem; font-size: 1rem; }
.pv-progress-log ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: .35rem;
}
.pv-progress-log li {
  display: flex; align-items: center; gap: .65rem;
  padding: .5rem .75rem;
  background: var(--pv-bg);
  border-radius: 8px;
  font-size: .88rem;
  font-family: ui-monospace, "SF Mono", Monaco, monospace;
}
.pv-progress-log li.ok::before { content: "✓"; color: var(--pv-success); }
.pv-progress-log li.fail::before { content: "✗"; color: var(--pv-danger); }
.pv-progress-log li.running::before { content: "⏳"; color: var(--pv-warn); }

/* result */
.pv-result {
  background: linear-gradient(135deg, rgba(16, 185, 129, .15), transparent);
  border: 1px solid var(--pv-success);
  border-radius: 10px; padding: 1rem;
  margin-bottom: 1.5rem;
}
.pv-result h3 { margin: 0 0 .75rem; color: var(--pv-success); }
.pv-result pre {
  background: var(--pv-bg);
  padding: 1rem; border-radius: 8px;
  overflow-x: auto;
  font-size: .85rem;
  max-width: 100%;
}

/* nav */
.pv-nav {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 2rem; gap: 1rem; flex-wrap: wrap;
}

/* toast */
.pv-toast {
  position: fixed; bottom: 2rem; right: 2rem;
  background: var(--pv-surface); color: var(--pv-ink);
  border: 1px solid var(--pv-accent);
  border-radius: 10px; padding: 1rem 1.25rem;
  max-width: 360px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, .4);
  z-index: 99;
  animation: pv-toast-in .25s ease;
}
.pv-toast.err { border-color: var(--pv-danger); }
.pv-toast.ok { border-color: var(--pv-success); }
@keyframes pv-toast-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* mobile safe */
@media (max-width: 640px) {
  .pv-shell { padding: .5rem; }
  .pv-main { padding: 1rem; }
  .pv-step-line { flex: 0 0 16px; }
  .pv-dot-label { font-size: .65rem; max-width: 70px; }
  .pv-summary-row { grid-template-columns: 1fr; gap: .15rem; }
  .pv-top-right { gap: .35rem; }
  h1, h2, h3 { word-break: break-word; overflow-wrap: break-word; }
}
