/*
  Landing Digitalización · Aareon / IESA
  Assets:
  - assets/aareon-logo.svg
  - assets/hero-gesfincas-ia.png
  - assets/human-in-the-loop.png
  - assets/icono-casa.svg
  - assets/icono-seguridad.svg
  - assets/icono-areas.svg
  - assets/icono-verificacion.svg
*/

:root{
  --navy:#202a63;
  --navy-form:#222a68;
  --ink:#080b19;
  --ink-soft:#303240;
  --muted:#60626f;
  --coral:#ff755f;
  --royal:#1177ff;
  --royal-strong:#005ee8;
  --cream:#f4f0ea;
  --cream-card:#f5f1ed;
  --white:#ffffff;

  --font-display:'Canela','Cormorant Garamond',Georgia,'Times New Roman',serif;
  --font-body:'Basis Grotesque','Basis',Inter,'Helvetica Neue',Arial,sans-serif;

  --maxw:1440px;
  --pad:clamp(16px,3.2vw,44px);

  --radius-card:24px;
  --radius-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --hero-grad:linear-gradient(112deg,#2645ae 0%,#5552a0 30%,#906188 60%,#e9a69a 100%);
  --soft-shadow:0 26px 70px -42px rgba(22,29,70,.55);
}



*{box-sizing:border-box;}
.d-none {display: none !important;}
.alert {font-size: smaller; color: var(--coral)}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;max-width:100%;overflow-x:hidden;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.46;
  color:var(--ink);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  max-width:100%;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;}
button,input{font:inherit;}
button{cursor:pointer;}

.wrap{width:min(100%,var(--maxw));max-width:100%;margin-inline:auto;padding-inline:var(--pad);}
.display{font-family:var(--font-display);font-weight:500;line-height:1.05;letter-spacing:-.015em;}
.eyebrow{margin:0 0 14px;color:var(--coral);font-weight:700;font-size:.88rem;}
.lead{max-width:72ch;margin:0;color:var(--ink-soft);font-size:1.08rem;}

.skip-link{
  position:absolute;left:16px;top:10px;z-index:999;
  transform:translateY(-140%);
  background:#fff;color:var(--navy);padding:10px 14px;border-radius:10px;
}
.skip-link:focus{transform:none;}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px) saturate(140%);
  border-bottom:1px solid rgba(8,11,25,.05);
}
.header-inner{height:72px;display:flex;align-items:center;justify-content:center;}
.brand-logo{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;}
.brand-logo img{width:142px;height:auto;display:block;}

