/*
Theme Name: Miscelánea Patrimonio
Theme URI: https://miscelanea.arqueoblog.eu/
Author: Fernando A. Muñoz Villarejo
Author URI: https://miscelanea.es/
Description: Tema clásico a medida para Miscelánea Arqueología + Patrimonio. Arqueología urbana, edificios históricos y planeamiento. Paleta verde/oro, tipografía serif para títulos.
Version: 0.1.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: miscelanea
*/

/* =========================================================
   TOKENS DE MARCA
   Cambiar SOLO estos valores para reajustar la paleta.
   ========================================================= */
:root{
  --verde:      #1f4d33;   /* botones, enlaces fuertes */
  --verde-osc:  #163a26;   /* hover de botones */
  --oro:        #a67c52;   /* acento bronce */
  --oro-osc:    #8a6540;
  --tinta:      #1c2620;   /* títulos (casi negro cálido) */
  --texto:      #3c423e;   /* cuerpo */
  --gris:       #6c716d;   /* secundario */
  --crema:      #efe9df;   /* fondos suaves de secciones/tarjetas */
  --crema-2:    #ffffff;
  --linea:      #e5e1d8;   /* bordes y reglas */
  --fondo:      #faf7f2;

  --serif: Georgia, 'Iowan Old Style', 'Palatino Linotype', 'Times New Roman', serif;
  --sans:  -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;

  --ancho: 1120px;        /* ancho máximo del contenido */
  --radio: 2px;           /* radios muy sutiles, casi rectos */
}

/* =========================================================
   RESET LIGERO
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--texto);
  background:var(--fondo);
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--verde); text-decoration:none; }
a:hover{ color:var(--verde-osc); }
h1,h2,h3,h4{ font-family:var(--serif); color:var(--tinta); font-weight:400; line-height:1.18; margin:0 0 .4em; }
p{ margin:0 0 1em; }

.contenedor{ width:100%; max-width:var(--ancho); margin:0 auto; padding:0 24px; }

/* Acento: reglas cortas en oro bajo títulos de sección */
.regla-oro{ width:54px; height:2px; background:var(--oro); border:0; margin:14px 0 22px; }

/* Texto eyebrow / subtítulo en oro */
.oro{ color:var(--oro); }

/* =========================================================
   BOTONES Y ENLACES DE ACCIÓN
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  background:var(--verde); color:#fff;
  font-family:var(--sans); font-size:.95rem; font-weight:600;
  padding:13px 22px; border-radius:var(--radio);
  border:1px solid var(--verde);
  transition:background .15s ease;
}
.btn:hover{ background:var(--verde-osc); color:#fff; }
.btn .flecha{ color:var(--oro); font-weight:700; }

.enlace-ver{
  display:inline-flex; align-items:center; gap:.5em;
  font-weight:600; color:var(--tinta); font-size:.95rem;
}
.enlace-ver .flecha{ color:var(--oro); transition:transform .15s ease; }
.enlace-ver:hover{ color:var(--verde); }
.enlace-ver:hover .flecha{ transform:translateX(4px); }

/* =========================================================
   CABECERA / NAVEGACIÓN
   ========================================================= */
.cabecera{
  background:var(--fondo);
  border-bottom:2px solid var(--oro);
}
.cabecera .contenedor{
  display:flex; align-items:center; justify-content:space-between;
  min-height:92px; gap:24px;
}
.marca{ font-family:var(--serif); line-height:1.05; }
.marca a{ color:var(--tinta); }
.marca .m1{ display:block; font-size:1.5rem; }
.marca .m2{ display:block; font-size:1.5rem; }

.nav-principal ul{
  list-style:none; margin:0; padding:0;
  display:flex; gap:26px; align-items:center;
}
.nav-principal a{
  color:var(--texto); font-size:.96rem; font-weight:500;
  padding:6px 0; border-bottom:2px solid transparent;
}
.nav-principal a:hover,
.nav-principal .current-menu-item > a{
  color:var(--tinta); border-bottom-color:var(--oro);
}

