/* =========================================================================
   DIGITALIZA2 — Demo municipal · Acabado «CONCEJO»
   Cuaderno técnico de campo: tinta teal sobre papel blanco, hairlines,
   esquinas casi rectas (2px), un único color expresivo (halo verde azufre).
   Autocontenido: solo fuentes del sistema, CSS propio. Sin terceros.
   ========================================================================= */

:root{
  --paper:#ffffff;        /* fondo */
  --ink:#00262b;          /* texto / CTA (Abyss Teal) */
  --primary:#0b363b;      /* primario (texto sobre primario = #fff) */
  --accent:#00684a;       /* acento */
  --accent-text:#8b3911;  /* eyebrows / micro-etiquetas */
  --surface:#f5f7f7;      /* superficie */
  --surface-2:#fafafa;    /* superficie-2 */
  --border:#e3e8e8;       /* borde hairline */
  --border-strong:#0b363b;/* borde fuerte */
  --muted:#46595c;        /* apagado */
  --on-primary:#ffffff;
  --halo:#abffae;         /* único color expresivo: halo del CTA */
  --sans:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --maxw:1120px;
  --radius:2px;
  --radius-img:6px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:500;
  font-size:1.0625rem;
  line-height:1.55;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}

/* ---------- Foco visible (WCAG 2.2) ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,
textarea:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--accent);
  outline-offset:2px;
}

/* ---------- Saltar al contenido ---------- */
.c-skip{
  position:absolute;left:8px;top:-48px;z-index:200;
  background:var(--ink);color:#fff;padding:12px 18px;
  border:2px solid var(--ink);border-radius:var(--radius);
  text-decoration:none;font-weight:600;transition:top .15s;
}
.c-skip:focus{top:8px}

/* ---------- Contenedor ---------- */
.c-wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.c-pad{padding-top:80px;padding-bottom:80px}
.c-center{text-align:center}

/* =========================================================================
   Switcher de acabados
   ========================================================================= */
.c-switch{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  font-size:0.84375rem;
  letter-spacing:.01em;
}
.c-switch-in{
  max-width:var(--maxw);margin:0 auto;padding:9px 24px;
  display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;
}
.c-switch-lbl{color:var(--muted);font-weight:600}
.c-switch a{
  display:inline-flex;align-items:center;min-height:32px;padding:4px 12px;
  color:var(--ink);text-decoration:none;font-weight:600;
  border:2px solid var(--border);border-radius:var(--radius);
  background:var(--paper);
}
.c-switch a:hover{border-color:var(--border-strong)}
.c-switch a[aria-current="true"]{
  background:var(--ink);color:#fff;border-color:var(--ink);
}

/* =========================================================================
   Navegación
   ========================================================================= */
.c-nav{
  position:sticky;top:0;z-index:100;
  background:var(--paper);
  border-bottom:1px solid var(--border);
}
.c-nav.solid{border-bottom-color:var(--border-strong)}
.c-nav-in{
  max-width:var(--maxw);margin:0 auto;padding:0 24px;
  height:64px;display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.c-brand{
  display:inline-flex;align-items:center;gap:11px;
  text-decoration:none;color:var(--ink);
}
.c-brand b{font-weight:700;letter-spacing:.04em;font-size:0.9375rem;white-space:nowrap}
.c-badge{width:30px;height:30px;flex:0 0 auto;border-radius:var(--radius)}
.c-links{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.c-links a{
  display:inline-flex;align-items:center;min-height:44px;padding:0 11px;
  text-decoration:none;color:var(--muted);font-weight:600;
  font-size:0.84375rem;letter-spacing:.04em;border-radius:var(--radius);
}
.c-links a:hover{color:var(--ink)}
.c-links a.c-on{color:var(--ink);box-shadow:inset 0 -2px 0 var(--accent)}
.c-navcta{
  background:var(--ink)!important;color:#fff!important;
  border:2px solid var(--ink);padding:0 16px!important;
  box-shadow:0 0 0 3px var(--halo);
}
.c-navcta:hover{background:var(--primary)!important;border-color:var(--primary)}

/* =========================================================================
   Botones
   ========================================================================= */
.c-btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:46px;padding:11px 22px;
  background:var(--ink);color:#fff;text-decoration:none;
  font-weight:600;font-size:0.9375rem;letter-spacing:.02em;
  border:2px solid var(--ink);border-radius:var(--radius);
  box-shadow:0 0 0 3px var(--halo);
  cursor:pointer;transition:background .15s,border-color .15s;
}
.c-btn:hover{background:var(--primary);border-color:var(--primary)}
.c-btn.ghost{
  background:transparent;color:var(--ink);
  border:2px solid var(--border-strong);box-shadow:none;
}
.c-btn.ghost:hover{background:var(--surface)}
.c-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}

