/* =========================================================
   AHUMADA ABOGADOS — Design System
   Brand: navy blue · carriage red · gold
   Type: Cormorant Garamond (display) + Montserrat (UI/body)
   ========================================================= */

:root{
  /* Brand */
  --navy:        #0c1f3f;   /* deep blue — primary background */
  --navy-700:    #0f2647;
  --navy-600:    #14305a;
  --navy-500:    #1d4e89;   /* accent blue */
  --blue-soft:   #2f6fb0;
  --red:         #7e2230;   /* rojo carruaje (burgundy) */
  --red-bright:  #9b2c3b;
  --gold:        #c6a35a;
  --gold-light:  #e7cf94;
  --gold-deep:   #a9842f;
  --cream:       #f6f1e7;   /* warm light background */
  --cream-2:     #efe7d6;
  --paper:       #fbf8f1;
  --ink:         #0c1424;   /* dark text on light */
  --ink-soft:    #3a4456;
  --line:        rgba(198,163,90,.28);
  --line-dark:   rgba(255,255,255,.12);

  /* Type */
  --display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* Rhythm */
  --container: 1240px;
  --gutter: clamp(20px, 5vw, 72px);
  --radius: 4px;
  --ease: cubic-bezier(.16,1,.3,1);
  --section-pad: clamp(72px, 11vw, 160px);
  --header-h: 88px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:auto; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--display); font-weight:600; line-height:1.05; }
p{ margin:0 0 1em; }
::selection{ background:var(--gold); color:var(--navy); }

/* ScrollSmoother needs these */
#smooth-wrapper, #smooth-content{ will-change:transform; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section-pad); position:relative; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:var(--ink-soft); }
.center{ text-align:center; }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:2rem; } .mt-l{ margin-top:3.5rem; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-size:.74rem; font-weight:600;
  letter-spacing:.32em; text-transform:uppercase; color:var(--gold-deep);
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--gold); display:inline-block; }
.eyebrow.is-light{ color:var(--gold-light); }
.section-title{
  font-size:clamp(2.1rem,4.6vw,3.6rem); line-height:1.02; letter-spacing:-.01em;
  margin-top:.5rem;
}
.section-title .accent{ color:var(--gold-deep); font-style:italic; }
.dark .section-title, .dark h1,.dark h2,.dark h3{ color:var(--cream); }
.dark .lead{ color:rgba(246,241,231,.72); }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--navy); --fg:var(--cream);
  position:relative; display:inline-flex; align-items:center; gap:.65em;
  padding:1.02em 1.9em; font-family:var(--sans); font-size:.78rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--fg);
  background:var(--bg); border-radius:var(--radius); overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), color .45s var(--ease);
  isolation:isolate;
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1; transform:translateY(101%);
  background:linear-gradient(120deg,var(--gold),var(--gold-light));
  transition:transform .55s var(--ease);
}
.btn:hover{ color:var(--navy); transform:translateY(-3px); box-shadow:0 18px 38px -18px rgba(12,31,63,.6); }
.btn:hover::after{ transform:translateY(0); }
.btn--gold{ --bg:linear-gradient(120deg,var(--gold),var(--gold-deep)); --fg:var(--navy); }
.btn--gold::after{ background:var(--navy); }
.btn--gold:hover{ color:var(--gold-light); }
.btn--ghost{ --bg:transparent; --fg:currentColor; border:1px solid var(--line); }
.btn--ghost::after{ background:var(--gold); }
.btn--ghost:hover{ color:var(--navy); border-color:var(--gold); }
.btn .ico{ width:1.05em; height:1.05em; }

.link-underline{
  position:relative; font-weight:600; letter-spacing:.04em;
  display:inline-flex; align-items:center; gap:.5em; color:var(--gold-deep);
}
.link-underline::after{
  content:""; position:absolute; left:0; bottom:-3px; width:100%; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .5s var(--ease);
}
.link-underline:hover::after{ transform:scaleX(1); transform-origin:left; }
.link-underline .arr{ transition:transform .45s var(--ease); }
.link-underline:hover .arr{ transform:translateX(5px); }

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{
  position:fixed; inset:0; z-index:9000; display:grid; place-items:center;
  background:var(--navy); color:var(--cream);
}
.preloader__inner{ text-align:center; }
.preloader__logo{ width:clamp(150px,28vw,220px); height:auto; }
.preloader__bar{
  margin:26px auto 0; width:min(220px,52vw); height:1px; background:var(--line-dark); position:relative; overflow:hidden;
}
.preloader__bar span{ position:absolute; inset:0; transform-origin:left; transform:scaleX(0);
  background:linear-gradient(90deg,var(--gold),var(--gold-light)); }
.preloader__pct{ margin-top:14px; font-size:.72rem; letter-spacing:.34em; color:var(--gold-light); }

/* =========================================================
   PAGE TRANSITION
   ========================================================= */
.transition{ position:fixed; inset:0; z-index:8000; display:flex; pointer-events:none; }
.transition__col{ flex:1; background:var(--navy); transform:scaleY(0); transform-origin:bottom; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  height:var(--header-h); display:flex; align-items:center;
  transition:background .5s var(--ease), height .5s var(--ease), box-shadow .5s var(--ease);
}
.site-header.is-scrolled{
  height:70px; background:rgba(10,26,52,.86); backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 var(--line-dark);
}
.nav{ width:100%; max-width:1500px; margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.nav__logo img{ height:46px; width:auto; transition:height .5s var(--ease); }
.is-scrolled .nav__logo img{ height:40px; }
.nav__links{ display:flex; align-items:center; gap:clamp(1rem,2.4vw,2.4rem); }
.nav__link{
  position:relative; font-size:.82rem; font-weight:500; letter-spacing:.06em;
  color:var(--cream); padding:.4em 0; opacity:.85; transition:opacity .3s;
}
.nav__link::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease);
}
.nav__link:hover, .nav__link.is-active{ opacity:1; }
.nav__link:hover::after, .nav__link.is-active::after{ transform:scaleX(1); transform-origin:left; }
.nav__right{ display:flex; align-items:center; gap:1.1rem; }

.lang{ display:flex; align-items:center; gap:.15rem; font-size:.72rem; font-weight:600; letter-spacing:.08em; }
.lang button{ color:rgba(246,241,231,.55); padding:.3em .45em; border-radius:3px; transition:color .3s; }
.lang button.is-active{ color:var(--gold-light); }
.lang button:hover{ color:var(--cream); }
.lang .sep{ color:rgba(246,241,231,.25); }

.nav__cta{ display:inline-flex; }
.nav__cta.btn{ padding:.82em 1.4em; font-size:.72rem; }

/* Burger */
.burger{ display:none; width:42px; height:42px; position:relative; z-index:1200; }
.burger span{ position:absolute; left:9px; right:9px; height:2px; background:var(--cream); transition:transform .4s var(--ease), opacity .3s; }
.burger span:nth-child(1){ top:15px; } .burger span:nth-child(2){ top:21px; } .burger span:nth-child(3){ top:27px; }
.menu-open .burger span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.menu-open .burger span:nth-child(2){ opacity:0; }
.menu-open .burger span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* Mobile drawer */
.mobile-menu{
  position:fixed; inset:0; z-index:1100; background:var(--navy);
  display:flex; flex-direction:column; justify-content:center; padding:var(--gutter);
  clip-path:circle(0% at calc(100% - 42px) 44px); transition:clip-path .7s var(--ease);
}
.menu-open .mobile-menu{ clip-path:circle(150% at calc(100% - 42px) 44px); }
.mobile-menu a{ font-family:var(--display); font-size:clamp(2rem,9vw,3.4rem); color:var(--cream); padding:.18em 0; opacity:.9; }
.mobile-menu a .num{ font-family:var(--sans); font-size:.8rem; color:var(--gold); margin-right:.8em; vertical-align:middle; letter-spacing:.1em; }
.mobile-menu__foot{ margin-top:2.6rem; color:rgba(246,241,231,.6); font-size:.85rem; }
.mobile-menu__foot a{ font-family:var(--sans); font-size:.9rem; }

/* =========================================================
   HERO (home)
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:var(--cream); overflow:hidden; padding-bottom:clamp(50px,8vh,96px); }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg img{ width:100%; height:120%; object-fit:cover; will-change:transform; }
.hero__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(8,20,40,.72) 0%, rgba(8,20,40,.55) 40%, rgba(8,20,40,.92) 100%); }
.hero__veil{ position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 80% at 80% 10%, rgba(198,163,90,.18), transparent 55%); }
.hero__content{ position:relative; z-index:2; width:100%; }
.hero__eyebrow{ color:var(--gold-light); }
.hero__title{ font-size:clamp(2.8rem,8.2vw,7rem); line-height:.98; letter-spacing:-.015em; margin-top:.4rem; }
.hero__title .it{ font-style:italic; color:var(--gold-light); }
.hero__sub{ max-width:46ch; margin-top:1.5rem; font-size:clamp(1rem,1.5vw,1.2rem); color:rgba(246,241,231,.82); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.3rem; }
.hero__scroll{ position:absolute; right:var(--gutter); bottom:clamp(40px,7vh,70px); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.8rem; font-size:.66rem; letter-spacing:.28em;
  text-transform:uppercase; color:rgba(246,241,231,.65); writing-mode:vertical-rl; }
.hero__scroll em{ width:1px; height:54px; background:linear-gradient(var(--gold),transparent); display:block; }
.hero__overline{ position:absolute; top:calc(var(--header-h) + 18px); left:var(--gutter); z-index:2;
  font-size:.7rem; letter-spacing:.26em; text-transform:uppercase; color:rgba(246,241,231,.55); }

/* Trust strip under hero */
.trust{ background:var(--navy); color:var(--cream); border-top:1px solid var(--line-dark); }
.trust__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.trust__item{ padding:clamp(26px,4vw,44px) clamp(18px,3vw,40px); border-right:1px solid var(--line-dark); }
.trust__item:last-child{ border-right:none; }
.trust__num{ font-family:var(--display); font-size:clamp(2.4rem,5vw,3.4rem); color:var(--gold-light); line-height:1; }
.trust__label{ margin-top:.5rem; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(246,241,231,.7); }

/* =========================================================
   INTRO / STATEMENT
   ========================================================= */
.statement{ background:var(--paper); }
.statement__text{ font-family:var(--display); font-size:clamp(1.8rem,4.4vw,3.4rem); line-height:1.18; max-width:24ch; }
.statement__text .accent{ color:var(--gold-deep); font-style:italic; }
.statement__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,6vw,5rem); align-items:center; }
.statement__aside p{ color:var(--ink-soft); }
.sig{ font-family:var(--display); font-style:italic; font-size:1.6rem; color:var(--navy); margin-top:1.4rem; }
.sig small{ display:block; font-family:var(--sans); font-style:normal; font-size:.72rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gold-deep); margin-top:.3rem; }

/* =========================================================
   SERVICES
   ========================================================= */
.services{ background:var(--cream); }
.services__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; margin-bottom:clamp(2.4rem,5vw,4rem); }
.svc-list{ border-top:1px solid var(--line); }
.svc{ position:relative; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:clamp(1rem,3vw,2.6rem);
  padding:clamp(1.6rem,3.2vw,2.6rem) 0; border-bottom:1px solid var(--line); overflow:hidden; cursor:pointer; }
.svc__bg{ position:absolute; inset:0; z-index:0; background:var(--navy); transform:scaleY(0); transform-origin:bottom; transition:transform .55s var(--ease); }
.svc:hover .svc__bg{ transform:scaleY(1); }
.svc > *{ position:relative; z-index:1; transition:color .45s var(--ease); }
.svc__num{ font-family:var(--display); font-size:1.1rem; color:var(--gold-deep); width:2.4em; }
.svc__title{ font-family:var(--display); font-size:clamp(1.6rem,3.4vw,2.5rem); letter-spacing:-.01em; }
.svc__desc{ font-size:.92rem; color:var(--ink-soft); max-width:52ch; margin-top:.35rem; }
.svc__arrow{ width:56px; height:56px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center;
  color:var(--gold-deep); transition:transform .5s var(--ease), border-color .5s, background .5s; }
.svc:hover .svc__title,.svc:hover .svc__num{ color:var(--cream); }
.svc:hover .svc__desc{ color:rgba(246,241,231,.78); }
.svc:hover .svc__arrow{ background:var(--gold); border-color:var(--gold); color:var(--navy); transform:rotate(-45deg) scale(1.05); }
.svc__media{ display:none; }

/* Service detail cards (servicios page) */
.svc-cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:clamp(1.2rem,2.4vw,2rem); }
.card{ position:relative; background:var(--paper); border:1px solid var(--line); border-radius:6px;
  padding:clamp(1.8rem,3vw,2.6rem); overflow:hidden; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.card::before{ content:""; position:absolute; left:0; top:0; height:3px; width:100%;
  background:linear-gradient(90deg,var(--gold),var(--gold-light)); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.card:hover{ transform:translateY(-8px); box-shadow:0 30px 60px -36px rgba(12,31,63,.4); }
.card:hover::before{ transform:scaleX(1); }
.card__ico{ width:54px; height:54px; color:var(--gold-deep); margin-bottom:1.2rem; }
.card__title{ font-size:1.5rem; }
.card__num{ position:absolute; top:1.4rem; right:1.6rem; font-family:var(--display); font-size:2.4rem; color:var(--line); }
.card ul.ticks{ margin-top:1rem; display:grid; gap:.55rem; }
.card ul.ticks li{ position:relative; padding-left:1.5em; font-size:.9rem; color:var(--ink-soft); }
.card ul.ticks li::before{ content:""; position:absolute; left:0; top:.55em; width:8px; height:8px; border-right:2px solid var(--gold-deep);
  border-bottom:2px solid var(--gold-deep); transform:rotate(45deg) translateY(-2px); }

/* =========================================================
   ABOUT / FEATURE SPLIT
   ========================================================= */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5.5rem); align-items:center; }
.split--rev .split__media{ order:2; }
.split__media{ position:relative; }
.split__media .frame{ position:relative; overflow:hidden; border-radius:6px; }
.split__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; will-change:transform; }
.split__media .badge{ position:absolute; bottom:-26px; left:-26px; background:var(--navy); color:var(--cream);
  padding:1.3rem 1.6rem; border-radius:6px; box-shadow:0 30px 60px -30px rgba(0,0,0,.5); }
.split__media .badge b{ font-family:var(--display); font-size:2.6rem; color:var(--gold-light); display:block; line-height:1; }
.split__media .badge span{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(246,241,231,.7); }
.feature-list{ margin-top:1.8rem; display:grid; gap:1.1rem; }
.feature-list li{ display:flex; gap:1rem; align-items:flex-start; }
.feature-list .fi{ flex:0 0 auto; width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  background:rgba(198,163,90,.14); color:var(--gold-deep); }
.feature-list b{ display:block; font-family:var(--sans); font-size:1rem; color:var(--ink); }
.feature-list p{ margin:.2rem 0 0; font-size:.9rem; color:var(--ink-soft); }

/* =========================================================
   PROCESS
   ========================================================= */
.process{ background:var(--navy); color:var(--cream); }
.process__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.2rem,2.5vw,2rem); margin-top:clamp(2.4rem,5vw,4rem); }
.step{ position:relative; padding-top:2.4rem; border-top:1px solid var(--line-dark); }
.step__num{ font-family:var(--display); font-size:1rem; color:var(--gold-light); letter-spacing:.1em; }
.step h3{ font-size:1.45rem; margin:.6rem 0 .6rem; color:var(--cream); }
.step p{ font-size:.9rem; color:rgba(246,241,231,.66); }
.step::before{ content:""; position:absolute; top:-1px; left:0; height:2px; width:0; background:var(--gold); transition:width .8s var(--ease); }
.step.is-in::before{ width:48px; }

/* =========================================================
   QUOTE / CTA band
   ========================================================= */
.cta-band{ position:relative; color:var(--cream); overflow:hidden; }
.cta-band__bg{ position:absolute; inset:0; z-index:0; }
.cta-band__bg img{ width:100%; height:100%; object-fit:cover; }
.cta-band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg,rgba(12,31,63,.94),rgba(126,34,48,.82)); }
.cta-band__inner{ position:relative; z-index:1; text-align:center; padding-block:clamp(70px,10vw,130px); }
.cta-band h2{ font-size:clamp(2.2rem,5vw,4rem); color:var(--cream); max-width:18ch; margin-inline:auto; }
.cta-band p{ color:rgba(246,241,231,.8); max-width:54ch; margin:1.2rem auto 2.2rem; }

/* =========================================================
   STATS / counters
   ========================================================= */
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.5rem,4vw,3rem); }
.stat{ text-align:center; }
.stat b{ font-family:var(--display); font-size:clamp(2.6rem,6vw,4.4rem); color:var(--navy); line-height:1; }
.dark .stat b{ color:var(--gold-light); }
.stat span{ display:block; margin-top:.5rem; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.dark .stat span{ color:rgba(246,241,231,.65); }

/* =========================================================
   PAGE HEADER (inner pages)
   ========================================================= */
.page-hero{ position:relative; min-height:62svh; display:flex; align-items:flex-end; color:var(--cream); overflow:hidden;
  padding-block:clamp(120px,16vh,200px) clamp(48px,7vh,80px); }
.page-hero__bg{ position:absolute; inset:0; z-index:0; }
.page-hero__bg img{ width:100%; height:118%; object-fit:cover; will-change:transform; }
.page-hero__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(8,20,40,.7),rgba(8,20,40,.92)); }
.page-hero__content{ position:relative; z-index:1; }
.page-hero h1{ font-size:clamp(2.6rem,7vw,5.4rem); letter-spacing:-.015em; }
.page-hero h1 .it{ font-style:italic; color:var(--gold-light); }
.breadcrumb{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(246,241,231,.6); margin-bottom:1rem; }
.breadcrumb a:hover{ color:var(--gold-light); }
.breadcrumb .sep{ margin-inline:.6em; color:var(--gold); }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery-grid{ columns:3; column-gap:clamp(.8rem,1.6vw,1.3rem); }
.gallery-grid .g-item{ break-inside:avoid; margin-bottom:clamp(.8rem,1.6vw,1.3rem); position:relative; overflow:hidden; border-radius:6px; }
.gallery-grid img{ width:100%; transition:transform .8s var(--ease); }
.gallery-grid .g-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(12,31,63,.78));
  opacity:0; transition:opacity .5s var(--ease); }
.gallery-grid .g-item figcaption{ position:absolute; left:1.1rem; bottom:1rem; z-index:2; color:var(--cream);
  font-family:var(--display); font-size:1.25rem; transform:translateY(12px); opacity:0; transition:.5s var(--ease); }