/* Botón hamburguesa (móvil) */
.nav-toggle{
  display:none; background:none; border:0; cursor:pointer;
  padding:8px; color:var(--tinta);
}
.nav-toggle svg{ width:26px; height:26px; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ padding:56px 0 64px; }
.hero .grid{
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start;
}
.hero h1{ font-size:2.7rem; margin-bottom:.25em; }
.hero .subtitulo{
  font-family:var(--serif); font-style:italic;
  color:var(--oro); font-size:1.22rem; margin:0 0 .2em;
}
.hero .texto{ margin-top:22px; max-width:34em; }
.hero .texto p{ color:var(--texto); }
.hero-figura img{
  width:100%; border-radius:var(--radio);
  object-fit:cover; aspect-ratio:4/3;
}

/* =========================================================
   TRES TARJETAS CON ICONO (valores / enfoque)
   ========================================================= */
.enfoque{ padding:8px 0 56px; }
.enfoque .grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}
.tarjeta-icono{
  background:var(--crema-2);
  border:1px solid var(--linea);
  border-radius:var(--radio);
  padding:30px 28px;
  display:flex; gap:20px; align-items:flex-start;
}
.tarjeta-icono .circulo{
  flex:0 0 auto; width:58px; height:58px; border-radius:50%;
  border:1.5px solid var(--oro);
  display:flex; align-items:center; justify-content:center;
  color:var(--oro);
}
.tarjeta-icono .circulo svg{ width:26px; height:26px; }
.tarjeta-icono h3{ font-size:1.2rem; margin-bottom:.3em; }
.tarjeta-icono p{ font-size:.95rem; margin:0; color:var(--gris); }

/* =========================================================
   CUATRO TARJETAS DE SERVICIO (2x2)
   ========================================================= */
.servicios{ padding:24px 0 56px; }
.servicios .grid{
  display:grid; grid-template-columns:1fr 1fr; gap:26px;
}
.tarjeta-servicio{
  display:grid; grid-template-columns:240px 1fr; gap:26px;
  border:1px solid var(--linea); border-radius:var(--radio);
  background:var(--fondo); overflow:hidden;
}
.tarjeta-servicio .miniatura{
  background:var(--crema); overflow:hidden;
}
.tarjeta-servicio .miniatura img{
  width:100%; height:100%; object-fit:cover; min-height:190px;
}
.tarjeta-servicio .cuerpo{ padding:26px 26px 24px 0; }
.tarjeta-servicio h3{ font-size:1.45rem; margin-bottom:.35em; }
.tarjeta-servicio p{ font-size:.95rem; color:var(--gris); margin-bottom:1.1em; }

/* =========================================================
   CRITERIOS TÉCNICOS (intro + 3 fichas de artículo)
   ========================================================= */
.criterios{ padding:36px 0 56px; }
.criterios .grid{
  display:grid; grid-template-columns:300px 1fr; gap:40px; align-items:start;
}
.criterios .intro h2{ font-size:2rem; }
.criterios .intro p{ font-size:.96rem; color:var(--gris); }
.criterios .intro .btn{ margin-top:18px; }
.fichas{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.ficha{
  border:1px solid var(--linea); border-radius:var(--radio);
  background:var(--fondo); overflow:hidden;
  display:flex; flex-direction:column;
}
.ficha .miniatura{ aspect-ratio:4/3; background:var(--crema); overflow:hidden; }
.ficha .miniatura img{ width:100%; height:100%; object-fit:cover; }
.ficha .cuerpo{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:14px; flex:1; }
.ficha h4{ font-size:1.08rem; line-height:1.3; margin:0; }
.ficha a.titulo{ color:var(--tinta); }
.ficha a.titulo:hover{ color:var(--verde); }
.ficha .flecha-fin{ margin-top:auto; color:var(--oro); font-weight:700; align-self:flex-end; }

/* =========================================================
   PROYECTOS DESTACADOS
   ========================================================= */
.proyectos{ padding:30px 0 56px; border-top:1px solid var(--linea); }
.proyectos h2{ font-size:2rem; }
.proyectos .grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:8px;
}
.proyecto{
  display:grid; grid-template-columns:96px 1fr; gap:18px; align-items:center;
}
.proyecto .miniatura{ width:96px; height:96px; overflow:hidden; border-radius:var(--radio); background:var(--crema); }
.proyecto .miniatura img{ width:100%; height:100%; object-fit:cover; }
.proyecto h3{ font-size:1.05rem; line-height:1.3; margin:0 0 10px; }
.proyecto h3 a{ color:var(--tinta); }
.proyecto h3 a:hover{ color:var(--verde); }
.proyecto .meta{
  border-top:1px solid var(--linea); padding-top:8px;
  display:flex; align-items:center; justify-content:space-between;
  font-size:.88rem; color:var(--gris);
}
.proyecto .meta .lugar{ color:var(--oro); font-weight:600; }
.proyecto .meta .flecha{ color:var(--oro); }

