/* ═══════════════════════════════════════════════════
   DISTRITO MADRID · plantilla compacta
   Versión ligera de zona.css para los 21 distritos
   ═══════════════════════════════════════════════════ */
:root {
  --d-bg: #FBFAF4;
  --d-paper: #F4F1E5;
  --d-ink: #1C2218;
  --d-ink-soft: #50584C;
  --d-ink-mute: #88907E;
  --d-line: rgba(28,34,24,.1);
  --d-accent: var(--accent-deep);
  --d-accent-2: var(--accent-lime);
  --d-amber: #C09548;
}
body { background: var(--d-bg); color: var(--d-ink); }
.nav { background: rgba(251,250,244,.85); border-color: var(--d-line); }
.nav-links { color: var(--d-ink-soft); }
h1,h2,h3,h4 { color: var(--d-ink); }
p { color: var(--d-ink-soft); }
.kicker { color: var(--d-accent); }
.btn-ghost { color: var(--d-ink); border-color: var(--d-line); }
.crumbs { color: var(--d-ink-mute); padding: 14px 32px; max-width: 1240px; margin: 0 auto; }
.crumbs a { color: var(--d-ink-soft); }

/* HERO compacto */
.dhero { padding: 70px 0 60px; background: radial-gradient(700px 400px at 100% 0%, var(--accent-soft), transparent 60%); }
.dhero-inner { max-width: 1240px; margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: end; }
.dhero-kicker {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: .18em; color: var(--d-accent); font-weight: 600;
  text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 12px;
}
.dhero-kicker::before { content: ""; width: 24px; height: 1px; background: var(--d-accent); }
.dhero h1 {
  font-family: 'Fraunces', serif; font-weight: 300;
  font-size: clamp(48px, 6.5vw, 88px); line-height: 0.96;
  letter-spacing: -0.035em; margin-top: 20px;
}
.dhero h1 em { font-style: italic; color: var(--d-accent); font-weight: 400; }
.dhero h1 .city { display: block; font-weight: 400; color: var(--d-accent); font-style: italic; }
.dhero p {
  font-size: 18px; line-height: 1.65; margin-top: 24px; max-width: 56ch;
}
.dhero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 32px; }
.dhero-aside {
  background: white; border: 1px solid var(--d-line); padding: 28px;
  display: grid; gap: 12px;
}
.dhero-aside-tag {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--d-accent); letter-spacing: .14em; text-transform: uppercase; font-weight: 700;
}
.dhero-aside-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 10px; border-bottom: 1px dashed var(--d-line);
}
.dhero-aside-row:last-child { border-bottom: none; padding-bottom: 0; }
.dhero-aside-row .lbl { font-size: 13.5px; color: var(--d-ink-soft); }
.dhero-aside-row .val { font-family: 'Figtree', sans-serif; font-weight: 700; font-size: 18px; letter-spacing: -0.01em; }

/* Strip marquee */
.dstrip { background: var(--d-paper); padding: 16px 0; overflow: hidden; border-top: 1px solid var(--d-line); border-bottom: 1px solid var(--d-line); }
.dstrip-inner { display: flex; gap: 40px; width: max-content; animation: dstrip 60s linear infinite; font-family: 'Fraunces', serif; font-size: 18px; font-style: italic; color: var(--d-ink-soft); align-items: center; }
@keyframes dstrip { to { transform: translateX(-50%); } }
.dstrip-inner em { color: var(--d-accent); font-style: normal; font-weight: 600; }
.dstrip-inner .dot { width: 5px; height: 5px; background: var(--d-amber); border-radius: 50%; }

/* Section */
.dsec { padding: 80px 0; }
.dsec.alt { background: var(--d-paper); border-top: 1px solid var(--d-line); border-bottom: 1px solid var(--d-line); }
.dsec-head { max-width: 720px; margin-bottom: 40px; }
.dsec-head h2 {
  font-family: 'Fraunces', serif; font-weight: 400;
  font-size: clamp(32px, 4vw, 48px); line-height: 1.05;
  letter-spacing: -0.025em; margin-top: 12px;
}
.dsec-head h2 em { font-style: italic; color: var(--d-accent); }
.dsec-head .lead { font-size: 16px; line-height: 1.65; margin-top: 16px; max-width: 58ch; }

/* Context narrative grid */
.dcontext-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: start; }
.dcontext-l h3 { font-family: 'Fraunces', serif; font-weight: 400; font-size: 26px; letter-spacing: -0.02em; margin: 28px 0 12px; }
.dcontext-l h3:first-child { margin-top: 0; }
.dcontext-l h3 em { font-style: italic; color: var(--d-accent); }
.dcontext-l p { font-size: 16px; line-height: 1.7; margin-bottom: 14px; }
.dcontext-l p strong { color: var(--d-ink); font-weight: 600; }
.dcontext-l p em { color: var(--d-accent); font-style: italic; }
.dcontext-r {
  position: sticky; top: 100px;
  background: white; border: 1px solid var(--d-line);
  padding: 24px;
}
.dcontext-r h4 { font-family: 'Figtree', sans-serif; font-weight: 700; font-size: 15px; margin-bottom: 14px; letter-spacing: -0.005em; }
.dcontext-r ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.dcontext-r li { display: flex; justify-content: space-between; font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--d-ink-soft); padding: 8px 0; border-bottom: 1px solid var(--d-line); letter-spacing: .04em; }
.dcontext-r li:last-child { border-bottom: none; }
.dcontext-r li strong { color: var(--d-ink); font-family: 'Figtree', sans-serif; font-weight: 600; letter-spacing: 0; }

