/*
Theme Name:   Baiti Kadence Child
Theme URI:    https://baiti.es
Description:  Tema hijo de Kadence para Baiti Innovaciones S.L. — Identidad de marca, portal inmobiliario con cartera pública y privada.
Author:       Baiti Innovaciones S.L.
Author URI:   https://baiti.es
Template:     kadence
Version:      2.0.0
Text Domain:  baiti-kadence-child
*/

/* ══ VARIABLES DE MARCA ══ */
:root {
  --negro:         #1A1A18;
  --negro-suave:   #222220;
  --negro-medio:   #2A2A27;
  --naranja:       #FF6600;
  --naranja-hover: #E55A00;
  --tierra-oscura: #4A3728;
  --tierra:        #8C6E55;
  --arena-oscura:  #C4A882;
  --arena:         #DDD0BC;
  --arena-claro:   #EDE5D8;
  --crema:         #F5EFE6;
  --crema-suave:   #FAF7F2;
  --blanco-70:     rgba(245,239,230,0.70);
  --blanco-35:     rgba(245,239,230,0.35);
  --gris-tierra:   #9A8E82;
  --bauhaus:       'Josefin Sans', sans-serif;
  --serif:         'Cormorant Garamond', serif;
  --sans:          'DM Sans', sans-serif;
}

/* ══ BASE ══ */
body { font-family: var(--sans); background: var(--crema); color: var(--negro); }
h1,h2,h3 { font-family: var(--serif); font-weight: 300; line-height: 1.08; }
p,li,input,textarea,select,button { font-family: var(--sans); font-weight: 300; }

/* ══ LOGO ══ */
.site-branding .site-title,
.site-branding a {
  font-family: var(--bauhaus) !important;
  font-weight: 100 !important;
  letter-spacing: 0.12em !important;
  text-transform: lowercase !important;
  color: #F5EFE6 !important;
  font-size: 1.9rem !important;
  text-decoration: none !important;
}

/* ══ CABECERA ══ */
.site-header, #masthead {
  background: rgba(26,26,24,0.97) !important;
  backdrop-filter: blur(18px);
  border-bottom: 2px solid var(--naranja) !important;
  position: sticky; top: 0; z-index: 100;
}

/* ══ NAVEGACIÓN ══ */
.main-navigation a, .nav-menu a {
  font-family: var(--bauhaus) !important;
  font-size: 0.65rem !important;
  font-weight: 300 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: rgba(245,239,230,0.7) !important;
  transition: color 0.2s !important;
}
.main-navigation a:hover, .nav-menu a:hover { color: var(--naranja) !important; }

/* ══ BOTONES ══ */
.wp-block-button__link, .button, button[type="submit"], .btn-primary, .baiti-btn {
  font-family: var(--bauhaus) !important;
  font-size: 0.68rem !important;
  font-weight: 300 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  background: var(--naranja) !important;
  color: var(--negro) !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 1rem 2.5rem !important;
  transition: background 0.2s !important;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}
.wp-block-button__link:hover, .button:hover, button[type="submit"]:hover, .baiti-btn:hover {
  background: var(--naranja-hover) !important;
  color: var(--negro) !important;
}

/* ══ ELEMENTO DE MARCA: LÍNEA NARANJA ══ */
.baiti-linea       { display: block; height: 2px; background: var(--naranja); width: 100%; }
.baiti-linea-corta { display: inline-block; width: 36px; height: 2px; background: var(--naranja); vertical-align: middle; margin-right: 0.8rem; flex-shrink: 0; }

/* ══ EYEBROW / TAG DE SECCIÓN ══ */
.baiti-eyebrow { display: flex; align-items: center; margin-bottom: 1.75rem; }
.baiti-tag {
  font-family: var(--bauhaus);
  font-size: 0.6rem; font-weight: 300;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--tierra);
}
.baiti-tag-light { color: var(--arena-oscura) !important; }
.baiti-tag-naranja { color: var(--naranja) !important; }

/* ══ TITULARES ══ */
.baiti-titulo {
  font-family: var(--serif);
  font-size: clamp(2.2rem, 4vw, 3.8rem);
  font-weight: 300; line-height: 1.08;
  margin-bottom: 1.5rem;
}
.baiti-titulo em { font-style: italic; color: var(--naranja); }
.baiti-titulo.light { color: var(--crema); }
.baiti-titulo.dark  { color: var(--negro); }

/* ══ FONDOS DE SECCIÓN ══ */
.baiti-bg-negro       { background: var(--negro) !important; }
.baiti-bg-negro-suave { background: var(--negro-suave) !important; }
.baiti-bg-negro-medio { background: var(--negro-medio) !important; }
.baiti-bg-crema       { background: var(--crema) !important; }
.baiti-bg-crema-suave { background: var(--crema-suave) !important; }
.baiti-bg-arena-claro { background: var(--arena-claro) !important; }