.gallery-grid .g-item:hover img{ transform:scale(1.06); }
.gallery-grid .g-item:hover::after{ opacity:1; }
.gallery-grid .g-item:hover figcaption{ transform:translateY(0); opacity:1; }

/* =========================================================
   BLOG
   ========================================================= */
.post-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:clamp(1.4rem,3vw,2.4rem); }
.post{ background:var(--paper); border-radius:8px; overflow:hidden; border:1px solid var(--line);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease); display:flex; flex-direction:column; }
.post:hover{ transform:translateY(-8px); box-shadow:0 30px 60px -36px rgba(12,31,63,.4); }
.post__media{ overflow:hidden; aspect-ratio:16/10; }
.post__media img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.post:hover .post__media img{ transform:scale(1.07); }
.post__body{ padding:1.6rem 1.6rem 1.9rem; display:flex; flex-direction:column; flex:1; }
.post__tag{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.post__title{ font-size:1.5rem; margin:.6rem 0 .7rem; line-height:1.12; }
.post__excerpt{ font-size:.9rem; color:var(--ink-soft); flex:1; }
.post__meta{ margin-top:1.2rem; font-size:.78rem; color:var(--ink-soft); display:flex; gap:1rem; align-items:center; }
.post__meta .dot{ color:var(--gold); }

.featured-post{ display:grid; grid-template-columns:1.1fr .9fr; gap:0; border-radius:10px; overflow:hidden;
  background:var(--navy); color:var(--cream); margin-bottom:clamp(2.4rem,5vw,4rem); }
.featured-post__media{ overflow:hidden; min-height:340px; }
.featured-post__media img{ width:100%; height:100%; object-fit:cover; }
.featured-post__body{ padding:clamp(2rem,4vw,3.4rem); display:flex; flex-direction:column; justify-content:center; }
.featured-post__body h2{ color:var(--cream); font-size:clamp(1.8rem,3.4vw,2.8rem); margin:.6rem 0 1rem; }

/* =========================================================
   FAQ (accordion)
   ========================================================= */
.faq{ border-top:1px solid var(--line); max-width:900px; margin-inline:auto; }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:1.5rem;
  padding:1.5rem 0; font-family:var(--display); font-size:clamp(1.2rem,2.2vw,1.6rem); color:var(--navy); }
.faq__q .pm{ flex:0 0 auto; width:34px; height:34px; border:1px solid var(--line); border-radius:50%; position:relative; }
.faq__q .pm::before,.faq__q .pm::after{ content:""; position:absolute; inset:0; margin:auto; background:var(--gold-deep); }
.faq__q .pm::before{ width:13px; height:2px; }
.faq__q .pm::after{ width:2px; height:13px; transition:transform .4s var(--ease); }
.faq__item.is-open .pm::after{ transform:scaleY(0); }
.faq__a{ overflow:hidden; height:0; }
.faq__a p{ padding-bottom:1.6rem; color:var(--ink-soft); max-width:70ch; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.info-card{ display:flex; gap:1.1rem; align-items:flex-start; padding:1.3rem 0; border-bottom:1px solid var(--line); }
.info-card .ic{ flex:0 0 auto; width:48px; height:48px; border-radius:50%; background:rgba(198,163,90,.14);
  color:var(--gold-deep); display:grid; place-items:center; }
.info-card b{ font-family:var(--sans); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); }
.info-card a,.info-card p{ font-size:1.05rem; color:var(--ink); margin:.2rem 0 0; }
.hours{ margin-top:1.4rem; }
.hours li{ display:flex; justify-content:space-between; padding:.5rem 0; border-bottom:1px dashed var(--line); font-size:.95rem; }
.hours li span:last-child{ color:var(--gold-deep); font-weight:600; }

.form{ background:var(--paper); border:1px solid var(--line); border-radius:10px; padding:clamp(1.6rem,3vw,2.6rem); }
.field{ position:relative; margin-bottom:1.4rem; }
.field label{ display:block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.5rem; }
.field input,.field select,.field textarea{
  width:100%; font-family:var(--sans); font-size:.98rem; color:var(--ink); background:var(--cream);
  border:1px solid var(--line); border-radius:5px; padding:.9em 1em; transition:border-color .3s, box-shadow .3s; }
.field textarea{ min-height:140px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(198,163,90,.18); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.consent{ display:flex; gap:.7rem; align-items:flex-start; font-size:.82rem; color:var(--ink-soft); }
.consent input{ margin-top:.25rem; accent-color:var(--gold-deep); }
.form__note{ font-size:.78rem; color:var(--ink-soft); margin-top:1rem; }
.form-success{ display:none; padding:1.1rem 1.2rem; background:rgba(45,120,80,.12); border:1px solid rgba(45,120,80,.4);
  border-radius:6px; color:#1f6b45; font-size:.92rem; }
.form-success.show{ display:block; }

.map{ margin-top:clamp(3rem,6vw,5rem); border-radius:10px; overflow:hidden; border:1px solid var(--line); }
.map iframe{ width:100%; height:420px; border:0; display:block; filter:grayscale(.3) contrast(1.05); }

/* =========================================================
   LEGAL / PROSE PAGES
   ========================================================= */
.prose{ max-width:820px; margin-inline:auto; }
.prose h2{ font-size:clamp(1.5rem,3vw,2.1rem); color:var(--navy); margin:2.4rem 0 .8rem; }
.prose h3{ font-family:var(--sans); font-size:1.05rem; font-weight:600; color:var(--navy); margin:1.6rem 0 .5rem; letter-spacing:.01em; }
.prose p, .prose li{ color:var(--ink-soft); font-size:1rem; }
.prose ul{ list-style:none; margin:0 0 1.2rem; padding:0; }
.prose ul li{ position:relative; padding-left:1.5em; margin-bottom:.5rem; }
.prose ul li::before{ content:""; position:absolute; left:0; top:.6em; width:7px; height:7px; background:var(--gold); border-radius:50%; }
.prose a{ color:var(--gold-deep); text-decoration:underline; text-underline-offset:3px; }
.prose .updated{ font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:2rem; display:block; }
.legal-box{ background:var(--paper); border:1px solid var(--line); border-radius:8px; padding:1.6rem 1.8rem; margin:1.6rem 0; }
.legal-box p{ margin:.3rem 0; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--navy); color:rgba(246,241,231,.7); padding-top:clamp(60px,8vw,100px); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:clamp(1.6rem,3vw,3rem); padding-bottom:clamp(40px,6vw,70px);
  border-bottom:1px solid var(--line-dark); }
.footer-brand img{ height:54px; margin-bottom:1.2rem; }
.footer-brand p{ font-size:.9rem; max-width:34ch; }
.footer-col h4{ font-family:var(--sans); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-light); margin-bottom:1.2rem; }
.footer-col a, .footer-col li{ display:block; font-size:.92rem; padding:.32em 0; transition:color .3s; }
.footer-col a:hover{ color:var(--gold-light); }
.footer-social{ display:flex; gap:.7rem; margin-top:1.4rem; }
.footer-social a{ width:40px; height:40px; border:1px solid var(--line-dark); border-radius:50%; display:grid; place-items:center;
  color:var(--cream); transition:background .4s, color .4s, transform .4s; }
.footer-social a:hover{ background:var(--gold); color:var(--navy); transform:translateY(-3px); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap;
  padding-block:1.8rem; font-size:.78rem; }
.footer-bottom a:hover{ color:var(--gold-light); }
.footer-bottom .legal-links{ display:flex; gap:1.4rem; flex-wrap:wrap; }

/* =========================================================
   WHATSAPP FLOAT
   ========================================================= */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:1500; width:60px; height:60px; border-radius:50%;
  background:#25d366; color:#fff; display:grid; place-items:center; box-shadow:0 14px 30px -8px rgba(37,211,102,.6);
  transition:transform .4s var(--ease); }
.wa-float:hover{ transform:scale(1.08) rotate(6deg); }
.wa-float svg{ width:30px; height:30px; }
.wa-float::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25d366; animation:waPulse 2.4s ease-out infinite; }
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(1.7); opacity:0; } }
.wa-tip{ position:absolute; right:74px; top:50%; transform:translateY(-50%) translateX(8px); white-space:nowrap;
  background:var(--navy); color:var(--cream); padding:.6em 1em; border-radius:6px; font-size:.8rem; opacity:0; pointer-events:none;
  transition:opacity .4s, transform .4s; box-shadow:0 10px 24px -10px rgba(0,0,0,.5); }
.wa-float:hover .wa-tip{ opacity:1; transform:translateY(-50%) translateX(0); }

/* =========================================================
   REVEAL utility (GSAP toggles these)
   ========================================================= */
[data-reveal]{ will-change:transform,opacity; }
.marquee-band{ background:var(--navy); color:var(--cream); padding:1.2rem 0; overflow:hidden; border-block:1px solid var(--line-dark); }
.marquee-row{ display:flex; gap:2.5rem; white-space:nowrap; width:max-content; font-family:var(--display); font-size:clamp(1.4rem,3vw,2.2rem); }
.marquee-row span{ color:var(--cream); }
.marquee-row .dot{ color:var(--gold); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .trust__grid, .process__grid{ grid-template-columns:repeat(2,1fr); }
  .trust__item:nth-child(2){ border-right:none; }
  .stats__grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ columns:2; }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .featured-post{ grid-template-columns:1fr; }
}
@media (max-width:860px){
  :root{ --header-h:72px; }
  .nav__links, .nav__cta, .lang{ display:none; }
  .burger{ display:block; }
  .split, .statement__grid, .contact-grid{ grid-template-columns:1fr; }
  .split--rev .split__media{ order:0; }
  .split__media .badge{ left:0; }
  .svc{ grid-template-columns:auto 1fr; }
  .svc__arrow{ display:none; }
}
@media (max-width:560px){
  .trust__grid, .process__grid, .stats__grid{ grid-template-columns:1fr; }
  .trust__item{ border-right:none; }
  .gallery-grid{ columns:1; }
  .footer-top{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .hero__scroll{ display:none; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  .wa-float::after{ display:none; }
}


/* === Ahumada WordPress / Elementor exact integration === */
html, body { margin:0; }
body.ahumada-identica-page { background: var(--cream); }
body.ahumada-identica-page .elementor-section,
body.ahumada-identica-page .elementor-container,
body.ahumada-identica-page .elementor-column,
body.ahumada-identica-page .elementor-widget-wrap,
body.ahumada-identica-page .elementor-widget-ahumada_page_template,
body.ahumada-identica-page .elementor-widget-container { padding:0 !important; margin:0 !important; max-width:none !important; }
body.ahumada-identica-page .elementor-widget:not(:last-child) { margin-bottom:0 !important; }
body.ahumada-identica-page .elementor-widget-container > #smooth-wrapper { width:100%; }
.nav__logo img, .footer-brand img, .preloader__logo { object-fit: contain; }
.nav__logo img { max-width: 190px; width: 190px; height:auto; }
.footer-brand img { max-width: 220px; width: 100%; height: auto; }
.preloader__logo { max-width: 250px; width:250px; height:auto; }
.kit-digital-footer { margin-top: 34px; padding-top: 18px; border-top: 1px solid var(--line-dark); }
.kit-digital-footer img { display:block; width:100%; max-width:1024px; height:auto; margin:0 auto; background:#fff; }
.footer-social a span { font-size:.72rem; font-weight:700; letter-spacing:.02em; line-height:1; }
.footer-social a { width:auto; min-width:42px; padding:0 12px; gap:6px; }
body.elementor-editor-active .preloader,
body.elementor-editor-active .transition,
body.elementor-editor-active .wa-float { display:none !important; }
body.elementor-editor-active #smooth-wrapper { position:relative !important; overflow:visible !important; }
body.elementor-editor-active #smooth-content { transform:none !important; }


/* =========================================================
   AHUMADA FINAL — Elementor style lock / exact visual layer
   Keeps original visual language even when theme or Elementor Kit
   tries to override typography, buttons, spacing, images or forms.
   ========================================================= */
body.ahumada-identica-page,
body.ahumada-identica-page.elementor-page,
body.ahumada-identica-page.elementor-default {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  overflow-x: hidden !important;
  background: var(--cream) !important;
  color: var(--ink) !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}
body.ahumada-identica-page .site,
body.ahumada-identica-page #page,
body.ahumada-identica-page .site-content,
body.ahumada-identica-page .content-area,
body.ahumada-identica-page .entry-content,
body.ahumada-identica-page .page-content,
body.ahumada-identica-page .elementor,
body.ahumada-identica-page .elementor-location-single,
body.ahumada-identica-page .elementor-section-wrap,
body.ahumada-identica-page .e-con,
body.ahumada-identica-page .e-con-inner,
body.ahumada-identica-page .elementor-section,
body.ahumada-identica-page .elementor-container,
body.ahumada-identica-page .elementor-column,
body.ahumada-identica-page .elementor-widget-wrap,
body.ahumada-identica-page .elementor-widget-container,
body.ahumada-identica-page .elementor-widget-ahumada_page_template {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}
body.ahumada-identica-page .entry-title,
body.ahumada-identica-page .page-title,
body.ahumada-identica-page header.entry-header,
body.ahumada-identica-page .site-header:not(#siteHeader),
body.ahumada-identica-page .site-footer:not(.site-footer) {
  display: none !important;
}
body.ahumada-identica-page .elementor-widget:not(:last-child),
body.ahumada-identica-page p,
body.ahumada-identica-page h1,
body.ahumada-identica-page h2,
body.ahumada-identica-page h3,
body.ahumada-identica-page h4,
body.ahumada-identica-page h5,
body.ahumada-identica-page h6 {
  margin-block-start: 0;
}
body.ahumada-identica-page .ahumada-original-page,
body.elementor-editor-active .ahumada-original-page {
  width: 100% !important;
  min-height: 100vh;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  isolation: isolate;
}
body.ahumada-identica-page .ahumada-original-page *,
body.ahumada-identica-page .ahumada-original-page *::before,
body.ahumada-identica-page .ahumada-original-page *::after,
body.elementor-editor-active .ahumada-original-page *,
body.elementor-editor-active .ahumada-original-page *::before,
body.elementor-editor-active .ahumada-original-page *::after {
  box-sizing: border-box;
}
body.ahumada-identica-page .ahumada-original-page a,
body.elementor-editor-active .ahumada-original-page a {
  color: inherit;
  text-decoration: none !important;
}
body.ahumada-identica-page .ahumada-original-page img,
body.elementor-editor-active .ahumada-original-page img {
  max-width: 100%;
  height: auto;
  border: 0;
  box-shadow: none;
}
body.ahumada-identica-page .ahumada-original-page section,
body.elementor-editor-active .ahumada-original-page section {
  position: relative;
}

/* Buttons: original gold/navy interaction, protected from Elementor kit */
body.ahumada-identica-page .btn,
body.elementor-editor-active .btn {
  appearance: none !important;
  -webkit-appearance: none !important;
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .6em !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  padding: 1em 1.75em !important;
  min-height: auto !important;
  background: var(--bg) !important;
  color: var(--fg) !important;
  font-family: var(--sans) !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  overflow: hidden !important;
  cursor: pointer !important;
  transition: transform .45s var(--ease), box-shadow .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease) !important;
  box-shadow: none !important;
}
body.ahumada-identica-page .btn::after,
body.elementor-editor-active .btn::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  transform: translateY(101%) !important;
  background: linear-gradient(120deg,var(--gold),var(--gold-light)) !important;
  transition: transform .55s var(--ease) !important;
}
body.ahumada-identica-page .btn > *,
body.elementor-editor-active .btn > * { position: relative; z-index: 1; }
body.ahumada-identica-page .btn:hover,
body.elementor-editor-active .btn:hover {
  color: var(--navy) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 18px 38px -18px rgba(12,31,63,.6) !important;
}
body.ahumada-identica-page .btn:hover::after,
body.elementor-editor-active .btn:hover::after { transform: translateY(0) !important; }
body.ahumada-identica-page .btn--gold,
body.elementor-editor-active .btn--gold { --bg: linear-gradient(120deg,var(--gold),var(--gold-deep)); --fg: var(--navy); }
body.ahumada-identica-page .btn--gold::after,
body.elementor-editor-active .btn--gold::after { background: var(--navy) !important; }
body.ahumada-identica-page .btn--gold:hover,
body.elementor-editor-active .btn--gold:hover { color: var(--gold-light) !important; }
body.ahumada-identica-page .btn--ghost,
body.elementor-editor-active .btn--ghost { --bg: transparent; --fg: currentColor; border-color: var(--line) !important; }
body.ahumada-identica-page .btn--ghost::after,
body.elementor-editor-active .btn--ghost::after { background: var(--gold) !important; }
body.ahumada-identica-page .hero__actions .btn--ghost,
body.elementor-editor-active .hero__actions .btn--ghost { color: var(--cream) !important; border-color: rgba(246,241,231,.28) !important; }
body.ahumada-identica-page .hero__actions .btn--ghost:hover,
body.elementor-editor-active .hero__actions .btn--ghost:hover { color: var(--navy) !important; border-color: var(--gold) !important; }
body.ahumada-identica-page .nav__cta.btn,
body.elementor-editor-active .nav__cta.btn { padding: .82em 1.4em !important; font-size: .72rem !important; }

/* Cards, service rows and links: lock original hover effects */
body.ahumada-identica-page .svc,
body.elementor-editor-active .svc {
  color: var(--ink) !important;
  text-decoration: none !important;
}
body.ahumada-identica-page .svc:hover,
body.elementor-editor-active .svc:hover { color: var(--cream) !important; }
body.ahumada-identica-page .svc:hover .svc__num,
body.ahumada-identica-page .svc:hover .svc__desc,
body.ahumada-identica-page .svc:hover .svc__arrow,
body.elementor-editor-active .svc:hover .svc__num,
body.elementor-editor-active .svc:hover .svc__desc,
body.elementor-editor-active .svc:hover .svc__arrow { color: rgba(246,241,231,.8) !important; }
body.ahumada-identica-page .link-underline,
body.elementor-editor-active .link-underline { color: var(--gold-deep) !important; }
body.ahumada-identica-page .card,
body.ahumada-identica-page .post-card,
body.ahumada-identica-page .gallery-card,
body.elementor-editor-active .card,
body.elementor-editor-active .post-card,
body.elementor-editor-active .gallery-card {
  overflow: hidden;
}

/* Header/footer/logos: same size and effects as static website */
body.ahumada-identica-page #siteHeader,
body.elementor-editor-active #siteHeader {
  background: transparent;
  color: var(--cream);
}
body.ahumada-identica-page #siteHeader.is-scrolled,
body.elementor-editor-active #siteHeader.is-scrolled {
  background: rgba(10,26,52,.86) !important;
  backdrop-filter: blur(14px) saturate(140%);
  box-shadow: 0 1px 0 var(--line-dark) !important;
}
body.ahumada-identica-page .nav__logo img,
body.elementor-editor-active .nav__logo img {
  display: block;
  width: auto !important;
  max-width: 190px !important;
  height: 46px !important;
  object-fit: contain !important;
}
body.ahumada-identica-page .is-scrolled .nav__logo img,
body.elementor-editor-active .is-scrolled .nav__logo img { height: 40px !important; }
body.ahumada-identica-page .footer-brand img,
body.elementor-editor-active .footer-brand img {
  display: block !important;
  width: auto !important;
  max-width: 220px !important;
  height: 54px !important;
  object-fit: contain !important;
}
body.ahumada-identica-page .site-footer a,
body.elementor-editor-active .site-footer a { color: inherit !important; }
body.ahumada-identica-page .site-footer a:hover,
body.elementor-editor-active .site-footer a:hover { color: var(--gold-light) !important; }
body.ahumada-identica-page .footer-social a,
body.elementor-editor-active .footer-social a {
  width: auto !important;
  min-width: 42px !important;
  height: 40px !important;
  padding: 0 12px !important;
  border: 1px solid var(--line-dark) !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  color: var(--cream) !important;
  background: transparent !important;
}
body.ahumada-identica-page .footer-social a:hover,
body.elementor-editor-active .footer-social a:hover {
  background: var(--gold) !important;
  color: var(--navy) !important;
  transform: translateY(-3px) !important;
}
body.ahumada-identica-page .kit-digital-footer,
body.elementor-editor-active .kit-digital-footer {
  margin-top: 34px !important;
  padding-top: 18px !important;
  border-top: 1px solid var(--line-dark) !important;
  background: transparent !important;
}
body.ahumada-identica-page .kit-digital-footer img,
body.elementor-editor-active .kit-digital-footer img {
  display: block !important;
  width: 100% !important;
  max-width: 1024px !important;
  height: auto !important;
  margin: 0 auto !important;
  background: #fff !important;
}

