/* =========================================================================================
   ATH-SP Marketplace (frontend demo)
   - Token-first (Athenian Site Themes) with safe fallbacks
   - Low-poly / faceted background (subtle)
   - No orange defaults
   ========================================================================================= */

.ath-sp-mkt{
  /* Theme token mapping (AST preferred) */
  --athsp-surface-0: var(--surface-0, #0b0f14);
  --athsp-surface-1: var(--surface-1, #0f1624);
  --athsp-surface-2: var(--surface-2, rgba(255,255,255,0.04));
  --athsp-card:      var(--surface-card, rgba(255,255,255,0.035));
  --athsp-stroke:    var(--stroke, var(--border, rgba(255,255,255,0.12)));
  --athsp-text:      var(--text-high, rgba(255,255,255,0.92));
  --athsp-muted:     var(--text-mid, rgba(255,255,255,0.64));
  --athsp-faint:     var(--text-low, rgba(255,255,255,0.48));

  /* Controls / accents (use site control colors if present) */
  --athsp-accent:    var(--ctl-c1, #6ee7ff);
  --athsp-accent2:   var(--ctl-c2, #a78bfa);
  --athsp-accent3:   var(--ctl-c3, #34d399);

  /* Radii / spacing */
  --athsp-r-lg: 20px;
  --athsp-r-md: 16px;
  --athsp-r-sm: 12px;
  --athsp-gap:  12px;

  color: var(--athsp-text);

  /* Low-poly / faceted background */
  background:
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(0,0,0,0.18)),
    conic-gradient(from 210deg at 14% 18%,
      rgba(110,231,255,0.10),
      rgba(167,139,250,0.10),
      rgba(52,211,153,0.08),
      rgba(110,231,255,0.10)
    ),
    repeating-linear-gradient(135deg,
      rgba(255,255,255,0.030) 0,
      rgba(255,255,255,0.030) 36px,
      rgba(255,255,255,0.010) 36px,
      rgba(255,255,255,0.010) 72px
    ),
    linear-gradient(180deg, rgba(11,15,20,0.92), rgba(11,15,20,0.86));

  border: 1px solid var(--athsp-stroke);
  border-radius: var(--athsp-r-lg);
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,0.35);
}

/* Inherit font sizing from site, but keep compact */
.ath-sp-mkt *{ box-sizing: border-box; }

/* ============================== Toolbar ============================== */
.ath-sp-mkt__bar{
  padding: 14px 14px 12px;
  border-bottom: 1px solid var(--athsp-stroke);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  backdrop-filter: blur(10px);
}

.ath-sp-mkt__barRow{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-end;
}

.ath-sp-mkt__field{
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--athsp-r-md);
  background: rgba(0,0,0,0.18);
  min-width: 240px;
}

.ath-sp-mkt__field--small{ min-width: 160px; }
.ath-sp-mkt__field--actions{ min-width: 150px; }

.ath-sp-mkt__field label{
  font-size: 12px;
  font-weight: 650;
  letter-spacing: 0.01em;
  color: var(--athsp-muted);
}

.ath-sp-mkt__hint{
  font-size: 11.5px;
  color: var(--athsp-faint);
  line-height: 1.25;
}

.ath-sp-mkt__loc{
  display: flex;
  gap: 8px;
  align-items: center;
  position: relative;
}

.ath-sp-mkt input[type="text"],
.ath-sp-mkt input[type="number"],
.ath-sp-mkt select{
  height: 34px;
  padding: 0 10px;
  color: var(--athsp-text);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--athsp-r-sm);
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.ath-sp-mkt input::placeholder{ color: rgba(255,255,255,0.45); }

.ath-sp-btn{
  height: 34px;
  padding: 0 12px;
  border-radius: var(--athsp-r-sm);
  border: 1px solid rgba(255,255,255,0.14);
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.05));
  color: var(--athsp-text);
  cursor: pointer;
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
}

.ath-sp-btn:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--athsp-accent) 55%, rgba(255,255,255,0.18));
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--athsp-accent) 18%, rgba(255,255,255,0.10)),
    rgba(255,255,255,0.06)
  );
}

.ath-sp-btn:active{ transform: translateY(0); }

.ath-sp-btn--ghost{
  background: rgba(0,0,0,0.18);
}

.ath-sp-btn--primary{
  border-color: color-mix(in srgb, var(--athsp-accent) 55%, rgba(255,255,255,0.18));
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--athsp-accent) 26%, rgba(255,255,255,0.10)),
    rgba(255,255,255,0.06)
  );
}

/* ============================== Grid ============================== */
.ath-sp-mkt__grid{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  min-height: var(--ath-sp-mkt-map-h, 520px);
}

.ath-sp-mkt__mapWrap{
  position: relative;
  min-height: var(--ath-sp-mkt-map-h, 520px);
}

