/* ════════════════════════════════════════════════════════
   CATÀLEG AURÓ — v2.0  |  Mobile-first · Premium UI
   ════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,700;1,500&family=Outfit:wght@300;400;500;600&display=swap');

/* ── TOKENS ────────────────────────────────────────────── */
:root {
  --g0:  #0d1f14;
  --g1:  #1a3326;
  --g2:  #2a5c3f;
  --g3:  #3d7a56;
  --g4:  #6aab82;
  --g5:  #a8cfb5;
  --g6:  #d6eadc;
  --g7:  #edf5ef;
  --g8:  #f6faf7;
  --g9:  #ffffff;

  --terra:  #c8a96e;
  --terra2: #f5edd8;

  --wa:   #25d366;
  --wa2:  #128c4a;

  --text:       #0d1f14;
  --text-mid:   #3a5a44;
  --text-soft:  #7a9e85;
  --border:     #d6eadc;

  --r-card: 20px;
  --r-sm:   10px;
  --r-pill: 999px;

  --shadow-card: 0 1px 3px rgba(13,31,20,.06), 0 4px 16px rgba(13,31,20,.08);
  --shadow-hover:0 8px 32px rgba(13,31,20,.16);

  --ease: cubic-bezier(.4,0,.2,1);
  --t:    .26s;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Outfit', system-ui, sans-serif;
}

/* ── RESET MÍNIM ─────────────────────────────────────── */
.ca-wrap *,
.ca-wrap *::before,
.ca-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.ca-wrap button { font-family: var(--font-body); cursor: pointer; }
.ca-wrap a { text-decoration: none; }
.ca-wrap img { display: block; }
.ca-wrap svg { flex-shrink: 0; }

/* ── CONTENIDOR ─────────────────────────────────────── */
.ca-wrap {
  font-family: var(--font-body);
  color: var(--text);
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 16px 64px;
  -webkit-font-smoothing: antialiased;
}

/* ══════════════════════════════════════════════════════
   TOGGLE + CERCA
══════════════════════════════════════════════════════ */
.ca-toggle-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 28px 0 20px;
}
@media (min-width: 640px) {
  .ca-toggle-wrap {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 36px 0 24px;
  }
}

/* Segmented control */
.ca-toggle {
  position: relative;
  display: inline-flex;
  background: var(--g7);
  border: 1.5px solid var(--border);
  border-radius: var(--r-pill);
  padding: 4px;
  gap: 2px;
  width: 100%;
}
@media (min-width: 640px) { .ca-toggle { width: auto; } }

.ca-toggle-slider {
  position: absolute;
  inset: 4px auto;
  height: calc(100% - 8px);
  background: var(--g9);
  border-radius: var(--r-pill);
  box-shadow: 0 1px 4px rgba(13,31,20,.14);
  transition: left var(--t) var(--ease), width var(--t) var(--ease);
  pointer-events: none;
  z-index: 0;
}

.ca-toggle-btn {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 10px 20px;
  border: none;
  background: transparent;
  border-radius: var(--r-pill);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-soft);
  transition: color var(--t) var(--ease);
  flex: 1;
  justify-content: center;
  white-space: nowrap;
}
@media (min-width: 640px) { .ca-toggle-btn { flex: initial; } }

.ca-toggle-btn.active { color: var(--g2); font-weight: 600; }

.ca-toggle-icon {
  display: flex;
  align-items: center;
  font-size: 15px;
}
.ca-toggle-icon svg { width: 16px; height: 16px; }

