.elementor-35 .elementor-element.elementor-element-473c462{--display:flex;}.elementor-35 .elementor-element.elementor-element-473c462.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-35 .elementor-element.elementor-element-6b07bb7{--display:flex;--overlay-opacity:0.5;}.elementor-35 .elementor-element.elementor-element-6b07bb7::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .elementor-background-video-container::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .e-con-inner > .elementor-background-video-container::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .elementor-background-slideshow::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .e-con-inner > .elementor-background-slideshow::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{--background-overlay:'';}:root{--page-title-display:none;}@media(max-width:767px){.elementor-35 .elementor-element.elementor-element-6b07bb7::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .elementor-background-video-container::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .e-con-inner > .elementor-background-video-container::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .elementor-background-slideshow::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .e-con-inner > .elementor-background-slideshow::before, .elementor-35 .elementor-element.elementor-element-6b07bb7 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-image:url("https://gabrielacastillo.es/wp-content/uploads/2026/04/Gabriela_Portad.png");background-position:145px 86px;background-repeat:no-repeat;background-size:242px auto;}.elementor-35 .elementor-element.elementor-element-6b07bb7{--overlay-opacity:1;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-35 .elementor-element.elementor-element-2cb2bb8{margin:30px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}}@media(min-width:768px){.elementor-35 .elementor-element.elementor-element-473c462{--width:82.574%;}}/* Start custom CSS for html, class: .elementor-element-579a932 *//* ================================================
   GABRIELA CASTILLO — CSS específico: Página INICIO
   Pegar SOLO en la página de inicio de WordPress:
   Elementor > Settings > Custom CSS  (en esa página)
   v1.3 - 2026
   ================================================ */



/* ------------------------------------------------
   HERO
   ------------------------------------------------ */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
  overflow: hidden;
}
.hero::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  left: calc(50% - 1px);
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--rule) 20%, var(--rule) 80%, transparent);
  z-index: 3;
}

.hero-left {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 8rem 3rem 5rem;
  position: relative;
  z-index: 2;
}
.hero-eyebrow {
  font-family: var(--mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent-dark);
  margin-bottom: 2rem;
  opacity: 0;
  animation: gc-slideUp 0.8s 0.6s ease forwards;
}
.hero-name {
  font-family: var(--serif);
  font-size: clamp(4.5rem, 7vw, 7rem);
  font-weight: 300;
  line-height: 0.92;
  letter-spacing: var(--tracking-tight);
  color: var(--ink);
  opacity: 0;
  animation: gc-slideUp 0.9s 0.8s ease forwards;
}
.hero-name em { font-style: italic; color: var(--accent-dark); display: block; }
.hero-tagline {
  margin-top: 2.5rem;
  font-family: var(--sans);
  font-size: var(--text-base);
  font-weight: 300;
  color: var(--warm-gray);
  max-width: 340px;
  line-height: var(--leading-loose);
  opacity: 0;
  animation: gc-slideUp 0.9s 1s ease forwards;
}
.hero-cta {
  margin-top: 3rem;
  display: flex;
  align-items: center;
  gap: var(--space-8);
  opacity: 0;
  animation: gc-slideUp 0.9s 1.2s ease forwards;
}

.hero-right {
  position: relative;
  overflow: hidden;
  background: var(--cream);
}
.hero-image-wrap { position: absolute; inset: 0; }
.hero-image-wrap img {
  width: 70%;
  height: 100%;
  object-fit: contain;
  object-position: center bottom;
  margin: 0 auto;
  display: block;
}
.hero-vertical-text {
  position: absolute;
  right: 2rem; bottom: 5rem;
  font-family: var(--mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--warm-gray);
  writing-mode: vertical-rl;
  opacity: 0;
  animation: gc-fadeIn 1s 1.6s ease forwards;
}
.hero-scroll {
  position: absolute;
  bottom: 3rem; left: 3rem;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  opacity: 0;
  animation: gc-fadeIn 1s 1.8s ease forwards;
}
.scroll-line {
  width: 48px; height: 1px;
  background: var(--accent);
  position: relative;
  overflow: hidden;
}
.scroll-line::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: var(--ink);
  animation: scrollLine 2s 2s ease-in-out infinite;
}
.scroll-label {
  font-family: var(--mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--warm-gray);
}
@keyframes scrollLine {
  0%   { left: -100%; }
  50%  { left: 0%; }
  100% { left: 100%; }
}


