.elementor-kit-5{--e-global-color-primary:#1F1D1A;--e-global-color-secondary:#8C6A4A;--e-global-color-text:#6E6A60;--e-global-color-accent:#FFFFFF;--e-global-color-eaeca31:#F7F5F0;--e-global-color-e7adfdc:#EFEBE2;--e-global-color-57801b3:#E4DFD3;--e-global-color-b951b1d:#A39E91;--e-global-typography-primary-font-family:"Cormorant Garamond";--e-global-typography-primary-font-weight:400;--e-global-typography-secondary-font-family:"Inter";--e-global-typography-secondary-font-weight:500;--e-global-typography-text-font-family:"Inter";--e-global-typography-text-font-size:14px;--e-global-typography-text-font-weight:400;--e-global-typography-text-line-height:1px;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;background-color:#FFFFFF;color:var( --e-global-color-primary );font-family:"Inter", Sans-serif;font-size:14px;font-weight:400;line-height:1px;letter-spacing:0.3px;}.elementor-kit-5 button,.elementor-kit-5 input[type="button"],.elementor-kit-5 input[type="submit"],.elementor-kit-5 .elementor-button{background-color:#1F1D1A;font-family:"Inter", Sans-serif;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.3em;color:#FCFBF8;padding:1em 2em 1em 2em;}.elementor-kit-5 button:hover,.elementor-kit-5 button:focus,.elementor-kit-5 input[type="button"]:hover,.elementor-kit-5 input[type="button"]:focus,.elementor-kit-5 input[type="submit"]:hover,.elementor-kit-5 input[type="submit"]:focus,.elementor-kit-5 .elementor-button:hover,.elementor-kit-5 .elementor-button:focus{background-color:#8C6A4A;color:#FCFBF8;}.elementor-kit-5 e-page-transition{background-color:#FFBC7D;}.elementor-kit-5 p{margin-block-end:0px;}.elementor-kit-5 h1{color:#1F1D1A;font-family:"Cormorant Garamond", Sans-serif;font-size:3rem;font-weight:300;}.elementor-kit-5 h2{color:var( --e-global-color-secondary );font-family:"Cormorant Garamond", Sans-serif;font-size:2rem;}.elementor-kit-5 h3{color:var( --e-global-color-secondary );font-family:"Cormorant Garamond", Sans-serif;font-size:1.7rem;}.elementor-kit-5 h4{color:var( --e-global-color-primary );font-family:"Inter", Sans-serif;font-size:0.65rem;font-weight:500;}.elementor-kit-5 h6{font-family:"Inter", Sans-serif;font-size:0.7rem;font-weight:400;text-transform:uppercase;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){margin-block-end:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* =========================================================
   NATALIA HORTELANO — CSS GLOBAL para Elementor Pro
   Pegar en: Elementor → Site Settings → Custom CSS
   (Icono ☰ arriba-izquierda → Site Settings → Custom CSS)
   ========================================================= */

/* ---------------------------------------------------------
   1. GOOGLE FONTS
   Si pegas este @import en Custom CSS, Elementor lo respeta.
   Alternativa más segura: instalar "OMGF | Host Google Fonts Locally"
   o añadir el <link> directamente en el header de Hello theme.
   --------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Inter:wght@300;400;500&display=swap');

/* ---------------------------------------------------------
   2. VARIABLES DE DISEÑO
   --------------------------------------------------------- */
:root {
  --white:     #Ffffff;
  --paper:     #F7F5F0;
  --bone:      #EFEBE2;
  --line:      #E4DFD3;
  --ink:       #1F1D1A;
  --ink-soft:  #6E6A60;
  --ink-mute:  #A39E91;
  --accent:    #8C6A4A;
  --serif: 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  --sans:  'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --ease:  cubic-bezier(.22,.61,.36,1);
}

/* ---------------------------------------------------------
   3. RESET BASE — específico de Elementor + Hello theme
   Usamos body.elementor-page para subir especificidad.
   --------------------------------------------------------- */
body,
body.elementor-page {
  background: var(--white) !important;
  color: var(--ink) !important;
  font-family: var(--sans) !important;
  font-weight: 300 !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* Hello Elementor pone padding raro en el body */
.elementor-default,
.page-content { margin: 0 !important; padding: 0 !important; }

/* Quitar bordes/sombras por defecto de la imagen */
.elementor img { display: block; max-width: 100%; height: auto; }

/* Links generales (no afectan a los del widget link) */
.elementor a { color: inherit; text-decoration: none; }
.elementor a:hover { color: var(--accent); }

/* ---------------------------------------------------------
   4. TIPOGRAFÍA — apuntando a los wrappers de Elementor
   .elementor-heading-title = wrapper del widget Heading
   --------------------------------------------------------- */

/* Por defecto TODOS los headings de Elementor son serif 300 */
.elementor-widget-heading .elementor-heading-title,
.elementor h1, .elementor h2, .elementor h3, .elementor h4, .elementor h5, .elementor h6 {
  font-family: var(--serif) !important;
  font-weight: 300 !important;
  font-style: normal;
  letter-spacing: -0.005em !important;
  line-height: 1.1 !important;
  color: var(--ink);
  margin: 0;
}

/* H1 — hero principal */
.elementor h1, .elementor-widget-heading h1.elementor-heading-title {
  font-size: clamp(3rem, 6.5vw, 6rem) !important;
  line-height: 1.05 !important;
}

/* H2 — titulares de sección */
.elementor h2, .elementor-widget-heading h2.elementor-heading-title {
  font-size: clamp(2rem, 3.5vw, 3rem) !important;
  line-height: 1.1 !important;
}

/* H3 — subtítulos / títulos de card */
.elementor h3, .elementor-widget-heading h3.elementor-heading-title {
  font-size: 1.7rem !important;
  line-height: 1.15 !important;
}

/* H4 — labels uppercase */
.elementor h4, .elementor-widget-heading h4.elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  line-height: 1.4 !important;
  color: var(--ink);
}

/* H5 / H6 — eyebrows por defecto */
.elementor h5, .elementor h6,
.elementor-widget-heading h5.elementor-heading-title,
.elementor-widget-heading h6.elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  line-height: 1.5 !important;
  color: var(--ink-soft) !important;
}

/* Cursivas (texto entre <em> dentro de un heading) -> bronce */
.elementor-widget-heading .elementor-heading-title em,
.elementor-widget-heading .elementor-heading-title i {
  font-style: italic;
  font-weight: 300;
  color: var(--accent);
}

/* ---------------------------------------------------------
   5. TEXT EDITOR (párrafos)
   --------------------------------------------------------- */
.elementor-widget-text-editor,
.elementor-widget-text-editor p {
  font-family: var(--sans) !important;
  font-weight: 300 !important;
  font-size: 1rem !important;
  line-height: 1.7 !important;
  color: var(--ink-soft) !important;
}
.elementor-widget-text-editor p { margin: 0 0 1rem; }
.elementor-widget-text-editor p:last-child { margin-bottom: 0; }
.elementor-widget-text-editor strong { color: var(--ink); font-weight: 500; }
.elementor-widget-text-editor em { font-style: italic; color: var(--accent); }
.elementor-widget-text-editor a {
  color: var(--accent);
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
}
.elementor-widget-text-editor a:hover { color: var(--ink); }

/* Blockquote (cita) */
.elementor-widget-text-editor blockquote,
.elementor blockquote {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 1.5rem !important;
  line-height: 1.45 !important;
  color: var(--ink) !important;
  border-left: 2px solid var(--accent) !important;
  padding: 0.5rem 0 0.5rem 2rem !important;
  margin: 2.5rem 0 !important;
  max-width: 36rem;
  background: transparent !important;
}

/* ---------------------------------------------------------
   6. UTILIDADES CON CLASE CUSTOM
   Para usar en CSS Classes del widget.
   --------------------------------------------------------- */