/* =========================================================================
   Tipografía editorial
   ========================================================================= */
.c-eyebrow{
  display:block;margin:0 0 14px;
  font-size:0.8125rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  color:var(--accent-text);
}
.c-eyebrow.center{text-align:center}
h1,h2,h3{letter-spacing:.01em;font-weight:600;line-height:1.18}
h1{font-size:clamp(2.125rem,6vw,3.625rem);margin:0}
h2{font-size:clamp(1.625rem,4vw,2.5rem);margin:0 0 18px}
.c-h2big{font-size:clamp(1.75rem,4.4vw,2.75rem)}
h3{font-size:1.3125rem;margin:0 0 8px}
.c-body{font-size:1.125rem;line-height:1.6;color:var(--ink);max-width:62ch}
.c-body.muted{color:var(--muted)}
.c-lema{margin:16px 0 0;font-size:1.125rem;color:var(--muted);max-width:60ch}
.c-mono{font-size:0.84375rem;letter-spacing:.01em;color:var(--muted)}

a.c-inline{
  color:var(--primary);font-weight:600;
  text-decoration:underline;text-underline-offset:2px;
  text-decoration-thickness:1px;
}
a.c-inline:hover{color:var(--accent)}

/* =========================================================================
   Cabecera contenida (cuaderno técnico — la imagen no manda)
   ========================================================================= */
.c-head{border-bottom:1px solid var(--border);background:var(--surface-2)}
.c-head-in{
  max-width:var(--maxw);margin:0 auto;padding:56px 24px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;
}
.c-head-txt .c-kicker{
  display:inline-block;margin-bottom:16px;padding:4px 10px;
  border:2px solid var(--border-strong);border-radius:var(--radius);
  font-size:0.78125rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);
}
.c-head-fig{margin:0}
.c-head-fig img{
  width:100%;height:280px;object-fit:cover;
  border:1px solid var(--border);border-radius:var(--radius-img);
}

/* Home: cabecera tipo portada de manual, contenida */
.c-hero{border-bottom:1px solid var(--border);background:var(--paper)}
.c-hero-in{
  max-width:var(--maxw);margin:0 auto;padding:64px 24px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
}
.c-hero h1{font-size:clamp(2.375rem,6.2vw,3.875rem)}
.c-hero .c-manifesto{
  margin:18px 0 0;font-size:1.1875rem;color:var(--muted);max-width:46ch;
}
.c-hero-fig{margin:0}
.c-hero-fig img{
  width:100%;height:360px;object-fit:cover;
  border:1px solid var(--border);border-radius:var(--radius-img);
}

/* =========================================================================
   Bloque declaración
   ========================================================================= */
.c-statement{max-width:760px;margin:0 auto;padding:80px 24px}
.c-statement .c-body{margin-top:18px;max-width:none}

/* =========================================================================
   Banda destacada (panel teal, texto reversed)
   ========================================================================= */