/* Cerca */
.ca-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--g9);
  border: 1.5px solid var(--border);
  border-radius: var(--r-pill);
  padding: 10px 14px;
  transition: border-color var(--t), box-shadow var(--t);
}
.ca-search-wrap:focus-within {
  border-color: var(--g3);
  box-shadow: 0 0 0 3px rgba(42,92,63,.1);
}
.ca-search-icon { width: 16px; height: 16px; color: var(--text-soft); flex-shrink: 0; }
.ca-search {
  border: none; outline: none; background: transparent;
  font-family: var(--font-body); font-size: 14px;
  color: var(--text); width: 100%;
  min-width: 0;
}
.ca-search::placeholder { color: var(--text-soft); }
.ca-search-clear {
  border: none; background: none; color: var(--text-soft);
  font-size: 12px; padding: 0; line-height: 1;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t);
}
.ca-search-clear.visible { opacity: 1; pointer-events: auto; }

/* ── RECOMPTE ─────────────────────────────────────────── */
.ca-recompte {
  font-size: 13px;
  color: var(--text-soft);
  margin-bottom: 20px;
  font-weight: 300;
  letter-spacing: .01em;
}
.ca-recompte-n {
  font-size: 22px;
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--g2);
  line-height: 1;
  margin-right: 4px;
  vertical-align: middle;
}

/* ══════════════════════════════════════════════════════
   GRID
══════════════════════════════════════════════════════ */
.ca-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 500px) {
  .ca-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
  .ca-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
}
@media (min-width: 1100px) {
  .ca-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ══════════════════════════════════════════════════════
   CARD
══════════════════════════════════════════════════════ */
.ca-card {
  background: var(--g9);
  border-radius: var(--r-card);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  display: flex;
  flex-direction: column;
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), opacity .3s ease;

  opacity: 0;
  transform: translateY(12px);
  animation: caFadeIn .5s var(--ease) var(--delay, 0s) forwards;
}
@keyframes caFadeIn {
  to { opacity: 1; transform: translateY(0); }
}

.ca-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}
.ca-card.ca-hidden {
  display: none;
}

/* ── FOTO ───────────────────────────────────────────── */
.ca-photo {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--g7);
}
.ca-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s var(--ease);
}
.ca-card:hover .ca-photo img { transform: scale(1.06); }

.ca-photo-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(13,31,20,.35) 0%, transparent 55%);
}

/* Badge tipus */
.ca-badge {
  position: absolute;
  top: 10px; left: 10px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .05em;
  padding: 5px 11px;
  border-radius: var(--r-pill);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  line-height: 1;
}
.ca-badge--exterior {
  background: rgba(26,51,38,.78);
  color: #b8dfc4;
  border: 1px solid rgba(184,223,196,.25);
}
.ca-badge--interior {
  background: rgba(200,169,110,.82);
  color: #fff8ec;
  border: 1px solid rgba(255,248,236,.2);
}

/* Preu */
.ca-preu-badge {
  position: absolute;
  bottom: 10px; right: 10px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 14px;
  color: var(--g9);
  text-shadow: 0 1px 3px rgba(0,0,0,.3);
  background: rgba(13,31,20,.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 4px 10px;
  border-radius: var(--r-sm);
  border: 1px solid rgba(255,255,255,.15);
}

/* ── COS ────────────────────────────────────────────── */
.ca-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 10px;
}

.ca-body-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.ca-nom {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--g1);
  letter-spacing: -.01em;
}
.ca-cient {
  font-size: 11.5px;
  color: var(--text-soft);
  font-style: italic;
  margin-top: 2px;
  font-weight: 300;
}

/* Disponibilitat */
.ca-disp {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: var(--r-pill);
  line-height: 1;
  margin-top: 2px;
}
.ca-disp--disponible { background: #e3f5e9; color: #1a6b35; }
.ca-disp--consultar  { background: #fff4e0; color: #9a5f00; }
.ca-disp--no         { background: #feecec; color: #b92c2c; }

/* ── TAGS RÀPIDS ─────────────────────────────────────── */
.ca-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.ca-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-mid);
  background: var(--g8);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  padding: 4px 9px;
  line-height: 1;
}
.ca-tag svg { width: 11px; height: 11px; color: var(--g3); }

/* ── BOTÓ TOGGLE DRAWER ───────────────────────────────── */
.ca-toggle-drawer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 9px 12px;
  background: var(--g8);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--g2);
  font-size: 13px;
  font-weight: 600;
  transition: background var(--t), color var(--t);
  margin-top: auto;
}
.ca-toggle-drawer:hover { background: var(--g7); }
.ca-toggle-drawer[aria-expanded="true"] { background: var(--g6); color: var(--g1); }