/* ══ UTILIDADES ══ */
.baiti-text-naranja  { color: var(--naranja) !important; }
.baiti-text-arena    { color: var(--arena-oscura) !important; }
.baiti-text-tierra   { color: var(--tierra) !important; }
.baiti-text-crema    { color: var(--crema) !important; }
.baiti-text-70       { color: var(--blanco-70) !important; }
.baiti-text-35       { color: var(--blanco-35) !important; }
.baiti-font-serif    { font-family: var(--serif) !important; }
.baiti-font-bauhaus  { font-family: var(--bauhaus) !important; }
.baiti-font-300      { font-weight: 300 !important; }
.baiti-italic        { font-style: italic !important; }

/* ══ CARDS DE SERVICIO ══ */
.baiti-service-card {
  background: var(--crema-suave);
  padding: 2rem;
  border-top: 2px solid transparent;
  transition: all 0.25s;
}
.baiti-service-card:hover { background: var(--negro); border-top-color: var(--naranja); }
.baiti-service-card:hover .baiti-serv-titulo { color: var(--arena-oscura); }
.baiti-service-card:hover .baiti-serv-desc   { color: var(--blanco-70); }
.baiti-serv-linea { width: 24px; height: 1.5px; background: var(--arena-oscura); margin-bottom: 1.25rem; transition: all 0.25s; }
.baiti-service-card:hover .baiti-serv-linea { width: 40px; background: var(--naranja); }
.baiti-serv-titulo { font-family: var(--serif); font-size: 1.15rem; font-weight: 300; color: var(--negro); margin-bottom: 0.6rem; transition: color 0.25s; }
.baiti-serv-desc   { font-size: 0.78rem; color: var(--gris-tierra); line-height: 1.8; font-weight: 300; transition: color 0.25s; }

/* ══ PORTAL INMOBILIARIO — CONTROLES ══ */
.baiti-portal-header {
  display: flex; justify-content: space-between; align-items: center;
  margin: 2.5rem 0 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 0.5px solid rgba(196,168,130,0.15);
}
.baiti-filtros { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.baiti-filtro {
  font-family: var(--bauhaus);
  font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 0.5rem 1.1rem;
  border: 0.5px solid rgba(196,168,130,0.2);
  color: var(--blanco-35);
  background: transparent; cursor: pointer;
  transition: all 0.2s; font-weight: 300;
}
.baiti-filtro.active, .baiti-filtro:hover { border-color: var(--naranja); color: var(--naranja); }

.baiti-vista-toggle { display: flex; align-items: center; gap: 0.75rem; }
.baiti-count {
  font-family: var(--bauhaus);
  font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--blanco-35); font-weight: 300;
}
.baiti-vista-btn {
  width: 30px; height: 30px;
  border: 0.5px solid rgba(196,168,130,0.2);
  background: transparent; color: var(--blanco-35);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.baiti-vista-btn.active { border-color: var(--naranja); color: var(--naranja); }
.baiti-vista-btn:hover  { border-color: var(--arena-oscura); color: var(--arena-oscura); }

/* ══ PORTAL — VISTA GRID ══ */
.baiti-prop-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.baiti-prop-card {
  background: var(--negro-medio);
  border: 0.5px solid rgba(196,168,130,0.1);
  border-top: 2px solid transparent;
  overflow: hidden; cursor: pointer;
  transition: all 0.35s;
}
.baiti-prop-card:hover { border-top-color: var(--naranja); transform: translateY(-5px); box-shadow: 0 20px 40px rgba(0,0,0,0.3); }
.baiti-prop-img { height: 210px; overflow: hidden; position: relative; }
.baiti-prop-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.8) saturate(0.85); transition: all 0.5s ease; }
.baiti-prop-card:hover .baiti-prop-img img { transform: scale(1.05); filter: brightness(0.9) saturate(1); }
.baiti-prop-badge {
  position: absolute; top: 1rem; left: 1rem;
  font-family: var(--bauhaus); font-size: 0.56rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  background: var(--naranja); color: var(--negro);
  padding: 0.3rem 0.8rem; font-weight: 400;
}
.baiti-prop-body { padding: 1.5rem; }
.baiti-prop-tipo { font-family: var(--bauhaus); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--arena-oscura); margin-bottom: 0.6rem; font-weight: 300; }
.baiti-prop-titulo { font-family: var(--serif); font-size: 1.3rem; font-weight: 300; color: var(--crema); margin-bottom: 0.4rem; line-height: 1.2; }
.baiti-prop-ubic { font-size: 0.75rem; color: var(--gris-tierra); margin-bottom: 1.25rem; font-weight: 300; }
.baiti-prop-footer { display: flex; gap: 1rem; padding-top: 1rem; border-top: 0.5px solid rgba(196,168,130,0.12); }
.baiti-prop-dato { font-size: 0.7rem; color: var(--gris-tierra); display: flex; flex-direction: column; gap: 0.2rem; font-weight: 300; }
.baiti-prop-dato strong { font-family: var(--serif); font-size: 1rem; color: var(--crema); font-weight: 300; }
.baiti-prop-precio { margin-left: auto; text-align: right; }
.baiti-prop-precio strong { color: var(--arena-oscura); }

