/* =========================================================
   1. FUENTES
   ========================================================= */
@font-face {
  font-family: "Congenial";
  src: url("../fonts/congenial/fonnts.com-congenial_extralight.otf") format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Congenial";
  src: url("../fonts/congenial/fonnts.com-congenial_regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Congenial";
  src: url("../fonts/congenial/fonnts.com-congenial_medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Congenial";
  src: url("../fonts/congenial/fonnts.com-congenial_heavy.otf") format("opentype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Congenial";
  src: url("../fonts/congenial/fonnts.com-congenial_black.otf") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Omnes";
  src: url("../fonts/omnes/omnes regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Omnes";
  src: url("../fonts/omnes/omnes medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Omnes";
  src: url("../fonts/omnes/omnes semibold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Omnes";
  src: url("../fonts/omnes/omnes bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* =========================================================
   2. TOKENS / BASE
   ========================================================= */
:root{
  --magenta:#e6007e;
  --violeta:#632c90;
  --azul:#1c1789;
  --gris:#6f6f6f;
  --ink:#1b1b1b;
  --paper:#f8f8f8;
  --bg:#dbdbdb;
  --ring:#e5e6f0;
  --shadow:0 12px 28px rgba(0,0,0,.16);
  --radius:24px;
  --page-side-space: 200px;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html,body{
  margin:0;
  padding:0;
  margin-top: 20px;
  scroll-behavior:smooth;
}

body{
  font-family:"Omnes",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--ink);
  margin:0;
  position:relative;
  background:transparent;
}

body::before{
  content:"";
  position:fixed;  
  inset:0;
  z-index:-1;      
 background:
  
    radial-gradient(circle at 30px 30px, rgb(255, 255, 255) 27px, transparent 24px) 0 0/24px 30px,
    var(--bg);
 filter: drop-shadow(1);
 filter:blur(7px);
  background-size:24px 30px, auto;
  animation: dotsSlide 24s ease-in-out infinite;
 
}

@keyframes dotsSlide{
  0%{
    background-position:0 0, 0 0;
    opacity:1;
  }
  100%{
    background-position:120px 0, 0 0;
    opacity:0.9;
  }
}

img{
  max-width:100%;
  display:block;
}

.wrapper{
  max-width:1100px;
  margin:0 auto;
  padding:0 16px 48px;
}

.section{
  padding:200px 0;


}

@media (max-width:1200px){
  .section{
    padding:100px 0;
  }
}

@media (max-width:1023px){
  :root{
    --page-side-space:50px;
  }
  .wrapper{
    padding:0 12px 40px;
  }
  .section{
    padding:120px 0;
  }
}

@media (max-width:767px){
  :root{
    --page-side-space:10px;
  }
  .wrapper{
    padding:0 10px 32px;
  }
  .section{
    padding:90px 0;
  }
  .watermark{
    font-size:3.2rem;
    left:12px;
  }
}

@media (max-width:540px){
  .section{
    padding:70px 0;
  }
}


.watermark{
  position:absolute;;
  left:8px;
  top:150px;
  font-family:"Congenial","Omnes",sans-serif;
  font-weight:700;
  font-size:5rem;
  text-transform:lowercase;
  letter-spacing:.06em;
  color:rgba(99,44,144,.06);
  pointer-events:none;
  user-select:none;
}

/* =========================================================
   3. HEADER + NAVBAR
   ========================================================= */
.site-header{
  padding-top:16px;
  position:relative;
  z-index:10;

}

.header-top{
  max-width:1100px;
  margin:0 auto;
  padding:0 16px 8px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.logo-row{
  display:flex;
  align-items:center;
  gap:10px;
}
.logo-mark{
  width: 370px;
  transition:transform .28s ease, filter .28s ease;
}
.logo-mark:hover{
  transform:translateY(-3px) scale(1.03);
  filter:drop-shadow(0 10px 18px rgba(99,44,144,.25));
}

.header-icons{
  display:flex;
  gap:13px;          
  margin-top:16px; 
}

.header-icon{
  display:inline-block;
  background:none;
  border:none;
}

.header-icon img{
  display:block;
  width: 70px;
  height:auto;
  transition:transform .2s ease, filter .2s ease;
}
.header-icon:hover img{
  transform:translateY(-2px) scale(1.05);
  filter:drop-shadow(0 6px 10px rgba(0,0,0,.18));
}

.main-nav-inner{
  max-width:1100px;
  margin:0 auto;
  padding:0 16px;
  display:flex;
  justify-content:flex-end;
  gap:45px;
}
.main-nav a{
  padding:9px 0 8px;
  font-size:1.2rem;
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
  font-weight:400;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  color:var(--magenta);
  border-radius: 2px 15px 
}
.main-nav a.is-active{
  background:var(--azul);
  color:#fff;
  padding:9px 18px 8px;
}
.main-nav a:hover:not(.is-active){
  text-decoration:underline;
}

.main-nav-inner.open{
  display:flex;
}

.nav-toggle{
  display:none;
  background:none;
  border:none;
  font-size:1.6rem;
  color:var(--magenta);
  padding:8px 16px 10px;
  margin-left:auto;
}

@media (max-width:1200px){
  .header-top{
    padding:0 12px 6px;
    gap:10px;
  }
  .logo-mark{
    width:320px;
  }
  .header-icons{
    margin-top:12px;
    gap:10px;
  }
  .header-icon img{
    width:58px;
  }
  .main-nav-inner{
    gap:26px;
  }
}

@media (max-width:1023px){
  .header-top{
    flex-wrap:wrap;
    align-items:flex-start;
    gap:8px;
  }
  .logo-mark{
    width:240px;
  }
  .header-icons{
    margin-top:0;
    flex-wrap:wrap;
    justify-content:flex-end;
    gap:10px;
  }
  .header-icon img{
    width:48px;
  }
  .main-nav-inner{
    gap:18px;
  }
  .main-nav a{
    font-size:1rem;
    padding:8px 0;
  }
}

@media (max-width:767px){
  .header-top{
    justify-content:space-between;
    padding:6px 12px 0;
  }
  .logo-mark{
    width:190px;
  }
  .header-icons{
    width:100%;
    order:2;
    justify-content:flex-start;
    gap:10px;
    padding:6px 0 10px;
    margin-top:0;
  }
  .header-icon img{
    width:38px;
  }
  .main-nav{
    position:relative;
    padding:0 12px 6px;
  }
  .nav-toggle{
    display:block;
    margin-left:auto;
    margin-top:0;
  }
  .main-nav-inner{
    display:none;
    width:100%;
    position:absolute;
    inset:100% 0 auto 0;
    background:#fff;
    flex-direction:column;
    gap:10px;
    padding:10px 12px 14px;
    box-shadow:var(--shadow);
    border-radius:0 0 12px 12px;
  }
  .main-nav-inner.open{
    display:flex;
  }
  .main-nav a{
    display:block;
    padding:8px 4px;
    font-size:1rem;
    text-align:left;
  }
}

@media (max-width:540px){
  .logo-mark{
    width:160px;
  }
  .header-icons{
    justify-content:center;
  }
}

/* =========================================================
   4. INICIO (HERO)
   ========================================================= */
.section-inicio{
  padding-top:36px;
}

.hero{
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
}

.hero-image-frame{
  position:relative;
  border-radius: 81px 0px;
  overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio: 1266 / 752; 
}
.hero-image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.hero-corner{
  position:absolute;
  width:180px; 
  height:auto;
  z-index:3;
  pointer-events:none;
}

.hero-corner--tl{
  top:  -10px;
  left: -10px;
}

.hero-corner--br{
  bottom: -10px;
  right:-10px;
  transform: rotate(180deg);
  transform-origin:center;
}

.hero-corner,
.nosotros-corner,
.servicios-corner,
.trabajos-corner,
.section-contacto .hero-corner{
  opacity:0;
  transform-origin:center;
  clip-path:circle(0% at 50% 50%);
  animation:none;
}

.corner-reveal .hero-corner,
.corner-reveal .nosotros-corner,
.corner-reveal .servicios-corner,
.corner-reveal .trabajos-corner,
.corner-reveal .hero-corner{
  animation:cornerRadialReveal 1s ease-in-out forwards;
  animation-delay:.05s;
}

.corner-reveal .hero-corner--br,
.corner-reveal .nosotros-corner--tr,
.corner-reveal .trabajos-corner--br{
  animation-delay:.18s;
}

@keyframes cornerRadialReveal{
  0%{
    opacity:0;
    clip-path:circle(0% at 50% 50%);
  }
  60%{
    opacity:0.9;
    clip-path:circle(75% at 50% 50%);
  }
  100%{
    opacity:1;
    clip-path:circle(140% at 50% 50%);
  }
}

.hero-badge{
  position: absolute;
  left:50px;
  bottom:-115px;
  max-width:270px;
  height: 256px;
  background:linear-gradient(135deg,rgba(56, 75, 159, 0.774),rgba(99,44,144,.98));
  color:#fff;
  padding:16px 18px 14px;
  border-radius:0px 0px 0px 18px;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
  z-index: 4;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .28s ease, transform .28s ease;
}
.hero-badge-main{
  margin:0 0 7px;
  font-size:1.8rem;
  font-weight:300;
  font-family:"Congenial", system-ui, sans-serif;
  justify-content: center;
  text-align: center;
  text-shadow: #0a0a0a6c;
}
.hero-badge-strong{
  margin:0;
  font-size:1.9rem;
  font-weight:800;
  font-family:"Congenial", system-ui, sans-serif;
  text-align: center;
  text-shadow: #0a0a0a6c;
}

.hero-text{
  position:absolute;
  right: 145px;
  bottom:-136px;
  width:57%;
  background:#ffffff00;
  padding:16px 27px 18px;
  border-radius:18px 0 22px 0;
  display:flex;
  flex-direction:column;
  z-index:3;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .28s ease, transform .28s ease;
}

.hero-copy{
  font-size:1.2rem;
  line-height: 1.2em;
  margin: 20px 0px 2px 0px;
  font-family:"Omnes", system-ui, sans-serif;
  font-weight: 400;
  color: #1c1789;
}

.hero.is-visible .hero-badge,
.hero.is-visible .hero-text{
  opacity:1;
  transform:translateY(0);
}

@media (max-width:1200px){
  .hero-text{
    right:80px;
    width:65%;
  }
  .hero-badge{
    left:32px;
    bottom:-110px;
    max-width:240px;
  }

  .hero-corner{
    width:110px;
  }
}

@media (max-width:1023px){
  .hero{
    padding:0 12px;
  }
  .hero-image-frame{
    border-radius:40px 0;
    aspect-ratio:auto;
  }
  .hero-corner{
    width:110px;
  }
  .hero-corner--tl{
    top:-6px;
    left:2px;
  }
  .hero-corner--br{
    bottom:-6px;
    right:2px;
  }
  .hero-corner,
  .nosotros-corner,
  .servicios-corner,
  .trabajos-corner,
  .section-contacto .hero-corner{
    display:none;
  }
  .hero-image-frame::before,
  .hero-image-frame::after{
    content:none;
  }
  .hero-badge{
    position:static;
    margin:14px auto 0;
    width:100%;
    max-width:520px;
    height:auto;
    padding:14px 16px;
    border-radius:14px;
    text-align:center;
    box-shadow:var(--shadow);
  }
  .hero-text{
    position:static;
    right:auto;
    bottom:auto;
    width:100%;
    margin-top:14px;
    padding:16px 18px;
    border-radius:18px;
    background:#fff;
    box-shadow:var(--shadow);
  }
  .hero-copy{
    font-size:1.08rem;
    line-height:1.48;
  }

  .hero-corner,
  .nosotros-corner,
  .servicios-corner,
  .trabajos-corner,
  .section-contacto .hero-corner{
    display:none;
  }
  .hero-image-frame::before,
  .hero-image-frame::after{
    content:none;
  }
}

@media (max-width:767px){
  .hero{
    padding:0 12px;
  }
  .hero-image-frame{
    border-radius:26px;
  }
  .hero-corner{
    width:78px;
  }
  .hero-corner,
  .nosotros-corner,
  .servicios-corner,
  .trabajos-corner,
  .section-contacto .hero-corner{
    display:none;
  }
  .hero-image-frame::before,
  .hero-image-frame::after{
    content:none;
  }
  .hero-badge{
    position:static;
    margin:12px auto 0;
    width:100%;
    max-width:420px;
    height:auto;
    text-align:center;
    padding:14px 16px 12px;
    border-radius:14px;
  }
  .hero-text{
    position:static;
    width:100%;
    margin-top:12px;
    border-radius:18px;
    box-shadow:var(--shadow);
    background:#fff;
    padding:16px 18px;
  }
  .hero-copy{
    font-size:1rem;
    line-height:1.5;
  }
  .hero-badge-main{
    font-size:1.12rem;
    line-height:1.35;
  }
  .hero-badge-strong{
    font-size:1.2rem;
    line-height:1.35;
  }
}

@media (max-width:540px){
  .hero{
    padding:0 10px;
  }
  .hero-image-frame{
    border-radius:20px;
  }
  .hero-corner{
    width:72px;
  }
  .hero-badge{
    padding:12px 14px;
    border-radius:12px;
  }
  .hero-copy{
    font-size:.98rem;
  }
}

/* =========================================================
   5. NOSOTROS
   ========================================================= */
.section-nosotros{
  padding-top:200px;   
  padding-bottom:10px;
}

.nosotros-frame{
  position:relative;
  max-width:1100px;
  margin:0 auto;
  border-radius: 0px 81px;
  box-shadow:var(--shadow);
  height: 520px;         
}

.nosotros-mask{
  position: relative;
  width:100%;
  height:100%;
  overflow:hidden;     
  border-radius:0px 81px 0px 90px;
}

.nosotros-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.nosotros-watermark{
  position:absolute;
  top:-24px;
  left:1px;
  font-family:"Congenial", system-ui, sans-serif;
  font-weight:700;
  font-size:6.4rem;
  text-transform:lowercase;
  letter-spacing:.06em;
  color:rgba(255, 255, 255, 0.336);    
  text-shadow:0 0 4px rgba(0, 0, 0, 0);
  z-index:2;
  pointer-events:none;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .6s ease, transform .6s ease;
}

.nosotros-corner{
  position: absolute;
  width:180px;
  height:auto;
  z-index: 5;
}

.nosotros-corner--bl{
  bottom:-10px;
  left:-10px;
  transform:rotate(-90deg);
  transform-origin:center;
  z-index: 4;
}

.nosotros-corner--tr{
  top:-12px;
  right:-10px;
  transform:rotate(90deg);
  transform-origin:center;
}

.nosotros-info{
  max-width:1100px;
  margin:-60px auto 0px;
  margin-left: 10px;
  padding:0 40px;
  display:grid;
  grid-template-columns:minmax(0,05fr) minmax(280px,0.85fr);
  column-gap:28px;
  row-gap:10px;
  align-items:flex-start;
  position:relative;
  z-index:5;
}

.nosotros-copy-wrap{
  display:flex;
  flex-direction:column;
  min-height:215px;
  padding:0 10px 0 0;
}

.nosotros-spacer{
  flex:1;
}

.nosotros-badge{
  position:relative;
  width:100%;
  max-width:400px;
  height:auto;
  padding: 18px 22px 16px 14px;
  background:linear-gradient(135deg,rgba(56,75,159,.95),rgba(99,44,144,.98));
  color:#fff;
  border-radius:0px 0px 18px 0px;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
  z-index:4;
  margin-left:auto;
  margin-top:-70px;
  margin-bottom:0;
  align-self:start;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .28s ease, transform .28s ease;
}

.nosotros-badge-main{
  margin:0px;
  font-size:1.54rem;
  font-weight:300;
  font-family:"Congenial", system-ui, sans-serif;
  justify-content: center;
  text-align: right;
  text-shadow: #0a0a0a6c;
}

.nosotros-badge-strong{
  margin:0;
  font-size:1.6rem;
  font-weight:800;
  font-family:"Congenial", system-ui, sans-serif;
  text-align: right;
  text-shadow: #0a0a0a6c;
}

.nosotros-copy{
  position: relative;
  max-width:100%; 
  margin:0;
  padding:0 6px 0 0;
  font-size:1.2rem;
  line-height: 1.45;
  font-family:"Omnes", system-ui, sans-serif;
  font-weight: 400;
  color: #1c1789;
  text-align:left;
  z-index:4;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .28s ease, transform .28s ease;
  
}

.section-nosotros.is-visible .nosotros-badge,
.section-nosotros.is-visible .nosotros-copy{
  opacity:1;
  transform:translateY(0);
}
.section-nosotros.is-visible .nosotros-watermark{
  opacity:1;
  transform:none;
  transition-delay:.08s;
}

@media (max-width:900px){
  .nosotros-info{
    margin:-80px auto 0;
    grid-template-columns:1fr;
    gap:12px;
  }
  .nosotros-copy-wrap{
    min-height:180px;
  }
  .nosotros-frame{
    aspect-ratio:auto;
    border-radius:30px 0;
  }
  .nosotros-watermark{
    font-size:3rem;
    top:16px;
    left:20px;
  }
  .nosotros-corner{
    width:120px;
  }
  .nosotros-badge{
    position:static;
    margin:0;
    width:100%;
    border-radius:0;
    box-shadow:none;
    margin-top:-4px;
  }
}


@media (max-width:1023px){
  .section-nosotros{
    padding-top:140px;
    padding-bottom:40px;
  }
  .nosotros-frame{
    height:auto;
    min-height:auto;
    overflow:hidden;
  }
  .nosotros-info{
    margin:12px auto 0;
    grid-template-columns:1fr;
    gap:10px;
    padding:0 10px;
  }
  .nosotros-copy-wrap{
    min-height:auto;
    padding:0;
  }
  .nosotros-spacer{
    display:none;
  }
  .nosotros-mask{
    height:auto;
  }
  .nosotros-img{
    height:auto;
  }
  .nosotros-watermark{
    font-size:3.6rem;
    color:rgba(255,255,255,0.75);
    top:8px;
    left:14px;
    z-index:4;
  }
  .nosotros-badge{
    position:static;
    margin:10px 0 0;
    width:100%;
    max-width:none;
    height:auto;
    border-radius:14px;
    padding:16px 18px 14px;
    box-shadow:var(--shadow);
  }
  .nosotros-badge-main,
  .nosotros-badge-strong{
    text-align:left;
  }
  .nosotros-copy{
    position:static;
    margin:14px 0 0;
    padding:0 6px;
    max-width:none;
    line-height:1.5;
  }
}

@media (max-width:767px){
  .section-nosotros{
    padding-top:90px;
  }
  .nosotros-frame{
    border-radius:24px 0;
    overflow:hidden;
    height:auto;
  }
  .nosotros-mask{
    border-radius:24px 0;
    height:auto;
  }
  .nosotros-img{
    height:auto;
  }
  .nosotros-watermark{
    font-size:3rem;
    top:12px;
    left:16px;
    color:rgba(255,255,255,0.7);
    z-index:6;
  }
  .nosotros-corner{
    width:110px;
  }
  .nosotros-badge{
    position:static;
    margin:6px 0 0;
    width:100%;
    max-width:none;
    height:auto;
    border-radius:14px;
    padding:16px 18px 14px;
    box-shadow:var(--shadow);
  }
  .nosotros-badge-main{
    font-size:1.18rem;
    line-height:1.4;
  }
  .nosotros-badge-strong{
    font-size:1.25rem;
    line-height:1.4;
  }
  .nosotros-badge-main,
  .nosotros-badge-strong{
    text-align:left;
  }
  .nosotros-copy{
    position:static;
    margin:0;
    padding:0 4px;
    font-size:1rem;
    line-height:1.55;
    color:#1c1789;
  }
}

@media (max-width:540px){
  .nosotros-watermark{
    font-size:2.6rem;
  }
}

/* =========================================================
   6. SERVICIOS
   ========================================================= */

.section-servicios{
  position:relative;
  padding-top:120px;
  padding-bottom:80px;
}
.section-servicios::before{
  content:none;
}

.section-servicios{
  position:relative;
}

.section-servicios .watermark{
  position:absolute;
  font-family:"Congenial", system-ui, sans-serif;
  font-weight:700;
  text-transform:lowercase;
  letter-spacing:.02em;
  pointer-events:none;
  z-index:4;
  margin-top: 20px;
  opacity:0;
  transition:opacity .7s ease;
}

.section-servicios.is-visible .watermark{
  opacity:1;
}
.section-servicios.is-visible .watermark-servi{
  transition-delay:.08s;
}
.section-servicios.is-visible .watermark-cios{
  transition-delay:.16s;
}

.section-servicios .watermark-servi{
  top:124px;
  left:15%;
  font-size:7rem;
  color:#1d178938;
}

.section-servicios .watermark-cios{
  top:124px;
  left:43%;        
  font-size:7rem; 
  color:rgba(255, 255, 255, 0.418);  
}



.servicios-grid{
  max-width:1100px;
  margin: auto;
  display:grid;
  grid-template-columns: minmax(0,0.85fr) minmax(0,1.35fr);
  column-gap:40px;
  align-items:center;
}

.servicios-text{
  position:relative;
  z-index:2;
  top: 15%;
  padding-left: auto;
  padding-bottom: 20%;
  line-height: 1;
}


.servicios-list{
  list-style:none;
  padding:0;
  margin:0;
  font-size:2.2rem;
  font-family:"Congenial","Omnes",system-ui,sans-serif;
  font-weight:300;
  font-stretch:95%;
  letter-spacing:-0.01em;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.servicios-list li{
  margin-bottom:6px;
  text-align: right;
  opacity:0;
  transform:translateX(12px);
  transition:opacity .5s ease, transform .5s ease;
}

.servicios-list li button{
  border:none;
  background:none;
  padding:2px 0;
  margin:0;
  font:inherit;
  text-align:left;
  cursor:pointer;
  color:inherit;
  text-align: right;
  position:relative;
  transition:color .18s ease, transform .18s ease;
}

.servicios-list strong{
  color:var(--azul);
  font-family:"Congenial","Omnes",system-ui,sans-serif;
  font-weight:800;
  font-size: 2.4rem;
  font-stretch:95%;
  letter-spacing:-0.01em;
  position:relative;
  display:inline-block;
  transition:color .18s ease;
}

.servicios-list li.is-active strong{
  color:var(--magenta);
}
.section-servicios.is-visible .servicios-list li{
  opacity:1;
  transform:none;
}
.section-servicios.is-visible .servicios-list li:nth-child(1){ transition-delay:.05s; }
.section-servicios.is-visible .servicios-list li:nth-child(2){ transition-delay:.1s; }
.section-servicios.is-visible .servicios-list li:nth-child(3){ transition-delay:.15s; }
.section-servicios.is-visible .servicios-list li:nth-child(4){ transition-delay:.2s; }
.servicios-list li button:hover,
.servicios-list li button:focus-visible{
  transform:translateY(-2px);
}
.servicios-list li button:hover strong,
.servicios-list li button:focus-visible strong{
  color:var(--magenta);
}

.servicios-visual{
  position:relative;
}

.servicios-collage-frame{
  position:relative;
  margin:0;
  border-radius: 81px 0px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}

.servicios-collage{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}


.servicios-corner{
  position:absolute;
  width:170px;           
  height:auto;
  z-index:3;
  pointer-events:none;
  z-index: 5;
}


.servicios-corner--tl{
  top:-6px;
  left:0%; 
  z-index: 5;            
}

.servicios-corner--br{
  bottom:-8px;
  right:-6px;
  transform:rotate(180deg);
  transform-origin:center;
}

.servicios-visual{
  position:relative;
}

.servicios-collage-frame{
  position:relative;
  margin:0;
  border-radius:81px 0px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}

.servicios-overlay{
  position:absolute;
  inset:0;
  z-index:6;
  display:none;
  border-radius:81px 0px;
  overflow:hidden;
}

.servicios-overlay.is-active{
  display:block;
}

.servicios-overlay-card{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  border-radius:81px 0px;
  overflow:hidden;
  box-shadow:none;
  background:rgba(0,0,0,0.76);
  pointer-events:auto;
}

.servicios-overlay-img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  margin-top:0;
  pointer-events:none;
}

.servicios-overlay-close{
  position:absolute;
  top:14px;
  right:18px;
  width:32px;
  height:32px;
  border-radius:999px;
  border:2px solid #fff;
  background:rgba(0,0,0,0.55);
  color:#fff;
  font-size:1.1rem;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,0.35);
  transition:background .18s ease, transform .18s ease, box-shadow .18s ease;
  z-index:8;
}

.servicios-overlay-close:hover{
  background:var(--magenta);
  transform:scale(1.05);
  box-shadow:0 6px 16px rgba(0,0,0,0.45);
  z-index: 5;
}


@media (max-width:1023px){
  .section-servicios{
    padding-top:90px;
    padding-bottom:70px;
  }
  .section-servicios .watermark-servi,
  .section-servicios .watermark-cios{
    display:none;
  }
  .section-servicios::before{
    content:"servicios";
    position:absolute;
    left:50%;
    top:-12px;
    transform:translateX(-50%);
    font-family:"Congenial", system-ui, sans-serif;
    font-weight:700;
    font-size:7rem;
    letter-spacing:.06em;
    color:rgba(29,23,137,0.32);
    pointer-events:none;
    z-index:4;
    opacity:.65;
    text-transform:lowercase;
  }

  .servicios-grid{
    grid-template-columns:1fr;
    column-gap:0;
    row-gap:24px;
    align-items:flex-start;
  }

  .servicios-visual{
    order:-1;
  }

  .servicios-corner{
    display:none;
  }

  .servicios-list{
    margin:0;
    font-size:1.8rem;
    line-height:1;
    text-align:center;
  }

  .servicios-list li{
    text-align:center;
  }

  .servicios-list strong{
    font-size:1.8rem;
    line-height:1.3;
  }
}

@media (max-width:767px){
  .section-servicios{
    padding-top:65px;
    padding-bottom:60px;
  }
  .section-servicios .watermark-servi,
  .section-servicios .watermark-cios{
    display:none;
  }
  .section-servicios::before{
    content:"servicios";
    position:absolute;
    left:50%;
    top:-22px;
    transform:translateX(-50%);
    font-family:"Congenial", system-ui, sans-serif;
    font-weight:700;
    font-size:3.6rem;
    letter-spacing:.06em;
    color:rgba(29, 23, 137, 0.315);
    pointer-events:none;
    z-index:4;
    opacity:.55;
    text-transform:lowercase;
  }

  .servicios-grid{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
    padding:0 12px;
  }

  .servicios-text{
    top:0;
    padding:6px 10px 0;
    width:100%;
    max-width:520px;
  }

  .servicios-list{
    font-size:1.25rem;
    line-height:1.3;
    text-align:center;
    padding:0;
    gap:6px;
    margin:0;
  }

  .servicios-list li{
    text-align:center;
    margin-bottom:6px;
  }

  .servicios-list strong{
    font-size:1.4rem;
    line-height:1.25;
  }

  .servicios-visual{
    order:-1;
    padding:0;
    margin-bottom:12px;
    width:100%;
    max-width:520px;
    margin-left:auto;
    margin-right:auto;
  }

  .servicios-collage-frame{
    border-radius:18px;
    width:100%;
  }
  .servicios-overlay,
  .servicios-overlay-card{
    border-radius:18px;
  }

  .servicios-corner{
    display:none;
  }


}



/* =========================================================
   7. TRABAJOS (MENÚ + GALERÍA 3×3)
   ========================================================= */
.section-trabajos{
  position: relative; 
  margin-top: -280px;
  margin-bottom: -330px;
  scale: 80%;
}

.section-trabajos .watermark{
  position:absolute;
  top:140px;
  left:200px;
  font-family:"Congenial", system-ui, sans-serif;
  font-weight:700;
  font-size:8rem;
  text-transform:lowercase;
  letter-spacing:.12em;
  color: #1d178927;
  pointer-events:none;
  z-index:5;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .6s ease, transform .6s ease;
}


.trabajos-inner{
  position:relative;             
  background:var(--paper);
  border-radius: 0px 81px;
  border:1px solid var(--ring);
  padding: 30px 35px 22px;
  box-shadow:0 10px 30px rgba(0,0,0,.14);
}

.trabajos-subnav{
  display:flex;
  flex-wrap:wrap;
  gap:50px;
  font-size:.9rem;
  margin-bottom:15px;
}

.trabajos-subnav button{
  border:none;
  background:none;
  padding:0 0 5px;
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
  font-size:2rem;
  font-weight:400;
  color:var(--magenta);
  cursor:pointer;
  position:relative;
  margin-left: 2%;
  opacity:0;
  transform:translateY(10px);
  transition:opacity .45s ease, transform .45s ease;
}

.trabajos-subnav button::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-4px;
  height:3px;
  border-radius:999px;
  background:transparent;
}

.trabajos-subnav button.is-active{
  font-weight:400;
}

.trabajos-subnav button.is-active::after{
  background:var(--magenta);
}

.section-trabajos.is-visible .trabajos-subnav button{
  opacity:1;
  transform:none;
}
.section-trabajos.is-visible .trabajos-subnav button:nth-child(1){ transition-delay:.05s; }
.section-trabajos.is-visible .trabajos-subnav button:nth-child(2){ transition-delay:.1s; }
.section-trabajos.is-visible .trabajos-subnav button:nth-child(3){ transition-delay:.15s; }
.section-trabajos.is-visible .watermark{
  opacity:1;
  transform:none;
  transition-delay:.12s;
}

.trabajos-grid{
  display:grid;
  border-radius: 0px 81px;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin: -30px;
  transition:opacity .22s ease, transform .22s ease;
  opacity:1;
  transform:translateY(0);
  background:var(--paper);
}

.trabajos-grid.is-fading-out{
  opacity:0;
  transform:translateY(10px);
}

.trabajos-grid.is-fading-in{
  opacity:1;
  transform:translateY(0);
}

.trabajos-grid.is-transitioning{
  background:linear-gradient(60deg,
              rgba(255, 0, 153, 0.356),
              rgba(29, 23, 137, 0.808));
  background-size:180% 180%;
  background-position:50% 50%;
  animation:trabajosGradient .65s ease-in-out forwards;
}

.trabajo-card{
  position:relative;
  overflow:hidden;
  margin:0;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  aspect-ratio:1 / 1;
  opacity:0;
  transform:translateY(8px);
  animation:trabajoFadeUp .35s ease-in-out forwards;
  animation-delay:var(--stagger, 0ms);
  will-change:transform, opacity;
}

.trabajo-card > img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .35s ease;
}

.trabajo-card:hover > img{
  transform:scale(1.04);
}

.trabajo-zoom{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(circle at center,
             #1d178960,
            #1d1789b9);
  opacity:0;
  border:none;
  cursor:pointer;
  transition:opacity .25s ease;
}

.trabajo-card.corner-tr{
  border-top-right-radius:81px;
}
.trabajo-card.corner-tr .trabajo-zoom{
  border-top-right-radius:81px;
}
.trabajo-card.corner-bl{
  border-bottom-left-radius:81px;
}
.trabajo-card.corner-bl .trabajo-zoom{
  border-bottom-left-radius:81px;
}

.trabajo-card:hover .trabajo-zoom{
  opacity:1;
}

@keyframes trabajoFadeUp{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes trabajosGradient{
  0%{
    background-position:30% 50%;
  }
  50%{
    background-position:70% 50%;
  }
  100%{
    background-position:50% 50%;
  }
}

.trabajo-zoom-img{
  display:block;
  width:120px;
  height:auto;
  max-width:70%;
  max-height:70%;
  object-fit:contain;
}

.trabajos-frase{
  text-align:center;
  margin-top:26px;
  margin-bottom:0;
  max-width:800px;
  margin-left:auto;
  margin-right:auto;
  font-family:"Congenial","Omnes",sans-serif;
  font-weight:400;
  font-size:2.6rem;
  line-height:1.32;
  font-stretch:95%;
  letter-spacing:-0.01em;
  color:var(--azul);
}

.trabajos-frase strong{
  font-family:"Congenial","Omnes",sans-serif;
  font-weight:700;
  color:var(--azul);
}

.trabajos-corner{
  position:absolute;
  width:170px;
  height:auto;
  z-index:5;
  pointer-events:none;
}

.trabajos-corner--tl{
  bottom:-23px;
  left:-2px;
  transform:rotate(-90deg);
  transform-origin:center;
}

.trabajos-corner--br{
  top:-10px;
  right:-2px;
  transform:rotate(90deg);
  transform-origin:center;
}

.trabajos-modal{
  position:fixed;
  inset:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .24s ease, visibility .24s ease;
}

.trabajos-modal.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.trabajos-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0, 0, 0, 0.712);
}

.trabajos-modal-dialog{
  position:relative;
  transform:scale(.94);
  width:80vw;
  max-width:1100px;
  max-height:88vh;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 18px 48px rgba(0, 0, 0, 0);
  background:#00000000;
  opacity:0;
  transition:transform .24s ease, opacity .24s ease;
  position:relative;
}

.trabajos-modal.is-open .trabajos-modal-dialog{
  transform:scale(1);
  opacity:1;
}

.trabajos-modal-img{
  display:block;
  width:100%;
  height:auto;
  max-height:82vh;
  object-fit:contain;
  background:none;
}

.trabajos-modal-close{
  position:absolute;
  top:12px;
  left:890px;
  width:36px;
  height:36px;
  border-radius:999px;
  border:2px solid #fff;
  background:rgba(0, 0, 0, 0.65);
  color:#fff;
  font-size:1.1rem;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,0.35);
  transition:background .18s ease, transform .18s ease, box-shadow .18s ease;
  z-index: 9;
}

.trabajos-modal-close:hover{
  background:var(--magenta);
  transform:scale(1.05);
  box-shadow:0 6px 16px rgba(0,0,0,0.45);
}

@media (max-width:1024px){
  .section-trabajos{
    margin-top:-40px;
    margin-bottom:40px;
    scale: 92%;
  }
  .trabajos-inner{
    padding:20px 18px 16px;
  }
  .trabajos-grid{
    display:grid;
    grid-template-columns:none;
    grid-auto-flow:column;
    grid-auto-columns:78%;
    grid-auto-rows:1fr;
    gap:14px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    padding:10px 6px 14px;
    margin:0;
    border-radius:18px;
    -webkit-overflow-scrolling:touch;
  }
  .trabajo-card{
    scroll-snap-align:start;
    border-radius:18px;
  }
  .trabajos-modal-dialog{
    width:90vw;
    max-width:90vw;
    max-height:90vh;
  }
  .trabajos-modal-close{
    top:10px;
    right:10px;
  }
  .trabajos-subnav button{
    font-size:1.5rem;
  }
  .section-trabajos .watermark{
    font-size:5.5rem;
    top:14px;
    left:20px;
  }
}

@media (max-width:767px){
  .section-trabajos{
    margin-top:-70px;
    margin-bottom: 20px;
  }
  .trabajos-subnav{
    justify-content:center;
    gap:22px;
  }
  .trabajos-subnav button{
    font-size:1.3rem;
    margin-left:0;
    white-space:nowrap;
    padding: 6px 0px;
  }
  .trabajos-grid{
    display:grid;
    grid-template-columns:none;
    grid-auto-flow:column;
    grid-auto-columns:80%;
    grid-auto-rows:1fr;
    gap:12px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    padding:10px 6px 12px;
    margin:0;
    border-radius:18px;
    -webkit-overflow-scrolling:touch;
  }
  .trabajo-card{
    scroll-snap-align:start;
    border-radius:18px;
    min-height:220px;
  }
  .trabajos-inner{
    padding:18px 14px;
  }
  .trabajos-modal-dialog{
    width:92vw;
    max-width:92vw;
    max-height:90vh;
  }
  .trabajos-modal-close{
    top:10px;
    right:10px;
  }
  .trabajos-corner{
    display:none;
  }
  .trabajos-frase{
    font-size:1.2rem;
    line-height:1.3;
    padding:0 8px;
    margin:14px 4px 0;
    background:transparent;
    border-radius:0;
  }
  .section-trabajos .watermark{
    font-size:3.4rem;
    top:6px;
    left:10px;
  }
}

/* =========================================================
   8. CONSULTAS
   ========================================================= */
.section-consultas{
  position:relative;
  padding-top:120px;
  padding-bottom:90px;
  margin-top: -140px;
}


.watermark-consultas{
  position:absolute;
  top:4px;
  left:50%;
  transform:translateX(-50%);
  font-family:"Congenial", system-ui, sans-serif;
  font-weight:700;
  font-size:7rem;
  text-transform:lowercase;
  letter-spacing:.12em;
  color:#1d178941;
  pointer-events:none;
  z-index:0;
}

.consultas-frame{
  position:relative;
  max-width:1100px;
  margin:0 auto;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
  z-index:1;
}

.consultas-img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}

.consultas-overlay{
  position:absolute;
  left:50%;
  top:19%;
  transform:translate(-50%, -50%);
  width:87%;
  padding:18px 26px;
  background:linear-gradient(135deg,
              rgba(56, 75, 159, 0.527),
              rgba(99, 44, 144, 0.712));
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index: 3;
}

.consultas-text{
  margin:0;
  font-family:"Congenial", system-ui, sans-serif;
  font-weight:700;
  font-size:1.5rem;
  line-height:1.4;
  text-align:center;
  color:#fff;
}

.consultas-icons{
  margin-top:26px;
  display:flex;
  justify-content:center;
  gap:22px;
  border-radius:999px;
}



.consultas-icon img{
  display:block;
  width:70px;
  height:70px;
  object-fit:contain;
  margin-top: 30px;
  transition:transform .2s ease, filter .2s ease;
}
.consultas-icon:hover img{
  transform:translateY(-2px) scale(1.05);
  filter:drop-shadow(0 6px 10px rgba(0,0,0,.18));
}



.consultas-link{
  display:block;
  max-width:1100px;
  margin:0 auto;
  text-decoration:none;
}

.consultas-frame{
  transition:transform .18s ease, box-shadow .18s ease;
}

.consultas-link:hover .consultas-frame{
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(0,0,0,.3);
}


@media (max-width:900px){
  .section-consultas{
    padding-top:80px;
    padding-bottom:70px;
  }

  .watermark-consultas{
    font-size:3.6rem;
    top:12px;
  }

  .consultas-overlay{
    width:88%;
    padding:14px 18px;
  }

  .consultas-text{
    font-size:1rem;
  }

  .consultas-icon{
    width:44px;
    height:44px;
  }

  .consultas-icon img{
    width:20px;
    height:20px;
  }
}

@media (max-width:1024px){
  .section-consultas{
    margin-top:-100px;
    padding-bottom:80px;
  }
  .consultas-overlay{
    width:80%;
  }

}

@media (max-width:767px){
  .section-consultas{
    margin-top:-60px;
    padding-top:70px;
    padding-bottom:70px;
  }
  .consultas-overlay{
    width:92%;
    padding:12px 14px;
  }
  .consultas-text{
    font-size:1.05rem;
  }
  .consultas-icons{
    gap:16px;
  }
  .consultas-icon img{
    width:56px;
    height:56px;
    margin-top:12px;
  }
}

@media (max-width:540px){
  .consultas-overlay{
    width:100%;
  }
  .consultas-text{
    font-size:1rem;
  }
}

/* =========================================================
   CONTACTO · LANDPAGE
   ========================================================= */

.section-contacto .hero{
  position:relative;
  max-width:1100px;
  margin:0 auto;
}

.section-contacto .hero-image-frame{
  position:relative;
  border-radius:81px 0px;
  overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio:auto;
}

.section-contacto .hero-image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.section-contacto .hero-corner{
  position:absolute;
  width:170px;
  height:auto;
  z-index:3;
  pointer-events:none;
}
.section-contacto .hero-corner--tl{
  top:-14px;
  left:-14px;
}

.section-contacto .hero-corner--br{
  bottom:-14px;
  right:-14px;
  transform:rotate(180deg);
  transform-origin:center;
}

.section-contacto .hero-badge{
  position:absolute;
  left:50px;
  bottom:-90px; 
  max-width:400px;
  height:170px;
  background:linear-gradient(135deg,rgba(56, 75, 159, 0.774),rgba(99,44,144,.98));
  color:#fff;
  padding:16px 18px 14px;
  border-radius:0px 0px 0px 18px;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
  z-index:4;
}

.contact-qa{
  max-width:1100px;
  margin:10px auto 0;
  padding:0 8px;
  display:flex;
  flex-direction:column;
  gap:32px;
  margin-top:150px;
}

.contact-question{
  font-family:"Omnes",system-ui,sans-serif;
  font-weight:400;
  font-size: 8rem;
  border-bottom:1px solid rgba(0,0,0,.06);
  padding-bottom:10px;
  
}

.contact-accordion-toggle{
  width:100%;
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 0;
  background:none;
  border:none;
  cursor:pointer;
  text-align:left;
  color:var(--azul);
  font-size:2.5rem;
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
  font-weight:400;
  line-height:1.05;
}

.contact-accordion-toggle:focus-visible{
  outline:20px solid var(--magenta);
  outline-offset:20px;
}

.contact-question-sign{
  font-family:"Omnes", system-ui, sans-serif;
  font-weight:400;
  font-size:4rem;
  color:var(--magenta);
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  transform:translateY(1px);
}

.contact-accordion-toggle span:not(.contact-question-sign){
  display:flex;
  align-items:center;
  line-height:1.1;
}

.contact-accordion-toggle::after{
  content:"▾";
  margin-left:auto;
  font-size:4rem;
  color:var(--magenta);
  transition:transform .2s ease;
}

.contact-accordion-toggle[aria-expanded="true"]::after{
  transform:rotate(180deg);
}

.contact-accordion-panel{
  padding:6px 2px 4px;
  font-size:1.8rem;
  line-height:1.5;
  color: #1c1789;
}

.contact-accordion-panel[hidden]{
  display:none;
}

.contact-question-sub{
  margin:0 0 10px;
  font-weight:600;
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
}

.contact-question-body p{
  margin:0 0 8px;
}

.contact-question-cta{
  margin-top:10px;
  font-weight:400;
  color:var(--azul);
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
}

.contact-question-contact{
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  margin-top:6px;
  font-style:normal;
  font-size:1rem;
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
}

.contact-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,0.1);
  background:#fff;
  color:var(--azul);
  text-decoration:none;
  cursor:pointer;
  font-style:normal;
  font-family:"Omnes","Segoe UI",system-ui,sans-serif;
  font-weight:400;
  transition:background .2s ease, box-shadow .2s ease, color .2s ease, border-color .2s ease;
}

.contact-chip:hover{
  background:var(--magenta);
  color:#fff;
  border-color:transparent;
  box-shadow:0 6px 14px rgba(0,0,0,0.18);
}

.contact-intro{
  max-width:1100px;
  margin:26px auto 0;
  padding:0 8px;
}

.contact-intro-card{
  border-radius:22px 0 22px 0;
  background:#ffffff;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  padding:24px 30px;
  text-align:center;
}

.contact-intro-title{
  margin:0 0 10px;
  font-family:"Omnes", system-ui, sans-serif;
  font-style:italic;
  font-size:2rem;
  color:var(--azul);
}

.contact-intro-text{
  margin:0;
  font-family:"Omnes", system-ui, sans-serif;
  font-style:italic;
  font-size:1.5rem;
  line-height:1.5;
}

.contact-form-section{
  max-width:1100px;
  margin:18px auto 0;
  padding:0 8px 40px;
}

.contact-form{
  border-radius:22px 0 22px 0;
  background:#ffffff;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
  padding:26px 30px 30px;
}

.contact-form-row{
  display:flex;
  gap:26px;
  margin-bottom:18px;
}

.contact-field{
  flex:1;
}

.contact-field--full{
  flex-basis:100%;
}

.contact-field label{
  display:block;
  font-size:1.3rem;
  font-family:"Omnes", system-ui, sans-serif;
  margin-bottom:4px;
  color:var(--ink);
}

.contact-field label span{
  color:var(--magenta);
}

.contact-field input,
.contact-field select,
.contact-field textarea{
  width:100%;
  border:none;
  border-bottom:1px solid #b9b9b9;
  padding:6px 2px;
  font-family:"Omnes", system-ui, sans-serif;
  font-size:.9rem;
  background:transparent;
  outline:none;
}

.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus{
  border-bottom-color:var(--magenta);
}

.contact-form-actions{
  margin-top:10px;
  text-align:center;
}

.contact-submit{
  display:inline-block;
  padding:8px 40px;
  border-radius:999px;
  border:2px solid var(--ink);
  background:#ffffff;
  font-family:"Omnes", system-ui, sans-serif;
  font-size:1.2rem;
  cursor:pointer;
  transition:background .18s ease, color .18s ease, box-shadow .18s ease;
}

.contact-submit:hover{
  background:var(--ink);
  color:#ffffff;
  box-shadow:0 8px 20px rgba(0,0,0,.25);
}

.contact-form-note{
  margin:10px 0 0;
  text-align:center;
  font-family:"Omnes", system-ui, sans-serif;
  font-size:0.95rem;
  color:var(--gris);
}

.contact-form-note a{
  color:var(--azul);
}

.contact-bottom-icons{
  padding-bottom:40px;
}

@media (max-width:900px){
  .contact-qa{
    margin-top:120px;
  }

  .section-contacto .hero-image-frame{
    width:100%;
    aspect-ratio:16 / 9;
    height:auto;
    min-height:0;
  }

  .contact-question{
    font-size:3rem;
    padding-bottom:6px;
  }
  .contact-accordion-toggle{
    font-size:1.4rem;
    gap:6px;
  }
  .contact-question-sign{
    font-size:2.2rem;
    transform:none;
  }
  .contact-accordion-toggle::after{
    font-size:1.8rem;
  }

  .contact-form-row{
    flex-direction:column;
    gap:12px;
  }

  .contact-intro-card,
  .contact-form{
    padding:20px 18px 24px;
  }
}

@media (max-width:767px){
  .contact-qa{
    margin-top:80px;
    gap:20px;
    padding:0 12px;
  }
  .contact-question{
    font-size:2.2rem;
    padding-bottom:4px;
  }
  .contact-accordion-toggle{
    font-size:1.1rem;
    gap:6px;
  }
  .contact-accordion-toggle::after{
    font-size:1.4rem;
  }
  .contact-question-sign{
    font-size:1.8rem;
    transform:none;
  }
  .contact-accordion-panel{
    font-size:1rem;
  }
  .contact-intro{
    padding:0 12px;
  }
  .contact-intro-text{
    font-size:1.05rem;
  }
  .contact-form-section{
    padding:0 12px 32px;
  }
  .contact-submit{
    width:100%;
  }
  .contact-bottom-icons .consultas-icons{
    gap:14px;
  }

  .section-contacto .hero{
    padding:0 8px;
  }
  .section-contacto .hero-image-frame{
    width:100%;
    aspect-ratio:16 / 9;
    min-height:0;
    border-radius:20px;
  }
  .section-contacto .hero-badge{
    position:static;
    margin:12px auto 0;
    width:100%;
    max-width:420px;
    height:auto;
    text-align:center;
    padding:14px 16px 12px;
    border-radius:14px;
  }
  .section-contacto .hero-corner{
    display:none;
  }
}

.whatsapp-float{
  position:fixed;
  left:18px;
  bottom:18px;
  width:60px;
  height:60px;
  border-radius:999px;
  background:#25d366;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 24px rgba(0,0,0,.2);
  z-index:999;
  transition:transform .2s ease, box-shadow .2s ease;
}

.whatsapp-float img{
  width:62%;
  height:62%;
  object-fit:contain;
}

.whatsapp-float:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 28px rgba(0,0,0,.24);
}

@media (max-width:640px){
  .whatsapp-float{
    width:52px;
    height:52px;
    left:14px;
    bottom:14px;
  }
}