.ath-sp-mkt__map{
  height: 100%;
  width: 100%;
  min-height: var(--ath-sp-mkt-map-h, 520px);
}

.ath-sp-mkt__map .leaflet-container{
  height: 100%;
  width: 100%;
  background: var(--athsp-surface-0);
}

.ath-sp-mkt__status{
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  padding: 10px 12px;
  border-radius: var(--athsp-r-md);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.30);
  backdrop-filter: blur(10px);
  font-size: 12px;
  color: var(--athsp-muted);
}

.ath-sp-mkt__status.is-ok{
  border-color: color-mix(in srgb, var(--athsp-accent3) 55%, rgba(255,255,255,0.16));
}

.ath-sp-mkt__status.is-warn{
  border-color: color-mix(in srgb, var(--athsp-accent2) 55%, rgba(255,255,255,0.16));
}

.ath-sp-mkt__panel{
  border-left: 1px solid var(--athsp-stroke);
  background: rgba(255,255,255,0.02);
}

.ath-sp-mkt__panelHead{
  padding: 12px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(0,0,0,0.10), rgba(0,0,0,0.04));
}

.ath-sp-mkt__panelTitle{
  font-size: 13px;
  font-weight: 750;
  letter-spacing: 0.01em;
}

.ath-sp-mkt__panelMeta{
  font-size: 12px;
  color: var(--athsp-muted);
}

.ath-sp-mkt__list{
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: var(--ath-sp-mkt-map-h, 520px);
  overflow: auto;
}

/* ============================== Cards ============================== */
.ath-sp-mkt__card{
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--athsp-r-md);
  background: rgba(0,0,0,0.18);
  padding: 12px;
  cursor: pointer;
  transition: border-color 120ms ease, transform 120ms ease, box-shadow 120ms ease;
}

.ath-sp-mkt__card:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--athsp-accent) 45%, rgba(255,255,255,0.12));
}

.ath-sp-mkt__card.is-active{
  border-color: color-mix(in srgb, var(--athsp-accent) 70%, rgba(255,255,255,0.12));
  box-shadow: 0 10px 30px rgba(0,0,0,0.30);
}

.ath-sp-mkt__cardTitle{
  font-weight: 750;
  font-size: 14px;
  line-height: 1.2;
}

.ath-sp-mkt__cardMeta{
  margin-top: 6px;
  font-size: 12px;
  color: var(--athsp-muted);
}

.ath-sp-mkt__offers{
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ath-sp-mkt__offer{
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--athsp-r-md);
  padding: 10px;
  background: rgba(255,255,255,0.03);
}

.ath-sp-mkt__offerHead{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}

.ath-sp-mkt__offerTitle{ font-size: 13px; font-weight: 750; }

.ath-sp-mkt__pill{
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--athsp-accent) 55%, rgba(255,255,255,0.12));
  background: color-mix(in srgb, var(--athsp-accent) 14%, rgba(0,0,0,0.20));
  color: var(--athsp-text);
  white-space: nowrap;
}

.ath-sp-mkt__items{
  margin-top: 8px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}

.ath-sp-mkt__item{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  padding: 6px 8px;
  border-radius: var(--athsp-r-sm);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.18);
}

.ath-sp-mkt__itemSub{ color: var(--athsp-muted); }

.ath-sp-mkt__empty{
  padding: 12px;
  border-radius: var(--athsp-r-md);
  border: 1px dashed rgba(255,255,255,0.18);
  color: var(--athsp-muted);
  background: rgba(0,0,0,0.12);
}

/* ============================== Autocomplete dropdown ============================== */
.ath-sp-mkt__ac{
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 50;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--athsp-r-md);
  background: rgba(0,0,0,0.82);
  backdrop-filter: blur(14px);
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,0.45);
  display: none;
}

.ath-sp-mkt__ac.is-open{ display: block; }

.ath-sp-mkt__acItem{
  padding: 10px 12px;
  font-size: 12px;
  color: var(--athsp-text);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
}

.ath-sp-mkt__acItem:last-child{ border-bottom: none; }

.ath-sp-mkt__acItem:hover{
  background: color-mix(in srgb, var(--athsp-accent) 12%, rgba(255,255,255,0.03));
}

.ath-sp-mkt__acMuted{
  padding: 10px 12px;
  font-size: 12px;
  color: var(--athsp-muted);
}

@media (max-width: 980px){
  .ath-sp-mkt__grid{ grid-template-columns: 1fr; }
  .ath-sp-mkt__panel{ border-left: none; border-top: 1px solid var(--athsp-stroke); }
  .ath-sp-mkt__mapWrap{ min-height: 420px; }
  .ath-sp-mkt__field{ min-width: min(100%, 520px); }
  .ath-sp-mkt__field--small{ min-width: 140px; }
}