/* ------------------------------------------------
   ABOUT
   ------------------------------------------------ */
.about {
  display: grid;
  grid-template-columns: 1fr 2fr;
  padding: var(--space-32) var(--page-x);
  border-top: 1px solid var(--rule);
}
.about-content h2 {
  font-family: var(--serif);
  font-size: clamp(2.2rem, 3.5vw, 3.2rem);
  font-weight: 300;
  line-height: 1.2;
  margin-bottom: var(--space-8);
}
.about-content h2 em { font-style: italic; color: var(--accent-dark); }
.about-content p {
  font-family: var(--sans);
  font-weight: 300;
  font-size: var(--text-md);
  line-height: var(--leading-loose);
  color: var(--warm-gray);
  margin-bottom: var(--space-5);
}


/* ------------------------------------------------
   FACETS
   ------------------------------------------------ */
.facets { padding: 0 var(--page-x) var(--space-32); }
.facets-grid { display: grid; grid-template-columns: repeat(5, 1fr); }

.facet {
  padding: var(--space-10) var(--space-8) var(--space-10) 0;
  border-right: 1px solid var(--rule);
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  position: relative;
  overflow: hidden;
  transition: opacity 0.2s ease;
}
.facet:first-child { padding-left: 0; }
.facet:last-child  { border-right: none; }
.facet::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
.facet:hover::before { transform: scaleX(1); }
.facet-number { font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 0.15em; color: var(--accent); }
.facet-icon   { font-size: 1.6rem; line-height: 1; }
.facet-title  { font-family: var(--serif); font-size: var(--text-lg); font-weight: 500; line-height: 1.2; }
.facet-desc {
  font-family: var(--sans);
  font-weight: 300;
  font-size: var(--text-md);
  line-height: 1.7;
  color: var(--warm-gray);
  flex: 1;
}
.facet-arrow  { font-size: var(--text-sm); color: var(--accent); transition: transform 0.2s ease; }
.facet:hover .facet-arrow { transform: translateX(4px); }


/* ------------------------------------------------
   LATEST
   ------------------------------------------------ */
.latest { background: var(--ink); color: var(--cream); padding: var(--space-32) var(--page-x); }
.latest-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; }

.latest-item {
  padding: 0 var(--space-10) 0 0;
  border-right: 1px solid var(--dark-rule);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: opacity 0.2s ease;
}
.latest-item:last-child           { border-right: none; padding-right: 0; }
.latest-item:not(:first-child)    { padding-left: var(--space-10); }
.latest-item:hover                { opacity: 0.75; }
.latest-item:first-child .gc-card__title { font-size: var(--text-2xl); }


/* ------------------------------------------------
   NEWSLETTER
   ------------------------------------------------ */
.newsletter {
  padding: var(--space-32) var(--page-x);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
  border-top: 1px solid var(--rule);
}
.newsletter h2 {
  font-family: var(--serif);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: 300;
  line-height: 1.2;
  margin-bottom: var(--space-5);
}
.newsletter h2 em { font-style: italic; color: var(--accent-dark); }
.newsletter p { font-size: var(--text-base); line-height: var(--leading-loose); color: var(--warm-gray); }

