/* ==========================================================================
   World Whisky Atlas — catálogo de DESTILERÍAS (Fase 6)
   Estilos EXTRA propios de esta página. catalogo.css (base compartida) lo
   escribe otro agente; acá sólo lo específico de la grilla de destilerías.
   ========================================================================== */

/* ---------- encabezado ---------- */
.cd-head { text-align: center; padding: 2.4rem 1.6rem 1rem; }
.cd-head .eyebrow { margin-bottom: .55rem; }
.cd-head h1 {
  font-family: var(--serif-display); font-weight: 700; letter-spacing: .05em;
  font-size: clamp(1.7rem, 3.4vw, 2.6rem); color: var(--cream); line-height: 1.05;
}
.cd-sub {
  font-family: var(--serif-body); font-size: clamp(1rem, 1.6vw, 1.2rem);
  color: var(--muted); max-width: 62ch; margin: .7rem auto 0; line-height: 1.5;
}

/* ---------- barra de herramientas / filtros ---------- */
.cd-toolbar {
  max-width: 1180px; margin: 1.4rem auto 0; padding: 1rem 1.1rem;
  border: 1px solid var(--line); border-radius: 12px;
  background: linear-gradient(180deg, rgba(28, 24, 17, .5), rgba(20, 17, 12, .3));
  display: grid; gap: .9rem;
}
.cd-tools-row {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: .8rem; align-items: end;
}
.cd-field { display: flex; flex-direction: column; gap: .35rem; min-width: 0; }
.cd-field > label {
  font-size: .6rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold); padding-left: .1rem;
}

/* buscador */
.cd-search {
  display: flex; align-items: center; gap: .55rem; background: rgba(0, 0, 0, .38);
  border: 1px solid var(--line); border-radius: 999px; padding: .6rem .95rem;
  transition: border-color .18s;
}
.cd-search:focus-within { border-color: var(--line-strong); }
.cd-search svg { width: 16px; height: 16px; color: var(--gold); flex: none; }
.cd-search input {
  background: none; border: none; outline: none; color: var(--cream);
  font-size: .9rem; width: 100%; font-family: var(--sans);
}
.cd-search input::placeholder { color: var(--muted-2); }

/* selects */
.cd-select {
  appearance: none; -webkit-appearance: none;
  width: 100%; background: rgba(0, 0, 0, .38); color: var(--cream);
  border: 1px solid var(--line); border-radius: 8px;
  padding: .6rem 2.1rem .6rem .85rem; font-size: .86rem; font-family: var(--sans);
  cursor: pointer; transition: border-color .18s;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c9a24a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right .7rem center; background-size: 15px;
}
.cd-select:focus { outline: none; border-color: var(--line-strong); }
.cd-select option { background: #1a160f; color: var(--cream); }

/* segunda fila: destacadas + contador */
.cd-tools-row2 {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  flex-wrap: wrap; padding-top: .2rem; border-top: 1px solid var(--line);
}
.cd-check {
  display: inline-flex; align-items: center; gap: .55rem; cursor: pointer;
  font-size: .82rem; color: var(--muted); user-select: none;
}
.cd-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.cd-check .box {
  width: 20px; height: 20px; border: 1px solid var(--line-strong); border-radius: 5px;
  display: grid; place-items: center; color: var(--carbon);
  background: rgba(0, 0, 0, .3); transition: all .18s; flex: none;
}
.cd-check .box svg { width: 13px; height: 13px; opacity: 0; transform: scale(.5); transition: all .18s; }
.cd-check input:checked + .box {
  background: linear-gradient(180deg, var(--gold-bright), var(--gold) 60%, var(--gold-deep));
  border-color: var(--gold-bright);
}
.cd-check input:checked + .box svg { opacity: 1; transform: scale(1); }
.cd-check input:focus-visible + .box { box-shadow: 0 0 0 2px rgba(201, 162, 74, .4); }
.cd-check:hover { color: var(--cream); }
.cd-check .box svg path { stroke: currentColor; }

.cd-count {
  font-family: var(--serif-body); font-size: 1.02rem; color: var(--gold-bright);
  letter-spacing: .02em; white-space: nowrap;
}
.cd-count::before { content: "❯ "; color: var(--gold); opacity: .6; }

/* ---------- grilla ---------- */
.cd-grid {
  max-width: 1180px; margin: 1.6rem auto 0; padding: 0 1.6rem 2rem;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(268px, 1fr)); gap: 1rem;
}

