/* ===== Light Theme Tokens ===== */
.ssf-light {
  --bg: #ffffff;
  --card: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --line: #e5e7eb;
  --line-strong: #d1d5db;
  --chip: #f8fafc;
  --chip-border: #e5e7eb;
  --focus: 0 0 0 3px rgba(17, 24, 39, .2);
  color: var(--text);
}

.ssf * { box-sizing: border-box; }

/* Card */
.ssf-card {
  background: var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  box-shadow: 0 8px 24px rgba(0,0,0,.05);
}

/* Header */
.ssf-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.ssf-title { display:flex; align-items:center; gap:8px; color:#111827; }
.ssf-title svg { color: #111827; }
.ssf-header h3 { margin:0; font-size:16px; font-weight:700; }
.ssf-reset {
  background:#f3f4f6; border:1px solid var(--line);
  padding:6px 12px; border-radius:10px; cursor:pointer; color:#111827;
}
.ssf-reset:hover { background:#edeff2; }

/* Form */
.ssf-filters { display:grid; gap:12px; }
.ssf-field { display:grid; gap:6px; }
.ssf-label { font-size:12px; color: var(--muted); }

.ssf-input-icon { position:relative; }
.ssf-input-icon svg {
  position:absolute; left:10px; top:50%; transform: translateY(-50%);
  color: var(--muted);
}
.ssf-input-icon input[type="text"] {
  width:100%; padding:10px 12px 10px 32px;
  border:1px solid var(--line); border-radius:12px; background:#fff; color:#111827;
}
.ssf-input-icon input:focus { outline:none; box-shadow: var(--focus); }

.ssf-row select,
.ssf-multiselect {
  width:100%; padding:10px 12px;
  border:1px solid var(--line); border-radius:12px; background:#fff; color:#111827;
}
.ssf-row select:focus,
.ssf-multiselect:focus { outline:none; box-shadow: var(--focus); }

.ssf-block { border-top:1px solid var(--line); padding-top:12px; }
.ssf-block-title { font-weight:700; font-size:13px; margin-bottom:8px; }

/* City chips */
.ssf-city-radio { display:flex; flex-wrap:wrap; gap:8px; }
.ssf-chip-radio input { display:none; }
.ssf-chip-radio span {
  display:inline-block; background: var(--chip);
  border: 1px solid var(--chip-border);
  border-radius: 999px; padding:6px 12px; font-size:12px; color:#111827;
  cursor:pointer;
}
.ssf-chip-radio input:checked + span {
  background: #111827; color:#fff; border-color:#111827;
}

/* Accordion (More Filters) */
.ssf-acc { border-top:1px solid var(--line); padding-top:12px; }
.ssf-acc-summary {
  list-style:none; display:flex; align-items:center; justify-content:space-between;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  padding:10px 12px; cursor:pointer;
}
.ssf-acc-title { display:flex; align-items:center; gap:8px; }
.ssf-caret { transition: transform .2s ease; }
.ssf-acc[open] .ssf-caret { transform: rotate(180deg); }
.ssf-acc-panel { padding:12px 2px 2px; }

.ssf-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.ssf-filter-col strong { display:block; margin:4px 0 10px; color:#111827; }
.ssf-filter-col em { display:block; margin:8px 0 6px; color:#374151; font-style:normal; font-weight:600; }

/* Pills (checkboxes) */
.ssf-chips { display:flex; flex-wrap:wrap; gap:8px; }
.ssf-chip-check input { display:none; }
.ssf-chip-check span {
  display:inline-block; background: var(--chip);
  border:1px solid var(--chip-border);
  border-radius:999px; padding:6px 12px; font-size:12px; color:#111827; cursor:pointer;
}
.ssf-chip-check input:checked + span {
  background:#111827; color:#fff; border-color:#111827;
}

/* Age */
.ssf-age { display:flex; align-items:center; gap:8px; }
.ssf-age input {
  flex:1; padding:10px 12px; border:1px solid var(--line); border-radius:12px; background:#fff; color:#111827;
}
.ssf-age input:focus { outline:none; box-shadow: var(--focus); }

/* Buttons */
.ssf-secondary {
  background:#f3f4f6; color:#111827; border:1px solid var(--line);
  padding:8px 12px; border-radius:10px; cursor:pointer; margin-top:8px;
}
.ssf-search {
  background:#111827; color:#fff; border:1px solid #0f172a;
  padding:12px 14px; border-radius:12px; cursor:pointer; font-weight:700;
}

/* Popular tags */
.ssf-popular { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:12px 0 0; }
.ssf-popular-title { font-weight:700; }
.ssf-tags { display:flex; gap:8px; flex-wrap:wrap; }
.ssf-chip {
  display:inline-flex; align-items:center; gap:6px; text-decoration:none;
  background:#f8fafc; border:1px solid var(--line);
  color:#111827; padding:6px 12px; border-radius:999px; font-size:12px;
}
.ssf-chip:hover { border-color: var(--line-strong); }
.ssf-chip span { opacity:.6; }

/* Services dropdown */
.ssf-select { position:relative; }
.ssf-select-summary {
  display:flex; align-items:center; justify-content:space-between;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  padding:10px 12px; cursor:pointer;
}
.ssf-select[open] .ssf-caret { transform:rotate(180deg); }
.ssf-select-panel {
  margin-top:8px; border:1px solid var(--line); border-radius:12px; background:#fff;
  padding:10px; box-shadow: 0 8px 24px rgba(0,0,0,.06);
}
.ssf-select-search input {
  width:100%; padding:8px 10px; border:1px solid var(--line); border-radius:10px;
}
.ssf-select-list { margin-top:8px; max-height:220px; overflow:auto; border:1px dashed var(--line); border-radius:10px; padding:6px; }
.ssf-check-row { display:flex; align-items:center; gap:8px; padding:6px 4px; border-radius:8px; }
.ssf-check-row:hover { background:#f9fafb; }
.ssf-select-actions { display:flex; justify-content:space-between; align-items:center; padding-top:8px; }
.ssf-link-btn { background:transparent; border:0; color:#111827; text-decoration:underline; cursor:pointer; }
.ssf-primary-btn { background:#111827; color:#fff; border:1px solid #0f172a; padding:8px 12px; border-radius:10px; cursor:pointer; }

/* Responsive */
@media (max-width: 640px) {
  .ssf-grid-2 { grid-template-columns: 1fr; }
}