/* Forms: remove default Elementor/theme button/input treatment */
body.ahumada-identica-page .field input,
body.ahumada-identica-page .field select,
body.ahumada-identica-page .field textarea,
body.elementor-editor-active .field input,
body.elementor-editor-active .field select,
body.elementor-editor-active .field textarea {
  width: 100% !important;
  border: 1px solid var(--line) !important;
  border-radius: 0 !important;
  background: rgba(255,255,255,.6) !important;
  color: var(--ink) !important;
  padding: 1em 1.05em !important;
  font-family: var(--sans) !important;
  font-size: .95rem !important;
  box-shadow: none !important;
  outline: none !important;
}
body.ahumada-identica-page .field input:focus,
body.ahumada-identica-page .field select:focus,
body.ahumada-identica-page .field textarea:focus,
body.elementor-editor-active .field input:focus,
body.elementor-editor-active .field select:focus,
body.elementor-editor-active .field textarea:focus {
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(198,163,90,.18) !important;
}
body.ahumada-identica-page button,
body.elementor-editor-active button {
  font-family: var(--sans);
}

/* Elementor editor: show the page with correct styles but without disruptive smooth-scroll/preloader overlays */
body.elementor-editor-active .preloader,
body.elementor-editor-active .transition,
body.elementor-editor-active .wa-float { display: none !important; }
body.elementor-editor-active #smooth-wrapper {
  position: relative !important;
  inset: auto !important;
  overflow: visible !important;
  height: auto !important;
  transform: none !important;
}
body.elementor-editor-active #smooth-content {
  position: relative !important;
  overflow: visible !important;
  transform: none !important;
  will-change: auto !important;
}
body.elementor-editor-active [data-reveal],
body.elementor-editor-active [data-split-lines],
body.elementor-editor-active [data-split-hero] {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}
body.elementor-editor-active .site-header {
  position: sticky !important;
  top: 0 !important;
}

/* No-GSAP fallback: page remains usable and visually close if CDN is blocked */
body.ahumada-no-gsap .preloader { display: none !important; }
body.ahumada-no-gsap [data-reveal],
body.ahumada-no-gsap [data-split-lines],
body.ahumada-no-gsap [data-split-hero] {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}
body.ahumada-no-gsap .faq__a { height: 0; overflow: hidden; transition: height .45s var(--ease); }
body.ahumada-no-gsap .faq__item.is-open .faq__a { height: auto; }


/* =========================================================
   ARTICLE POPUPS + TEXT SPACING FIXES (v6)
   ========================================================= */
.ahumada-original-page h1 .it,
.ahumada-original-page .section-title .accent,
.ahumada-original-page .statement__text .accent{ display:inline-block; }

.post__read{ align-self:flex-start; margin-top:1.1rem; border:0; background:transparent; padding:0; cursor:pointer; font:inherit; color:var(--gold-deep); }
.featured-post .post__read{ color:var(--gold-light); }
.post__read:hover{ color:var(--navy); }
.featured-post .post__read:hover{ color:var(--cream); }
.post:has(.post__read){ cursor:default; }

.article-modal{ position:fixed; inset:0; z-index:99998; display:none; align-items:center; justify-content:center; padding:clamp(1rem,3vw,2rem); }
.article-modal.is-open{ display:flex; }
.article-modal__backdrop{ position:absolute; inset:0; background:rgba(8,20,40,.78); backdrop-filter:blur(8px); }
.article-modal__dialog{ position:relative; z-index:1; width:min(980px,100%); max-height:min(88vh,860px); overflow:auto; background:var(--paper); color:var(--ink); border:1px solid rgba(198,163,90,.45); border-radius:12px; box-shadow:0 32px 90px -28px rgba(0,0,0,.65); display:grid; grid-template-columns:minmax(280px,.85fr) 1.15fr; }
.article-modal__media{ min-height:100%; background:var(--navy); overflow:hidden; }
.article-modal__media img{ width:100%; height:100%; min-height:460px; object-fit:cover; display:block; }
.article-modal__body{ padding:clamp(1.8rem,4vw,3.4rem); }
.article-modal__body h2{ font-size:clamp(1.7rem,3.4vw,2.7rem); color:var(--navy); margin:.7rem 0 1rem; }
.article-modal__copy{ margin-top:1.4rem; color:var(--ink-soft); font-size:1rem; line-height:1.8; }
.article-modal__copy p{ margin:0 0 1.05rem; }
.article-modal__copy ul{ margin:0 0 1.2rem; padding-left:1.2rem; }
.article-modal__copy li{ margin-bottom:.45rem; }
.article-modal__close{ position:absolute; top:14px; right:14px; z-index:2; width:42px; height:42px; border-radius:50%; border:1px solid rgba(198,163,90,.5); background:rgba(246,241,231,.92); color:var(--navy); font-size:2rem; line-height:1; cursor:pointer; display:grid; place-items:center; transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease); }
.article-modal__close:hover{ transform:rotate(90deg); background:var(--gold); color:var(--navy); }
body.article-modal-open{ overflow:hidden; }
body.article-modal-open .site-header{ pointer-events:none; }

@media (max-width:820px){
  .article-modal{ padding:.7rem; align-items:flex-end; }
  .article-modal__dialog{ grid-template-columns:1fr; max-height:92vh; }
  .article-modal__media img{ min-height:220px; max-height:260px; }
  .article-modal__body{ padding:1.6rem; }
}

/* =========================================================
   V7 · Service hover cursor images + readable hover text
   ========================================================= */
.ahumada-original-page .svc,
.ahumada-original-page .card[data-cursor-image] {
  isolation: isolate;
}
.ahumada-original-page .svc__bg {
  z-index: 0 !important;
  background: var(--navy) !important;
  pointer-events: none !important;
}
.ahumada-original-page .svc > *:not(.svc__bg) {
  position: relative !important;
  z-index: 3 !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc:hover .svc__title,
body.elementor-editor-active .svc:hover .svc__title {
  color: var(--cream) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc:hover .svc__num,
body.elementor-editor-active .svc:hover .svc__num {
  color: var(--gold-light) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc:hover .svc__desc,
body.elementor-editor-active .svc:hover .svc__desc {
  color: rgba(246,241,231,.82) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc:hover .svc__arrow,
body.elementor-editor-active .svc:hover .svc__arrow {
  color: var(--navy) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
.svc-cursor-visual {
  position: fixed;
  left: 0;
  top: 0;
  width: clamp(180px, 22vw, 330px);
  aspect-ratio: 4 / 3;
  border: 1px solid rgba(190,151,88,.72);
  border-radius: 3px;
  overflow: hidden;
  background: var(--navy);
  box-shadow: 0 28px 70px -34px rgba(8,18,38,.72);
  pointer-events: none;
  z-index: 2147483000;
  opacity: 0;
  visibility: hidden;
  transform: translate3d(0,14px,0) scale(.96);
  transition: opacity .26s var(--ease), visibility .26s var(--ease), transform .26s var(--ease);
  will-change: left, top, transform, opacity;
}
.svc-cursor-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10,26,52,.02), rgba(10,26,52,.22));
  pointer-events: none;
}
.svc-cursor-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.04);
  transition: transform .55s var(--ease), filter .35s var(--ease);
  filter: saturate(.9) contrast(1.02);
}
.svc-cursor-visual.is-active {
  opacity: 1;
  visibility: visible;
  transform: translate3d(0,0,0) scale(1);
}
.svc-cursor-visual.is-active img {
  transform: scale(1.08);
}
.ahumada-original-page [data-cursor-image] {
  cursor: pointer;
}
@media (hover:none), (pointer:coarse), (max-width: 767px) {
  .svc-cursor-visual { display: none !important; }
}

/* =========================================================
   V8 · Areas de práctica con imagen fija a la derecha
   ========================================================= */
