/* Apex Court Designer — plugin CSS. */

.apw-designer {
  --apw-card-bg: #ffffff;
  --apw-border: rgba(15,27,45,0.10);
  --apw-accent: #e8743c;
  --apw-ink: #0f1b2d;
  --apw-ink-soft: #404a5e;
  --apw-ink-mute: #6d7486;
  --apw-radius: 12px;

  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 32px;
  align-items: start;
  margin-top: 24px;
}

@media (max-width: 900px) {
  .apw-designer { grid-template-columns: 1fr; gap: 24px; }
}

/* ─── Preview ───────────────────────────────────── */
.apw-designer-preview {
  position: sticky; top: 96px;
  background: var(--apw-card-bg);
  border: 1px solid var(--apw-border);
  border-radius: var(--apw-radius);
  padding: 24px;
  box-shadow: 0 2px 8px rgba(15,27,45,0.06), 0 12px 32px rgba(15,27,45,0.08);
}
.apw-court-svg { width: 100%; height: auto; border-radius: 8px; overflow: hidden; display: block; }
.apw-court-svg rect { transition: fill 200ms; }

.apw-selected-summary {
  display: grid; gap: 10px;
  margin-top: 20px;
  font-size: 0.95rem;
}
.apw-selected-summary > div { display: flex; align-items: center; gap: 12px; color: var(--apw-ink-soft); }
.apw-sw {
  display: inline-block; width: 24px; height: 24px; border-radius: 50%;
  border: 2px solid rgba(15,27,45,0.08);
  transition: background 200ms;
  flex-shrink: 0;
}
.apw-selected-summary strong { color: var(--apw-ink); font-weight: 700; }

/* ─── Controls ──────────────────────────────────── */
.apw-designer-controls { display: grid; gap: 20px; }

.apw-zone {
  background: var(--apw-card-bg);
  border: 1px solid var(--apw-border);
  border-radius: var(--apw-radius);
  padding: 20px 22px;
  margin: 0;
}
.apw-zone legend {
  padding: 0;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--apw-accent);
  margin-bottom: 14px;
}

.apw-swatches {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
@media (max-width: 560px) { .apw-swatches { grid-template-columns: repeat(3, 1fr); } }

.apw-swatch {
  background: transparent; border: 2px solid var(--apw-border);
  border-radius: 10px;
  padding: 10px 6px 8px;
  cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  font-family: inherit;
  transition: border-color 180ms, transform 120ms, background 180ms;
  min-height: 74px;
}
.apw-swatch:hover { border-color: var(--apw-accent); transform: translateY(-1px); }
.apw-swatch[aria-checked="true"] {
  border-color: var(--apw-accent); background: rgba(232,116,60,0.05);
  box-shadow: 0 0 0 3px rgba(232,116,60,0.15);
}
.apw-swatch-dot {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--sw, #ccc);
  box-shadow: inset 0 0 0 2px rgba(0,0,0,0.08);
}
.apw-swatch-name {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--apw-ink-soft);
  text-align: center;
  line-height: 1.2;
}
.apw-swatch[aria-checked="true"] .apw-swatch-name { color: var(--apw-ink); }

.apw-cta-row { padding-top: 8px; }
.apw-cta-row .btn { width: 100%; justify-content: center; }

/* ─── Modal ─────────────────────────────────────── */
.apw-modal {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
  padding: 20px;
}
.apw-modal[hidden] { display: none; }
.apw-modal-scrim {
  position: absolute; inset: 0;
  background: rgba(15,27,45,0.55);
  backdrop-filter: blur(4px);
}
.apw-modal-card {
  position: relative;
  background: var(--apw-card-bg);
  border-radius: 16px;
  padding: 32px 32px 28px;
  max-width: 520px; width: 100%;
  box-shadow: 0 24px 48px rgba(15,27,45,0.25);
  max-height: calc(100vh - 40px);
  overflow-y: auto;
}
.apw-modal-close {
  position: absolute; top: 12px; right: 14px;
  background: none; border: none;
  font-size: 1.6rem; color: var(--apw-ink-mute);
  cursor: pointer; line-height: 1; padding: 6px 10px;
}
.apw-modal-close:hover { color: var(--apw-ink); }

.apw-form-row { margin-bottom: 14px; }
.apw-form-row.two {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
@media (max-width: 480px) { .apw-form-row.two { grid-template-columns: 1fr; } }

.apw-form label {
  display: flex; flex-direction: column; gap: 6px;
  font-weight: 600; font-size: 0.9rem; color: var(--apw-ink);
}
.apw-form input[type="text"],
.apw-form input[type="email"],
.apw-form input[type="tel"],
.apw-form select {
  width: 100%;
  padding: 11px 13px;
  border: 1px solid rgba(15,27,45,0.2);
  border-radius: 8px;
  font-size: 1rem;
  font-family: inherit;
  font-weight: 400;
  color: var(--apw-ink);
  background: #fff;
}
.apw-form input:focus, .apw-form select:focus {
  outline: none;
  border-color: var(--apw-accent);
  box-shadow: 0 0 0 3px rgba(232,116,60,0.15);
}

.apw-form-status { margin: 10px 0 4px; font-size: 0.9rem; min-height: 22px; }
.apw-form-status.error   { color: #a3322a; font-weight: 600; }
.apw-form-status.success { color: #2f5d3a; font-weight: 600; }

.apw-submit { width: 100%; justify-content: center; margin-top: 8px; }
.apw-submit[disabled] { opacity: 0.7; cursor: not-allowed; }

.apw-disclaimer {
  text-align: center;
  font-size: 0.8rem;
  color: var(--apw-ink-mute);
  margin-top: 14px;
  margin-bottom: 0;
}

@media (prefers-reduced-motion: reduce) {
  .apw-swatch, .apw-court-svg rect, .apw-sw { transition: none; }
}