.ca-chevron {
  width: 16px; height: 16px;
  transition: transform var(--t) var(--ease);
}
.ca-toggle-drawer[aria-expanded="true"] .ca-chevron {
  transform: rotate(180deg);
}

/* ── DRAWER EXPANDIBLE ────────────────────────────────── */
.ca-drawer {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .38s var(--ease);
  overflow: hidden;
}
.ca-drawer.open {
  grid-template-rows: 1fr;
}
.ca-drawer > * {
  min-height: 0;
  overflow: hidden;
}

/* Wrapper intern del drawer */
.ca-drawer-inner {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-top: 14px;
}

/* Descripció */
.ca-desc {
  font-size: 13px;
  line-height: 1.65;
  color: var(--text-soft);
  font-weight: 300;
}
.ca-desc p { margin: 0; }

/* Fitxa taula */
.ca-fitxa {
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  overflow: hidden;
}
.ca-fitxa-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  font-size: 12.5px;
  border-bottom: 1px solid var(--border);
}
.ca-fitxa-row:last-child { border-bottom: none; }
.ca-fitxa-row:nth-child(even) { background: var(--g8); }
.ca-fitxa-k {
  font-weight: 600;
  color: var(--text-soft);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.ca-fitxa-v {
  color: var(--g1);
  font-weight: 500;
  text-align: right;
}

/* Cures */
.ca-cures-heading {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-soft);
  margin-bottom: 6px;
}
.ca-cures ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.ca-cures li {
  font-size: 12.5px;
  color: var(--text-soft);
  padding-left: 16px;
  position: relative;
  line-height: 1.5;
  font-weight: 300;
}
.ca-cures li::before {
  content: '';
  position: absolute;
  left: 4px; top: 7px;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--g4);
}

/* Botó WhatsApp */
.ca-wa {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--wa);
  color: #fff;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 14px;
  padding: 12px 20px;
  border-radius: var(--r-pill);
  transition: background var(--t), transform var(--t) var(--ease);
  -webkit-tap-highlight-color: transparent;
}
.ca-wa:hover {
  background: var(--wa2);
  color: #fff;
  transform: scale(1.02);
}
.ca-wa:active { transform: scale(.98); }
.ca-wa svg { width: 18px; height: 18px; }

/* ── EMPTY STATE ─────────────────────────────────────── */
.ca-empty {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 80px 20px;
  gap: 12px;
}
.ca-empty.visible { display: flex; }
.ca-empty-icon { font-size: 48px; line-height: 1; }
.ca-empty p { color: var(--text-soft); font-size: 15px; font-weight: 300; }
.ca-empty-reset {
  border: 1.5px solid var(--g3);
  background: transparent;
  color: var(--g2);
  padding: 10px 24px;
  border-radius: var(--r-pill);
  font-size: 14px;
  font-weight: 600;
  transition: background var(--t), color var(--t);
  margin-top: 4px;
}
.ca-empty-reset:hover { background: var(--g2); color: #fff; }

/* ── ACCESSIBILITY ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .ca-card { animation: none; opacity: 1; transform: none; }
  * { transition-duration: .01ms !important; }
}

/* Focus visible */
.ca-toggle-btn:focus-visible,
.ca-toggle-drawer:focus-visible,
.ca-wa:focus-visible,
.ca-search:focus-visible,
.ca-empty-reset:focus-visible {
  outline: 2px solid var(--g3);
  outline-offset: 2px;
}