/* Eyebrow: clase para H5/H6 de "Sobre el estudio", "Portfolio", etc. */
.eyebrow,
.elementor-widget-heading.eyebrow .elementor-heading-title,
.eyebrow .elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  color: var(--ink-soft) !important;
  line-height: 1.5 !important;
  text-align: inherit;
}

.italic, .elementor .italic { font-style: italic !important; font-weight: 300 !important; }
.accent, .elementor .accent { color: var(--accent) !important; }

/* ---------------------------------------------------------
   6b. UTILIDADES DE SPAN — apuntan a clases dentro del título
   Se usan en Headings que contienen markup HTML, p.ej:
   <span class="cat-top">Hospitality · Madrid</span>
   Estos resets ganan al CSS de heading porque son más
   específicos (apuntan a clase concreta) y llevan !important.
   --------------------------------------------------------- */

/* Categoría sobre títulos de proyecto */
.elementor span.cat-top,
.elementor .cat-top {
  display: inline-block !important;
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
  line-height: 1.5 !important;
  margin-bottom: 1.5rem !important;
  letter-spacing: 0.3em !important;
}

/* Categoría sobre cards (.cat) */
.elementor span.cat,
.elementor .cat {
  display: inline-block !important;
  font-family: var(--sans) !important;
  font-size: 0.62rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--ink-mute) !important;
  line-height: 1.5 !important;
  margin-bottom: 0.6rem !important;
}

/* Info bajo el título de card */
.elementor span.info,
.elementor .info {
  display: inline-block !important;
  font-family: var(--sans) !important;
  font-size: 0.8rem !important;
  font-weight: 300 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--ink-soft) !important;
  line-height: 1.5 !important;
}

/* Eyebrow inline (cuando lo metes dentro de una heading) */
.elementor span.eyebrow-inline,
.elementor .eyebrow-inline {
  display: inline-block !important;
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.32em !important;
  text-transform: uppercase !important;
  color: var(--ink-soft) !important;
  line-height: 1.5 !important;
}

/* Número de sección "— 01" */
.elementor span.num,
.elementor .num {
  display: block !important;
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 1rem !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--accent) !important;
  line-height: 1 !important;
  margin-bottom: 2rem !important;
}

/* Número grande del proceso */
.elementor span.step-num,
.elementor .step-num {
  display: block !important;
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 2.5rem !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--accent) !important;
  line-height: 1 !important;
  margin-bottom: 1.5rem !important;
}

/* Número grande de stat */
.elementor span.num-big,
.elementor .num-big {
  display: block !important;
  font-family: var(--serif) !important;
  font-style: normal !important;
  font-weight: 300 !important;
  font-size: 4.5rem !important;
  letter-spacing: -0.005em !important;
  text-transform: none !important;
  color: var(--accent) !important;
  line-height: 1 !important;
  margin-bottom: 0.8rem !important;
}

/* Label uppercase pequeño */
.elementor span.label,
.elementor .label-small {
  display: block !important;
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: var(--ink-soft) !important;
  line-height: 1.5 !important;
}

/* Fuente del medio (Prensa: "— Nuevo Estilo") */
.elementor span.source,
.elementor .source {
  display: block !important;
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 1.2rem !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--accent) !important;
  line-height: 1.4 !important;
  margin-bottom: 1.2rem !important;
}

/* Fecha pequeña uppercase */
.elementor span.date,
.elementor .date {
  display: block !important;
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: var(--ink-mute) !important;
  line-height: 1.5 !important;
  margin-bottom: 1.5rem !important;
}

/* Count en el filtro / section head */
.elementor span.count,
.elementor .count {
  display: inline-block !important;
  font-family: var(--sans) !important;
  font-size: 0.68rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--ink-mute) !important;
  line-height: 1.5 !important;
}

/* Firma "— Natalia" */
.elementor .nh-signature,
.elementor-widget-heading.nh-signature .elementor-heading-title {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 1.5rem !important;
  color: var(--accent) !important;
  margin-top: 2rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid var(--line);
  display: inline-block !important;
  letter-spacing: 0 !important;
}

/* Lead paragraph (intro de proyecto) */
.elementor .lead,
.elementor p.lead {
  font-family: var(--sans) !important;
  font-weight: 300 !important;
  font-size: 1.15rem !important;
  line-height: 1.65 !important;
  color: var(--ink-soft) !important;
  max-width: 42rem;
}

/* Claim hero quien-soy */
.elementor .nh-qs-claim {
  font-family: var(--sans) !important;
  font-weight: 300 !important;
  font-size: 1.2rem !important;
  line-height: 1.6 !important;
  color: var(--ink-soft) !important;
  max-width: 30rem;
}

/* ---------------------------------------------------------
   7. BOTONES — clase nativa de Elementor + nuestras .btn-*
   --------------------------------------------------------- */

/* Botón nativo de Elementor con CSS Class "btn-primary" */
.elementor-button-wrapper .elementor-button,
.elementor a.elementor-button,
a.btn,
button.btn {
  font-family: var(--sans) !important;
  font-size: 0.72rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  padding: 1.1rem 2.2rem !important;
  border-radius: 0 !important;
  border: 1px solid var(--ink) !important;
  background-color: var(--ink) !important;
  color: var(--white) !important;
  display: inline-flex !important;
  align-items: center;
  gap: 0.7rem;
  text-decoration: none !important;
  transition: all 0.3s var(--ease);
  line-height: 1;
}
.elementor-button-wrapper .elementor-button:hover,
.elementor a.elementor-button:hover,
a.btn:hover, button.btn:hover {
  background-color: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--white) !important;
}

/* Outline / Secondary */
.btn.btn-secondary,
.btn.btn-outline,
a.btn-secondary, button.btn-secondary,
.elementor-button.btn-secondary {
  background-color: transparent !important;
  color: var(--ink) !important;
}
.btn.btn-secondary:hover,
.btn.btn-outline:hover,
a.btn-secondary:hover, button.btn-secondary:hover,
.elementor-button.btn-secondary:hover {
  background-color: var(--ink) !important;
  color: var(--white) !important;
}

.btn.btn-primary, a.btn-primary, .elementor-button.btn-primary {
  background-color: var(--ink) !important;
  color: var(--white) !important;
}

/* ---------------------------------------------------------
   8. FORMULARIO (widget HTML / Form Elementor Pro)
   --------------------------------------------------------- */