/* =========================================================
   CTA "CONSULTA TÉCNICA"
   ========================================================= */
.cta{ padding:14px 0 56px; }
.cta .caja{
  background:var(--crema);
  border:1px solid var(--linea); border-radius:var(--radio);
  padding:32px 36px;
  display:flex; align-items:center; gap:26px; flex-wrap:wrap;
}
.cta .circulo{
  flex:0 0 auto; width:58px; height:58px; border-radius:50%;
  border:1.5px solid var(--oro); color:var(--oro);
  display:flex; align-items:center; justify-content:center;
}
.cta .circulo svg{ width:26px; height:26px; }
.cta .texto{ flex:1 1 320px; }
.cta .texto h3{ font-size:1.35rem; margin-bottom:.25em; }
.cta .texto p{ margin:0; color:var(--gris); font-size:.96rem; }
.cta .btn{ margin-left:auto; }

/* =========================================================
   PIE
   ========================================================= */
.pie{ border-top:1px solid var(--linea); padding:46px 0 30px; }
.pie .grid{
  display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:40px;
}
.pie .marca-pie .m1,.pie .marca-pie .m2{ display:block; font-family:var(--serif); font-size:1.35rem; color:var(--tinta); }
.pie .marca-pie p{ margin-top:12px; font-size:.92rem; color:var(--gris); max-width:24em; }
.pie h4{ font-size:1rem; color:var(--tinta); margin-bottom:16px; }
.pie ul{ list-style:none; margin:0; padding:0; }
.pie ul li{ margin-bottom:10px; }
.pie ul a{ color:var(--texto); font-size:.94rem; }
.pie ul a:hover{ color:var(--verde); }
.pie .contacto li{ display:flex; align-items:center; gap:12px; }
.pie .contacto svg{ width:18px; height:18px; color:var(--oro); flex:0 0 auto; }
.pie .copy{ margin-top:34px; font-size:.84rem; color:var(--gris); }

/* =========================================================
   ENTRADAS / PÁGINAS INTERIORES
   ========================================================= */
.cabecera-interior{ background:var(--crema); border-bottom:1px solid var(--linea); padding:46px 0; }
.cabecera-interior h1{ font-size:2.2rem; margin:0; }
.cabecera-interior .lugar-fecha{ color:var(--oro); font-size:.95rem; margin-top:8px; }
.contenido-articulo{ padding:46px 0 60px; }
.contenido-articulo .columna{ max-width:720px; margin:0 auto; }
.contenido-articulo h2{ font-size:1.6rem; margin-top:1.4em; }
.contenido-articulo h3{ font-size:1.3rem; margin-top:1.2em; }
.contenido-articulo img{ border-radius:var(--radio); margin:1.4em 0; }
.contenido-articulo blockquote{
  border-left:3px solid var(--oro); margin:1.4em 0; padding:.2em 0 .2em 1.2em;
  color:var(--gris); font-style:italic;
}

/* Listado de archivo */
.listado{ padding:46px 0 60px; }
.listado .grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