.c-band{background:var(--primary);color:var(--on-primary);border-radius:var(--radius)}
.c-band-in{max-width:var(--maxw);margin:0 auto;padding:56px 24px}
.c-band h2{color:#fff}
.c-band .c-eyebrow{color:var(--halo)}
.c-band .c-body{color:#dbe6e6;max-width:62ch}
.c-band a.c-inline{color:#fff;text-decoration-color:var(--halo)}

/* Llamada (antes parallax) — panel teal con CTA */
.c-call{background:var(--ink);color:var(--on-primary);border-radius:var(--radius)}
.c-call-in{max-width:760px;margin:0 auto;padding:64px 24px;text-align:center}
.c-call h2{color:#fff}
.c-call .c-body{color:#cfe0e0;margin:0 auto 26px}
.c-call .c-btn{box-shadow:0 0 0 3px var(--halo)}

/* =========================================================================
   Grids: secciones / previews / noticias / eventos / sabores
   ========================================================================= */
.c-grid{display:grid;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius)}
.c-grid.cols2{grid-template-columns:repeat(2,1fr)}
.c-grid.cols3{grid-template-columns:repeat(3,1fr)}

/* Tarjeta preview (sección a sección) */
.c-card-link{
  display:flex;flex-direction:column;text-decoration:none;color:var(--ink);
  background:var(--paper);
}
.c-card-link:hover{background:var(--surface-2)}
.c-card-img{overflow:hidden}
.c-card-img img{width:100%;height:180px;object-fit:cover}
.c-card-body{padding:24px}
.c-card-body p{margin:0;color:var(--muted);font-size:0.96875rem}
.c-go{
  display:inline-block;margin-top:14px;font-weight:700;font-size:0.875rem;
  letter-spacing:.02em;color:var(--accent);
}

/* Noticias / tablón */
.c-news{
  display:flex;flex-direction:column;text-decoration:none;color:var(--ink);
  background:var(--paper);
}
.c-news:hover{background:var(--surface-2)}
.c-news-img img{width:100%;height:150px;object-fit:cover}
.c-news-body{padding:20px;display:flex;flex-direction:column;gap:8px}
.c-tag{
  align-self:flex-start;font-size:0.71875rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent-text);
  border:2px solid var(--border-strong);border-radius:var(--radius);padding:2px 8px;
}
.c-news-body strong{font-weight:600;font-size:1rem;line-height:1.35}
.c-news-body time{font-size:0.8125rem;color:var(--muted);font-variant-numeric:tabular-nums}

/* Eventos */
.c-event{
  display:flex;flex-direction:column;text-decoration:none;color:var(--ink);
  background:var(--paper);
}
.c-event:hover{background:var(--surface-2)}
.c-event-img img{width:100%;height:150px;object-fit:cover}
.c-event-body{padding:20px;display:flex;flex-direction:column;gap:8px}
.c-date{
  align-self:flex-start;font-size:0.8125rem;font-weight:700;letter-spacing:.06em;
  color:var(--ink);border:2px solid var(--border-strong);border-radius:var(--radius);
  padding:3px 9px;font-variant-numeric:tabular-nums;
}
.c-event-body strong{font-weight:600;font-size:1rem;line-height:1.35}
.c-place{font-size:0.84375rem;color:var(--muted)}

/* Galería turismo */
.c-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.c-photo{margin:0}
.c-photo img{
  width:100%;height:220px;object-fit:cover;
  border:1px solid var(--border);border-radius:var(--radius-img);
}
.c-photo figcaption{
  margin-top:10px;font-size:0.9375rem;color:var(--ink);font-weight:600;
}
.c-photo .c-k{
  display:block;font-size:0.71875rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-text);margin-bottom:3px;
}

/* Sabores */
.c-sabgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.c-sab{margin:0}
.c-sab img{
  width:100%;height:140px;object-fit:cover;
  border:1px solid var(--border);border-radius:var(--radius-img);
}
.c-sab figcaption{
  margin-top:8px;font-size:0.8125rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink);text-align:center;
}

/* =========================================================================
   Sede — fichas numeradas
   ========================================================================= */
.c-admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.c-admin{
  display:block;text-decoration:none;color:var(--ink);
  background:var(--paper);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;
}
.c-admin:hover{border-color:var(--border-strong);background:var(--surface-2)}
.c-num{
  display:block;font-size:0.8125rem;font-weight:700;letter-spacing:.08em;
  color:var(--accent);margin-bottom:12px;font-variant-numeric:tabular-nums;
}
.c-admin p{margin:0;color:var(--muted);font-size:0.9375rem}

/* =========================================================================
   Bloques de dos columnas (contacto / avisos)
   ========================================================================= */
.c-two{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}

/* Aside info */
.c-info{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px;
}
.c-info h3{margin-bottom:16px}
.c-info-list{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-direction:column;gap:14px}
.c-info-list li{display:flex;flex-direction:column;font-size:1rem}
.c-info-list span{font-size:0.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-text);margin-bottom:2px}
.c-info-list a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}