.elementor-field-group input[type="text"],
.elementor-field-group input[type="email"],
.elementor-field-group input[type="tel"],
.elementor-field-group select,
.elementor-field-group textarea,
.elementor input[type="text"],
.elementor input[type="email"],
.elementor input[type="tel"],
.elementor select,
.elementor textarea {
  font-family: var(--sans) !important;
  font-size: 0.95rem !important;
  font-weight: 300 !important;
  border: none !important;
  border-bottom: 1px solid var(--line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 0.8rem 0 !important;
  color: var(--ink) !important;
  box-shadow: none !important;
  outline: none !important;
  transition: border-color 0.3s var(--ease);
}
.elementor-field-group input:focus,
.elementor-field-group textarea:focus,
.elementor-field-group select:focus {
  border-color: var(--ink) !important;
}
.elementor-field-group .elementor-field-label {
  font-family: var(--sans) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: var(--ink-soft) !important;
  font-weight: 400 !important;
  margin-bottom: 0.4rem;
}

/* ---------------------------------------------------------
   9. AJUSTES ELEMENTOR (evitar interferencias)
   --------------------------------------------------------- */

/* Que los containers no recorten contenido */
.elementor-section, .elementor-container, .e-con, .e-con-inner { overflow: visible; }

/* Quitar el padding que añade Hello a las páginas */
.elementor-section.elementor-section-stretched,
.e-con.e-con-full {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* HTML widget sin padding extra */
.elementor-widget-html > .elementor-widget-container { padding: 0 !important; }

/* Image widget: que no fuerce bordes ni sombras de Hello */
.elementor-widget-image img {
  border-radius: 0 !important;
  display: block;
  max-width: 100%;
}

/* En las cards de proyecto las imágenes tienen height por CSS específico (.tall, .short, .featured),
   pero el wrapper de image widget pone un wrapper extra. Forzamos altura completa. */
.nh-pcard .elementor-widget-image,
.nh-pcard .elementor-widget-image .elementor-widget-container,
.nh-pcard .elementor-widget-image .elementor-image,
.nh-pfcard .elementor-widget-image,
.nh-pfcard .elementor-widget-image .elementor-widget-container,
.nh-sv-img .elementor-widget-image,
.nh-sv-img .elementor-widget-image .elementor-widget-container,
.nh-about-img .elementor-widget-image,
.nh-about-img .elementor-widget-image .elementor-widget-container,
.nh-qs-hero-img .elementor-widget-image,
.nh-qs-hero-img .elementor-widget-image .elementor-widget-container,
.nh-pr-img .elementor-widget-image,
.nh-pr-img .elementor-widget-image .elementor-widget-container {
  height: 100%;
}
.nh-pcard .elementor-widget-image img,
.nh-pfcard .elementor-widget-image img,
.nh-sv-img .elementor-widget-image img,
.nh-about-img .elementor-widget-image img,
.nh-qs-hero-img .elementor-widget-image img,
.nh-pr-img .elementor-widget-image img,
.nh-proj-hero-img .elementor-widget-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ---------------------------------------------------------
  10. PALETA · CLASES UTILITARIAS DE FONDO
  --------------------------------------------------------- */
.bg-white  { background: var(--white)  !important; }
.bg-paper  { background: var(--paper)  !important; }
.bg-bone   { background: var(--bone)   !important; }
.bg-ink    { background: var(--ink)    !important; color: var(--white); }

/* Selección de texto */
::selection { background: var(--accent); color: var(--white); }
/* =========================================================
   NATALIA HORTELANO — CSS para Portfolio dinámico (CMS)
   
   Pegar en: Elementor → Site Settings → Custom CSS
   AL FINAL del CSS global (después de pegar 01-css-global.css)
   
   Cubre:
   - Archive Portfolio (loop grid de proyectos)
   - Single Proyecto (ficha individual con ACF)
   - Filtros por categoría
   ========================================================= */

/* =========================================================
   ARCHIVE — PORTFOLIO
   ========================================================= */

/* Cabecera de la página */
.nh-pf-header { width:100%; }
.nh-pf-header .elementor-heading-title { }
.nh-pf-header h1.elementor-heading-title {
  font-size: clamp(3rem, 6vw, 5.5rem) !important;
  margin: 1.5rem 0 1.5rem !important;
  line-height: 1.05 !important;
}
.nh-pf-header h1 em {
  color: var(--accent);
  font-style: italic;
}
.nh-pf-header .elementor-widget-text-editor p {
  color: var(--ink-soft) !important;
  max-width: 34rem;
  margin: 0 auto !important;
  text-align: center;
}

/* =========================================================
   FILTROS POR CATEGORÍA
   ========================================================= */
.nh-filters {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
  padding: 3rem 3rem 2rem;
  border-bottom: 1px solid var(--line);
}
.nh-filters a.filter-btn {
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 400;
  color: var(--ink-soft);
  padding: 0.5rem 0;
  position: relative;
  transition: color 0.3s ease;
  text-decoration: none;
}
.nh-filters a.filter-btn::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 1px;
  background: var(--accent);
  transition: all 0.4s ease;
}
.nh-filters a.filter-btn:hover { color: var(--ink); }
.nh-filters a.filter-btn.active { color: var(--accent); }
.nh-filters a.filter-btn.active::after {
  width: 100%;
  left: 0;
}

/* =========================================================
   LOOP GRID (rejilla de proyectos)
   ========================================================= */

/* El contenedor del loop grid */
.nh-portfolio-loop .elementor-loop-container,
.elementor-widget-loop-grid .elementor-loop-container {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 64px 40px !important;
}

@media (max-width: 1100px) {
  .nh-portfolio-loop .elementor-loop-container,
  .elementor-widget-loop-grid .elementor-loop-container {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 700px) {
  .nh-portfolio-loop .elementor-loop-container,
  .elementor-widget-loop-grid .elementor-loop-container {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
}

/* =========================================================
   LOOP ITEM (la card individual)
   ========================================================= */

/* Contenedor principal de cada card */
.nh-loop-card {
  display: flex;
  flex-direction: column;
  position: relative;
  transition: opacity 0.4s ease;
}

/* Imagen cover */
.nh-loop-card .nh-loop-cover,
.elementor-loop-item .nh-loop-cover {
  overflow: hidden;
  background: var(--bone);
  margin-bottom: 1.3rem;
  height: 380px;
}
.nh-loop-card .nh-loop-cover .elementor-widget-image,
.nh-loop-card .nh-loop-cover .elementor-widget-image .elementor-widget-container,
.nh-loop-card .nh-loop-cover .elementor-widget-image .elementor-image {
  height: 100%;
  width: 100%;
}
.nh-loop-card .nh-loop-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.4s cubic-bezier(.22,.61,.36,1);
  display: block;
}
.nh-loop-card:hover .nh-loop-cover img {
  transform: scale(1.04);
}

/* Categoría (sobre el título) */
.nh-loop-card .nh-cat,
.nh-loop-card .nh-cat .elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 0.62rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--ink-mute) !important;
  line-height: 1.5 !important;
  margin-bottom: 0.5rem !important;
}

/* Título de la card */
.nh-loop-card .nh-title h3.elementor-heading-title,
.nh-loop-card .nh-title .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: 1.4rem !important;
  font-weight: 300 !important;
  line-height: 1.15 !important;
  margin-bottom: 0.3rem !important;
  color: var(--ink) !important;
  transition: color 0.3s ease;
}
.nh-loop-card:hover .nh-title h3.elementor-heading-title { color: var(--accent) !important; }

/* Info debajo (tipología · año) */
.nh-loop-card .nh-info {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 300;
  color: var(--ink-soft);
}

/* Link overlay (toda la card es cliqueable) */
.nh-loop-card a.card-link {
  position: absolute;
  inset: 0;
  z-index: 5;
}

/* ========== FEATURED CARDS (proyecto destacado) ========== */
/* Si el ACF "destacado" está activo, la card ocupa 2 columnas y es más alta */

.elementor-loop-item.featured,
.nh-loop-card.featured,
.elementor-loop-item[data-acf-destacado="1"] {
  grid-column: span 2;
}

.elementor-loop-item.featured .nh-loop-cover,
.nh-loop-card.featured .nh-loop-cover,
.elementor-loop-item[data-acf-destacado="1"] .nh-loop-cover {
  height: 520px;
}

.elementor-loop-item.featured .nh-title h3.elementor-heading-title,
.nh-loop-card.featured .nh-title h3.elementor-heading-title,
.elementor-loop-item[data-acf-destacado="1"] .nh-title h3.elementor-heading-title {
  font-size: 1.8rem !important;
}

@media (max-width: 1100px) {
  .nh-loop-card.featured,
  .elementor-loop-item.featured,
  .elementor-loop-item[data-acf-destacado="1"] { grid-column: span 1; }
  .nh-loop-card.featured .nh-loop-cover,
  .elementor-loop-item.featured .nh-loop-cover,
  .elementor-loop-item[data-acf-destacado="1"] .nh-loop-cover {
    height: 380px;
  }
}

/* =========================================================
   PAGINACIÓN DEL LOOP GRID (si la activas)
   ========================================================= */