.ahumada-original-page .svc-cursor-visual,
body.ahumada-identica-page .svc-cursor-visual,
body.elementor-editor-active .svc-cursor-visual {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}
body.ahumada-identica-page .svc,
body.elementor-editor-active .svc {
  grid-template-columns: auto minmax(0, 1fr) clamp(150px, 18vw, 240px) auto !important;
  gap: clamp(1rem, 2.4vw, 2rem) !important;
  min-height: clamp(128px, 13vw, 168px) !important;
  overflow: hidden !important;
  background: transparent !important;
}
body.ahumada-identica-page .svc__bg,
body.elementor-editor-active .svc__bg {
  background: rgba(190,151,88,.08) !important;
  transform: scaleY(0) !important;
}
body.ahumada-identica-page .svc:hover .svc__bg,
body.elementor-editor-active .svc:hover .svc__bg {
  transform: scaleY(1) !important;
}
body.ahumada-identica-page .svc__title,
body.elementor-editor-active .svc__title,
body.ahumada-identica-page .svc:hover .svc__title,
body.elementor-editor-active .svc:hover .svc__title {
  color: var(--navy) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc__num,
body.elementor-editor-active .svc__num,
body.ahumada-identica-page .svc:hover .svc__num,
body.elementor-editor-active .svc:hover .svc__num {
  color: var(--gold-deep) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc__desc,
body.elementor-editor-active .svc__desc,
body.ahumada-identica-page .svc:hover .svc__desc,
body.elementor-editor-active .svc:hover .svc__desc {
  color: var(--ink-soft) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .svc__media,
body.elementor-editor-active .svc__media {
  display: block !important;
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  height: clamp(96px, 10vw, 132px) !important;
  border-radius: 2px !important;
  overflow: hidden !important;
  border: 1px solid rgba(190,151,88,.35) !important;
  box-shadow: 0 18px 38px -28px rgba(12,31,63,.45) !important;
  background: var(--navy) !important;
}
body.ahumada-identica-page .svc__media img,
body.elementor-editor-active .svc__media img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  filter: saturate(.9) contrast(1.02) !important;
  transform: scale(1) !important;
  transition: transform .55s var(--ease), filter .45s var(--ease) !important;
}
body.ahumada-identica-page .svc:hover .svc__media img,
body.elementor-editor-active .svc:hover .svc__media img {
  transform: scale(1.045) !important;
  filter: saturate(1) contrast(1.05) !important;
}
body.ahumada-identica-page .svc:hover .svc__arrow,
body.elementor-editor-active .svc:hover .svc__arrow {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: var(--navy) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .card--service,
body.elementor-editor-active .card--service {
  position: relative !important;
  overflow: hidden !important;
  padding-right: clamp(1.4rem, 16vw, 15rem) !important;
  min-height: 360px !important;
}
body.ahumada-identica-page .card--service .card__media,
body.elementor-editor-active .card--service .card__media {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: clamp(150px, 34%, 235px) !important;
  display: block !important;
  overflow: hidden !important;
  background: var(--navy) !important;
  border-left: 1px solid rgba(190,151,88,.35) !important;
}
body.ahumada-identica-page .card--service .card__media::after,
body.elementor-editor-active .card--service .card__media::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(90deg, rgba(246,241,231,.86), rgba(246,241,231,.08) 44%, rgba(12,31,63,.12)) !important;
  pointer-events: none !important;
}
body.ahumada-identica-page .card--service .card__media img,
body.elementor-editor-active .card--service .card__media img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  filter: saturate(.9) contrast(1.02) !important;
  transform: scale(1) !important;
  transition: transform .55s var(--ease), filter .45s var(--ease) !important;
}
body.ahumada-identica-page .card--service:hover .card__media img,
body.elementor-editor-active .card--service:hover .card__media img {
  transform: scale(1.04) !important;
  filter: saturate(1) contrast(1.05) !important;
}
body.ahumada-identica-page .card--service > *:not(.card__media),
body.elementor-editor-active .card--service > *:not(.card__media) {
  position: relative !important;
  z-index: 2 !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.ahumada-identica-page .card--service:hover,
body.elementor-editor-active .card--service:hover {
  transform: translateY(-6px) !important;
}
@media (max-width: 900px) {
  body.ahumada-identica-page .svc,
  body.elementor-editor-active .svc {
    grid-template-columns: auto minmax(0,1fr) auto !important;
  }
  body.ahumada-identica-page .svc__media,
  body.elementor-editor-active .svc__media {
    grid-column: 2 / 4 !important;
    height: 150px !important;
    margin-top: .2rem !important;
  }
  body.ahumada-identica-page .card--service,
  body.elementor-editor-active .card--service {
    padding-right: var(--card-pad, clamp(1.2rem,3vw,1.8rem)) !important;
    padding-top: 0 !important;
  }
  body.ahumada-identica-page .card--service .card__media,
  body.elementor-editor-active .card--service .card__media {
    position: relative !important;
    width: calc(100% + (var(--card-pad, 1.6rem) * 2)) !important;
    height: 190px !important;
    margin: 0 0 1.2rem calc(var(--card-pad, 1.6rem) * -1) !important;
    border-left: 0 !important;
    border-bottom: 1px solid rgba(190,151,88,.35) !important;
  }
  body.ahumada-identica-page .card--service .card__media::after,
  body.elementor-editor-active .card--service .card__media::after {
    background: linear-gradient(180deg, rgba(12,31,63,.05), rgba(12,31,63,.18)) !important;
  }
}
@media (max-width: 640px) {
  body.ahumada-identica-page .svc,
  body.elementor-editor-active .svc {
    grid-template-columns: auto minmax(0,1fr) !important;
  }
  body.ahumada-identica-page .svc__arrow,
  body.elementor-editor-active .svc__arrow {
    grid-column: 1 / 3 !important;
    width: 44px !important;
    height: 44px !important;
    justify-self: flex-start !important;
  }
  body.ahumada-identica-page .svc__media,
  body.elementor-editor-active .svc__media {
    grid-column: 1 / 3 !important;
    height: 170px !important;
  }
}


/* =========================================================
   V9 · Áreas de práctica y página Servicios saneadas
   - Texto siempre visible.
   - Imágenes fijas, limpias y alineadas.
   - Responsive corregido en tablet y móvil.
   ========================================================= */
body.ahumada-identica-page .ahumada-page-inicio .services,
body.elementor-editor-active .ahumada-page-inicio .services,
body.ahumada-identica-page .ahumada-page-servicios .services,
body.elementor-editor-active .ahumada-page-servicios .services {
  overflow: hidden !important;
}

body.ahumada-identica-page .services__head,
body.elementor-editor-active .services__head {
  align-items: flex-end !important;
  border-bottom: 1px solid var(--line) !important;
  padding-bottom: clamp(1.6rem, 3vw, 2.3rem) !important;
}

body.ahumada-identica-page .services__head .section-title,
body.elementor-editor-active .services__head .section-title {
  margin: 0 !important;
}

/* HOME · listado de áreas */
body.ahumada-identica-page .ahumada-page-inicio .svc-list,
body.elementor-editor-active .ahumada-page-inicio .svc-list {
  border-top: 0 !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc,
body.elementor-editor-active .ahumada-page-inicio .svc {
  grid-template-columns: minmax(2.4rem, 3.2rem) minmax(0, 1fr) clamp(190px, 22vw, 315px) 56px !important;
  align-items: center !important;
  column-gap: clamp(1rem, 2.5vw, 2.2rem) !important;
  min-height: clamp(124px, 13vw, 168px) !important;
  padding: clamp(1.2rem, 2.4vw, 1.9rem) 0 !important;
  border-bottom: 1px solid var(--line) !important;
  color: var(--ink) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__bg,
body.elementor-editor-active .ahumada-page-inicio .svc__bg {
  background: linear-gradient(90deg, rgba(190,151,88,.10), rgba(190,151,88,.045)) !important;
  transform-origin: center !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc:hover,
body.elementor-editor-active .ahumada-page-inicio .svc:hover {
  color: var(--ink) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__title,
body.elementor-editor-active .ahumada-page-inicio .svc__title,
body.ahumada-identica-page .ahumada-page-inicio .svc:hover .svc__title,
body.elementor-editor-active .ahumada-page-inicio .svc:hover .svc__title {
  color: var(--navy) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__num,
body.elementor-editor-active .ahumada-page-inicio .svc__num,
body.ahumada-identica-page .ahumada-page-inicio .svc:hover .svc__num,
body.elementor-editor-active .ahumada-page-inicio .svc:hover .svc__num {
  color: var(--gold-deep) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__desc,
body.elementor-editor-active .ahumada-page-inicio .svc__desc,
body.ahumada-identica-page .ahumada-page-inicio .svc:hover .svc__desc,
body.elementor-editor-active .ahumada-page-inicio .svc:hover .svc__desc {
  color: var(--ink-soft) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__media,
body.elementor-editor-active .ahumada-page-inicio .svc__media {
  display: block !important;
  grid-column: 3 !important;
  grid-row: 1 !important;
  width: 100% !important;
  height: clamp(100px, 10vw, 136px) !important;
  margin: 0 !important;
  border: 1px solid rgba(190,151,88,.32) !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  background: var(--navy) !important;
  box-shadow: 0 18px 45px -34px rgba(10,26,52,.56) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__media::after,
body.elementor-editor-active .ahumada-page-inicio .svc__media::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(12,31,63,.02), rgba(12,31,63,.18)) !important;
  pointer-events: none !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__media img,
body.elementor-editor-active .ahumada-page-inicio .svc__media img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  transform: scale(1) !important;
  transition: transform .55s var(--ease), filter .45s var(--ease) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc:hover .svc__media img,
body.elementor-editor-active .ahumada-page-inicio .svc:hover .svc__media img {
  transform: scale(1.045) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc__arrow,
body.elementor-editor-active .ahumada-page-inicio .svc__arrow {
  grid-column: 4 !important;
  grid-row: 1 !important;
  background: transparent !important;
  border-color: rgba(190,151,88,.38) !important;
  color: var(--gold-deep) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .svc:hover .svc__arrow,
body.elementor-editor-active .ahumada-page-inicio .svc:hover .svc__arrow {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: var(--navy) !important;
}

/* SERVICIOS · convertir cards en bloques horizontales limpios */
body.ahumada-identica-page .ahumada-page-servicios .svc-cards,
body.elementor-editor-active .ahumada-page-servicios .svc-cards {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(1.2rem, 2.4vw, 1.8rem) !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service,
body.elementor-editor-active .ahumada-page-servicios .card--service {
  --aa-card-pad: clamp(1.45rem, 3vw, 2.6rem);
  display: grid !important;
  grid-template-columns: minmax(0, 1.36fr) minmax(250px, .64fr) !important;
  column-gap: clamp(1.4rem, 3.5vw, 3rem) !important;
  align-items: stretch !important;
  min-height: auto !important;
  padding: var(--aa-card-pad) !important;
  padding-right: var(--aa-card-pad) !important;
  background: var(--paper) !important;
  border: 1px solid var(--line) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service::before,
body.elementor-editor-active .ahumada-page-servicios .card--service::before {
  z-index: 4 !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service .card__media,
body.elementor-editor-active .ahumada-page-servicios .card--service .card__media {
  position: relative !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 / 10 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 285px !important;
  margin: 0 !important;
  border: 1px solid rgba(190,151,88,.34) !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  background: var(--navy) !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service .card__media::after,
body.elementor-editor-active .ahumada-page-servicios .card--service .card__media::after {
  background: linear-gradient(180deg, rgba(12,31,63,.02), rgba(12,31,63,.24)) !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service .card__media img,
body.elementor-editor-active .ahumada-page-servicios .card--service .card__media img {
  width: 100% !important;
  height: 100% !important;
  min-height: inherit !important;
  object-fit: cover !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service > *:not(.card__media),
body.elementor-editor-active .ahumada-page-servicios .card--service > *:not(.card__media) {
  grid-column: 1 !important;
  position: relative !important;
  z-index: 2 !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service .card__num,
body.elementor-editor-active .ahumada-page-servicios .card--service .card__num {
  position: relative !important;
  top: auto !important;
  right: auto !important;
  width: max-content !important;
  margin: 0 0 .8rem !important;
  font-family: var(--display) !important;
  font-size: clamp(1.05rem, 1.4vw, 1.25rem) !important;
  color: var(--gold-deep) !important;
  line-height: 1 !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service .card__ico,
body.elementor-editor-active .ahumada-page-servicios .card--service .card__ico {
  width: 46px !important;
  height: 46px !important;
  margin: 0 0 1rem !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service .card__title,
body.elementor-editor-active .ahumada-page-servicios .card--service .card__title {
  color: var(--navy) !important;
  font-size: clamp(1.55rem, 3vw, 2.35rem) !important;
  line-height: 1.08 !important;
  margin: 0 0 .7rem !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service p,
body.elementor-editor-active .ahumada-page-servicios .card--service p {
  max-width: 62ch !important;
  margin: 0 0 1rem !important;
  color: var(--ink-soft) !important;
}

body.ahumada-identica-page .ahumada-page-servicios .card--service ul.ticks,
body.elementor-editor-active .ahumada-page-servicios .card--service ul.ticks {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: .55rem 1.2rem !important;
  margin-top: .8rem !important;
}

body.ahumada-identica-page .ahumada-page-servicios .svc-cards > .card:not(.card--service),
body.elementor-editor-active .ahumada-page-servicios .svc-cards > .card:not(.card--service) {
  min-height: 260px !important;
  border-radius: 8px !important;
}

/* Tablet */
@media (max-width: 1024px) {
  body.ahumada-identica-page .services__head,
  body.elementor-editor-active .services__head {
    align-items: flex-start !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc,
  body.elementor-editor-active .ahumada-page-inicio .svc {
    grid-template-columns: 2.8rem minmax(0, 1fr) minmax(170px, 230px) !important;
    column-gap: 1.2rem !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__arrow,
  body.elementor-editor-active .ahumada-page-inicio .svc__arrow {
    display: none !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__media,
  body.elementor-editor-active .ahumada-page-inicio .svc__media {
    grid-column: 3 !important;
    height: 124px !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service,
  body.elementor-editor-active .ahumada-page-servicios .card--service {
    grid-template-columns: minmax(0, 1fr) minmax(220px, 34%) !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service .card__media,
  body.elementor-editor-active .ahumada-page-servicios .card--service .card__media {
    min-height: 250px !important;
  }
}

/* Móvil */
@media (max-width: 760px) {
  body.ahumada-identica-page .services__head,
  body.elementor-editor-active .services__head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1.2rem !important;
    margin-bottom: 1.5rem !important;
  }

  body.ahumada-identica-page .services__head .link-underline,
  body.elementor-editor-active .services__head .link-underline {
    justify-self: flex-start !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc-list,
  body.elementor-editor-active .ahumada-page-inicio .svc-list {
    display: grid !important;
    gap: 1rem !important;
    border: 0 !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc,
  body.elementor-editor-active .ahumada-page-inicio .svc {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .7rem !important;
    min-height: 0 !important;
    padding: 1.05rem !important;
    background: var(--paper) !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__bg,
  body.elementor-editor-active .ahumada-page-inicio .svc__bg {
    display: none !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__num,
  body.elementor-editor-active .ahumada-page-inicio .svc__num,
  body.ahumada-identica-page .ahumada-page-inicio .svc > div:not(.svc__bg):not(.svc__media),
  body.elementor-editor-active .ahumada-page-inicio .svc > div:not(.svc__bg):not(.svc__media),
  body.ahumada-identica-page .ahumada-page-inicio .svc__media,
  body.elementor-editor-active .ahumada-page-inicio .svc__media {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__num,
  body.elementor-editor-active .ahumada-page-inicio .svc__num {
    width: auto !important;
    font-size: 1rem !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__title,
  body.elementor-editor-active .ahumada-page-inicio .svc__title {
    font-size: clamp(1.45rem, 8vw, 2rem) !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__media,
  body.elementor-editor-active .ahumada-page-inicio .svc__media {
    width: 100% !important;
    height: 190px !important;
    margin-top: .4rem !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__arrow,
  body.elementor-editor-active .ahumada-page-inicio .svc__arrow {
    display: none !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .svc-cards,
  body.elementor-editor-active .ahumada-page-servicios .svc-cards {
    gap: 1rem !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service,
  body.elementor-editor-active .ahumada-page-servicios .card--service {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0 !important;
    border-radius: 8px !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service .card__media,
  body.elementor-editor-active .ahumada-page-servicios .card--service .card__media {
    order: 0 !important;
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    height: 220px !important;
    min-height: 220px !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    border-bottom: 1px solid rgba(190,151,88,.34) !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service > *:not(.card__media),
  body.elementor-editor-active .ahumada-page-servicios .card--service > *:not(.card__media) {
    grid-column: auto !important;
    margin-left: 1.2rem !important;
    margin-right: 1.2rem !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service .card__num,
  body.elementor-editor-active .ahumada-page-servicios .card--service .card__num {
    margin-top: 1.3rem !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service ul.ticks,
  body.elementor-editor-active .ahumada-page-servicios .card--service ul.ticks {
    grid-template-columns: 1fr !important;
    margin-bottom: 1.3rem !important;
  }
}

@media (max-width: 480px) {
  body.ahumada-identica-page .section,
  body.elementor-editor-active .section {
    padding-block: clamp(3rem, 14vw, 4.4rem) !important;
  }

  body.ahumada-identica-page .page-hero,
  body.elementor-editor-active .page-hero {
    min-height: 52svh !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .svc__media,
  body.elementor-editor-active .ahumada-page-inicio .svc__media,
  body.ahumada-identica-page .ahumada-page-servicios .card--service .card__media,
  body.elementor-editor-active .ahumada-page-servicios .card--service .card__media {
    height: 188px !important;
    min-height: 188px !important;
  }

  body.ahumada-identica-page .ahumada-page-servicios .card--service .card__title,
  body.elementor-editor-active .ahumada-page-servicios .card--service .card__title {
    font-size: clamp(1.45rem, 9vw, 1.85rem) !important;
  }
}

/* =========================================================
   V10 · Cabecera de Áreas de práctica saneada
   - Menos descompensada en escritorio.
   - Título legible, sin saltos feos ni espacios raros.
   - CTA visible y alineado.
   - Responsive específico para tablet y móvil.
   ========================================================= */
body.ahumada-identica-page .ahumada-page-inicio .services__head,
body.elementor-editor-active .ahumada-page-inicio .services__head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: end !important;
  gap: clamp(1.6rem, 4vw, 4rem) !important;
  width: 100% !important;
  margin-bottom: clamp(2rem, 4vw, 3.2rem) !important;
  padding-bottom: clamp(1.8rem, 3vw, 2.6rem) !important;
  border-bottom: 1px solid rgba(190,151,88,.30) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head > div,
body.elementor-editor-active .ahumada-page-inicio .services__head > div {
  min-width: 0 !important;
  max-width: 900px !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .eyebrow,
body.elementor-editor-active .ahumada-page-inicio .services__head .eyebrow {
  margin-bottom: clamp(.65rem, 1.2vw, .95rem) !important;
  font-size: clamp(.66rem, .76vw, .76rem) !important;
  letter-spacing: clamp(.20em, .52vw, .34em) !important;
  white-space: nowrap !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .section-title,
body.elementor-editor-active .ahumada-page-inicio .services__head .section-title {
  margin: 0 !important;
  max-width: 12.5em !important;
  font-size: clamp(2.55rem, 5.15vw, 5.05rem) !important;
  line-height: .95 !important;
  letter-spacing: -.028em !important;
  text-wrap: balance !important;
  overflow: visible !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .section-title br,
body.elementor-editor-active .ahumada-page-inicio .services__head .section-title br {
  display: block !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .section-title .accent,
body.elementor-editor-active .ahumada-page-inicio .services__head .section-title .accent {
  display: inline-block !important;
  margin-top: .04em !important;
  color: var(--gold-deep) !important;
  font-style: italic !important;
  letter-spacing: -.035em !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .link-underline,
body.elementor-editor-active .ahumada-page-inicio .services__head .link-underline {
  justify-self: end !important;
  align-self: end !important;
  margin: 0 0 .55rem 0 !important;
  padding: .86rem 1.08rem !important;
  border: 1px solid rgba(190,151,88,.34) !important;
  border-radius: 999px !important;
  background: rgba(190,151,88,.07) !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: .04em !important;
  white-space: nowrap !important;
  transition: background .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease), color .35s var(--ease) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .link-underline::after,
body.elementor-editor-active .ahumada-page-inicio .services__head .link-underline::after {
  display: none !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .link-underline:hover,
body.elementor-editor-active .ahumada-page-inicio .services__head .link-underline:hover {
  background: var(--navy) !important;
  border-color: var(--navy) !important;
  color: var(--cream) !important;
  transform: translateY(-2px) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .services__head .line,
body.elementor-editor-active .ahumada-page-inicio .services__head .line {
  overflow: visible !important;
}

@media (max-width: 1100px) {
  body.ahumada-identica-page .ahumada-page-inicio .services__head,
  body.elementor-editor-active .ahumada-page-inicio .services__head {
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 1.6rem !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .section-title,
  body.elementor-editor-active .ahumada-page-inicio .services__head .section-title {
    max-width: 11.4em !important;
    font-size: clamp(2.45rem, 5vw, 4.35rem) !important;
  }
}

@media (max-width: 860px) {
  body.ahumada-identica-page .ahumada-page-inicio .services__head,
  body.elementor-editor-active .ahumada-page-inicio .services__head {
    grid-template-columns: 1fr !important;
    align-items: start !important;
    gap: 1.15rem !important;
    margin-bottom: 1.55rem !important;
    padding-bottom: 1.45rem !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head > div,
  body.elementor-editor-active .ahumada-page-inicio .services__head > div {
    max-width: 100% !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .section-title,
  body.elementor-editor-active .ahumada-page-inicio .services__head .section-title {
    max-width: 10.8em !important;
    font-size: clamp(2.25rem, 8.8vw, 3.9rem) !important;
    line-height: .98 !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .link-underline,
  body.elementor-editor-active .ahumada-page-inicio .services__head .link-underline {
    justify-self: start !important;
    margin: .15rem 0 0 !important;
  }
}

@media (max-width: 560px) {
  body.ahumada-identica-page .ahumada-page-inicio .services,
  body.elementor-editor-active .ahumada-page-inicio .services {
    padding-top: clamp(3.3rem, 14vw, 4.4rem) !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .eyebrow,
  body.elementor-editor-active .ahumada-page-inicio .services__head .eyebrow {
    font-size: .64rem !important;
    letter-spacing: .18em !important;
    white-space: normal !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .eyebrow::before,
  body.elementor-editor-active .ahumada-page-inicio .services__head .eyebrow::before {
    width: 26px !important;
    flex: 0 0 26px !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .section-title,
  body.elementor-editor-active .ahumada-page-inicio .services__head .section-title {
    max-width: 9.6em !important;
    font-size: clamp(2.05rem, 10.8vw, 3.05rem) !important;
    line-height: 1 !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .services__head .link-underline,
  body.elementor-editor-active .ahumada-page-inicio .services__head .link-underline {
    width: max-content !important;
    max-width: 100% !important;
    padding: .82rem 1rem !important;
    font-size: .76rem !important;
  }
}

/* =========================================================
   V11 · Cabecera Áreas de práctica reconstruida
   - Evita desbordes en anchos intermedios.
   - Mantiene texto visible, limpio y con interlineado correcto.
   - CTA alineado sin salirse de pantalla.
   ========================================================= */
body.ahumada-identica-page .ahumada-page-inicio .services#areas,
body.elementor-editor-active .ahumada-page-inicio .services#areas {
  background: var(--cream) !important;
  overflow: hidden !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head {
  display: grid !important;
  grid-template-columns: minmax(0, 760px) auto !important;
  align-items: end !important;
  justify-content: space-between !important;
  gap: clamp(1.5rem, 4vw, 4.25rem) !important;
  width: 100% !important;
  margin: 0 0 clamp(2.2rem, 4.2vw, 3.9rem) !important;
  padding: 0 0 clamp(1.7rem, 3vw, 2.45rem) !important;
  border-bottom: 1px solid rgba(198,163,90,.32) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__copy,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__copy {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 760px !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head .eyebrow,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head .eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: .8em !important;
  margin: 0 0 clamp(.8rem, 1.3vw, 1.05rem) !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: clamp(.66rem, .72vw, .74rem) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .32em !important;
  text-transform: uppercase !important;
  white-space: normal !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head .eyebrow::before,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head .eyebrow::before {
  width: 36px !important;
  min-width: 36px !important;
  flex: 0 0 36px !important;
  height: 1px !important;
  background: var(--gold) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-title {
  display: block !important;
  width: 100% !important;
  max-width: 760px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--ink) !important;
  font-family: var(--display) !important;
  font-size: clamp(3rem, 4.75vw, 4.95rem) !important;
  font-weight: 600 !important;
  line-height: .98 !important;
  letter-spacing: -.028em !important;
  text-wrap: balance !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  overflow: visible !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title__line,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-title__line {
  display: block !important;
  width: max-content !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: inherit !important;
  color: inherit !important;
  white-space: normal !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title__line--accent,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-title__line--accent {
  display: block !important;
  margin-top: .02em !important;
  color: var(--gold-deep) !important;
  font-style: italic !important;
  letter-spacing: -.04em !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__link,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__link {
  justify-self: end !important;
  align-self: end !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  max-width: 100% !important;
  margin: 0 0 .6rem !important;
  padding: .95rem 1.22rem !important;
  border: 1px solid rgba(198,163,90,.42) !important;
  border-radius: 999px !important;
  background: rgba(198,163,90,.08) !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: .035em !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  transition: background .35s var(--ease), border-color .35s var(--ease), color .35s var(--ease), transform .35s var(--ease) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__link::after,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__link::after {
  display: none !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__link:hover,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__link:hover {
  background: var(--navy) !important;
  border-color: var(--navy) !important;
  color: var(--cream) !important;
  transform: translateY(-2px) !important;
}

/* Anchos intermedios: el CTA baja para no romper la cabecera ni salirse de pantalla. */
@media (max-width: 1180px) {
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head {
    grid-template-columns: 1fr !important;
    align-items: start !important;
    justify-content: start !important;
    gap: 1.2rem !important;
    margin-bottom: clamp(1.85rem, 4vw, 3rem) !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__copy,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__copy,
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-title {
    max-width: 820px !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__link,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__link {
    justify-self: start !important;
    align-self: start !important;
    margin: .1rem 0 0 !important;
  }
}

@media (max-width: 760px) {
  body.ahumada-identica-page .ahumada-page-inicio .services#areas,
  body.elementor-editor-active .ahumada-page-inicio .services#areas {
    padding-top: clamp(3.8rem, 13vw, 5rem) !important;
    padding-bottom: clamp(3.6rem, 12vw, 5rem) !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head {
    padding-bottom: 1.35rem !important;
    margin-bottom: 1.55rem !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head .eyebrow,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head .eyebrow {
    gap: .65em !important;
    font-size: .64rem !important;
    letter-spacing: .2em !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head .eyebrow::before,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head .eyebrow::before {
    width: 28px !important;
    min-width: 28px !important;
    flex-basis: 28px !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-title {
    max-width: 100% !important;
    font-size: clamp(2.38rem, 11vw, 3.25rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -.025em !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title__line,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-title__line {
    width: 100% !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__link,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__link {
    padding: .82rem 1rem !important;
    font-size: .74rem !important;
  }
}

@media (max-width: 420px) {
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-title,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-title {
    font-size: clamp(2.05rem, 11.5vw, 2.7rem) !important;
    line-height: 1.04 !important;
  }

  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-head__link,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-head__link {
    white-space: normal !important;
    text-align: center !important;
  }
}


/* =========================================================
   V12 · BLOQUE ÁREAS DE PRÁCTICA — FIX DEFINITIVO
   Este bloque deja de depender de .services__head / .section-title para que
   ninguna regla anterior de Elementor, del tema o de versiones previas lo rompa.
   ========================================================= */
body.ahumada-identica-page .ahumada-page-inicio #areas,
body.elementor-editor-active .ahumada-page-inicio #areas {
  background: var(--cream) !important;
  padding-top: clamp(78px, 8.2vw, 124px) !important;
  padding-bottom: clamp(78px, 8.2vw, 124px) !important;
  overflow: hidden !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-head,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-head {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: clamp(28px, 5vw, 72px) !important;
  width: 100% !important;
  margin: 0 0 clamp(42px, 5vw, 70px) !important;
  padding: 0 0 clamp(28px, 3vw, 42px) !important;
  border-bottom: 1px solid rgba(198,163,90,.30) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-copy,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-copy {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: 820px !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-eyebrow,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: .75rem !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .34em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-eyebrow::before,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-eyebrow::before {
  content: "" !important;
  display: inline-block !important;
  width: 40px !important;
  height: 1px !important;
  flex: 0 0 40px !important;
  background: var(--gold) !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: 820px !important;
  color: var(--ink) !important;
  font-family: var(--display) !important;
  font-size: clamp(52px, 5.15vw, 82px) !important;
  font-weight: 600 !important;
  line-height: .98 !important;
  letter-spacing: -.035em !important;
  text-wrap: balance !important;
  overflow: visible !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title span,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title span,
body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title em,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title em {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: inherit !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  white-space: normal !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title em,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title em {
  color: var(--gold-deep) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  letter-spacing: -.045em !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-link,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-link {
  flex: 0 0 auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .03em !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-link:hover,
body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-link:hover {
  color: var(--navy) !important;
}

@media (max-width: 1180px) {
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-head,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-head {
    align-items: flex-start !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title {
    font-size: clamp(46px, 6vw, 68px) !important;
    max-width: 720px !important;
  }
}

@media (max-width: 920px) {
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-head,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-head {
    display: block !important;
    margin-bottom: 32px !important;
    padding-bottom: 28px !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-copy,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-copy {
    max-width: 100% !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title {
    max-width: 100% !important;
    font-size: clamp(40px, 8.8vw, 58px) !important;
    line-height: 1.02 !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-link,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-link {
    margin-top: 22px !important;
    margin-bottom: 0 !important;
  }
}

@media (max-width: 560px) {
  body.ahumada-identica-page .ahumada-page-inicio #areas,
  body.elementor-editor-active .ahumada-page-inicio #areas {
    padding-top: 58px !important;
    padding-bottom: 58px !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-eyebrow,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-eyebrow {
    gap: .55rem !important;
    font-size: 10px !important;
    letter-spacing: .22em !important;
    white-space: normal !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-eyebrow::before,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-eyebrow::before {
    width: 28px !important;
    flex-basis: 28px !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-title,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-title {
    font-size: clamp(34px, 11vw, 46px) !important;
    line-height: 1.04 !important;
    letter-spacing: -.025em !important;
  }
  body.ahumada-identica-page .ahumada-page-inicio .aa-areas-clean-link,
  body.elementor-editor-active .ahumada-page-inicio .aa-areas-clean-link {
    font-size: 14px !important;
  }
}


/* =========================================================
   V13 · ARREGLO REAL DEL BLOQUE "ÁREAS DE PRÁCTICA"
   Regla final sin depender del body, del tema ni de clases antiguas.
   Fuerza una composición estable: texto izquierda + botón derecha.
   ========================================================= */
.ahumada-original-page.ahumada-page-inicio #areas,
.ahumada-original-page .ahumada-page-inicio #areas,
.ahumada-page-inicio #areas,
#areas.services {
  background: #f6f1e7 !important;
  padding: 92px 0 96px !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.ahumada-original-page.ahumada-page-inicio #areas > .container,
.ahumada-page-inicio #areas > .container,
#areas.services > .container {
  width: min(100% - 48px, 1240px) !important;
  max-width: 1240px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.ahumada-original-page .aa-areas-clean-head,
.ahumada-page-inicio .aa-areas-clean-head,
#aa-force-areas-head,
.aa-areas-clean-head {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: minmax(0, 760px) auto !important;
  align-items: end !important;
  justify-content: space-between !important;
  column-gap: 48px !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 0 48px !important;
  padding: 0 0 34px !important;
  border-bottom: 1px solid rgba(198, 163, 90, .34) !important;
  background: transparent !important;
  overflow: visible !important;
}

.ahumada-original-page .aa-areas-clean-copy,
.ahumada-page-inicio .aa-areas-clean-copy,
.aa-areas-clean-copy {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 760px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.ahumada-original-page .aa-areas-clean-eyebrow,
.ahumada-page-inicio .aa-areas-clean-eyebrow,
.aa-areas-clean-eyebrow {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  color: #a9842f !important;
  font-family: "Montserrat", system-ui, sans-serif !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: .34em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.ahumada-original-page .aa-areas-clean-eyebrow::before,
.ahumada-page-inicio .aa-areas-clean-eyebrow::before,
.aa-areas-clean-eyebrow::before {
  content: "" !important;
  display: block !important;
  width: 42px !important;
  min-width: 42px !important;
  height: 1px !important;
  background: #c6a35a !important;
}

.ahumada-original-page .aa-areas-clean-title,
.ahumada-page-inicio .aa-areas-clean-title,
.aa-areas-clean-title {
  display: block !important;
  width: 100% !important;
  max-width: 760px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #0c1424 !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: clamp(46px, 4.6vw, 68px) !important;
  line-height: 1.02 !important;
  font-weight: 600 !important;
  letter-spacing: -.035em !important;
  text-align: left !important;
  text-transform: none !important;
  overflow: visible !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.ahumada-original-page .aa-areas-clean-title span,
.ahumada-original-page .aa-areas-clean-title em,
.ahumada-page-inicio .aa-areas-clean-title span,
.ahumada-page-inicio .aa-areas-clean-title em,
.aa-areas-clean-title span,
.aa-areas-clean-title em {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: inherit !important;
  font-family: inherit !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  text-align: left !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.ahumada-original-page .aa-areas-clean-title em,
.ahumada-page-inicio .aa-areas-clean-title em,
.aa-areas-clean-title em {
  color: #a9842f !important;
  font-style: italic !important;
  letter-spacing: -.045em !important;
}

.ahumada-original-page .aa-areas-clean-link,
.ahumada-page-inicio .aa-areas-clean-link,
.aa-areas-clean-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  justify-self: end !important;
  align-self: end !important;
  min-width: max-content !important;
  margin: 0 0 12px !important;
  padding: 14px 22px !important;
  border: 1px solid rgba(169,132,47,.45) !important;
  border-radius: 999px !important;
  background: rgba(198,163,90,.10) !important;
  color: #a9842f !important;
  font-family: "Montserrat", system-ui, sans-serif !important;
  font-size: 14px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  pointer-events: auto !important;
}

.ahumada-original-page .aa-areas-clean-link:hover,
.ahumada-page-inicio .aa-areas-clean-link:hover,
.aa-areas-clean-link:hover {
  background: #0c1f3f !important;
  border-color: #0c1f3f !important;
  color: #f6f1e7 !important;
}

@media (max-width: 1024px) {
  .ahumada-original-page .aa-areas-clean-head,
  .ahumada-page-inicio .aa-areas-clean-head,
  .aa-areas-clean-head {
    grid-template-columns: 1fr !important;
    row-gap: 24px !important;
    align-items: start !important;
    margin-bottom: 40px !important;
  }
  .ahumada-original-page .aa-areas-clean-link,
  .ahumada-page-inicio .aa-areas-clean-link,
  .aa-areas-clean-link {
    justify-self: start !important;
    align-self: start !important;
    margin: 0 !important;
  }
}

@media (max-width: 680px) {
  .ahumada-original-page.ahumada-page-inicio #areas,
  .ahumada-page-inicio #areas,
  #areas.services {
    padding: 58px 0 64px !important;
  }
  .ahumada-original-page.ahumada-page-inicio #areas > .container,
  .ahumada-page-inicio #areas > .container,
  #areas.services > .container {
    width: min(100% - 32px, 1240px) !important;
  }
  .ahumada-original-page .aa-areas-clean-head,
  .ahumada-page-inicio .aa-areas-clean-head,
  .aa-areas-clean-head {
    padding-bottom: 26px !important;
    margin-bottom: 30px !important;
  }
  .ahumada-original-page .aa-areas-clean-eyebrow,
  .ahumada-page-inicio .aa-areas-clean-eyebrow,
  .aa-areas-clean-eyebrow {
    font-size: 10px !important;
    letter-spacing: .22em !important;
    gap: 10px !important;
    white-space: normal !important;
  }
  .ahumada-original-page .aa-areas-clean-eyebrow::before,
  .ahumada-page-inicio .aa-areas-clean-eyebrow::before,
  .aa-areas-clean-eyebrow::before {
    width: 28px !important;
    min-width: 28px !important;
  }
  .ahumada-original-page .aa-areas-clean-title,
  .ahumada-page-inicio .aa-areas-clean-title,
  .aa-areas-clean-title {
    font-size: clamp(38px, 12vw, 48px) !important;
    line-height: 1.04 !important;
  }
  .ahumada-original-page .aa-areas-clean-link,
  .ahumada-page-inicio .aa-areas-clean-link,
  .aa-areas-clean-link {
    width: 100% !important;
    min-width: 0 !important;
    padding: 14px 16px !important;
    font-size: 13px !important;
  }
}

/* =========================================================
   V13 · ÁREAS DE PRÁCTICA — BLOQUE ESTABLE
   Reemplaza por completo los intentos anteriores. No depende de .services__head,
   .section-title ni de clases que Elementor pueda alterar.
   ========================================================= */
.ahumada-original-page .ahumada-page-inicio #areas,
.ahumada-original-page.ahumada-page-inicio #areas,
body.ahumada-identica-page .ahumada-page-inicio #areas,
body.elementor-editor-active .ahumada-page-inicio #areas {
  background: var(--cream) !important;
  padding: clamp(72px, 8vw, 112px) 0 !important;
  overflow: visible !important;
}

.ahumada-original-page .ahumada-page-inicio #areas > .container,
.ahumada-original-page.ahumada-page-inicio #areas > .container,
body.ahumada-identica-page .ahumada-page-inicio #areas > .container,
body.elementor-editor-active .ahumada-page-inicio #areas > .container {
  width: min(calc(100% - 48px), 1240px) !important;
  max-width: 1240px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.ahumada-original-page .aa-practice-intro,
body.ahumada-identica-page .aa-practice-intro,
body.elementor-editor-active .aa-practice-intro {
  display: grid !important;
  grid-template-columns: minmax(0, 760px) auto !important;
  align-items: end !important;
  justify-content: space-between !important;
  column-gap: clamp(28px, 5vw, 64px) !important;
  row-gap: 24px !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 0 clamp(40px, 5vw, 64px) !important;
  padding: 0 0 clamp(28px, 3vw, 40px) !important;
  border-bottom: 1px solid rgba(198,163,90,.32) !important;
  position: relative !important;
  overflow: visible !important;
  clear: both !important;
}

.ahumada-original-page .aa-practice-intro__text,
body.ahumada-identica-page .aa-practice-intro__text,
body.elementor-editor-active .aa-practice-intro__text {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 760px !important;
}

.ahumada-original-page .aa-practice-intro__eyebrow,
body.ahumada-identica-page .aa-practice-intro__eyebrow,
body.elementor-editor-active .aa-practice-intro__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .32em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.ahumada-original-page .aa-practice-intro__eyebrow::before,
body.ahumada-identica-page .aa-practice-intro__eyebrow::before,
body.elementor-editor-active .aa-practice-intro__eyebrow::before {
  content: "" !important;
  width: 40px !important;
  height: 1px !important;
  flex: 0 0 40px !important;
  background: var(--gold) !important;
}

.ahumada-original-page .aa-practice-intro__title,
body.ahumada-identica-page .aa-practice-intro__title,
body.elementor-editor-active .aa-practice-intro__title {
  display: block !important;
  width: 100% !important;
  max-width: 760px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--ink) !important;
  font-family: var(--display) !important;
  font-size: clamp(48px, 4.35vw, 70px) !important;
  font-weight: 600 !important;
  line-height: .98 !important;
  letter-spacing: -.035em !important;
  text-align: left !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  white-space: normal !important;
  overflow: visible !important;
  text-wrap: balance !important;
}

.ahumada-original-page .aa-practice-intro__title span,
body.ahumada-identica-page .aa-practice-intro__title span,
body.elementor-editor-active .aa-practice-intro__title span {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  color: inherit !important;
  font: inherit !important;
  line-height: inherit !important;
  letter-spacing: inherit !important;
  white-space: normal !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  filter: none !important;
}

.ahumada-original-page .aa-practice-intro__title .aa-practice-intro__accent,
body.ahumada-identica-page .aa-practice-intro__title .aa-practice-intro__accent,
body.elementor-editor-active .aa-practice-intro__title .aa-practice-intro__accent {
  color: var(--gold-deep) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  letter-spacing: -.045em !important;
}

.ahumada-original-page .aa-practice-intro__link,
body.ahumada-identica-page .aa-practice-intro__link,
body.elementor-editor-active .aa-practice-intro__link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  justify-self: end !important;
  align-self: center !important;
  min-width: max-content !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--gold-deep) !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .03em !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  position: relative !important;
  z-index: 5 !important;
}

.ahumada-original-page .aa-practice-intro__link:hover,
body.ahumada-identica-page .aa-practice-intro__link:hover,
body.elementor-editor-active .aa-practice-intro__link:hover {
  color: var(--navy) !important;
}

.ahumada-original-page .aa-practice-intro__link::after,
body.ahumada-identica-page .aa-practice-intro__link::after,
body.elementor-editor-active .aa-practice-intro__link::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: -6px !important;
  height: 1px !important;
  background: currentColor !important;
  transform: scaleX(0) !important;
  transform-origin: left !important;
  transition: transform .35s var(--ease) !important;
}

.ahumada-original-page .aa-practice-intro__link:hover::after,
body.ahumada-identica-page .aa-practice-intro__link:hover::after,
body.elementor-editor-active .aa-practice-intro__link:hover::after {
  transform: scaleX(1) !important;
}

/* Por si la página aún tiene el HTML de una versión anterior cargado en Elementor */
.ahumada-original-page .ahumada-page-inicio #areas .services__head,
body.ahumada-identica-page .ahumada-page-inicio #areas .services__head,
body.elementor-editor-active .ahumada-page-inicio #areas .services__head,
.ahumada-original-page .ahumada-page-inicio #areas .aa-areas-clean-head,
body.ahumada-identica-page .ahumada-page-inicio #areas .aa-areas-clean-head,
body.elementor-editor-active .ahumada-page-inicio #areas .aa-areas-clean-head {
  display: none !important;
}

@media (max-width: 1180px) {
  .ahumada-original-page .aa-practice-intro,
  body.ahumada-identica-page .aa-practice-intro,
  body.elementor-editor-active .aa-practice-intro {
    grid-template-columns: 1fr !important;
    align-items: start !important;
    justify-content: start !important;
  }
  .ahumada-original-page .aa-practice-intro__text,
  body.ahumada-identica-page .aa-practice-intro__text,
  body.elementor-editor-active .aa-practice-intro__text,
  .ahumada-original-page .aa-practice-intro__title,
  body.ahumada-identica-page .aa-practice-intro__title,
  body.elementor-editor-active .aa-practice-intro__title {
    max-width: 860px !important;
  }
  .ahumada-original-page .aa-practice-intro__link,
  body.ahumada-identica-page .aa-practice-intro__link,
  body.elementor-editor-active .aa-practice-intro__link {
    justify-self: start !important;
  }
}

@media (max-width: 768px) {
  .ahumada-original-page .ahumada-page-inicio #areas,
  body.ahumada-identica-page .ahumada-page-inicio #areas,
  body.elementor-editor-active .ahumada-page-inicio #areas {
    padding: 58px 0 !important;
  }
  .ahumada-original-page .ahumada-page-inicio #areas > .container,
  body.ahumada-identica-page .ahumada-page-inicio #areas > .container,
  body.elementor-editor-active .ahumada-page-inicio #areas > .container {
    width: min(calc(100% - 36px), 1240px) !important;
  }
  .ahumada-original-page .aa-practice-intro,
  body.ahumada-identica-page .aa-practice-intro,
  body.elementor-editor-active .aa-practice-intro {
    margin-bottom: 32px !important;
    padding-bottom: 26px !important;
  }
  .ahumada-original-page .aa-practice-intro__title,
  body.ahumada-identica-page .aa-practice-intro__title,
  body.elementor-editor-active .aa-practice-intro__title {
    font-size: clamp(38px, 10.5vw, 52px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.028em !important;
    text-wrap: initial !important;
  }
  .ahumada-original-page .aa-practice-intro__eyebrow,
  body.ahumada-identica-page .aa-practice-intro__eyebrow,
  body.elementor-editor-active .aa-practice-intro__eyebrow {
    font-size: 10px !important;
    letter-spacing: .22em !important;
    gap: 9px !important;
  }
  .ahumada-original-page .aa-practice-intro__eyebrow::before,
  body.ahumada-identica-page .aa-practice-intro__eyebrow::before,
  body.elementor-editor-active .aa-practice-intro__eyebrow::before {
    width: 28px !important;
    flex-basis: 28px !important;
  }
}

@media (max-width: 420px) {
  .ahumada-original-page .aa-practice-intro__title,
  body.ahumada-identica-page .aa-practice-intro__title,
  body.elementor-editor-active .aa-practice-intro__title {
    font-size: clamp(34px, 11vw, 44px) !important;
  }
  .ahumada-original-page .aa-practice-intro__link,
  body.ahumada-identica-page .aa-practice-intro__link,
  body.elementor-editor-active .aa-practice-intro__link {
    font-size: 14px !important;
  }
}

/* =========================================================
   V14 · ÁREAS DE PRÁCTICA — RECONSTRUCCIÓN REAL DEL BLOQUE
   Bloque aislado con ID propio. No hereda .services__head, .section-title,
   estilos del tema ni ajustes antiguos de Elementor.
   ========================================================= */
#areas.aa-final-areas-section,
body.ahumada-identica-page #areas.aa-final-areas-section,
body.elementor-editor-active #areas.aa-final-areas-section {
  box-sizing: border-box !important;
  display: block !important;
  width: 100% !important;
  background: #f6f1e7 !important;
  padding: clamp(78px, 8vw, 112px) 0 clamp(82px, 8vw, 118px) !important;
  margin: 0 !important;
  overflow: hidden !important;
}

#areas.aa-final-areas-section > .aa-final-areas-container,
body.ahumada-identica-page #areas.aa-final-areas-section > .aa-final-areas-container,
body.elementor-editor-active #areas.aa-final-areas-section > .aa-final-areas-container {
  box-sizing: border-box !important;
  display: block !important;
  width: min(calc(100% - 96px), 1240px) !important;
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

#aa-final-practice-head,
body.ahumada-identica-page #aa-final-practice-head,
body.elementor-editor-active #aa-final-practice-head {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: minmax(0, 760px) max-content !important;
  align-items: end !important;
  justify-content: space-between !important;
  gap: 30px clamp(40px, 7vw, 96px) !important;
  width: 100% !important;
  max-width: 100% !important;
  min-height: 0 !important;
  margin: 0 0 clamp(42px, 5vw, 64px) !important;
  padding: 0 0 clamp(32px, 3.4vw, 44px) !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(198, 163, 90, .38) !important;
  background: transparent !important;
  overflow: visible !important;
  position: relative !important;
  float: none !important;
  clear: both !important;
  transform: none !important;
  opacity: 1 !important;
  visibility: visible !important;
}

#aa-final-practice-head *,
body.ahumada-identica-page #aa-final-practice-head *,
body.elementor-editor-active #aa-final-practice-head * {
  box-sizing: border-box !important;
}

#aa-final-practice-head .aa-final-practice-copy,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-copy,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-copy {
  display: block !important;
  width: 100% !important;
  max-width: 760px !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

#aa-final-practice-head .aa-final-practice-kicker,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-kicker,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 13px !important;
  width: auto !important;
  max-width: 100% !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  color: #a9842f !important;
  font-family: "Montserrat", Arial, sans-serif !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-style: normal !important;
  font-weight: 700 !important;
  letter-spacing: .34em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

#aa-final-practice-head .aa-final-practice-kicker::before,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-kicker::before,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-kicker::before {
  content: "" !important;
  display: block !important;
  width: 42px !important;
  height: 1px !important;
  min-width: 42px !important;
  background: #c6a35a !important;
}

#aa-final-practice-head .aa-final-practice-title,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title {
  display: block !important;
  width: 100% !important;
  max-width: 760px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #0c1424 !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: clamp(50px, 4.55vw, 70px) !important;
  line-height: .98 !important;
  font-style: normal !important;
  font-weight: 600 !important;
  letter-spacing: -.038em !important;
  text-align: left !important;
  text-transform: none !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  text-wrap: normal !important;
  overflow: visible !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

#aa-final-practice-head .aa-final-practice-title span,
#aa-final-practice-head .aa-final-practice-title em,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title span,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title em,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title span,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title em {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  color: inherit !important;
  font-family: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
  font-weight: inherit !important;
  letter-spacing: inherit !important;
  text-align: left !important;
  text-transform: none !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  filter: none !important;
}

@media (min-width: 1181px) {
  #aa-final-practice-head .aa-final-practice-title span,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title span,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title span {
    white-space: nowrap !important;
  }
}

#aa-final-practice-head .aa-final-practice-title em,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title em,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title em {
  color: #a9842f !important;
  font-style: italic !important;
  letter-spacing: -.05em !important;
}

#aa-final-practice-head .aa-final-practice-cta,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-cta,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  justify-self: end !important;
  align-self: center !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  height: auto !important;
  margin: 22px 0 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #a9842f !important;
  font-family: "Montserrat", Arial, sans-serif !important;
  font-size: 17px !important;
  line-height: 1.2 !important;
  font-style: normal !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  text-align: right !important;
  text-transform: none !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  position: relative !important;
  z-index: 10 !important;
  pointer-events: auto !important;
}

#aa-final-practice-head .aa-final-practice-cta:hover,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-cta:hover,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-cta:hover {
  color: #0c1f3f !important;
}

#aa-final-practice-head .aa-final-practice-cta::after,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-cta::after,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-cta::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: -7px !important;
  height: 1px !important;
  background: currentColor !important;
  transform: scaleX(0) !important;
  transform-origin: left center !important;
  transition: transform .35s cubic-bezier(.22, 1, .36, 1) !important;
}

#aa-final-practice-head .aa-final-practice-cta:hover::after,
body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-cta:hover::after,
body.elementor-editor-active #aa-final-practice-head .aa-final-practice-cta:hover::after {
  transform: scaleX(1) !important;
}

#areas.aa-final-areas-section .aa-final-svc-list,
body.ahumada-identica-page #areas.aa-final-areas-section .aa-final-svc-list,
body.elementor-editor-active #areas.aa-final-areas-section .aa-final-svc-list {
  margin-top: 0 !important;
  border-top: 1px solid rgba(198, 163, 90, .32) !important;
}

/* Si alguna página aún tiene una versión vieja guardada, se fuerza una maqueta limpia igualmente. */
.ahumada-page-inicio #areas .services__head,
.ahumada-page-inicio #areas .aa-areas-clean-head,
.ahumada-page-inicio #areas .aa-practice-intro {
  display: none !important;
}

@media (max-width: 1180px) {
  #aa-final-practice-head,
  body.ahumada-identica-page #aa-final-practice-head,
  body.elementor-editor-active #aa-final-practice-head {
    grid-template-columns: 1fr !important;
    align-items: start !important;
    justify-content: start !important;
  }
  #aa-final-practice-head .aa-final-practice-copy,
  #aa-final-practice-head .aa-final-practice-title,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-copy,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-copy,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title {
    max-width: 820px !important;
  }
  #aa-final-practice-head .aa-final-practice-cta,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-cta,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-cta {
    justify-self: start !important;
    align-self: start !important;
    margin-top: 0 !important;
  }
}

@media (max-width: 768px) {
  #areas.aa-final-areas-section,
  body.ahumada-identica-page #areas.aa-final-areas-section,
  body.elementor-editor-active #areas.aa-final-areas-section {
    padding: 58px 0 66px !important;
  }
  #areas.aa-final-areas-section > .aa-final-areas-container,
  body.ahumada-identica-page #areas.aa-final-areas-section > .aa-final-areas-container,
  body.elementor-editor-active #areas.aa-final-areas-section > .aa-final-areas-container {
    width: min(calc(100% - 36px), 1240px) !important;
  }
  #aa-final-practice-head,
  body.ahumada-identica-page #aa-final-practice-head,
  body.elementor-editor-active #aa-final-practice-head {
    gap: 22px !important;
    margin-bottom: 34px !important;
    padding-bottom: 28px !important;
  }
  #aa-final-practice-head .aa-final-practice-title,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title {
    font-size: clamp(38px, 10.8vw, 52px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.032em !important;
  }
  #aa-final-practice-head .aa-final-practice-kicker,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-kicker,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-kicker {
    font-size: 10px !important;
    gap: 10px !important;
    letter-spacing: .22em !important;
    white-space: normal !important;
  }
  #aa-final-practice-head .aa-final-practice-kicker::before,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-kicker::before,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-kicker::before {
    width: 28px !important;
    min-width: 28px !important;
  }
  #aa-final-practice-head .aa-final-practice-cta,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-cta,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-cta {
    font-size: 15px !important;
    text-align: left !important;
  }
}

@media (max-width: 420px) {
  #aa-final-practice-head .aa-final-practice-title,
  body.ahumada-identica-page #aa-final-practice-head .aa-final-practice-title,
  body.elementor-editor-active #aa-final-practice-head .aa-final-practice-title {
    font-size: clamp(34px, 11.5vw, 44px) !important;
  }
}

/* =========================================================
   V15 · FIX DEFINITIVO ÁREAS/SERVICIOS
   Este bloque va al final para ganar a Elementor, al tema y a los parches anteriores.
   Objetivo: tarjetas de áreas anchas, texto legible, imagen fija a la derecha,
   sin palabras apiladas una debajo de otra.
   ========================================================= */
html body .ahumada-original-page.ahumada-page-servicios,
html body .ahumada-original-page .ahumada-page-servicios,
html body .ahumada-page-servicios {
  overflow-x: clip !important;
}

html body .ahumada-original-page.ahumada-page-servicios .services > .container,
html body .ahumada-original-page .ahumada-page-servicios .services > .container,
html body .ahumada-page-servicios .services > .container {
  width: min(calc(100% - 48px), 1240px) !important;
  max-width: 1240px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}

html body .ahumada-original-page.ahumada-page-servicios .svc-cards,
html body .ahumada-original-page .ahumada-page-servicios .svc-cards,
html body .ahumada-page-servicios .svc-cards {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  grid-template-columns: none !important;
  gap: clamp(18px, 2.4vw, 30px) !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 auto !important;
  padding: 0 !important;
  columns: auto !important;
  column-count: auto !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service,
html body .ahumada-page-servicios .card.card--service {
  --aa-v15-card-pad: clamp(24px, 3.2vw, 44px);
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) clamp(260px, 33vw, 430px) !important;
  grid-auto-columns: unset !important;
  grid-auto-flow: row !important;
  column-gap: clamp(24px, 4.2vw, 58px) !important;
  row-gap: 0 !important;
  align-items: stretch !important;
  justify-items: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 360px !important;
  margin: 0 !important;
  padding: var(--aa-v15-card-pad) !important;
  padding-right: var(--aa-v15-card-pad) !important;
  border: 1px solid rgba(198, 163, 90, .32) !important;
  border-radius: 10px !important;
  background: #f7f1e7 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  float: none !important;
  clear: both !important;
  transform: none !important;
  columns: auto !important;
  column-count: auto !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service:hover,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service:hover,
html body .ahumada-page-servicios .card.card--service:hover {
  transform: translateY(-4px) !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__media,
html body .ahumada-page-servicios .card.card--service .card__media {
  display: block !important;
  position: relative !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 / 20 !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: 100% !important;
  min-height: 300px !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 1px solid rgba(198, 163, 90, .34) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  background: #0c1f3f !important;
  box-sizing: border-box !important;
  order: initial !important;
  transform: none !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media img,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__media img,
html body .ahumada-page-servicios .card.card--service .card__media img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 300px !important;
  object-fit: cover !important;
  object-position: center center !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service > *:not(.card__media),
html body .ahumada-original-page .ahumada-page-servicios .card.card--service > *:not(.card__media),
html body .ahumada-page-servicios .card.card--service > *:not(.card__media) {
  grid-column: 1 !important;
  position: relative !important;
  z-index: 3 !important;
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 720px !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  float: none !important;
  clear: none !important;
  box-sizing: border-box !important;
  columns: auto !important;
  column-count: auto !important;
  column-width: auto !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__num,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__num,
html body .ahumada-page-servicios .card.card--service .card__num {
  width: max-content !important;
  max-width: max-content !important;
  margin: 0 0 14px !important;
  color: #a9842f !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: 1 !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__ico,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__ico,
html body .ahumada-page-servicios .card.card--service .card__ico {
  width: 52px !important;
  height: 52px !important;
  max-width: 52px !important;
  margin: 0 0 18px !important;
  color: #a9842f !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__title,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__title,
html body .ahumada-page-servicios .card.card--service .card__title {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 680px !important;
  margin: 0 0 14px !important;
  color: #0c1424 !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: clamp(34px, 4.3vw, 56px) !important;
  line-height: 1.02 !important;
  letter-spacing: -.035em !important;
  font-weight: 600 !important;
  text-align: left !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  text-wrap: pretty !important;
  hyphens: manual !important;
  writing-mode: horizontal-tb !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service p,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service p,
html body .ahumada-page-servicios .card.card--service p {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 62ch !important;
  margin: 0 0 20px !important;
  color: #5f6470 !important;
  font-family: "Montserrat", Arial, sans-serif !important;
  font-size: clamp(15px, 1.35vw, 17px) !important;
  line-height: 1.75 !important;
  letter-spacing: 0 !important;
  text-align: left !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  text-wrap: pretty !important;
  hyphens: manual !important;
  writing-mode: horizontal-tb !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service ul.ticks,
html body .ahumada-page-servicios .card.card--service ul.ticks {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px 24px !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 680px !important;
  margin: 6px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  columns: auto !important;
  column-count: auto !important;
}

html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks li,
html body .ahumada-original-page .ahumada-page-servicios .card.card--service ul.ticks li,
html body .ahumada-page-servicios .card.card--service ul.ticks li {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding-left: 22px !important;
  color: #5f6470 !important;
  font-family: "Montserrat", Arial, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  text-align: left !important;
}

/* HOME · listado de áreas: evitar columnas estrechas y texto apilado */
html body .ahumada-original-page.ahumada-page-inicio #areas .svc,
html body .ahumada-original-page .ahumada-page-inicio #areas .svc,
html body .ahumada-page-inicio #areas .svc {
  display: grid !important;
  grid-template-columns: 54px minmax(0, 1fr) clamp(220px, 26vw, 340px) 56px !important;
  column-gap: clamp(18px, 2.6vw, 34px) !important;
  align-items: center !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

html body .ahumada-original-page.ahumada-page-inicio #areas .svc > div:not(.svc__bg):not(.svc__media),
html body .ahumada-original-page .ahumada-page-inicio #areas .svc > div:not(.svc__bg):not(.svc__media),
html body .ahumada-page-inicio #areas .svc > div:not(.svc__bg):not(.svc__media),
html body .ahumada-original-page.ahumada-page-inicio #areas .svc__title,
html body .ahumada-original-page .ahumada-page-inicio #areas .svc__title,
html body .ahumada-page-inicio #areas .svc__title,
html body .ahumada-original-page.ahumada-page-inicio #areas .svc__desc,
html body .ahumada-original-page .ahumada-page-inicio #areas .svc__desc,
html body .ahumada-page-inicio #areas .svc__desc {
  min-width: 0 !important;
  max-width: 100% !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  text-wrap: pretty !important;
}

@media (max-width: 920px) {
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service,
  html body .ahumada-page-servicios .card.card--service {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__media,
  html body .ahumada-page-servicios .card.card--service .card__media {
    order: 0 !important;
    width: 100% !important;
    height: 240px !important;
    min-height: 240px !important;
    border: 0 !important;
    border-radius: 0 !important;
    border-bottom: 1px solid rgba(198, 163, 90, .32) !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service > *:not(.card__media),
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service > *:not(.card__media),
  html body .ahumada-page-servicios .card.card--service > *:not(.card__media) {
    width: auto !important;
    max-width: none !important;
    margin-left: 22px !important;
    margin-right: 22px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__num,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__num,
  html body .ahumada-page-servicios .card.card--service .card__num {
    margin-top: 24px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service ul.ticks,
  html body .ahumada-page-servicios .card.card--service ul.ticks {
    grid-template-columns: 1fr !important;
    margin-bottom: 24px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio #areas .svc,
  html body .ahumada-original-page .ahumada-page-inicio #areas .svc,
  html body .ahumada-page-inicio #areas .svc {
    grid-template-columns: 40px minmax(0, 1fr) !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio #areas .svc__media,
  html body .ahumada-original-page .ahumada-page-inicio #areas .svc__media,
  html body .ahumada-page-inicio #areas .svc__media {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    height: 210px !important;
    margin-top: 12px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio #areas .svc__arrow,
  html body .ahumada-original-page .ahumada-page-inicio #areas .svc__arrow,
  html body .ahumada-page-inicio #areas .svc__arrow {
    display: none !important;
  }
}

@media (max-width: 560px) {
  html body .ahumada-original-page.ahumada-page-servicios .services > .container,
  html body .ahumada-original-page .ahumada-page-servicios .services > .container,
  html body .ahumada-page-servicios .services > .container {
    width: min(calc(100% - 28px), 1240px) !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__media,
  html body .ahumada-page-servicios .card.card--service .card__media {
    height: 200px !important;
    min-height: 200px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__title,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service .card__title,
  html body .ahumada-page-servicios .card.card--service .card__title {
    font-size: clamp(31px, 10vw, 42px) !important;
    line-height: 1.03 !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service p,
  html body .ahumada-original-page .ahumada-page-servicios .card.card--service p,
  html body .ahumada-page-servicios .card.card--service p {
    font-size: 15px !important;
    line-height: 1.65 !important;
  }
}

/* =========================================================
   V16 DEFINITIVA · Bloque Áreas / Servicios blindado
   - No depende de body_class de WordPress.
   - Corrige también HTML antiguo .card--service si Elementor mantiene caché.
   - Evita columnas estrechas, textos palabra a palabra y saltos rotos.
   ========================================================= */
.ahumada-original-page.ahumada-page-servicios,
.ahumada-original-page.ahumada-page-servicios * {
  box-sizing: border-box !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-services-fixed-section,
.ahumada-original-page.ahumada-page-servicios .services {
  width: 100% !important;
  overflow: visible !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-services-fixed-container,
.ahumada-original-page.ahumada-page-servicios .services > .container {
  width: min(100% - (var(--gutter, 24px) * 2), 1180px) !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
  float: none !important;
  clear: both !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-services-fixed-list,
.ahumada-original-page.ahumada-page-servicios .svc-cards {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(18px, 2.4vw, 30px) !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  float: none !important;
  clear: both !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card,
.ahumada-original-page.ahumada-page-servicios .card.card--service {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, clamp(300px, 34vw, 430px)) !important;
  gap: clamp(26px, 4vw, 56px) !important;
  align-items: stretch !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: clamp(24px, 3.4vw, 46px) !important;
  margin: 0 !important;
  background: var(--paper) !important;
  color: var(--ink) !important;
  border: 1px solid var(--line) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  transform: none !important;
  box-shadow: none !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  float: none !important;
  clear: both !important;
  writing-mode: horizontal-tb !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card:hover,
.ahumada-original-page.ahumada-page-servicios .card.card--service:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 24px 50px -42px rgba(12,31,63,.45) !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card::before,
.ahumada-original-page.ahumada-page-servicios .card.card--service::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 3px !important;
  background: linear-gradient(90deg,var(--gold),var(--gold-light)) !important;
  transform: scaleX(1) !important;
  transform-origin: left !important;
  z-index: 3 !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__content {
  display: block !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 100% !important;
  max-width: 720px !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
}

.ahumada-original-page.ahumada-page-servicios .card.card--service > *:not(.card__media) {
  grid-column: 1 !important;
  position: static !important;
  display: block !important;
  width: 100% !important;
  max-width: 720px !important;
  min-width: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  float: none !important;
  clear: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__media,
.ahumada-original-page.ahumada-page-servicios .card.card--service .card__media {
  position: relative !important;
  inset: auto !important;
  z-index: 1 !important;
  display: block !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  align-self: stretch !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: 100% !important;
  min-height: 320px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 1px solid rgba(190,151,88,.34) !important;
  border-radius: 7px !important;
  overflow: hidden !important;
  background: var(--navy) !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  float: none !important;
  clear: none !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__media::after,
.ahumada-original-page.ahumada-page-servicios .card.card--service .card__media::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background: linear-gradient(180deg, rgba(12,31,63,0), rgba(12,31,63,.20)) !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__media img,
.ahumada-original-page.ahumada-page-servicios .card.card--service .card__media img {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  min-height: inherit !important;
  object-fit: cover !important;
  object-position: center center !important;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card:hover .aa-service-card__media img,
.ahumada-original-page.ahumada-page-servicios .card.card--service:hover .card__media img {
  transform: scale(1.035) !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__num,
.ahumada-original-page.ahumada-page-servicios .card.card--service .card__num {
  position: static !important;
  display: block !important;
  width: fit-content !important;
  max-width: none !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  font-family: var(--display) !important;
  font-size: clamp(18px, 1.5vw, 23px) !important;
  line-height: 1 !important;
  color: var(--gold-deep) !important;
  white-space: normal !important;
  opacity: 1 !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__ico,
.ahumada-original-page.ahumada-page-servicios .card.card--service .card__ico {
  position: static !important;
  display: block !important;
  width: 50px !important;
  height: 50px !important;
  margin: 0 0 18px !important;
  color: var(--gold-deep) !important;
  opacity: 1 !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__title,
.ahumada-original-page.ahumada-page-servicios .card.card--service .card__title {
  display: block !important;
  width: 100% !important;
  max-width: 680px !important;
  min-width: 0 !important;
  margin: 0 0 13px !important;
  padding: 0 !important;
  color: var(--navy) !important;
  font-family: var(--display) !important;
  font-size: clamp(34px, 4.4vw, 58px) !important;
  line-height: 1.03 !important;
  letter-spacing: -.018em !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  text-align: left !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__text,
.ahumada-original-page.ahumada-page-servicios .card.card--service p {
  display: block !important;
  width: 100% !important;
  max-width: 66ch !important;
  min-width: 0 !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  color: var(--ink-soft) !important;
  font-family: var(--sans) !important;
  font-size: clamp(15px, 1.05vw, 17px) !important;
  line-height: 1.75 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: none !important;
  text-align: left !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks,
.ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks {
  list-style: none !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px 24px !important;
  width: 100% !important;
  max-width: 700px !important;
  min-width: 0 !important;
  margin: 8px 0 0 !important;
  padding: 0 !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks li,
.ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks li {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 0 0 1.55em !important;
  color: var(--ink-soft) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: none !important;
  text-align: left !important;
  writing-mode: horizontal-tb !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks li::before,
.ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .56em !important;
  width: 8px !important;
  height: 8px !important;
  border-right: 2px solid var(--gold-deep) !important;
  border-bottom: 2px solid var(--gold-deep) !important;
  transform: rotate(45deg) translateY(-2px) !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-cta-card,
.ahumada-original-page.ahumada-page-servicios .svc-cards > .card:not(.card--service) {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: clamp(30px, 4vw, 54px) !important;
  background: var(--navy) !important;
  color: var(--cream) !important;
  border: 1px solid rgba(190,151,88,.32) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-cta-card h3,
.ahumada-original-page.ahumada-page-servicios .svc-cards > .card:not(.card--service) h3 {
  color: var(--cream) !important;
  max-width: 720px !important;
}

.ahumada-original-page.ahumada-page-servicios .aa-service-cta-card p,
.ahumada-original-page.ahumada-page-servicios .svc-cards > .card:not(.card--service) p {
  color: rgba(246,241,231,.75) !important;
  max-width: 720px !important;
}

@media (max-width: 920px) {
  .ahumada-original-page.ahumada-page-servicios .aa-service-card,
  .ahumada-original-page.ahumada-page-servicios .card.card--service {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0 !important;
    grid-template-columns: none !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__content {
    width: 100% !important;
    max-width: none !important;
    padding: 24px !important;
    order: 2 !important;
  }

  .ahumada-original-page.ahumada-page-servicios .card.card--service > *:not(.card__media) {
    width: auto !important;
    max-width: none !important;
    margin-left: 24px !important;
    margin-right: 24px !important;
    order: 2 !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__media,
  .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media {
    order: 1 !important;
    width: 100% !important;
    height: 240px !important;
    min-height: 240px !important;
    border: 0 !important;
    border-radius: 0 !important;
    border-bottom: 1px solid rgba(190,151,88,.34) !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__title,
  .ahumada-original-page.ahumada-page-servicios .card.card--service .card__title {
    font-size: clamp(34px, 8.4vw, 48px) !important;
    max-width: none !important;
    margin-bottom: 14px !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__text,
  .ahumada-original-page.ahumada-page-servicios .card.card--service p {
    max-width: none !important;
  }
}

@media (max-width: 560px) {
  .ahumada-original-page.ahumada-page-servicios .aa-services-fixed-container,
  .ahumada-original-page.ahumada-page-servicios .services > .container {
    width: min(100% - 28px, 1180px) !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__content {
    padding: 22px 18px 24px !important;
  }

  .ahumada-original-page.ahumada-page-servicios .card.card--service > *:not(.card__media) {
    margin-left: 18px !important;
    margin-right: 18px !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__media,
  .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media {
    height: 205px !important;
    min-height: 205px !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__title,
  .ahumada-original-page.ahumada-page-servicios .card.card--service .card__title {
    font-size: clamp(31px, 10vw, 40px) !important;
    line-height: 1.05 !important;
  }

  .ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks,
  .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
}

/* =========================================================
   V17 · BLOQUE ÁREAS/SERVICIOS DEFINITIVO SIN IMÁGENES
   Motivo: las imágenes laterales estaban dejando el contenido en una columna estrecha.
   Solución: tarjetas full width, sin media, texto horizontal y responsive controlado.
   ========================================================= */
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-areas-section,
html body .ahumada-original-page.ahumada-page-inicio #areas {
  background: var(--cream) !important;
  overflow: visible !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-areas-container,
html body .ahumada-original-page.ahumada-page-servicios .services > .container,
html body .ahumada-original-page.ahumada-page-inicio #areas .container {
  width: min(100% - 48px, 1180px) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding-inline: 0 !important;
  box-sizing: border-box !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-areas-list,
html body .ahumada-original-page.ahumada-page-servicios .aa-services-fixed-list,
html body .ahumada-original-page.ahumada-page-servicios .svc-cards {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(18px, 2.4vw, 30px) !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  float: none !important;
  clear: both !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: clamp(24px, 3.4vw, 46px) !important;
  box-sizing: border-box !important;
  background: var(--paper) !important;
  border: 1px solid var(--line) !important;
  border-radius: 10px !important;
  overflow: visible !important;
  color: var(--ink) !important;
  transform: none !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card::before,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card::before,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 3px !important;
  background: linear-gradient(90deg,var(--gold),var(--gold-light)) !important;
  transform: none !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card:hover,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card:hover,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 24px 50px -42px rgba(12,31,63,.45) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__media,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__media,
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__media,
html body .ahumada-original-page.ahumada-page-inicio #areas .svc__media {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__content,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service > *:not(.card__media),
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card > * {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  float: none !important;
  clear: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  box-sizing: border-box !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__top {
  display: flex !important;
  align-items: flex-start !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: none !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__num,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__num,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__num {
  position: static !important;
  display: block !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  font-family: var(--display) !important;
  font-size: clamp(18px, 1.5vw, 23px) !important;
  line-height: 1 !important;
  color: var(--gold-deep) !important;
  white-space: normal !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__ico,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__ico,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__ico {
  position: static !important;
  display: block !important;
  width: 50px !important;
  height: 50px !important;
  margin: 0 0 18px !important;
  color: var(--gold-deep) !important;
  flex: 0 0 auto !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__title,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__title,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__title {
  display: block !important;
  width: 100% !important;
  max-width: 980px !important;
  min-width: 0 !important;
  margin: 18px 0 14px !important;
  padding: 0 !important;
  color: var(--navy) !important;
  font-family: var(--display) !important;
  font-size: clamp(34px, 4.2vw, 58px) !important;
  line-height: 1.05 !important;
  letter-spacing: -.018em !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  text-align: left !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__text,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__text,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service p {
  display: block !important;
  width: 100% !important;
  max-width: 78ch !important;
  min-width: 0 !important;
  margin: 0 0 20px !important;
  padding: 0 !important;
  color: var(--ink-soft) !important;
  font-family: var(--sans) !important;
  font-size: clamp(15px, 1.05vw, 17px) !important;
  line-height: 1.75 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: none !important;
  text-align: left !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__ticks,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks {
  list-style: none !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px 24px !important;
  width: 100% !important;
  max-width: 850px !important;
  min-width: 0 !important;
  margin: 8px 0 0 !important;
  padding: 0 !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  writing-mode: horizontal-tb !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__ticks li,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks li,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks li {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 0 0 1.55em !important;
  color: var(--ink-soft) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: none !important;
  text-align: left !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__ticks li::before,
html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks li::before,
html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .56em !important;
  width: 8px !important;
  height: 8px !important;
  border-right: 2px solid var(--gold-deep) !important;
  border-bottom: 2px solid var(--gold-deep) !important;
  transform: rotate(45deg) translateY(-2px) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card--cta {
  background: var(--navy) !important;
  color: var(--cream) !important;
}
html body .ahumada-original-page.ahumada-page-inicio #areas .svc-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  border-top: 1px solid var(--line) !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
}
html body .ahumada-original-page.ahumada-page-inicio #areas .svc {
  display: grid !important;
  grid-template-columns: 54px minmax(0,1fr) 56px !important;
  gap: clamp(16px,2.6vw,34px) !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
html body .ahumada-original-page.ahumada-page-inicio #areas .svc > div:not(.svc__bg):not(.svc__media),
html body .ahumada-original-page.ahumada-page-inicio #areas .svc__title,
html body .ahumada-original-page.ahumada-page-inicio #areas .svc__desc {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  columns: auto !important;
  column-count: initial !important;
  writing-mode: horizontal-tb !important;
}
html body .ahumada-original-page.ahumada-page-inicio #areas .svc:hover .svc__title,
html body .ahumada-original-page.ahumada-page-inicio #areas .svc:hover .svc__num,
html body .ahumada-original-page.ahumada-page-inicio #areas .svc:hover .svc__desc {
  color: var(--cream) !important;
}
@media (max-width: 760px) {
  html body .ahumada-original-page.ahumada-page-servicios .aa-v17-areas-container,
  html body .ahumada-original-page.ahumada-page-servicios .services > .container,
  html body .ahumada-original-page.ahumada-page-inicio #areas .container {
    width: min(100% - 28px, 1180px) !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card,
  html body .ahumada-original-page.ahumada-page-servicios .aa-service-card,
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service {
    padding: 22px 18px 24px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__title,
  html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__title,
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service .card__title {
    font-size: clamp(31px, 10vw, 40px) !important;
    line-height: 1.05 !important;
    max-width: none !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v17-area-card__ticks,
  html body .ahumada-original-page.ahumada-page-servicios .aa-service-card__ticks,
  html body .ahumada-original-page.ahumada-page-servicios .card.card--service ul.ticks {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio #areas .svc {
    grid-template-columns: 40px minmax(0,1fr) !important;
    gap: 14px !important;
    padding: 1.15rem 0 !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio #areas .svc__arrow { display: none !important; }
}


/* =========================================================
   V18 · ÁREAS / SERVICIOS RECONSTRUIDO DESDE CERO
   Formato sin imágenes y sin dependencia de .services, .card ni .svc.
   Evita columnas estrechas provocadas por Elementor/tema/caché.
   ========================================================= */
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-section,
html body .ahumada-page-servicios .aa-v18-practice-section {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(70px, 8vw, 120px) 0 !important;
  background: var(--cream) !important;
  color: var(--navy) !important;
  overflow: visible !important;
  columns: auto !important;
  column-count: initial !important;
  writing-mode: horizontal-tb !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-section *,
html body .ahumada-page-servicios .aa-v18-practice-section * {
  box-sizing: border-box !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  white-space: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-container,
html body .ahumada-page-servicios .aa-v18-practice-container {
  width: min(100% - 48px, 1180px) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: block !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-header,
html body .ahumada-page-servicios .aa-v18-practice-header {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px) !important;
  gap: clamp(28px, 6vw, 80px) !important;
  align-items: end !important;
  width: 100% !important;
  margin: 0 0 clamp(34px, 5vw, 64px) !important;
  padding: 0 0 clamp(24px, 3vw, 38px) !important;
  border-bottom: 1px solid var(--line) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-kicker,
html body .ahumada-page-servicios .aa-v18-kicker {
  display: flex !important;
  align-items: center !important;
  gap: .8rem !important;
  margin: 0 0 18px !important;
  font-family: var(--sans) !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  letter-spacing: .26em !important;
  text-transform: uppercase !important;
  color: var(--gold-deep) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-kicker::before,
html body .ahumada-page-servicios .aa-v18-kicker::before {
  content: "" !important;
  display: block !important;
  width: 42px !important;
  height: 1px !important;
  background: currentColor !important;
  flex: 0 0 42px !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-main-title,
html body .ahumada-page-servicios .aa-v18-main-title {
  display: block !important;
  width: 100% !important;
  max-width: 780px !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--display) !important;
  font-size: clamp(42px, 5vw, 76px) !important;
  font-weight: 600 !important;
  line-height: .96 !important;
  letter-spacing: -.035em !important;
  color: var(--navy) !important;
  text-align: left !important;
  overflow-wrap: normal !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-header-text,
html body .ahumada-page-servicios .aa-v18-header-text {
  display: block !important;
  width: 100% !important;
  max-width: 420px !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  line-height: 1.8 !important;
  color: var(--ink-soft) !important;
  text-align: left !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-list,
html body .ahumada-page-servicios .aa-v18-practice-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card,
html body .ahumada-page-servicios .aa-v18-practice-card {
  position: relative !important;
  display: grid !important;
  grid-template-columns: clamp(64px, 8vw, 104px) minmax(0, 1fr) !important;
  gap: clamp(20px, 3.5vw, 52px) !important;
  align-items: start !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: clamp(26px, 4vw, 48px) !important;
  border: 1px solid var(--line) !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.30) !important;
  overflow: hidden !important;
  float: none !important;
  clear: both !important;
  box-shadow: none !important;
  transition: transform .28s ease, border-color .28s ease, background .28s ease !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card::before,
html body .ahumada-page-servicios .aa-v18-practice-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 auto 0 0 !important;
  width: 4px !important;
  background: var(--gold-deep) !important;
  opacity: .18 !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card:hover,
html body .ahumada-page-servicios .aa-v18-practice-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(180,137,58,.45) !important;
  background: rgba(255,255,255,.50) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-number,
html body .ahumada-page-servicios .aa-v18-practice-number {
  display: block !important;
  width: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--display) !important;
  font-size: clamp(34px, 5vw, 66px) !important;
  line-height: .9 !important;
  color: var(--gold-deep) !important;
  opacity: .78 !important;
  text-align: left !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content,
html body .ahumada-page-servicios .aa-v18-practice-content {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content h3,
html body .ahumada-page-servicios .aa-v18-practice-content h3 {
  display: block !important;
  width: 100% !important;
  max-width: 920px !important;
  min-width: 0 !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  font-family: var(--display) !important;
  font-size: clamp(34px, 4.6vw, 58px) !important;
  font-weight: 600 !important;
  line-height: 1.02 !important;
  letter-spacing: -.025em !important;
  color: var(--navy) !important;
  text-align: left !important;
  overflow-wrap: normal !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content p,
html body .ahumada-page-servicios .aa-v18-practice-content p {
  display: block !important;
  width: 100% !important;
  max-width: 78ch !important;
  min-width: 0 !important;
  margin: 0 0 22px !important;
  padding: 0 !important;
  font-family: var(--sans) !important;
  font-size: clamp(15px, 1.05vw, 17px) !important;
  line-height: 1.75 !important;
  color: var(--ink-soft) !important;
  text-align: left !important;
  overflow-wrap: break-word !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content ul,
html body .ahumada-page-servicios .aa-v18-practice-content ul {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px 22px !important;
  width: 100% !important;
  max-width: 980px !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content li,
html body .ahumada-page-servicios .aa-v18-practice-content li {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 0 0 18px !important;
  font-family: var(--sans) !important;
  font-size: 14.5px !important;
  line-height: 1.55 !important;
  color: var(--ink-soft) !important;
  text-align: left !important;
  overflow-wrap: break-word !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content li::before,
html body .ahumada-page-servicios .aa-v18-practice-content li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .62em !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 999px !important;
  background: var(--gold-deep) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card--cta,
html body .ahumada-page-servicios .aa-v18-practice-card--cta {
  background: var(--navy) !important;
  border-color: rgba(190,151,88,.36) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card--cta .aa-v18-practice-number,
html body .ahumada-page-servicios .aa-v18-practice-card--cta .aa-v18-practice-number,
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card--cta h3,
html body .ahumada-page-servicios .aa-v18-practice-card--cta h3 {
  color: var(--cream) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card--cta p,
html body .ahumada-page-servicios .aa-v18-practice-card--cta p {
  color: rgba(246,241,231,.76) !important;
}
html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card--cta .btn,
html body .ahumada-page-servicios .aa-v18-practice-card--cta .btn {
  margin-top: 4px !important;
}
@media (max-width: 980px) {
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-header,
  html body .ahumada-page-servicios .aa-v18-practice-header {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    align-items: start !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-header-text,
  html body .ahumada-page-servicios .aa-v18-header-text {
    max-width: 760px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content ul,
  html body .ahumada-page-servicios .aa-v18-practice-content ul {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 640px) {
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-container,
  html body .ahumada-page-servicios .aa-v18-practice-container {
    width: min(100% - 28px, 1180px) !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-main-title,
  html body .ahumada-page-servicios .aa-v18-main-title {
    font-size: clamp(36px, 11vw, 48px) !important;
    line-height: 1 !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-card,
  html body .ahumada-page-servicios .aa-v18-practice-card {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding: 24px 18px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-number,
  html body .ahumada-page-servicios .aa-v18-practice-number {
    font-size: 34px !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content h3,
  html body .ahumada-page-servicios .aa-v18-practice-content h3 {
    font-size: clamp(32px, 10.5vw, 42px) !important;
    line-height: 1.05 !important;
  }
  html body .ahumada-original-page.ahumada-page-servicios .aa-v18-practice-content ul,
  html body .ahumada-page-servicios .aa-v18-practice-content ul {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
}

/* =========================================================
   V19 · Home / Áreas de práctica reconstruida desde cero
   No usa .services, .services__head, .section-title, .svc ni clases antiguas.
   ========================================================= */
html body .ahumada-original-page.ahumada-page-inicio #areas.aa-home-areas-v19,
html body .ahumada-page-inicio #areas.aa-home-areas-v19,
html body #areas.aa-home-areas-v19 {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  padding: clamp(72px, 8vw, 120px) 0 clamp(76px, 8vw, 126px) !important;
  margin: 0 !important;
  background: var(--cream, #f4efe6) !important;
  color: var(--ink, #0d1426) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  position: relative !important;
  isolation: isolate !important;
}
html body .ahumada-original-page.ahumada-page-inicio #areas.aa-home-areas-v19 *,
html body .ahumada-page-inicio #areas.aa-home-areas-v19 *,
html body #areas.aa-home-areas-v19 * {
  box-sizing: border-box !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  columns: auto !important;
  column-count: initial !important;
  column-width: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__inner,
html body .ahumada-page-inicio .aa-home-areas-v19__inner,
html body .aa-home-areas-v19__inner {
  width: min(1240px, calc(100% - 48px)) !important;
  max-width: 1240px !important;
  min-width: 0 !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: block !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__header,
html body .ahumada-page-inicio .aa-home-areas-v19__header,
html body .aa-home-areas-v19__header {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: end !important;
  gap: clamp(28px, 5vw, 72px) !important;
  padding: 0 0 clamp(34px, 4.5vw, 64px) !important;
  margin: 0 0 clamp(28px, 4vw, 46px) !important;
  border-bottom: 1px solid rgba(184, 134, 46, .28) !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__title-wrap,
html body .ahumada-page-inicio .aa-home-areas-v19__title-wrap,
html body .aa-home-areas-v19__title-wrap {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 920px !important;
  margin: 0 !important;
  padding: 0 !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__kicker,
html body .ahumada-page-inicio .aa-home-areas-v19__kicker,
html body .aa-home-areas-v19__kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 14px !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  font-family: var(--sans, Montserrat, sans-serif) !important;
  font-size: clamp(12px, 1.1vw, 15px) !important;
  line-height: 1.1 !important;
  letter-spacing: .42em !important;
  text-transform: uppercase !important;
  color: var(--gold, #b8862e) !important;
  font-weight: 700 !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__kicker::before,
html body .ahumada-page-inicio .aa-home-areas-v19__kicker::before,
html body .aa-home-areas-v19__kicker::before {
  content: "" !important;
  display: inline-block !important;
  width: 46px !important;
  height: 1px !important;
  min-width: 46px !important;
  background: currentColor !important;
  opacity: .75 !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__title,
html body .ahumada-page-inicio .aa-home-areas-v19__title,
html body .aa-home-areas-v19__title {
  display: block !important;
  width: 100% !important;
  max-width: 920px !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--serif, 'Cormorant Garamond', serif) !important;
  font-size: clamp(54px, 7.2vw, 104px) !important;
  line-height: .88 !important;
  letter-spacing: -.055em !important;
  font-weight: 600 !important;
  color: var(--ink, #0d1426) !important;
  text-wrap: balance !important;
  overflow: visible !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__title-main,
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__title-accent,
html body .ahumada-page-inicio .aa-home-areas-v19__title-main,
html body .ahumada-page-inicio .aa-home-areas-v19__title-accent,
html body .aa-home-areas-v19__title-main,
html body .aa-home-areas-v19__title-accent {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: .9 !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__title-accent,
html body .ahumada-page-inicio .aa-home-areas-v19__title-accent,
html body .aa-home-areas-v19__title-accent {
  color: var(--gold, #b8862e) !important;
  font-style: italic !important;
  font-weight: 500 !important;
  letter-spacing: -.045em !important;
  margin-top: .04em !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__cta,
html body .ahumada-page-inicio .aa-home-areas-v19__cta,
html body .aa-home-areas-v19__cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  min-width: max-content !important;
  max-width: none !important;
  margin: 0 0 16px !important;
  padding: 0 0 8px !important;
  border: 0 !important;
  border-bottom: 1px solid currentColor !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--gold, #b8862e) !important;
  font-family: var(--sans, Montserrat, sans-serif) !important;
  font-size: clamp(15px, 1.25vw, 18px) !important;
  line-height: 1.1 !important;
  letter-spacing: .03em !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transform: none !important;
  transition: color .25s ease, transform .25s ease !important;
  cursor: pointer !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__cta:hover,
html body .ahumada-page-inicio .aa-home-areas-v19__cta:hover,
html body .aa-home-areas-v19__cta:hover {
  color: var(--ink, #0d1426) !important;
  transform: translateX(4px) !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__grid,
html body .ahumada-page-inicio .aa-home-areas-v19__grid,
html body .aa-home-areas-v19__grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card,
html body .ahumada-page-inicio .aa-home-areas-v19__card,
html body .aa-home-areas-v19__card {
  display: grid !important;
  grid-template-columns: 56px minmax(0, 1fr) 42px !important;
  align-items: start !important;
  gap: clamp(18px, 2.5vw, 34px) !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 170px !important;
  margin: 0 !important;
  padding: clamp(24px, 3vw, 38px) !important;
  background: rgba(255,255,255,.34) !important;
  border: 1px solid rgba(184, 134, 46, .22) !important;
  border-radius: 0 !important;
  color: var(--ink, #0d1426) !important;
  text-decoration: none !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: none !important;
  transform: none !important;
  transition: background .25s ease, border-color .25s ease, transform .25s ease !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card::before,
html body .ahumada-page-inicio .aa-home-areas-v19__card::before,
html body .aa-home-areas-v19__card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 auto 0 0 !important;
  width: 3px !important;
  background: var(--gold, #b8862e) !important;
  transform: scaleY(0) !important;
  transform-origin: top !important;
  transition: transform .25s ease !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card:hover,
html body .ahumada-page-inicio .aa-home-areas-v19__card:hover,
html body .aa-home-areas-v19__card:hover {
  background: rgba(255,255,255,.56) !important;
  border-color: rgba(184, 134, 46, .48) !important;
  transform: translateY(-3px) !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card:hover::before,
html body .ahumada-page-inicio .aa-home-areas-v19__card:hover::before,
html body .aa-home-areas-v19__card:hover::before {
  transform: scaleY(1) !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card--wide,
html body .ahumada-page-inicio .aa-home-areas-v19__card--wide,
html body .aa-home-areas-v19__card--wide {
  grid-column: 1 / -1 !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__num,
html body .ahumada-page-inicio .aa-home-areas-v19__num,
html body .aa-home-areas-v19__num {
  display: block !important;
  width: 56px !important;
  min-width: 56px !important;
  max-width: 56px !important;
  margin: 4px 0 0 !important;
  padding: 0 !important;
  font-family: var(--sans, Montserrat, sans-serif) !important;
  font-size: 13px !important;
  line-height: 1 !important;
  letter-spacing: .26em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  color: var(--gold, #b8862e) !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__copy,
html body .ahumada-page-inicio .aa-home-areas-v19__copy,
html body .aa-home-areas-v19__copy {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__copy h3,
html body .ahumada-page-inicio .aa-home-areas-v19__copy h3,
html body .aa-home-areas-v19__copy h3 {
  display: block !important;
  width: 100% !important;
  max-width: 760px !important;
  min-width: 0 !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
  font-family: var(--serif, 'Cormorant Garamond', serif) !important;
  font-size: clamp(34px, 3vw, 54px) !important;
  line-height: .98 !important;
  letter-spacing: -.035em !important;
  font-weight: 600 !important;
  color: var(--ink, #0d1426) !important;
  text-align: left !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__copy p,
html body .ahumada-page-inicio .aa-home-areas-v19__copy p,
html body .aa-home-areas-v19__copy p {
  display: block !important;
  width: 100% !important;
  max-width: 72ch !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--sans, Montserrat, sans-serif) !important;
  font-size: clamp(15px, 1.04vw, 17px) !important;
  line-height: 1.75 !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;
  color: rgba(13, 20, 38, .72) !important;
  text-align: left !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__arrow,
html body .ahumada-page-inicio .aa-home-areas-v19__arrow,
html body .aa-home-areas-v19__arrow {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  margin: 2px 0 0 auto !important;
  padding: 0 !important;
  border: 1px solid rgba(184, 134, 46, .36) !important;
  border-radius: 999px !important;
  font-family: var(--sans, Montserrat, sans-serif) !important;
  font-size: 18px !important;
  line-height: 1 !important;
  color: var(--gold, #b8862e) !important;
  transition: background .25s ease, color .25s ease, transform .25s ease !important;
}
html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card:hover .aa-home-areas-v19__arrow,
html body .ahumada-page-inicio .aa-home-areas-v19__card:hover .aa-home-areas-v19__arrow,
html body .aa-home-areas-v19__card:hover .aa-home-areas-v19__arrow {
  background: var(--gold, #b8862e) !important;
  color: var(--cream, #f4efe6) !important;
  transform: translateX(4px) !important;
}
@media (max-width: 1024px) {
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__header,
  html body .ahumada-page-inicio .aa-home-areas-v19__header,
  html body .aa-home-areas-v19__header {
    grid-template-columns: 1fr !important;
    align-items: start !important;
    gap: 24px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__cta,
  html body .ahumada-page-inicio .aa-home-areas-v19__cta,
  html body .aa-home-areas-v19__cta {
    justify-self: start !important;
    margin: 0 !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__grid,
  html body .ahumada-page-inicio .aa-home-areas-v19__grid,
  html body .aa-home-areas-v19__grid {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 760px) {
  html body .ahumada-original-page.ahumada-page-inicio #areas.aa-home-areas-v19,
  html body .ahumada-page-inicio #areas.aa-home-areas-v19,
  html body #areas.aa-home-areas-v19 {
    padding: 58px 0 72px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__inner,
  html body .ahumada-page-inicio .aa-home-areas-v19__inner,
  html body .aa-home-areas-v19__inner {
    width: min(100% - 28px, 1240px) !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__kicker,
  html body .ahumada-page-inicio .aa-home-areas-v19__kicker,
  html body .aa-home-areas-v19__kicker {
    gap: 10px !important;
    letter-spacing: .28em !important;
    font-size: 11px !important;
    margin-bottom: 16px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__kicker::before,
  html body .ahumada-page-inicio .aa-home-areas-v19__kicker::before,
  html body .aa-home-areas-v19__kicker::before {
    width: 32px !important;
    min-width: 32px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__title,
  html body .ahumada-page-inicio .aa-home-areas-v19__title,
  html body .aa-home-areas-v19__title {
    font-size: clamp(44px, 15vw, 64px) !important;
    line-height: .9 !important;
    letter-spacing: -.045em !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__card,
  html body .ahumada-page-inicio .aa-home-areas-v19__card,
  html body .aa-home-areas-v19__card {
    grid-template-columns: 1fr 42px !important;
    gap: 16px !important;
    min-height: 0 !important;
    padding: 24px 20px !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__num,
  html body .ahumada-page-inicio .aa-home-areas-v19__num,
  html body .aa-home-areas-v19__num {
    grid-column: 1 / -1 !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__copy,
  html body .ahumada-page-inicio .aa-home-areas-v19__copy,
  html body .aa-home-areas-v19__copy {
    grid-column: 1 !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__arrow,
  html body .ahumada-page-inicio .aa-home-areas-v19__arrow,
  html body .aa-home-areas-v19__arrow {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }
  html body .ahumada-original-page.ahumada-page-inicio .aa-home-areas-v19__copy h3,
  html body .ahumada-page-inicio .aa-home-areas-v19__copy h3,
  html body .aa-home-areas-v19__copy h3 {
    font-size: clamp(32px, 11vw, 44px) !important;
    line-height: 1.02 !important;
    margin-bottom: 10px !important;
  }
}

/* =========================================================
   V20 · Acentos visuales en rojo carruaje
   Aplicación sutil para reforzar identidad sin romper el estilo jurídico.
   ========================================================= */
:root{
  --carriage-red: #7e2230;
  --carriage-red-2: #9b2c3b;
  --carriage-red-soft: rgba(126,34,48,.13);
  --carriage-red-line: rgba(126,34,48,.32);
}

body.ahumada-identica-page .hero__veil,
body.elementor-editor-active .hero__veil{
  background: radial-gradient(circle at 16% 28%, rgba(126,34,48,.24), transparent 32%),
              linear-gradient(90deg, rgba(10,26,52,.92), rgba(10,26,52,.64) 46%, rgba(10,26,52,.24)) !important;
}

body.ahumada-identica-page .hero__title .it,
body.elementor-editor-active .hero__title .it,
body.ahumada-identica-page .page-hero h1 .it,
body.elementor-editor-active .page-hero h1 .it{
  color: var(--gold-light) !important;
  text-shadow: 0 0 26px rgba(126,34,48,.36) !important;
}

body.ahumada-identica-page .eyebrow::before,
body.elementor-editor-active .eyebrow::before,
body.ahumada-identica-page .aa-home-areas-v19__kicker::before,
body.elementor-editor-active .aa-home-areas-v19__kicker::before{
  background: linear-gradient(90deg, var(--carriage-red), var(--gold)) !important;
}

body.ahumada-identica-page .section-title .accent,
body.elementor-editor-active .section-title .accent,
body.ahumada-identica-page .statement__text .accent,
body.elementor-editor-active .statement__text .accent{
  color: var(--carriage-red) !important;
}

body.ahumada-identica-page .btn--gold,
body.elementor-editor-active .btn--gold{
  --bg: linear-gradient(120deg, var(--gold), var(--gold-deep));
  --fg: var(--navy);
  box-shadow: 0 18px 42px -30px rgba(126,34,48,.72) !important;
}
body.ahumada-identica-page .btn--gold::after,
body.elementor-editor-active .btn--gold::after{
  background: linear-gradient(120deg, var(--carriage-red), var(--carriage-red-2)) !important;
}
body.ahumada-identica-page .btn--gold:hover,
body.elementor-editor-active .btn--gold:hover{
  color: var(--cream) !important;
  box-shadow: 0 20px 46px -24px rgba(126,34,48,.82) !important;
}
body.ahumada-identica-page .btn--ghost:hover,
body.elementor-editor-active .btn--ghost:hover{
  border-color: var(--carriage-red) !important;
}
body.ahumada-identica-page .btn--ghost::after,
body.elementor-editor-active .btn--ghost::after{
  background: linear-gradient(120deg, var(--carriage-red), var(--gold)) !important;
}

body.ahumada-identica-page .trust__item,
body.elementor-editor-active .trust__item{
  box-shadow: inset 0 -2px 0 rgba(126,34,48,.16) !important;
}
body.ahumada-identica-page .trust__num,
body.elementor-editor-active .trust__num{
  color: var(--carriage-red) !important;
}

body.ahumada-identica-page .aa-home-areas-v19__title-accent,
body.elementor-editor-active .aa-home-areas-v19__title-accent{
  color: var(--carriage-red) !important;
}
body.ahumada-identica-page .aa-home-areas-v19__card,
body.elementor-editor-active .aa-home-areas-v19__card{
  border-left: 3px solid transparent !important;
  transition: transform .38s var(--ease), border-color .38s var(--ease), background .38s var(--ease), box-shadow .38s var(--ease) !important;
}
body.ahumada-identica-page .aa-home-areas-v19__card:hover,
body.elementor-editor-active .aa-home-areas-v19__card:hover{
  border-left-color: var(--carriage-red) !important;
  background: linear-gradient(90deg, rgba(126,34,48,.085), rgba(255,255,255,.42)) !important;
  box-shadow: 0 22px 52px -46px rgba(126,34,48,.65) !important;
}
body.ahumada-identica-page .aa-home-areas-v19__num,
body.elementor-editor-active .aa-home-areas-v19__num,
body.ahumada-identica-page .aa-home-areas-v19__arrow,
body.elementor-editor-active .aa-home-areas-v19__arrow{
  color: var(--carriage-red) !important;
}
body.ahumada-identica-page .aa-home-areas-v19__card:hover .aa-home-areas-v19__arrow,
body.elementor-editor-active .aa-home-areas-v19__card:hover .aa-home-areas-v19__arrow{
  background: var(--carriage-red) !important;
  border-color: var(--carriage-red) !important;
  color: var(--cream) !important;
}

body.ahumada-identica-page .marquee-band,
body.elementor-editor-active .marquee-band{
  background: linear-gradient(90deg, var(--navy), var(--carriage-red), var(--navy)) !important;
}
body.ahumada-identica-page .marquee-row .dot,
body.elementor-editor-active .marquee-row .dot{
  color: var(--gold-light) !important;
}

body.ahumada-identica-page .badge,
body.elementor-editor-active .badge,
body.ahumada-identica-page .step__num,
body.elementor-editor-active .step__num{
  border-color: var(--carriage-red-line) !important;
}
body.ahumada-identica-page .step:hover,
body.elementor-editor-active .step:hover{
  box-shadow: inset 0 0 0 1px rgba(126,34,48,.28), 0 28px 60px -48px rgba(126,34,48,.72) !important;
}
body.ahumada-identica-page .feature-list .fi,
body.elementor-editor-active .feature-list .fi{
  background: var(--carriage-red) !important;
  color: var(--cream) !important;
}

body.ahumada-identica-page .page-hero__bg::after,
body.elementor-editor-active .page-hero__bg::after{
  background: radial-gradient(circle at 24% 30%, rgba(126,34,48,.30), transparent 34%),
              linear-gradient(90deg, rgba(10,26,52,.92), rgba(10,26,52,.58), rgba(10,26,52,.18)) !important;
}

body.ahumada-identica-page .field input:focus,
body.ahumada-identica-page .field select:focus,
body.ahumada-identica-page .field textarea:focus,
body.elementor-editor-active .field input:focus,
body.elementor-editor-active .field select:focus,
body.elementor-editor-active .field textarea:focus{
  border-color: var(--carriage-red) !important;
  box-shadow: 0 0 0 3px rgba(126,34,48,.14) !important;
}

body.ahumada-identica-page .footer-social a:hover,
body.elementor-editor-active .footer-social a:hover{
  background: var(--carriage-red) !important;
  color: var(--cream) !important;
  border-color: var(--carriage-red) !important;
}
body.ahumada-identica-page .site-footer,
body.elementor-editor-active .site-footer{
  background: radial-gradient(circle at 15% 20%, rgba(126,34,48,.34), transparent 34%), var(--navy) !important;
}
body.ahumada-identica-page .footer-top,
body.elementor-editor-active .footer-top{
  border-bottom-color: rgba(126,34,48,.35) !important;
}

body.ahumada-identica-page .cta-band::before,
body.elementor-editor-active .cta-band::before{
  background: linear-gradient(135deg, rgba(126,34,48,.28), transparent 45%) !important;
}