/* Hero */
.hero{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  color:#fff;
  background:var(--hero-grad);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(62% 82% at 92% 20%, rgba(255,255,255,.22), transparent 55%),
    radial-gradient(56% 70% at 4% 100%, rgba(8,24,94,.35), transparent 62%);
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);
  align-items:end;
  gap:clamp(26px,4.4vw,64px);
  min-height:520px;
  padding-block:clamp(34px,5vw,70px) 0;
}
.hero-copy{
  position:relative;
  z-index:2;
  align-self:center;
  max-width:560px;
  padding-bottom:clamp(16px,3.3vw,44px);
  min-width:0;
  width:100%;
}
.hero h1{margin:0 0 24px;font-size:clamp(2.45rem,4.35vw,3.85rem);max-width:100%;overflow-wrap:break-word;}
.hero p{margin:0 0 32px;max-width:40ch;color:rgba(255,255,255,.94);font-size:1.1rem;overflow-wrap:break-word;}
.hero-visual{
  position:relative;
  align-self:end;
  min-height:0;
  display:flex;
  align-items:flex-end;
  justify-content:center;
}
.hero-visual img{
  width:clamp(560px,48vw,780px);
  max-width:none;
  height:auto;
  margin-right:clamp(-70px,-3.5vw,-16px);
  margin-bottom:-1px;
  filter:drop-shadow(0 34px 34px rgba(0,0,0,.16));
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  min-height:54px;padding:15px 34px;border:0;border-radius:var(--radius-pill);
  font-weight:700;text-decoration:none;line-height:1;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease);
}
.btn-primary{background:var(--royal);color:#fff;box-shadow:0 16px 32px -18px rgba(0,0,0,.85);}
.btn-primary:hover{background:var(--royal-strong);transform:translateY(-2px);}
.btn .arrow{transition:transform .25s var(--ease);}
.btn:hover .arrow{transform:translateX(4px);}

/* Sections */
.section{padding-block:clamp(54px,6.1vw,84px);}
#por-que-importa{padding-bottom:clamp(34px,4.6vw,62px);}
#punto-de-partida{padding-top:clamp(32px,4vw,54px);}
#metodologia{padding-block:clamp(54px,6vw,80px);}
#adopcion{padding-block:clamp(48px,5.6vw,76px);}
.section-cream{background:var(--cream);}
.section-head{margin-bottom:38px;}
.section-head h2{margin:0 0 18px;font-size:clamp(2rem,3.45vw,3rem);max-width:1120px;}
.section-head .eyebrow,
.method-copy .eyebrow,
.adoption-copy .eyebrow{color:var(--coral);}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px 30px;}
.card{
  background:var(--cream-card);
  border-radius:var(--radius-card);
  padding:34px 38px 36px;
  min-height:176px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.card-wide{grid-column:1 / -1;min-height:unset;}
.card-icon{width:38px;height:38px;object-fit:contain;margin-bottom:22px;}
.card h3{margin:0 0 10px;font-size:1.17rem;line-height:1.2;}
.card p{margin:0;color:var(--ink-soft);font-size:1.02rem;max-width:68ch;}
.card-wide p{max-width:106ch;}

/* Digital maturity */
.levels{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(22px,3.7vw,58px);
  margin-top:34px;
}
.level-track{position:relative;height:18px;margin-bottom:18px;}
.level-track::before{content:"";position:absolute;left:0;right:0;top:50%;height:5px;border-radius:999px;background:#d7d9de;transform:translateY(-50%);}
.level-fill{position:absolute;left:0;top:50%;height:5px;width:0;border-radius:999px;background:var(--royal);transform:translateY(-50%);transition:width 1s var(--ease);}
.level-dot{position:absolute;left:0;top:50%;width:18px;height:18px;border-radius:50%;background:var(--royal);border:5px solid #dcecff;box-shadow:0 3px 9px rgba(17,119,255,.35);transform:translate(-50%,-50%) scale(.5);opacity:0;transition:left 1s var(--ease),opacity .45s var(--ease),transform .45s var(--ease);}
.is-visible .level-dot{opacity:1;transform:translate(-50%,-50%) scale(1);}
.level h3{margin:0 0 4px;font-size:1.08rem;line-height:1.15;}
.level p{margin:0;color:#333641;font-size:.96rem;line-height:1.28;}

/* Methodology */
.method-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:clamp(20px,3vw,38px);
  align-items:start;
}
.method-copy h2{margin:0 0 24px;font-size:clamp(2rem,3.15vw,2.8rem);}
.method-copy p:not(.eyebrow){max-width:38ch;margin:0 0 16px;color:var(--ink-soft);}
.method-copy strong{color:var(--ink);font-weight:700;}
.steps{
  position:relative;
  margin:0;
  padding:0;
  list-style:none;
  counter-reset:step;
}
.step{
  counter-increment:step;
  position:relative;
  display:grid;
  grid-template-columns:38px 1fr;
  gap:14px;
  padding-bottom:34px;
}
.step:last-child{padding-bottom:0;}
.step::before{
  content:counter(step);
  position:relative;
  z-index:2;
  width:38px;
  height:38px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--royal);
  color:#fff;
  font-weight:700;
  font-size:.96rem;
  box-shadow:0 8px 18px -11px rgba(17,119,255,.75);
  transform:scale(.5);
  opacity:0;
  transition:transform .28s var(--ease),opacity .28s var(--ease);
}
.step:not(:last-child)::after{
  content:"";
  position:absolute;
  left:18px;
  top:38px;
  bottom:0;
  width:2px;
  background:#bcc8e9;
  transform:scaleY(0);
  transform-origin:top;
  transition:transform .32s var(--ease);
}
.steps.is-visible .step::before{transform:scale(1);opacity:1;}
.steps.is-visible .step:not(:last-child)::after{transform:scaleY(1);}
.steps.is-visible .step:nth-child(1)::before{transition-delay:.02s;}
.steps.is-visible .step:nth-child(1)::after{transition-delay:.10s;}
.steps.is-visible .step:nth-child(2)::before{transition-delay:.18s;}
.steps.is-visible .step:nth-child(2)::after{transition-delay:.26s;}
.steps.is-visible .step:nth-child(3)::before{transition-delay:.34s;}
.steps.is-visible .step:nth-child(3)::after{transition-delay:.42s;}
.steps.is-visible .step:nth-child(4)::before{transition-delay:.50s;}
.step h3{margin:0 0 8px;font-size:1.08rem;}
.step p{margin:0;color:var(--ink-soft);max-width:58ch;}

/* Human in the loop */
.adoption-grid{
  display:grid;
  grid-template-columns:minmax(260px,.62fr) minmax(0,0.8fr);
  gap:clamp(28px,5vw,70px);
  align-items:center;
}
.hil-visual{display:flex;align-items:center;justify-content:center;min-width:0;}
.hil-image{width:100%;max-width:340px;max-height:340px;height:auto;object-fit:contain;object-position:center;margin-inline:auto;}
.adoption-copy{min-width:0;}
.adoption-copy h2{margin:0 0 24px;font-size:clamp(2rem,3.35vw,3rem);max-width:18ch;}
.adoption-copy p:not(.eyebrow){max-width:64ch;margin:0 0 20px;color:var(--ink-soft);font-size:1.08rem;}

/* CTA */
.cta{background:var(--hero-grad);color:#fff;text-align:center;padding-block:clamp(58px,7.4vw,92px);}
.cta h2{margin:0 0 16px;font-size:clamp(2rem,3.25vw,2.8rem);}
.cta p{margin:0 auto;max-width:52ch;color:rgba(255,255,255,.9);font-size:1.08rem;}

/* Contact */
.contact{background:var(--navy-form);color:#fff;padding-block:clamp(58px,6.6vw,86px);}
.contact-grid{display:grid;grid-template-columns:minmax(260px,.66fr) minmax(0,1.34fr);gap:clamp(38px,6vw,76px);}
.contact-copy h2{margin:0 0 14px;font-size:clamp(2rem,3.1vw,2.75rem);}
.contact-copy p{margin:0;max-width:34ch;color:rgba(255,255,255,.84);font-size:1.06rem;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px 32px;}
.field{display:flex;flex-direction:column;}
.field-full{grid-column:1 / -1;max-width:50%;padding-right:16px;}
.field label{margin:0 0 8px;color:#fff;font-size:1rem;}
.field input{width:100%;height:42px;border:0;border-radius:var(--radius-pill);background:#fff;color:var(--ink);padding:0 18px;outline:none;box-shadow:none;}
.field input:focus{box-shadow:0 0 0 4px rgba(17,119,255,.38);}
.field input.is-invalid{box-shadow:0 0 0 3px #ff9b8a;}
.field-collapsible{overflow:hidden;max-height:0;opacity:0;transform:translateY(18px);transition:max-height .38s var(--ease),opacity .32s var(--ease),transform .32s var(--ease);}
.field-collapsible.is-visible{max-height:96px;opacity:1;transform:none;}
.radio-group{display:flex;gap:12px;flex-wrap:wrap;}
.radio-option{display:flex;align-items:center;gap:9px;margin:0;color:#fff;cursor:pointer;}
.radio-option input{appearance:none;width:18px;height:18px;padding:0;border:1px solid rgba(255,255,255,.58);border-radius:50%;background:rgba(255,255,255,.18);box-shadow:none;outline:none;}
.radio-option input:checked{border-color:#fff;background:radial-gradient(circle at center,var(--coral) 0 42%,#fff 45% 100%);}
.radio-option input:focus{box-shadow:none;}
.radio-option input:focus-visible + span{outline:1px solid rgba(255,255,255,.45);outline-offset:4px;border-radius:4px;}
.checks{grid-column:1 / -1;display:grid;gap:18px;margin-top:18px;}
.check{display:flex;align-items:flex-start;gap:18px;color:#fff;font-size:1rem;line-height:1.35;cursor:pointer;}
.check input{position:absolute;opacity:0;pointer-events:none;}
.check-box{width:23px;height:23px;flex:0 0 23px;border-radius:6px;background:#fff;display:grid;place-items:center;margin-top:-1px;box-shadow:0 0 0 0 rgba(255,155,138,0);transition:box-shadow .2s var(--ease),background .2s var(--ease);}
.check-box svg{width:15px;height:15px;opacity:0;transform:scale(.55);color:var(--royal);transition:opacity .16s var(--ease),transform .16s var(--ease);}
.check input:checked + .check-box svg{opacity:1;transform:scale(1);}
.check input:focus-visible + .check-box{box-shadow:0 0 0 4px rgba(255,255,255,.35);}
.check.is-invalid .check-box{box-shadow:0 0 0 3px #ff9b8a;}
.check a{text-underline-offset:3px;}
.form-actions{grid-column:1 / -1;margin-top:4px;}
.btn-light{background:#fff;color:var(--navy);min-width:132px;}
.btn-light:hover{transform:translateY(-2px);background:#f4f5ff;}
.btn[disabled]{opacity:.7;cursor:progress;transform:none;}
.form-note{grid-column:1 / -1;margin:18px 0 0;max-width:760px;color:rgba(255,255,255,.68);font-size:.72rem;line-height:1.42;}
.form-note a{color:rgba(255,255,255,.9);}
/* Footer copied visually from news.iesa.es/s/gesfincas-net */
.footer-site{
  background:#000;
  color:#fff;
  font-size:.82rem;
  line-height:1.2;
}
.footer-site__inner{
  width:min(100%,var(--maxw));
  min-height:31px;
  margin-inline:auto;
  padding:7px var(--pad);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
}
.footer-site a{color:#fff;text-decoration:none;}
.footer-site a:hover{text-decoration:underline;text-underline-offset:3px;}
.footer-site__copy{justify-self:start;white-space:nowrap;}
.footer-site__contact{
  justify-self:center;
  display:flex;
  align-items:center;
  gap:26px;
  white-space:nowrap;
}
.footer-site__links{
  justify-self:end;
  display:flex;
  align-items:center;
  gap:24px;
  white-space:nowrap;
}

/* Animations */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
.hero .reveal{transition-delay:.08s;}
.hero-copy .reveal:nth-child(2){transition-delay:.18s;}
.hero-copy .reveal:nth-child(3){transition-delay:.28s;}
.hero-visual.reveal{transition-delay:.24s;}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;min-height:unset;padding-bottom:0;}
  .hero-copy{max-width:640px;padding-bottom:0;}
  .hero p{max-width:min(100%,48ch);}
  .hero-visual{margin-top:6px;}
  .hero-visual img{
    width:min(640px,96vw);
    margin:0 auto -1px;
  }
  .hil-visual{order:2;}
  .method-grid,.adoption-grid,.contact-grid{grid-template-columns:1fr;}
  .method-grid{gap:22px;}
  .method-copy p:not(.eyebrow),
  .step p{max-width:100%;}
  .adoption-grid{gap:26px;}
  .hil-image{max-width:310px;max-height:310px;}
  .field-full{max-width:100%;padding-right:0;}
}
@media (max-width:860px){
  .footer-site__inner{
    grid-template-columns:1fr;
    justify-items:center;
    gap:8px;
    padding-block:14px;
    text-align:center;
  }
  .footer-site__copy,
  .footer-site__contact,
  .footer-site__links{justify-self:center;flex-wrap:wrap;justify-content:center;}
}
@media (max-width:760px){
  .header-inner{height:66px;}
  .brand-logo img{width:124px;}
  .hero-grid{grid-template-columns:1fr;gap:18px;padding-top:32px;min-height:auto;}
  .hero-copy{max-width:100%;width:100%;}
  .hero h1{font-size:clamp(2rem,7vw,2.45rem);line-height:1.08;max-width:100%;}
  .hero p{max-width:min(100%,38ch);font-size:1rem;line-height:1.38;margin-bottom:24px;}
  .hero-visual img{width:min(560px,98vw);max-width:none;margin:0 auto -1px;}
  .cards{grid-template-columns:1fr;}
  .card-wide{grid-column:auto;}
  .levels{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:28px;}
  .level{background:var(--cream-card);border-radius:20px;padding:20px 20px 22px;box-shadow:0 18px 44px -36px rgba(22,29,70,.45);}
  .level-track{margin-bottom:16px;}
  .adoption-grid{gap:18px;align-items:start;}
  .adoption-copy{order:1;}
  .hil-image{max-width:300px;max-height:auto;}
  .adoption-copy h2{max-width:28ch;font-size:clamp(1.9rem,5.4vw,2.45rem);margin-bottom:18px;}
  .adoption-copy p:not(.eyebrow){max-width:100%;font-size:1rem;line-height:1.42;margin-bottom:16px;}
  .form-grid{grid-template-columns:1fr;}
  .field-full{grid-column:auto;max-width:100%;padding-right:0;}
}
@media (max-width:560px){
  :root{--pad:18px;}
  .hero-grid{padding-top:26px;gap:14px;}
  .hero-copy{max-width:100%;width:100%;overflow:hidden;}
  .hero h1{font-size:clamp(1.72rem,7.2vw,2.05rem);line-height:1.08;margin-bottom:16px;}
  .hero p{max-width:min(100%,34ch);font-size:.94rem;line-height:1.34;margin-bottom:20px;}
  .hero .btn{min-height:50px;padding:14px 24px;font-size:.96rem;}
  .hero-visual img{width:min(500px,102vw);max-width:none;margin-left:-1vw;margin-right:-1vw;margin-bottom:-1px;}
  .section{padding-block:42px;}
  #por-que-importa{padding-bottom:34px;}
  #punto-de-partida{padding-top:30px;}
  .section-head{margin-bottom:30px;}
  .section-head h2,.adoption-copy h2,.method-copy h2{font-size:1.86rem;line-height:1.08;}
  .cards{gap:18px;}
  .card{padding:28px 24px 30px;}
  .levels{grid-template-columns:1fr;gap:14px;margin-top:24px;}
  .level{padding:18px 18px 20px;}
  .level-track{height:16px;margin-bottom:14px;}
  .level h3{font-size:1.05rem;}
  .level p{font-size:.95rem;line-height:1.35;}
  .method-grid{gap:16px;}
  .method-copy p:not(.eyebrow){max-width:100%;margin-bottom:12px;}
  .step{grid-template-columns:34px 1fr;gap:12px;padding-bottom:24px;}
  .step::before{width:34px;height:34px;font-size:.9rem;}
  .step:not(:last-child)::after{left:16px;top:34px;}
  .step h3{font-size:1.02rem;margin-bottom:6px;}
  .step p{font-size:.96rem;line-height:1.35;}
  .adoption-grid{gap:14px;}
  .adoption-copy .eyebrow{margin-bottom:10px;font-size:.84rem;}
  .adoption-copy h2{font-size:1.72rem;line-height:1.1;max-width:30ch;margin-bottom:14px;}
  .adoption-copy p:not(.eyebrow){font-size:.98rem;line-height:1.38;margin-bottom:14px;}
  .hil-visual{padding:14px 14px 10px;border-radius:20px;}
  .hil-image{max-width:190px;max-height:190px;}
  .contact{padding-block:50px;}
  .check{gap:14px;font-size:.95rem;}
  .footer-site__contact,.footer-site__links{gap:14px;}
}

@media (max-width:430px){
  :root{--pad:16px;}
  .hero-grid{padding-top:24px;}
  .hero h1{font-size:1.7rem;}
  .hero p{max-width:31ch;font-size:.92rem;}
  .hero-visual img{width:min(480px,101vw);}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{animation:none!important;transition:none!important;}
  .reveal{opacity:1!important;transform:none!important;}
  .level-fill{width:var(--target)!important;}
  .level-dot{left:var(--target)!important;opacity:1!important;transform:translate(-50%,-50%) scale(1)!important;}
  .step::before{opacity:1!important;transform:scale(1)!important;}
  .step:not(:last-child)::after{transform:scaleY(1)!important;}
}