.elementor-widget-loop-grid .elementor-pagination {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
  gap: 1rem;
}
.elementor-widget-loop-grid .page-numbers {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink-soft);
  padding: 0.5rem 0.8rem;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: all 0.3s;
}
.elementor-widget-loop-grid .page-numbers:hover { color: var(--ink); }
.elementor-widget-loop-grid .page-numbers.current {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* =========================================================
   SINGLE PROYECTO — ficha individual
   ========================================================= */

/* Breadcrumb */
.nh-breadcrumb {
  font-family: var(--sans);
  font-size: 0.68rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.nh-breadcrumb a {
  color: var(--ink-soft);
  text-decoration: none;
  transition: color 0.3s;
}
.nh-breadcrumb a:hover { color: var(--accent); }
.nh-breadcrumb .sep { margin: 0 0.8rem; color: var(--ink-mute); }

/* ========== HERO del proyecto ========== */
.nh-proj-hero { }

/* Categoría arriba (eyebrow con accent) */
.nh-proj-hero .nh-proj-cat-top,
.nh-proj-hero .nh-proj-cat-top .elementor-heading-title,
.elementor .nh-proj-cat-top.elementor-widget-heading .elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
  line-height: 1.5 !important;
  margin-bottom: 1.5rem !important;
}

/* H1 del proyecto */
.nh-proj-hero h1.elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: clamp(3rem, 6.5vw, 6rem) !important;
  font-weight: 300 !important;
  line-height: 1.05 !important;
  margin-bottom: 2rem !important;
  color: var(--ink) !important;
}
.nh-proj-hero h1 em {
  color: var(--accent);
  font-style: italic;
  font-weight: 300;
}

/* Lead bajo el H1 */
.nh-proj-hero .lead,
.nh-proj-hero p.lead,
.elementor .nh-proj-hero .elementor-widget-text-editor p {
  font-family: var(--sans) !important;
  font-size: 1.15rem !important;
  font-weight: 300 !important;
  line-height: 1.65 !important;
  color: var(--ink-soft) !important;
  max-width: 42rem;
}

/* Imagen grande del hero */
.nh-proj-hero-img .elementor-widget-image,
.nh-proj-hero-img .elementor-widget-image .elementor-widget-container,
.nh-proj-hero-img .elementor-widget-image .elementor-image {
  height: 85vh;
}
.nh-proj-hero-img .elementor-widget-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ========== SIDEBAR de datos (data-list) ========== */
.nh-data-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding-top: 0.5rem;
}
.nh-data-item { }
.nh-data-item .label {
  font-family: var(--sans);
  font-size: 0.62rem;
  font-weight: 400;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 0.35rem;
}
.nh-data-item .value {
  font-family: var(--serif);
  font-size: 1.3rem;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.4;
}
.nh-data-item .value.italic {
  font-style: italic;
  color: var(--accent);
}

/* ========== Descripción ========== */
.nh-desc h2.elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: clamp(1.6rem, 2.4vw, 2rem) !important;
  font-weight: 300 !important;
  font-style: italic !important;
  line-height: 1.2 !important;
  margin-bottom: 1.8rem !important;
}
.nh-desc .elementor-widget-text-editor p {
  font-family: var(--sans) !important;
  font-size: 1rem !important;
  font-weight: 300 !important;
  line-height: 1.7 !important;
  color: var(--ink-soft) !important;
  margin-bottom: 1.3rem !important;
  max-width: 38rem;
}

/* Cita / blockquote dentro de la descripción */
.nh-cita { margin: 2.5rem 0; }
.nh-cita blockquote,
.nh-cita p {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 1.5rem !important;
  line-height: 1.45 !important;
  color: var(--ink) !important;
  border-left: 2px solid var(--accent) !important;
  padding: 0.5rem 0 0.5rem 2rem !important;
  margin: 0;
  max-width: 36rem;
  background: transparent;
}

/* =========================================================
   GALERÍA DEL PROYECTO (Elementor Gallery widget + ACF)
   ========================================================= */
.nh-galeria .elementor-gallery__container {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.nh-galeria .elementor-gallery-item {
  height: 600px;
  overflow: hidden;
  background: var(--bone);
}
.nh-galeria .elementor-gallery-item__image,
.nh-galeria .elementor-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-size: cover !important;
  background-position: center !important;
  transition: transform 1.4s cubic-bezier(.22,.61,.36,1);
}
.nh-galeria .elementor-gallery-item:hover .elementor-gallery-item__image,
.nh-galeria .elementor-gallery-item:hover img {
  transform: scale(1.04);
}

/* Cada 3-4 items, una imagen ocupa el doble (asimetría) */
.nh-galeria .elementor-gallery-item:nth-child(4n+1) {
  grid-column: span 2;
  height: 75vh;
}

@media (max-width: 900px) {
  .nh-galeria .elementor-gallery__container {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .nh-galeria .elementor-gallery-item,
  .nh-galeria .elementor-gallery-item:nth-child(4n+1) {
    height: 400px;
    grid-column: span 1;
  }
}

/* =========================================================
   NAVEGACIÓN ENTRE PROYECTOS (prev/next)
   ========================================================= */
.nh-pn-item {
  display: block;
  cursor: pointer;
  transition: opacity 0.3s ease;
  text-decoration: none;
}
.nh-pn-item .label {
  font-family: var(--sans);
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 0.8rem;
}
.nh-pn-item h3.elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: 2rem !important;
  font-weight: 300 !important;
  color: var(--ink) !important;
  transition: color 0.3s;
}
.nh-pn-item:hover h3.elementor-heading-title { color: var(--accent) !important; }
.nh-pn-item .cat {
  font-family: var(--sans);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 0.4rem;
}

/* =========================================================
   CTA común (página proyecto y archive)
   ========================================================= */
.nh-cta-proj h2.elementor-heading-title,
.nh-cta-pf h2.elementor-heading-title {
  font-size: clamp(2.2rem, 4vw, 3.2rem) !important;
  margin: 1rem 0 1.2rem !important;
}
.nh-cta-proj h2 em,
.nh-cta-pf h2 em {
  color: var(--accent);
  font-style: italic;
}
.nh-cta-proj .elementor-widget-text-editor p,
.nh-cta-pf .elementor-widget-text-editor p {
  color: var(--ink-soft) !important;
  max-width: 26rem;
  margin: 0 auto 2.5rem !important;
  text-align: center;
}

/* =========================================================
   RESPONSIVE — ajustes generales
   ========================================================= */
@media (max-width: 900px) {
  .nh-proj-hero-img .elementor-widget-image,
  .nh-proj-hero-img .elementor-widget-image .elementor-widget-container,
  .nh-proj-hero-img .elementor-widget-image .elementor-image {
    height: 60vh;
  }
  .nh-loop-card .nh-loop-cover {
    height: 380px;
  }
}

/* =========================================================
   AJUSTES PARA ELEMENTOR FREE (sin Loop Grid)
   Si por alguna razón el Loop Grid no carga, este fallback
   maquetra cards CPT estándar de WP.
   ========================================================= */
.post-type-archive-proyecto .elementor-posts-container {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 64px 40px !important;
}
.post-type-archive-proyecto .elementor-post__card,
.post-type-archive-proyecto article.post {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
}
/* =========================================================
   NATALIA HORTELANO — CSS MAESTRO DE SECCIONES
   
   ⚠️ IMPORTANTE — Por qué este archivo:
   Elementor BORRA las etiquetas <style> de los widgets HTML.
   Por eso los estilos de cada sección (listas de servicios,
   grids, alturas de imagen, etc.) se perdían.
   
   SOLUCIÓN: este archivo contiene TODOS los estilos de sección.
   Va en Site Settings → Custom CSS, que SIEMPRE carga.
   
   ORDEN DE PEGADO en Custom CSS:
   1º  el contenido de 01-css-global.css       (tipografía, colores, botones)
   2º  el contenido de 13-css-portfolio-cms.css (loop grid, single proyecto)
   3º  ESTE archivo                             (estilos de todas las secciones)
   ========================================================= */