/* ══ PORTAL — VISTA LISTA ══ */
.baiti-prop-list { display: none; }
.baiti-prop-list-card {
  display: flex;
  background: var(--negro-medio);
  border: 0.5px solid rgba(196,168,130,0.1);
  border-left: 2px solid transparent;
  overflow: hidden; cursor: pointer;
  transition: all 0.3s; margin-bottom: 1rem;
}
.baiti-prop-list-card:hover { border-left-color: var(--naranja); }
.baiti-prop-list-img { width: 220px; flex-shrink: 0; position: relative; overflow: hidden; }
.baiti-prop-list-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.8) saturate(0.85); transition: all 0.4s; }
.baiti-prop-list-card:hover .baiti-prop-list-img img { filter: brightness(0.9); transform: scale(1.03); }
.baiti-prop-list-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; justify-content: center; }
.baiti-prop-list-meta { display: flex; gap: 1.5rem; align-items: flex-end; margin-top: 1rem; padding-top: 1rem; border-top: 0.5px solid rgba(196,168,130,0.1); }

/* ══ ÁREA PRIVADA INVERSORES ══ */
.baiti-privado {
  margin-top: 4rem;
  display: grid; grid-template-columns: 1.3fr 1fr;
  gap: 4rem; padding: 3rem;
  background: var(--negro-medio);
  border-top: 2px solid var(--naranja);
}
.baiti-privado-tag {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--bauhaus);
  font-size: 0.58rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--naranja); margin-bottom: 1.5rem; font-weight: 300;
}
.baiti-privado-titulo { font-family: var(--serif); font-size: 2rem; font-weight: 300; color: var(--crema); line-height: 1.15; margin-bottom: 1.5rem; }
.baiti-privado-titulo em { font-style: italic; color: var(--arena-oscura); }
.baiti-privado-body { font-size: 0.85rem; font-weight: 300; color: var(--blanco-70); line-height: 1.95; }
.baiti-privado-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(196,168,130,0.1); margin-bottom: 1.5rem; }
.baiti-privado-stat { background: var(--negro-suave); padding: 1.5rem 1rem; text-align: center; }
.baiti-pstat-num { font-family: var(--serif); font-size: 2.5rem; font-weight: 300; color: var(--arena-oscura); line-height: 1; display: block; }
.baiti-pstat-label { font-family: var(--bauhaus); font-size: 0.58rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--blanco-35); margin-top: 0.4rem; display: block; font-weight: 300; }
.baiti-privado-nota { font-family: var(--bauhaus); font-size: 0.58rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--blanco-35); text-align: center; margin-top: 1rem; font-weight: 300; }

/* ══ CTA INMOBILIARIA ══ */
.baiti-inmo-cta {
  margin-top: 3rem;
  padding: 2.5rem 3rem;
  background: var(--negro-suave);
  border-left: 2px solid var(--naranja);
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
}
.baiti-inmo-cta-txt { font-family: var(--serif); font-size: 1.4rem; font-weight: 300; font-style: italic; color: var(--blanco-70); }

/* ══ FORMULARIO ══ */
.wpcf7-form input, .wpcf7-form textarea, .wpcf7-form select,
input[type="text"], input[type="email"], input[type="tel"], textarea {
  background: var(--negro-suave) !important;
  border: none !important;
  border-bottom: 1px solid rgba(196,168,130,0.2) !important;
  border-radius: 0 !important;
  color: var(--crema) !important;
  font-family: var(--sans) !important;
  font-weight: 300 !important;
  padding: 0.85rem 1rem !important;
  transition: border-color 0.2s !important;
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus { border-bottom-color: var(--naranja) !important; outline: none !important; }

/* ══ FOOTER ══ */
.site-footer, #colophon {
  background: var(--negro-suave) !important;
  border-top: 2px solid var(--naranja) !important;
  color: var(--blanco-35) !important;
}
.site-footer a { color: var(--blanco-35) !important; transition: color 0.2s !important; }
.site-footer a:hover { color: var(--naranja) !important; }

/* ══ ANIMACIONES ══ */
.baiti-fade-up { opacity: 0; transform: translateY(28px); transition: opacity 0.75s ease, transform 0.75s ease; }
.baiti-fade-up.visible { opacity: 1; transform: translateY(0); }

/* ══ RESPONSIVE ══ */
@media (max-width: 900px) {
  .baiti-prop-grid { grid-template-columns: 1fr !important; }
  .baiti-prop-list-card { flex-direction: column; }
  .baiti-prop-list-img { width: 100%; height: 200px; }
  .baiti-privado { grid-template-columns: 1fr; gap: 2rem; }
  .baiti-inmo-cta { flex-direction: column; text-align: center; }
  .baiti-portal-header { flex-direction: column; align-items: flex-start; gap: 1rem; }
}