.cd-card {
  display: flex; flex-direction: column; gap: .75rem;
  border: 1px solid var(--line); border-radius: 11px; padding: 1.1rem 1.15rem;
  background: linear-gradient(180deg, rgba(201, 162, 74, .045), rgba(20, 17, 12, .25));
  position: relative; overflow: hidden; transition: transform .22s, border-color .22s, box-shadow .22s;
}
.cd-card::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  opacity: 0; transition: opacity .22s;
}
.cd-card:hover {
  transform: translateY(-3px); border-color: var(--line-strong); box-shadow: var(--shadow);
}
.cd-card:hover::before { opacity: 1; }
.cd-card[data-star="1"] { border-color: rgba(201, 162, 74, .4); }

.cd-top { display: flex; align-items: flex-start; justify-content: space-between; gap: .6rem; }
.cd-name {
  font-family: var(--serif-display); font-weight: 600; font-size: 1.16rem;
  letter-spacing: .015em; color: var(--cream); line-height: 1.12;
}
.cd-star {
  display: inline-flex; align-items: center; gap: .3rem; flex: none;
  font-size: .58rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--gold-bright); border: 1px solid var(--line-strong); border-radius: 999px;
  padding: .22rem .5rem; background: rgba(201, 162, 74, .08); white-space: nowrap;
}
.cd-star svg { width: 11px; height: 11px; }

.cd-meta { display: flex; flex-direction: column; gap: .35rem; }
.cd-region {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--serif-body); font-size: 1.02rem; color: #e4d9bf; line-height: 1.1;
}
.cd-region-none { color: var(--muted-2); font-style: italic; }
.cd-dot {
  width: 10px; height: 10px; border-radius: 50%; flex: none;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, .5), 0 0 6px rgba(0, 0, 0, .3);
}
.cd-pais {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted-2);
}
.cd-pais svg { width: 13px; height: 13px; color: var(--gold); opacity: .8; flex: none; }

.cd-foot {
  display: flex; align-items: center; justify-content: space-between; gap: .6rem;
  margin-top: auto; padding-top: .7rem; border-top: 1px solid var(--line);
}
.cd-year { display: inline-flex; align-items: center; gap: .4rem; font-size: .74rem; color: var(--muted); }
.cd-year svg { width: 14px; height: 14px; color: var(--gold); opacity: .8; flex: none; }
.cd-year b { color: var(--gold-bright); font-weight: 700; }
.cd-go {
  display: inline-flex; align-items: center; gap: .3rem;
  font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold);
  opacity: .75; transition: opacity .2s, transform .2s;
}
.cd-go svg { width: 14px; height: 14px; transition: transform .2s; }
.cd-card:hover .cd-go { opacity: 1; color: var(--gold-bright); }
.cd-card:hover .cd-go svg { transform: translateX(3px); }

/* ---------- estado vacío ---------- */
.cd-empty {
  max-width: 560px; margin: 2rem auto 3rem; text-align: center; padding: 2.5rem 1.5rem;
  border: 1px dashed var(--line-strong); border-radius: 14px; background: rgba(20, 17, 12, .3);
}
.cd-empty-orn {
  width: 62px; height: 62px; margin: 0 auto 1.1rem; color: var(--gold); opacity: .7;
  display: grid; place-items: center;
}
.cd-empty-orn svg { width: 40px; height: 40px; }
.cd-empty h2 {
  font-family: var(--serif-display); font-size: 1.35rem; color: var(--cream);
  letter-spacing: .02em; line-height: 1.2;
}
.cd-empty p {
  font-family: var(--serif-body); font-size: 1.05rem; color: var(--muted);
  margin: .6rem auto 1.4rem; max-width: 46ch; line-height: 1.5;
}
.cd-empty .panel-cta.ghost { display: inline-block; width: auto; margin: 0; padding: .75rem 1.6rem; }

/* ---------- responsive ---------- */
@media (max-width: 820px) {
  .cd-tools-row { grid-template-columns: 1fr 1fr; }
  .cd-field.cd-field-q { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .cd-head { padding: 1.8rem 1.1rem .6rem; }
  .cd-toolbar { margin: 1.1rem .9rem 0; padding: .9rem; border-radius: 10px; }
  .cd-tools-row { grid-template-columns: 1fr; }
  .cd-tools-row2 { justify-content: center; }
  .cd-grid { padding: 0 1rem 2rem; grid-template-columns: 1fr; gap: .85rem; }
}