/* =========================================================
   INICIO — HERO
   ========================================================= */
.nh-hero { max-width: 1600px; margin: 0 auto; }
.nh-hero-text h1.elementor-heading-title {
  font-size: clamp(3rem, 6.5vw, 6rem) !important;
  margin: 2rem 0 2.5rem !important;
  line-height: 1.05 !important;
}
.nh-hero-text h1 em { color: var(--accent); font-style: italic; }
.nh-meta-line {
  display: flex; gap: 1.2rem; align-items: center;
  font-size: .7rem; letter-spacing: .25em; text-transform: uppercase;
  color: var(--ink-soft); padding-top: 2rem;
  border-top: 1px solid var(--line); max-width: 24rem;
}
.nh-meta-line .sep { color: var(--ink-mute); }
.nh-hero-image { position: relative; }
.nh-hero-image .elementor-widget-image,
.nh-hero-image .elementor-widget-image img { height: 80vh; width: 100%; object-fit: cover; }
.nh-hero-image .tag {
  position: absolute; top: 1.5rem; right: 1.5rem; z-index: 2;
  background: var(--white); padding: .5rem 1rem; font-size: .62rem;
  letter-spacing: .3em; text-transform: uppercase; color: var(--ink-soft);
}

/* INICIO — INTRO (manifiesto) */
.nh-intro { max-width: 1100px; margin: 0 auto; }
.nh-intro h2.elementor-heading-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem) !important;
  font-style: italic !important; font-weight: 300 !important;
  line-height: 1.4 !important; max-width: 36rem; margin: 1.5rem auto 0 !important;
}
.nh-intro h2 em { color: var(--accent); font-style: italic; }

/* INICIO / general — SECTION HEAD (título + contador a la derecha) */
.nh-section-head {
  padding-bottom: 1.5rem !important;
  border-bottom: 1px solid var(--line);
  margin-bottom: 5rem !important;
}
.nh-section-head h2.elementor-heading-title {
  font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
  font-style: italic !important; font-weight: 300 !important;
}
.nh-section-head .count,
.nh-section-head .count .elementor-heading-title {
  font-size: .68rem !important; letter-spacing: .3em !important;
  text-transform: uppercase !important; color: var(--ink-mute) !important;
  font-family: var(--sans) !important; font-weight: 400 !important;
}

/* INICIO — GRID DE PROYECTOS (estático, cards manuales) */
.nh-projects-section { max-width: 1600px; margin: 0 auto; }
.nh-pgrid > *:nth-child(2),
.nh-pgrid > *:nth-child(4) { padding-top: 4rem !important; }
.nh-pcard a.cover-link {
  display: block; overflow: hidden; background: var(--bone);
  margin-bottom: 1.5rem;
}
.nh-pcard a.cover-link img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 1.4s cubic-bezier(.22,.61,.36,1);
}
.nh-pcard a.cover-link:hover img { transform: scale(1.04); }
.nh-pcard.tall a.cover-link { height: 640px; }
.nh-pcard.short a.cover-link { height: 480px; }
.nh-pcard h3.elementor-heading-title {
  font-size: 1.7rem !important; font-weight: 300 !important;
  margin-bottom: .4rem !important; transition: color .3s;
}
.nh-pcard:hover h3.elementor-heading-title { color: var(--accent) !important; }
.nh-view-all { text-align: center; margin-top: 4rem; }
.nh-view-all a {
  font-size: .72rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 5px;
}
.nh-view-all a:hover { color: var(--accent); border-color: var(--accent); }

/* INICIO — ABOUT (sobre el estudio) */
.nh-about-img { overflow: hidden; background: var(--bone); }
.nh-about-img .elementor-widget-image,
.nh-about-img .elementor-widget-image img { height: 75vh; width: 100%; object-fit: cover; }
.nh-about-text h2.elementor-heading-title {
  font-size: clamp(2rem, 3.6vw, 3.2rem) !important;
  margin: 1.5rem 0 2rem !important; line-height: 1.1 !important;
}
.nh-about-text h2 em { font-style: italic; font-weight: 300; }
.nh-about-text .elementor-widget-text-editor p {
  color: var(--ink-soft) !important; font-size: 1rem !important; max-width: 32rem;
}

/* =========================================================
   SERVICIOS (3 columnas en home + página servicios)
   ⭐ ESTO ARREGLA LAS BOLITAS → guiones "—"
   ========================================================= */
.nh-service .num,
.nh-service .num .elementor-heading-title {
  font-family: var(--serif) !important; font-style: italic !important;
  font-size: 1rem !important; color: var(--accent) !important;
  display: block !important; margin-bottom: 2rem !important;
}
.nh-service h3.elementor-heading-title {
  font-size: 1.6rem !important; font-weight: 300 !important;
  margin-bottom: 1rem !important;
}
.nh-service .elementor-widget-text-editor p {
  color: var(--ink-soft) !important; font-size: .92rem !important;
  margin-bottom: 1.5rem !important;
}
/* La lista: sin bolitas, con borde superior y guiones */
.nh-service ul {
  list-style: none !important;
  border-top: 1px solid var(--line);
  padding: 1rem 0 0 0 !important;
  margin: 0 !important;
}
.nh-service ul li {
  font-size: .78rem !important;
  color: var(--ink-soft) !important;
  padding: .35rem 0 !important;
  letter-spacing: .02em;
  list-style: none !important;
}
.nh-service ul li::marker { content: none !important; }
.nh-service ul li::before {
  content: '— ' !important;
  color: var(--ink-mute) !important;
}

/* INICIO — PRENSA */
.nh-press-logos {
  display: flex; justify-content: center; align-items: center;
  gap: 5rem; flex-wrap: wrap; max-width: 900px; margin: 0 auto;
}
.nh-press-logo {
  font-family: var(--serif); font-size: 2rem; font-weight: 400;
  color: var(--ink-mute); transition: color .4s;
}
.nh-press-logo:hover { color: var(--ink); }
.nh-press-logo.italic { font-style: italic; }

/* INICIO — CTA */
.nh-cta-home h2.elementor-heading-title {
  font-size: clamp(2.4rem, 4.5vw, 4rem) !important;
  margin: 1.5rem 0 1.5rem !important;
}
.nh-cta-home h2 em { color: var(--accent); font-style: italic; }
.nh-cta-home .elementor-widget-text-editor p {
  color: var(--ink-soft) !important; max-width: 28rem; margin: 0 auto 3rem !important;
}
.nh-cta-buttons,
.nh-cta-sv-btns {
  display: inline-flex; gap: 1rem; flex-wrap: wrap; justify-content: center;
}


/* =========================================================
   PÁGINA SERVICIOS — bloques alternados
   ========================================================= */
.nh-sv-hero { position: relative; }
.nh-sv-hero::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(31,29,26,0) 40%, rgba(31,29,26,.55) 100%);
  pointer-events: none;
}
.nh-sv-hero > * { position: relative; z-index: 2; }
.nh-sv-hero h1.elementor-heading-title {
  color: var(--white) !important; font-size: clamp(3rem, 6vw, 5.5rem) !important;
}
.nh-sv-hero h1 em { color: var(--accent); font-style: italic; font-weight: 300; }
.nh-sv-hero .eyebrow .elementor-heading-title { color: rgba(252,251,248,.85) !important; }

.nh-sv-intro h2.elementor-heading-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem) !important; line-height: 1.4 !important;
  max-width: 36rem; margin: 0 auto !important; font-weight: 300 !important;
  font-style: italic !important;
}
.nh-sv-intro h2 em { color: var(--accent); font-style: italic; }