/* Categorías avisos */
.c-cats{list-style:none;margin:0;padding:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.c-cat-h{
  background:var(--ink);color:#fff;padding:14px 20px;
  font-size:0.78125rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
}
.c-cat{padding:14px 20px;border-top:1px solid var(--border);font-size:1rem;background:var(--paper)}

/* =========================================================================
   Formulario contacto
   ========================================================================= */
.c-cf{display:flex;flex-direction:column;gap:18px;margin-top:26px;max-width:560px}
.c-cf label{display:flex;flex-direction:column;gap:7px;font-weight:600;font-size:0.875rem;letter-spacing:.02em}
.c-cf input,.c-cf textarea{
  font-family:inherit;font-size:1rem;color:var(--ink);font-weight:500;
  background:var(--paper);border:2px solid var(--border-strong);
  border-radius:var(--radius);padding:12px 14px;
}
.c-cf input:focus,.c-cf textarea:focus{outline:3px solid var(--accent);outline-offset:1px}
.c-cf textarea{resize:vertical;min-height:120px}
.c-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.c-cf .c-btn{align-self:flex-start}
.c-cf-st{margin:0;font-weight:600;font-size:0.9375rem;min-height:1.2em}
.c-cf-st.ok{color:var(--accent)}
.c-cf-st.err{color:#8b3911}

/* =========================================================================
   Footer (institucional)
   ========================================================================= */
.c-footer{background:var(--surface);border-top:1px solid var(--border);margin-top:0;padding:48px 0 36px}
.c-foot-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.c-foot-top b{font-weight:700;letter-spacing:.04em;font-size:0.9375rem}
.c-foot-top .c-mono{margin-left:auto}
.c-foot-cols{
  display:flex;flex-wrap:wrap;gap:8px 22px;margin:26px 0;
  padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.c-foot-cols a{
  color:var(--muted);text-decoration:none;font-size:0.875rem;font-weight:600;
  display:inline-flex;align-items:center;min-height:32px;
}
.c-foot-cols a:hover{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.c-copy{max-width:none;line-height:1.55}

/* =========================================================================
   Tablón de anuncios (texto, sin imagen — cuaderno sobrio)
   ========================================================================= */
.c-ann{
  display:flex;flex-direction:column;gap:9px;
  background:var(--paper);padding:22px;text-decoration:none;color:var(--ink);
}
.c-ann h3{margin:0;font-size:1.0625rem;font-weight:600;line-height:1.35}
.c-ann p{margin:0;color:var(--muted);font-size:0.9375rem;line-height:1.5}
.c-ann-meta{
  margin-top:2px;font-size:0.78125rem;color:var(--muted);
  font-variant-numeric:tabular-nums;letter-spacing:.01em;
}
.c-note{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px 24px;
}
.c-note h3{margin:0 0 8px}
.c-note p{margin:0;color:var(--muted);font-size:0.96875rem;line-height:1.6;max-width:74ch}

/* =========================================================================
   Reveal (movimiento mínimo y sobrio)
   ========================================================================= */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width:900px){
  .c-hero-in,.c-head-in,.c-two{grid-template-columns:1fr}
  .c-hero-fig,.c-head-fig{order:-1}
  .c-grid.cols3{grid-template-columns:repeat(2,1fr)}
  .c-admin-grid{grid-template-columns:repeat(2,1fr)}
  .c-gallery{grid-template-columns:repeat(2,1fr)}
  .c-sabgrid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:560px){
  body{font-size:1rem}
  .c-pad{padding-top:56px;padding-bottom:56px}
  .c-grid.cols2,.c-grid.cols3{grid-template-columns:1fr}
  .c-admin-grid,.c-gallery{grid-template-columns:1fr}
  .c-sabgrid{grid-template-columns:repeat(2,1fr)}
  .c-links{gap:0}
  .c-links a{padding:0 8px;font-size:0.78125rem}
}