.newsletter-form { display: flex; flex-direction: column; gap: var(--space-4); }
.form-row { display: flex; }
.form-row input {
  flex: 1;
  padding: 0.9rem 1.2rem;
  border: 1px solid var(--rule);
  border-right: none;
  background: var(--white);
  font-family: var(--sans);
  font-size: var(--text-base);
  color: var(--ink);
  outline: none;
  transition: border-color 0.2s ease;
}
.form-row input:focus { border-color: var(--accent); }
.form-row input::placeholder { color: var(--warm-gray-lt); }
.form-row button {
  padding: 0.9rem 1.8rem;
  background: var(--ink);
  color: var(--cream);
  border: none;
  font-family: var(--sans);
  font-size: var(--text-sm);
  font-weight: 400;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s ease;
}
.form-row button:hover { background: var(--accent-dark); }


/* ------------------------------------------------
   RESPONSIVE — Página de inicio
   ------------------------------------------------ */
@media (max-width: 1024px) {
  .facets-grid { grid-template-columns: repeat(3, 1fr); }
  .facet:nth-child(3) { border-right: none; }
  .facet:nth-child(4) { border-right: 1px solid var(--rule); }
  .latest-grid { grid-template-columns: 1fr 1fr; }
  .latest-item:nth-child(3) { display: none; }
}

@media (max-width: 768px) {
  .hero {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: 1fr;
    height: 100svh;
    min-height: 100svh;
    align-items: end;
    overflow: hidden;
    position: relative;
  }
  .hero::after { display: none; }

  .hero-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100svh;
  padding: 0rem 0.75rem 3rem 1.5rem;
  position: relative;
  z-index: 2;
 }
  .hero-eyebrow  { margin-bottom: 1rem; }
  .hero-name     { font-size: clamp(2.6rem, 10vw, 4rem); }
  .hero-tagline  { max-width: 100%; font-size: 0.82rem; margin-top: 1rem; }
  .hero-cta      { margin-top: 1.5rem; flex-wrap: wrap; gap: var(--space-4); }
  .hero-scroll   { position: relative; bottom: auto; left: auto; margin-top: 1.5rem; }
  .hero-vertical-text { display: none; }

  /* IMAGEN HERO: ocupa toda la altura, sin recorte */
  .hero-right {
    position: relative;
    align-self: stretch;
    width: 38vw;
    max-width: 155px;
    margin-top: 0;
    margin-right: 1rem;
    overflow: hidden;
    flex-shrink: 0;
  }
  .hero-image-wrap { position: absolute; inset: 0; }
  .hero-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;        /* contain = figura completa, sin recorte */
    object-position: center 15%;
  }

  .about        { grid-template-columns: 1fr; padding: var(--space-20) var(--page-x); }
  .facets       { padding: 0 var(--page-x) var(--space-20); }
  .facets-grid  { grid-template-columns: 1fr 1fr; }

  .facet        { padding: var(--space-8) var(--space-4) var(--space-8) 0; }
  .facet:nth-child(2n)  { border-right: none; padding-right: 0; padding-left: var(--space-4); }
  .facet:nth-child(3)   { border-right: 1px solid var(--rule); padding-left: 0; }

  .latest       { padding: var(--space-20) var(--page-x); }
  .latest-grid  { grid-template-columns: 1fr; gap: var(--space-12); }
  .latest-item  { border-right: none !important; padding: 0 !important; }
  .latest-item:not(:last-child) { border-bottom: 1px solid var(--dark-rule); padding-bottom: var(--space-10) !important; }

  .newsletter   { grid-template-columns: 1fr; padding: var(--space-20) var(--page-x); gap: var(--space-10); }
}

@media (max-width: 480px) {
  /* Sin height ni max-height — align-self: stretch se encarga */
  .hero-right {
    width: 34vw;
    max-width: 130px;
  }
  .facets-grid  { grid-template-columns: 1fr; }
  .facet        { border-right: none !important; border-bottom: 1px solid var(--rule); padding: var(--space-8) 0 !important; }
  .facet:last-child { border-bottom: none; }
}/* End custom CSS */