.nh-sv-img { overflow: hidden; background: var(--bone); }
.nh-sv-img .elementor-widget-image,
.nh-sv-img .elementor-widget-image img { height: 70vh; width: 100%; object-fit: cover; }
.nh-sv-content .num .elementor-heading-title {
  font-family: var(--serif) !important; font-style: italic !important;
  font-size: 1rem !important; color: var(--accent) !important;
  margin-bottom: 1.2rem !important;
}
.nh-sv-content h2.elementor-heading-title {
  font-size: clamp(2rem, 3.5vw, 3rem) !important; margin: 1rem 0 1.8rem !important;
}
.nh-sv-content h2 em { color: var(--accent); font-style: italic; }
.nh-sv-content .elementor-widget-text-editor p {
  color: var(--ink-soft) !important; font-size: 1rem !important; max-width: 32rem;
}
/* Lista de servicios con item + tag a los lados */
.nh-sv-list {
  list-style: none !important; padding: 0 !important;
  margin: 2rem 0 !important; border-top: 1px solid var(--line);
}
.nh-sv-list li {
  display: flex !important; justify-content: space-between; align-items: baseline;
  border-bottom: 1px solid var(--line); padding: 1rem 0 !important; gap: 1rem;
  list-style: none !important;
}
.nh-sv-list li::before { content: none !important; }
.nh-sv-list li .item { font-family: var(--serif); font-size: 1.2rem; font-weight: 300; color: var(--ink); }
.nh-sv-list li .num-text { font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; color: var(--ink-mute); }
.nh-sv-link {
  font-size: .72rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 5px;
  display: inline-block; margin-top: 1rem;
}
.nh-sv-link:hover { color: var(--accent); border-color: var(--accent); }

/* PROCESO — 4 pasos */
.nh-process-head h2.elementor-heading-title { font-size: clamp(2rem, 3.5vw, 3rem) !important; margin: 1rem 0 !important; }
.nh-process-head h2 em { color: var(--accent); font-style: italic; }
.nh-process-head .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 32rem; margin: 0 auto !important; }
.nh-process-step .step-num .elementor-heading-title {
  font-family: var(--serif) !important; font-style: italic !important;
  font-size: 2.5rem !important; color: var(--accent) !important;
  line-height: 1 !important; margin-bottom: 1.5rem !important;
}
.nh-process-step h3.elementor-heading-title { font-size: 1.3rem !important; font-weight: 300 !important; margin-bottom: 1rem !important; }
.nh-process-step .elementor-widget-text-editor p { color: var(--ink-soft) !important; font-size: .92rem !important; }

/* FAQ acordeón */
.nh-faq-head h2.elementor-heading-title { font-size: clamp(2rem, 3.5vw, 3rem) !important; margin: 1rem 0 !important; }
.nh-faq-head h2 em { color: var(--accent); font-style: italic; }
.nh-faq-list { border-top: 1px solid var(--line); }
.nh-faq-item { border-bottom: 1px solid var(--line); }
.nh-faq-q { display: flex; justify-content: space-between; align-items: center; padding: 1.8rem 0; cursor: pointer; transition: color .3s; }
.nh-faq-q:hover { color: var(--accent); }
.nh-faq-q .text { font-family: var(--serif); font-size: 1.3rem; font-weight: 300; }
.nh-faq-q .toggle { font-family: var(--serif); font-size: 1.5rem; color: var(--accent); transition: transform .3s; }
.nh-faq-item.open .nh-faq-q .toggle { transform: rotate(45deg); }
.nh-faq-a { max-height: 0; overflow: hidden; transition: max-height .4s; }
.nh-faq-item.open .nh-faq-a { max-height: 500px; }
.nh-faq-a p { color: var(--ink-soft); font-size: 1rem; padding-bottom: 1.8rem; max-width: 48rem; }

.nh-cta-sv h2.elementor-heading-title { font-size: clamp(2.4rem, 4.5vw, 4rem) !important; margin: 1rem 0 1.5rem !important; }
.nh-cta-sv h2 em { color: var(--accent); font-style: italic; }
.nh-cta-sv .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 28rem; margin: 0 auto 3rem !important; }


/* =========================================================
   QUIÉN SOY
   ========================================================= */
.nh-qs-hero-img .elementor-widget-image,
.nh-qs-hero-img .elementor-widget-image img { height: 75vh; width: 100%; object-fit: cover; }
.nh-qs-hero-text h1.elementor-heading-title { font-size: clamp(3rem, 6vw, 5.5rem) !important; margin: 1.5rem 0 2rem !important; line-height: 1.05 !important; }
.nh-qs-hero-text h1 em { color: var(--accent); font-style: italic; }
.nh-qs-claim { font-size: 1.2rem !important; color: var(--ink-soft) !important; max-width: 30rem; line-height: 1.6 !important; }

.nh-bio .elementor-widget-text-editor p { font-size: 1.1rem !important; color: var(--ink) !important; line-height: 1.8 !important; margin-bottom: 1.5rem !important; }
.nh-bio p .accent { color: var(--accent); }

.nh-stat .num,
.nh-stat .num .elementor-heading-title {
  font-family: var(--serif) !important; font-size: 4.5rem !important;
  font-weight: 300 !important; color: var(--accent) !important;
  line-height: 1 !important; margin-bottom: .8rem !important;
}
.nh-stat .label,
.nh-stat .label .elementor-heading-title {
  font-size: .7rem !important; letter-spacing: .25em !important;
  text-transform: uppercase !important; color: var(--ink-soft) !important;
  font-family: var(--sans) !important; font-weight: 400 !important;
}

.nh-cv-head h2.elementor-heading-title { font-size: clamp(2rem, 3.5vw, 3rem) !important; margin: 1rem 0 !important; }
.nh-cv-head h2 em { color: var(--accent); font-style: italic; }
.nh-cv-item { display: grid; grid-template-columns: 160px 1fr; gap: 3rem; padding: 2.5rem 0; border-bottom: 1px solid var(--line); }
.nh-cv-item:last-child { border-bottom: none; }
.nh-cv-item .year { font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--accent); padding-top: .4rem; }
.nh-cv-item .role h3 { font-family: var(--serif); font-size: 1.5rem; font-weight: 300; margin-bottom: .5rem; }
.nh-cv-item .role .place { font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 1rem; }
.nh-cv-item .role p { color: var(--ink-soft); font-size: .95rem; }

.nh-clients h2.elementor-heading-title { font-size: clamp(2rem, 3.5vw, 3rem) !important; margin: 1rem 0 4rem !important; }
.nh-clients h2 em { color: var(--accent); font-style: italic; }
.nh-clients-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.nh-clients-grid .client {
  padding: 2.5rem 1rem; font-family: var(--serif); font-size: 1.2rem; font-weight: 300;
  color: var(--ink-soft); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  transition: color .3s, background .3s; text-align: center;
}
.nh-clients-grid .client:hover { color: var(--ink); background: var(--paper); }

.nh-press-qs h2.elementor-heading-title { font-size: clamp(1.8rem, 3vw, 2.4rem) !important; margin: 1rem 0 !important; font-style: italic !important; }
.nh-press-qs .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 28rem; margin: 0 auto 3rem !important; }
.nh-press-qs-logos { display: flex; justify-content: center; align-items: center; gap: 5rem; flex-wrap: wrap; margin-bottom: 3rem; }
.nh-press-qs-logos .logo { font-family: var(--serif); font-size: 2rem; color: var(--ink-mute); }
.nh-press-qs-logos .logo.italic { font-style: italic; }
.nh-press-qs-link { font-size: .72rem; letter-spacing: .3em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 5px; }
.nh-press-qs-link:hover { color: var(--accent); border-color: var(--accent); }