/* Barrios grid */
.dbarrios { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.dbarrio { background: white; border: 1px solid var(--d-line); padding: 20px 18px; transition: all .25s; }
.dbarrio:hover { border-color: var(--d-accent); transform: translateY(-2px); }
.dbarrio-n { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; color: var(--d-accent); letter-spacing: .14em; font-weight: 700; }
.dbarrio h4 { font-family: 'Figtree', sans-serif; font-weight: 700; font-size: 17px; margin: 8px 0 6px; letter-spacing: -0.01em; }
.dbarrio p { font-size: 13px; line-height: 1.5; margin: 0; }

/* Services in distrito */
.dsvc-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.dsvc-card { background: white; border: 1px solid var(--d-line); padding: 22px 20px; display: grid; gap: 6px; transition: all .25s; }
.dsvc-card:hover { background: var(--d-paper); border-color: var(--d-accent); }
.dsvc-card-n { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; color: var(--d-accent); letter-spacing: .12em; font-weight: 700; }
.dsvc-card h4 { font-family: 'Figtree', sans-serif; font-weight: 700; font-size: 16px; letter-spacing: -0.01em; }
.dsvc-card .arr { color: var(--d-accent); font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 600; letter-spacing: .1em; }

/* Stats */
.dstats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--d-line); border: 1px solid var(--d-line); }
.dstats-cell { background: white; padding: 24px 22px; }
.dstats-cell-tag { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--d-accent); letter-spacing: .14em; font-weight: 700; }
.dstats-cell-n { font-family: 'Fraunces', serif; font-weight: 300; font-size: 38px; color: var(--d-ink); letter-spacing: -0.03em; line-height: 1; margin: 8px 0 6px; }
.dstats-cell-n em { font-style: italic; color: var(--d-accent); font-weight: 400; }
.dstats-cell p { font-size: 12.5px; line-height: 1.5; margin: 0; }

/* FAQ */
.dfaq { display: grid; gap: 0; border-top: 1px solid var(--d-line); margin-top: 24px; }
.dfaq-item { border-bottom: 1px solid var(--d-line); }
.dfaq-q { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; cursor: pointer; font-family: 'Fraunces', serif; font-size: 19px; font-weight: 400; list-style: none; letter-spacing: -0.01em; }
.dfaq-q::-webkit-details-marker { display: none; }
.dfaq-q::after { content: "+"; font-family: 'Figtree', sans-serif; font-size: 22px; color: var(--d-accent); transition: transform .25s; }
.dfaq-item[open] .dfaq-q::after { transform: rotate(45deg); }
.dfaq-a { padding: 0 0 20px; font-size: 15px; line-height: 1.65; max-width: 62ch; }
.dfaq-a strong { color: var(--d-ink); }
.dfaq-a a { color: var(--d-accent); font-weight: 600; }

/* Near distritos */
.dnear { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 32px; }
.dnear-card { background: white; border: 1px solid var(--d-line); padding: 20px 18px; transition: all .25s; display: grid; gap: 6px; }
.dnear-card:hover { transform: translateY(-3px); border-color: var(--d-accent); }
.dnear-card-n { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; color: var(--d-accent); letter-spacing: .12em; font-weight: 700; }
.dnear-card h4 { font-family: 'Figtree', sans-serif; font-weight: 700; font-size: 16px; }
.dnear-card p { font-size: 12.5px; margin: 0; line-height: 1.45; }

/* Final */
.dfinal { padding: 80px 0; background: var(--d-paper); text-align: center; border-top: 1px solid var(--d-line); }
.dfinal h2 { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(36px, 4.5vw, 60px); line-height: 1.0; letter-spacing: -0.03em; }
.dfinal h2 em { font-style: italic; color: var(--d-accent); font-weight: 400; }
.dfinal p { font-family: 'Fraunces', serif; font-style: italic; font-size: 18px; margin: 20px auto; max-width: 50ch; }
.dfinal-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }

.foot { background: oklch(0.16 0.015 150); margin-top: 0; }

@media (max-width: 1000px) {
  .dhero-inner, .dcontext-grid { grid-template-columns: 1fr; gap: 32px; }
  .dcontext-r { position: static; }
  .dbarrios, .dsvc-list, .dstats, .dnear { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .dbarrios, .dsvc-list, .dstats, .dnear { grid-template-columns: 1fr; }
}