/* Paginación */
.paginacion{ margin-top:40px; display:flex; gap:10px; flex-wrap:wrap; }
.paginacion a,.paginacion span{
  padding:8px 14px; border:1px solid var(--linea); border-radius:var(--radio);
  color:var(--texto); font-size:.92rem;
}
.paginacion .current{ background:var(--verde); color:#fff; border-color:var(--verde); }

/* =========================================================
   ACCESIBILIDAD
   ========================================================= */
.saltar{
  position:absolute; left:-9999px; top:0;
  background:var(--verde); color:#fff; padding:10px 16px; z-index:1000;
}
.saltar:focus{ left:8px; top:8px; }
a:focus-visible,.btn:focus-visible,button:focus-visible{
  outline:2px solid var(--oro); outline-offset:2px;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .hero .grid,
  .criterios .grid{ grid-template-columns:1fr; }
  .hero-figura{ order:-1; }
  .pie .grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .nav-principal{
    position:absolute; left:0; right:0; top:100%;
    background:var(--fondo); border-bottom:2px solid var(--oro);
    box-shadow:0 12px 24px rgba(0,0,0,.06);
    display:none; z-index:50;
  }
  .cabecera{ position:relative; }
  .nav-principal.abierto{ display:block; }
  .nav-principal ul{ flex-direction:column; align-items:stretch; gap:0; padding:8px 0; }
  .nav-principal li{ padding:0 24px; }
  .nav-principal a{ display:block; padding:12px 0; border-bottom:1px solid var(--linea); }
  .nav-toggle{ display:inline-flex; }
  .hero h1{ font-size:2.1rem; }
  .enfoque .grid,
  .servicios .grid,
  .fichas,
  .proyectos .grid,
  .listado .grid{ grid-template-columns:1fr; }
  .tarjeta-servicio{ grid-template-columns:1fr; }
  .tarjeta-servicio .cuerpo{ padding:0 24px 24px; }
  .tarjeta-servicio .miniatura img{ min-height:200px; }
  .cta .caja{ flex-direction:column; align-items:flex-start; }
  .cta .btn{ margin-left:0; }
  .pie .grid{ grid-template-columns:1fr; gap:28px; }
}

}

/* Ajuste: tarjetas en blanco sobre fondo crema */
.tarjeta-servicio, .ficha { background:#ffffff; }
.cabecera { background:var(--fondo); }

/* =========================================================
   HERO — bloque consolidado (sustituye a los parches previos)
   Imagen contenida en la retícula, altura limitada,
   fundido suave a izquierda e inferior.
   ========================================================= */
.hero{ padding:40px 0 48px; }
.hero .grid{ grid-template-columns:1fr 1fr; align-items:center; }
.hero-figura{ position:relative; margin:0; }
.hero-figura img{
  width:100%;
  height:clamp(280px, 32vw, 400px);
  aspect-ratio:auto;
  object-fit:cover;
  object-position:center 70%;
  border-radius:0;
}
.hero-figura::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to right, var(--fondo) 0%, rgba(250,247,242,0) 14%);
  pointer-events:none;
}
.hero-figura::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:12%;
  background:linear-gradient(to top, var(--fondo), rgba(250,247,242,0));
  pointer-events:none;
}
@media (max-width:980px){
  .hero-figura img{ height:clamp(240px, 45vw, 360px); }
}

/* === Entrada individual: imagen destacada flotada a la izquierda === */
.contenido-articulo .columna .wp-post-image{
  float:left;
  width:min(42%, 360px);
  height:auto;
  margin:0.35em 28px 16px 0;   /* aire a la derecha y por debajo */
  border-radius:var(--radio);
}
/* que nada quede flotando suelto al final del artículo */
.contenido-articulo .columna::after{
  content:""; display:block; clear:both;
}
@media (max-width:760px){
  .contenido-articulo .columna .wp-post-image{
    float:none;
    width:100%;
    margin:0 0 1.2em;
  }
}