.nh-values-head h2.elementor-heading-title { font-size: clamp(2rem, 3.5vw, 3rem) !important; margin: 1rem 0 !important; }
.nh-values-head h2 em { color: var(--accent); font-style: italic; }
.nh-value .num .elementor-heading-title {
  font-family: var(--serif) !important; font-style: italic !important;
  font-size: 1rem !important; color: var(--accent) !important; margin-bottom: 1.5rem !important;
}
.nh-value h3.elementor-heading-title { font-size: 1.5rem !important; font-weight: 300 !important; margin-bottom: 1rem !important; }
.nh-value .elementor-widget-text-editor p { color: var(--ink-soft) !important; font-size: .95rem !important; }

.nh-cta-qs h2.elementor-heading-title { font-size: clamp(2.4rem, 4vw, 3.5rem) !important; margin: 1rem 0 1.5rem !important; }
.nh-cta-qs h2 em { color: var(--accent); font-style: italic; }
.nh-cta-qs .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 26rem; margin: 0 auto 3rem !important; }


/* =========================================================
   PRENSA
   ========================================================= */
.nh-pr-header h1.elementor-heading-title { font-size: clamp(3rem, 6vw, 5.5rem) !important; margin: 1.5rem 0 1.5rem !important; line-height: 1.05 !important; }
.nh-pr-header h1 em { color: var(--accent); font-style: italic; }
.nh-pr-header .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 34rem; margin: 0 auto !important; }
.nh-pr-bar { display: flex; justify-content: center; align-items: center; gap: 5rem; flex-wrap: wrap; }
.nh-pr-bar .logo-item { font-family: var(--serif); font-size: 2rem; color: var(--ink-mute); }
.nh-pr-bar .logo-item.italic { font-style: italic; }
.nh-pr-img { overflow: hidden; background: var(--bone); }
.nh-pr-img .elementor-widget-image,
.nh-pr-img .elementor-widget-image img { height: 60vh; width: 100%; object-fit: cover; }
.nh-pr-content .source .elementor-heading-title {
  font-family: var(--serif) !important; font-style: italic !important;
  font-size: 1.2rem !important; color: var(--accent) !important; margin-bottom: 1.2rem !important;
}
.nh-pr-content h2.elementor-heading-title { font-size: clamp(1.8rem, 3vw, 2.6rem) !important; margin: 1rem 0 1rem !important; }
.nh-pr-content h2 em { color: var(--accent); font-style: italic; }
.nh-pr-content .date .elementor-heading-title {
  font-size: .7rem !important; letter-spacing: .25em !important; text-transform: uppercase !important;
  color: var(--ink-mute) !important; font-family: var(--sans) !important; margin-bottom: 1.5rem !important;
}
.nh-pr-content .elementor-widget-text-editor p { color: var(--ink-soft) !important; font-size: 1rem !important; margin-bottom: 1.5rem !important; }
.nh-pr-link { font-size: .72rem; letter-spacing: .3em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 5px; display: inline-block; }
.nh-pr-link:hover { color: var(--accent); border-color: var(--accent); }
.nh-pr-download h2.elementor-heading-title { font-size: clamp(2.2rem, 4vw, 3rem) !important; margin: 1rem 0 1.2rem !important; }
.nh-pr-download h2 em { color: var(--accent); font-style: italic; }
.nh-pr-download .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 26rem; margin: 0 auto 2.5rem !important; }


/* =========================================================
   CONTACTO
   ========================================================= */
.nh-co-header h1.elementor-heading-title { font-size: clamp(3rem, 6vw, 5rem) !important; margin: 1.5rem 0 1.5rem !important; line-height: 1.05 !important; }
.nh-co-header h1 em { color: var(--accent); font-style: italic; }
.nh-co-header .elementor-widget-text-editor p { color: var(--ink-soft) !important; max-width: 34rem; margin: 0 auto !important; }

.nh-form-col h2.elementor-heading-title { font-size: clamp(2rem, 3.5vw, 2.8rem) !important; margin-bottom: 2.5rem !important; font-style: italic !important; }
.nh-form-col form { display: flex; flex-direction: column; gap: 1.5rem; }
.nh-form-col .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.nh-form-col .field { display: flex; flex-direction: column; gap: .4rem; }
.nh-form-col label { font-size: .68rem; letter-spacing: .25em; text-transform: uppercase; color: var(--ink-soft); font-weight: 400; }
.nh-form-col input, .nh-form-col select, .nh-form-col textarea {
  font-family: var(--sans); font-size: .95rem; font-weight: 300;
  border: none; border-bottom: 1px solid var(--line); background: transparent;
  padding: .8rem 0; color: var(--ink); outline: none; transition: border-color .3s;
}
.nh-form-col input:focus, .nh-form-col select:focus, .nh-form-col textarea:focus { border-color: var(--ink); }
.nh-form-col textarea { min-height: 150px; resize: vertical; }
.nh-form-col .consent { display: flex; gap: .8rem; align-items: flex-start; margin-top: 1rem; }
.nh-form-col .consent input[type="checkbox"] { margin-top: .25rem; accent-color: var(--accent); }
.nh-form-col .submit-btn {
  margin-top: 1rem; padding: 1.2rem 2.5rem; font-size: .72rem; letter-spacing: .3em;
  text-transform: uppercase; font-weight: 400; font-family: var(--sans);
  background: var(--ink); color: var(--white); border: 1px solid var(--ink);
  transition: all .3s; cursor: pointer; align-self: flex-start;
}
.nh-form-col .submit-btn:hover { background: var(--accent); border-color: var(--accent); }

.nh-info-col { padding-top: 5rem; }
.nh-info-block { margin-bottom: 2.5rem; }
.nh-info-block .label { font-size: .65rem; letter-spacing: .3em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: .6rem; }
.nh-info-block .value { font-family: var(--serif); font-size: 1.5rem; font-weight: 300; }
.nh-info-block .value.small { font-size: 1rem; }
.nh-info-block .value a { color: var(--ink); }
.nh-info-block .value a:hover { color: var(--accent); }
.nh-info-col .divider { width: 60px; height: 1px; background: var(--line); margin: 2rem 0; }
.nh-wa-btn {
  display: inline-flex; align-items: center; gap: .6rem; margin-top: 1rem;
  padding: .9rem 1.4rem; background: var(--accent); color: var(--white);
  font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; transition: background .3s;
}
.nh-wa-btn:hover { background: var(--ink); }
.nh-location-box { position: relative; height: 50vh; overflow: hidden; background: var(--bone); }
.nh-location-box img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.4); }
.nh-location-box .pin {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: var(--white); padding: 1.2rem 1.8rem; border: 1px solid var(--line); text-align: center;
}
.nh-location-box .pin .city { font-family: var(--serif); font-size: 1.4rem; font-style: italic; color: var(--accent); }
.nh-location-box .pin .note { font-size: .65rem; letter-spacing: .25em; text-transform: uppercase; color: var(--ink-soft); margin-top: .4rem; }


/* =========================================================
   PROYECTO single (estático) — galería + datos
   ========================================================= */
