/* CDMX salsa & bachata — minimal personal guide. Light, system font, scannable. */
:root {
  --bg: #ffffff;
  --bg-soft: #f6f7f8;
  --text: #1b1d1f;
  --dim: #6b7280;
  --line: #e4e7eb;
  --link: #1565c0;
  --salsa-la: #d9480f;   /* salsa en línea on1 (LA) — el objetivo */
  --salsa-ny: #6741d9;   /* salsa on2 (NY) */
  --salsa-cuba: #0c8599; /* salsa cubana / casino */
  --salsa-otro: #868e96; /* salsa, estilo por confirmar */
  --bachata: #c2255c;
  --social: #2b8a3e;
  --zouk: #3b5bdb;
  --cumbia: #e8590c;
  --kizomba: #a61e4d;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font: 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
  color: var(--text);
  background: var(--bg);
}
a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }

/* top bar */
.top { position: sticky; top: 0; z-index: 5; background: var(--bg); border-bottom: 1px solid var(--line); }
.top__in { max-width: 880px; margin: 0 auto; display: flex; align-items: center; gap: 14px;
  padding: 10px 16px; flex-wrap: wrap; }
.brand { font-weight: 600; color: var(--text); }
.tabs { display: flex; gap: 4px; margin-right: auto; }
.tabs a { padding: 5px 11px; border-radius: 7px; color: var(--dim); font-weight: 500; }
.tabs a:hover { background: var(--bg-soft); text-decoration: none; }
.tabs a.on { background: var(--text); color: #fff; }
.upd { color: var(--dim); font-size: 12px; }

.wrap { max-width: 880px; margin: 0 auto; padding: 18px 16px 60px; }
h1 { font-size: 22px; margin: 8px 0 4px; }
h2 { font-size: 16px; margin: 0; }
.lede { color: var(--dim); margin: 0 0 16px; font-size: 14px; }
section { margin-bottom: 26px; }

/* filters */
.filters { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0; }
.fchip { font: inherit; font-size: 13px; padding: 5px 11px; border: 1px solid var(--line);
  background: var(--bg); color: var(--text); border-radius: 999px; cursor: pointer; }
.fchip.on { background: var(--text); color: #fff; border-color: var(--text); }

/* week / day sections */
.day { margin-top: 14px; }
.day > h2 { padding-bottom: 4px; border-bottom: 2px solid var(--line); margin-bottom: 6px;
  display: flex; align-items: baseline; gap: 8px; }
.day.today > h2 { border-color: var(--salsa-la); }
.day.today > h2::after { content: "hoy"; font-size: 11px; font-weight: 600; color: var(--salsa-la);
  text-transform: uppercase; letter-spacing: .05em; }
.rows { list-style: none; margin: 0; padding: 0; }

.row { display: flex; gap: 12px; padding: 8px 10px; border-left: 3px solid var(--line);
  border-bottom: 1px solid var(--line); }
.row.hide, .day.hide, .card.hide { display: none; }
.row--salsa-la { border-left-color: var(--salsa-la); }
.row--salsa-ny { border-left-color: var(--salsa-ny); }
.row--salsa-cuba { border-left-color: var(--salsa-cuba); }
.row--salsa-otro { border-left-color: var(--salsa-otro); }
.row--bachata { border-left-color: var(--bachata); }
.row--social { border-left-color: var(--social); }
.row--cls { border-left-color: var(--bachata); }
.row--empty { border-left-color: var(--line); color: var(--dim); font-size: 14px; }
.row .t { flex: 0 0 96px; font-variant-numeric: tabular-nums; font-size: 14px; color: var(--text); }
.row .m { flex: 1; font-size: 14px; }
.row .m b { font-weight: 600; }
.row .sub { display: block; color: var(--dim); font-size: 13px; margin-top: 2px; }
.note { font-style: italic; color: var(--dim); }
.dim { color: var(--dim); }

/* tags */
.tag { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em;
  padding: 1px 7px; border-radius: 5px; background: var(--bg-soft); color: var(--dim);
  border: 1px solid var(--line); white-space: nowrap; }
.tag--cls { background: #fff0f5; color: var(--bachata); border-color: #f3c6d6; }

/* cards */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 12px; }
.card { border: 1px solid var(--line); border-radius: 10px; padding: 13px 14px; }
.card h3 { font-size: 15px; margin: 0 0 2px; }
.card .hood { color: var(--dim); font-size: 13px; margin: 0 0 8px; }
.card .dim { font-size: 13px; margin: 6px 0; }
.card .addr { font-size: 13px; margin: 8px 0 0; }
.chips { display: flex; flex-wrap: wrap; gap: 5px; }
.chip { font-size: 11.5px; padding: 2px 8px 2px 18px; border-radius: 999px; background: var(--bg-soft);
  position: relative; color: var(--text); border: 1px solid var(--line); }
.chip::before { content: ""; position: absolute; left: 7px; top: 50%; transform: translateY(-50%);
  width: 7px; height: 7px; border-radius: 50%; background: var(--salsa-otro); }
.chip--salsa-la::before { background: var(--salsa-la); }
.chip--salsa-ny::before { background: var(--salsa-ny); }
.chip--salsa-cuba::before { background: var(--salsa-cuba); }
.chip--bachata::before { background: var(--bachata); }
.chip--zouk::before { background: var(--zouk); }
.chip--cumbia::before { background: var(--cumbia); }
.chip--kizomba::before { background: var(--kizomba); }
.cls { list-style: none; margin: 8px 0 0; padding: 8px 0 0; border-top: 1px dashed var(--line);
  font-size: 13px; color: var(--text); display: flex; flex-direction: column; gap: 3px; }
.cls b { font-variant-numeric: tabular-nums; }

.more { margin-top: 16px; }
.more summary { cursor: pointer; color: var(--dim); font-size: 14px; padding: 6px 0; }
.more .cards { margin-top: 10px; }

.foot { max-width: 880px; margin: 0 auto; padding: 20px 16px 40px; border-top: 1px solid var(--line); }
.foot p { color: var(--dim); font-size: 12.5px; margin: 0; }

@media (max-width: 560px) {
  .row { flex-direction: column; gap: 2px; }
  .row .t { flex: none; font-weight: 600; }
  .tabs { width: 100%; order: 3; }
  .upd { display: none; }
}