.nh-data-list { display: flex; flex-direction: column; gap: 1.5rem; padding-top: .5rem; }
.nh-data-item .label { font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: .35rem; }
.nh-data-item .value { font-family: var(--serif); font-size: 1.3rem; font-weight: 300; color: var(--ink); }
.nh-data-item .value.italic { font-style: italic; color: var(--accent); }
.nh-desc h2.elementor-heading-title { font-size: clamp(1.6rem, 2.4vw, 2rem) !important; font-style: italic !important; margin-bottom: 1.8rem !important; }
.nh-desc .elementor-widget-text-editor p { color: var(--ink-soft) !important; font-size: 1rem !important; margin-bottom: 1.3rem !important; max-width: 38rem; }
.nh-cita blockquote, .nh-cita p {
  font-family: var(--serif) !important; font-style: italic !important; font-size: 1.5rem !important;
  line-height: 1.45 !important; color: var(--ink) !important; border-left: 2px solid var(--accent) !important;
  padding: .5rem 0 .5rem 2rem !important; margin: 0; max-width: 36rem; background: transparent;
}
.nh-gal-double { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.nh-gal-double .gal-img { height: 600px; overflow: hidden; background: var(--bone); }
.nh-gal-full .gal-img { height: 75vh; overflow: hidden; background: var(--bone); }
.nh-gal-asym { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; }
.nh-gal-asym .gal-img:first-child { height: 700px; overflow: hidden; background: var(--bone); }
.nh-gal-asym .gal-img:last-child { height: 500px; align-self: end; overflow: hidden; background: var(--bone); }
.nh-gal-asym.reverse { grid-template-columns: 1fr 2fr; }
.nh-gal-asym.reverse .gal-img:first-child { height: 500px; align-self: start; }
.nh-gal-asym.reverse .gal-img:last-child { height: 700px; }
.nh-gal img { width: 100%; height: 100%; object-fit: cover; transition: transform 2s; display: block; }
.nh-gal .gal-img:hover img { transform: scale(1.04); }
.nh-gal-caption { margin-top: 1rem; font-size: .78rem; color: var(--ink-soft); font-style: italic; font-family: var(--serif); padding-left: .5rem; }
.nh-gal-section { margin-bottom: 6rem; }


/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 900px) {
  .nh-hero-image .elementor-widget-image,
  .nh-hero-image .elementor-widget-image img { height: 60vh; }
  .nh-about-img .elementor-widget-image,
  .nh-about-img .elementor-widget-image img { height: 55vh; }
  .nh-pcard.tall a.cover-link, .nh-pcard.short a.cover-link { height: 420px; }
  .nh-pgrid > *:nth-child(2), .nh-pgrid > *:nth-child(4) { padding-top: 0 !important; }
  .nh-cv-item { grid-template-columns: 1fr; gap: 1rem; }
  .nh-clients-grid { grid-template-columns: repeat(2, 1fr); }
  .nh-gal-double, .nh-gal-asym, .nh-gal-asym.reverse { grid-template-columns: 1fr; gap: 1.5rem; }
  .nh-gal-double .gal-img,
  .nh-gal-asym .gal-img:first-child, .nh-gal-asym .gal-img:last-child,
  .nh-gal-asym.reverse .gal-img:first-child, .nh-gal-asym.reverse .gal-img:last-child { height: 400px; }
  .nh-gal-full .gal-img { height: 50vh; }
  .nh-form-col .field-row { grid-template-columns: 1fr; }
  .nh-info-col { padding-top: 0; }
}

/* ============================================
   MASONRY — Portfolio (loop grid) y Home  [corregido]
   ============================================ */
.nh-portfolio-loop .elementor-loop-container,
.nh-home-destacados .elementor-loop-container {
  display: block !important;
  column-count: 2;
  column-gap: 40px;
}

/* Ocultar cualquier <style> que Elementor meta dentro */
.nh-portfolio-loop .elementor-loop-container > style,
.nh-home-destacados .elementor-loop-container > style {
  display: none !important;
}

/* Solo las CARDS reales (no el <style>) */
.nh-portfolio-loop .elementor-loop-container > .e-loop-item,
.nh-portfolio-loop .elementor-loop-container > article,
.nh-home-destacados .elementor-loop-container > .e-loop-item,
.nh-home-destacados .elementor-loop-container > article {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  margin-bottom: 64px;
  width: 100%;
  display: inline-block;
}

/* Imágenes con proporción natural (masonry real) */
.nh-portfolio-loop .nh-loop-cover,
.nh-home-destacados .nh-loop-cover { height: auto !important; }
.nh-portfolio-loop .nh-loop-cover img,
.nh-home-destacados .nh-loop-cover img {
  height: auto !important; width: 100% !important; object-fit: cover;
}

@media (max-width: 1100px) {
  .nh-portfolio-loop .elementor-loop-container,
  .nh-home-destacados .elementor-loop-container { column-count: 2; }
}
@media (max-width: 700px) {
  .nh-portfolio-loop .elementor-loop-container,
  .nh-home-destacados .elementor-loop-container { column-count: 1; }
}

/* =========================================================
   NATALIA HORTELANO — CSS DE ACCESIBILIDAD
   
   Pegar en: Site Settings → Custom CSS
   AL FINAL de todo (después de 01, 13 y 14)
   
   Arregla los fallos de CONTRASTE de Lighthouse/PageSpeed
   sin cambiar la estética: solo oscurece lo justo los grises
   para pasar el ratio mínimo AA (4.5:1 en texto normal,
   3:1 en texto grande).
   ========================================================= */

/* ---------------------------------------------------------
   1. CONTRASTE — redefinir los grises problemáticos
   
   Originales (fallaban en AA sobre fondo claro):
     --ink-soft: #6E6A60   ratio ~4.3  → casi
     --ink-mute: #A39E91   ratio ~2.4  → FALLA
   
   Nuevos (pasan AA, casi imperceptible el cambio):
     --ink-soft: #5C5950   ratio ~5.2  ✓
     --ink-mute: #807B6E   ratio ~3.6  ✓ (solo en textos grandes/labels)
   --------------------------------------------------------- */
:root {
  --ink-soft: #5C5950;
  --ink-mute: #807B6E;
}

/* Para los eyebrows / labels pequeños en mayúsculas, subir un
   poco más el contraste porque el texto es chico (<18px) */
.eyebrow,
.nh-data-item .label,
.nh-info-block .label,
.nh-loop-card .nh-cat,
.nh-pcard .cat,
.nh-pfcard .cat,
.nh-filters a.filter-btn,
.nh-section-head .count,
.nh-meta-line,
.nh-gal-caption,
.nh-pn-item .label {
  color: #6B6658 !important;   /* ratio ~4.6 sobre #FCFBF8 ✓ */
}

/* Sobre fondos oscuros (hero servicios), el blanco translúcido
   debe ser más opaco para contrastar */
.nh-sv-hero .eyebrow,
.nh-sv-hero .eyebrow .elementor-heading-title {
  color: rgba(252, 251, 248, 0.95) !important;
}

/* ---------------------------------------------------------
   2. FOCUS VISIBLE — para navegación por teclado
   Lighthouse penaliza si no hay indicador de foco visible.
   --------------------------------------------------------- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.btn:focus-visible,
.filter-btn:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--accent) !important;
  outline-offset: 3px !important;
  border-radius: 2px;
}

/* Quitar el outline solo cuando NO es navegación por teclado */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
  outline: none;
}

/* ---------------------------------------------------------
   3. ÁREAS CLICABLES (touch targets) — mínimo 44x44px en móvil
   Lighthouse mobile penaliza enlaces/botones pequeños juntos.
   --------------------------------------------------------- */
@media (max-width: 900px) {
  .nh-filters a.filter-btn {
    padding: 0.8rem 0.4rem !important;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }
  .nh-footer .footer-col ul li a,
  .nh-nav .nav-left a,
  .nh-nav .nav-right a {
    display: inline-block;
    padding: 6px 0;
    min-height: 32px;
  }
  .nh-info-block .value a {
    display: inline-block;
    padding: 4px 0;
  }
}

/* ---------------------------------------------------------
   4. Texto seleccionable / legibilidad
   --------------------------------------------------------- */
::selection {
  background: var(--accent);
  color: var(--white);
}

/* Asegurar que ningún texto baje de 12px (Lighthouse: font-size legible) */
.nh-press-logo,
.nh-data-item .value,
.nh-info-block .value {
  font-size: max(1rem, 14px);
}

/* ---------------------------------------------------------
   5. prefers-reduced-motion — respetar usuarios que
   desactivan animaciones (accesibilidad vestibular)
   --------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .nh-pcard a.cover-link img:hover,
  .nh-pfcard:hover a.cover img,
  .nh-loop-card:hover .nh-loop-cover img {
    transform: none !important;
  }
}/* End custom CSS */