/* ════════════════════════════════════════════════════════════════
   RACCIATTI & AMELONG — SEDE ENTRE RÍOS
   Editorial · Institucional · Cinematográfico
   ════════════════════════════════════════════════════════════════ */

/* — Reset & base — */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  -moz-osx-font-smoothing:grayscale;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  font-feature-settings:"kern","liga","calt","ss01";
  overflow-x:hidden;
}

/* ════════ Accesibilidad: skip-link + focus visible ════════ */
.skip-link{
  position:absolute;
  top:-100px;left:0;
  background:var(--navy);
  color:var(--cream);
  padding:14px 22px;
  font-family:var(--mono);
  font-size:.8rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  z-index:9999;
  border-radius:0 0 4px 0;
  transition:top .2s;
}
.skip-link:focus{
  top:0;
  outline:2px solid var(--gold);
  outline-offset:2px;
}

/* Focus visible global — solo cuando se navega con teclado (no en clicks de mouse) */
*:focus{outline:none}
*:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:2px;
}
.btn-primary:focus-visible,
.btn-nav:focus-visible,
.btn-mini-wa:focus-visible{
  outline-color:var(--cream);
  outline-offset:4px;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .4s cubic-bezier(.25,.46,.45,.94)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ═══ Design tokens ═══ */
:root{
  /* Color */
  --cream:#f4f1ea;
  --cream-deep:#ebe7dd;
  --sand:#e1d9c5;
  --paper:#fafaf6;
  --navy:#0d1b2a;
  --navy-deep:#06101b;
  --navy-soft:#1a2942;
  --wine:#5c1f2b;
  --gold:#8a6b3d;
  --gold-soft:#d4b67e;
  --gold-deep:#5e4828;
  /* Verde institucional — acento exclusivo para área CONTABLE */
  --green:#2c5530;
  --green-soft:#7a9e7e;
  --green-deep:#1a3a1f;
  --green-pale:#e6efe7;
  /* Acento dinámico: el body define cuál usar */
  --accent:var(--gold);
  --accent-soft:var(--gold-soft);
  --accent-deep:var(--gold-deep);
  --ink:#1a1a1a;
  --ink-soft:#3a3a3a;
  --muted:#6b6b6b;
  --muted-soft:#8a8a8a;
  --line:#c9c0a8;
  --line-soft:#dfd8c6;
  --wpp:#25d366;

  /* Type */
  --serif:'Fraunces','Cormorant Garamond','Georgia',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono','Consolas',monospace;

  /* Layout */
  --max-w:1320px;
  --max-narrow:880px;
  --pad:clamp(20px,4vw,40px);

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur:.7s;
}

/* ═══ Typography ═══ */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:400;
  color:var(--navy);
  line-height:1.05;
  letter-spacing:-.02em;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
h1{font-size:clamp(3rem,9vw,8rem);font-weight:300;letter-spacing:-.035em}
h2{font-size:clamp(2.2rem,5.5vw,4.5rem);font-weight:400;letter-spacing:-.025em}
h3{font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:500;line-height:1.15}
h4{font-size:1.15rem;font-weight:500;line-height:1.3}
em,i{font-style:italic;color:var(--wine)}
strong{font-weight:600}
p{color:var(--ink-soft);margin-bottom:1.1em;font-feature-settings:"kern","liga","onum"}
p.lead{font-size:clamp(1.1rem,1.6vw,1.4rem);line-height:1.5;color:var(--ink)}
p.lead em{font-style:italic;color:var(--wine)}
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono);font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);font-weight:500}
::selection{background:var(--gold);color:var(--cream)}

/* — Container — */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad)}
.container-narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 var(--pad)}

/* — Reveal animation utility — */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.18s}
.reveal-delay-3{transition-delay:.28s}
.reveal-delay-4{transition-delay:.38s}

/* ═══ TOP BAR ═══ */
.topbar{
  background:var(--navy-deep);
  color:rgba(244,241,234,.7);
  font-size:.78rem;
  padding:10px 0;
  letter-spacing:.05em;
  border-bottom:1px solid rgba(176,141,87,.15);
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.topbar a{color:var(--gold-soft)}
.topbar a:hover{color:var(--gold)}
.topbar-dot{display:inline-block;width:6px;height:6px;background:var(--gold);border-radius:50%;margin:0 10px;vertical-align:middle}

/* ═══ NAV ═══ */
.nav{
  background:var(--cream);
  position:sticky;top:0;z-index:80;
  border-bottom:1px solid var(--line-soft);
  transition:background .4s var(--ease);
  backdrop-filter:blur(8px);
}
.nav.scrolled{background:rgba(244,241,234,.92)}
.nav .container{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:18px;padding-bottom:18px;gap:30px;
}
.nav-logo{display:flex;align-items:center;gap:14px}
.nav-logo img{height:46px;width:auto}
.nav-logo-text{
  font-family:var(--serif);
  font-size:1.05rem;
  font-weight:500;
  color:var(--navy);
  line-height:1.1;
  letter-spacing:-.005em;
}
.nav-logo-text small{
  display:block;
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold);
  margin-top:4px;
  font-weight:500;
}

.nav-menu{display:flex;align-items:center;gap:36px;list-style:none}
.nav-menu > li > a{
  font-size:.92rem;
  font-weight:500;
  color:var(--ink);
  position:relative;
  padding:8px 0;
  letter-spacing:.005em;
}
.nav-menu > li > a:hover{color:var(--wine)}
.nav-menu > li > a.active::after,
.nav-menu > li:hover > a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--gold);
  animation:underline .35s var(--ease-out);
}
@keyframes underline{from{width:0}to{width:100%}}

.has-sub{position:relative}
.submenu{
  position:absolute;top:100%;left:-20px;
  background:var(--paper);
  min-width:280px;
  border:1px solid var(--line-soft);
  box-shadow:0 24px 60px -20px rgba(13,27,42,.18);
  padding:14px 0;
  opacity:0;visibility:hidden;transform:translateY(12px);
  transition:.3s var(--ease-out);
}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 22px;font-size:.88rem;color:var(--ink-soft);
  border-left:2px solid transparent;
  transition:.25s var(--ease);
}
.submenu a::after{
  content:"→";opacity:0;margin-left:12px;color:var(--gold);transition:.25s var(--ease);
}
.submenu a:hover{background:var(--cream-deep);color:var(--navy);border-left-color:var(--gold);padding-left:26px}
.submenu a:hover::after{opacity:1}

.btn-nav{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.86rem;font-weight:500;letter-spacing:.02em;
  color:var(--navy)!important;
  padding:12px 22px;
  border:1px solid var(--navy);
  position:relative;overflow:hidden;
  transition:.4s var(--ease);
}
.btn-nav::before{
  content:"";position:absolute;inset:0;background:var(--navy);
  transform:translateY(100%);transition:.4s var(--ease);z-index:-1;
}
.btn-nav:hover{color:var(--cream)!important}
.btn-nav:hover::before{transform:translateY(0)}

.nav-toggle{display:none;font-size:1.5rem;color:var(--navy);padding:6px}

@media (max-width:1020px){
  .nav-toggle{
    display:flex;align-items:center;justify-content:center;
    min-width:48px;min-height:48px;  /* tap target ≥ 48px (WCAG) */
    font-size:1.5rem;color:var(--navy);
  }
  /* Drawer mobile: usa transform en vez de right negativo para evitar
     overflow-x indeseado en mobile (era scrollWidth 750 vs viewport 375) */
  .nav-menu{
    position:fixed;top:0;right:0;
    flex-direction:column;align-items:flex-start;
    width:min(320px, 85vw);max-width:320px;height:100vh;
    background:var(--paper);
    padding:90px 28px 32px;
    gap:6px;
    box-shadow:-20px 0 60px rgba(13,27,42,.15);
    transform:translateX(110%);
    transition:transform .35s var(--ease);
    overflow-y:auto;
    will-change:transform;
  }
  .nav-menu.open{transform:translateX(0)}
  .nav-menu > li{width:100%;padding:8px 0;border-bottom:1px solid var(--line-soft)}
  .nav-menu > li > a{display:block;font-size:1.05rem;min-height:44px;display:flex;align-items:center}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:10px 0 12px 16px;background:transparent}
  .submenu a{min-height:40px;display:flex;align-items:center}
  .btn-nav{margin-top:14px;width:100%;justify-content:center;min-height:48px}
  /* Topbar phone link: tap target mejor */
  .topbar a{display:inline-flex;align-items:center;min-height:32px;padding:4px 6px}
}

/* ═══ HERO — split editorial robusto (sin position:absolute) ═══ */
.hero{
  position:relative;
  background:var(--cream);
  overflow:hidden;
  padding:50px 0 70px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.7  0 0 0 0 0.6  0 0 0 0 0.4  0 0 0 .035 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.5;mix-blend-mode:multiply;pointer-events:none;
  z-index:0;
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  width:100%;
  align-items:center;
}
.hero-content{min-width:0}

/* Imagen como tarjeta editorial dentro del grid */
.hero-image-wrap{
  position:relative;
  aspect-ratio:4/5;
  max-height:640px;
  overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(13,27,42,.35);
}
.hero-image{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(.75) contrast(1.05);
}
.hero-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom right, rgba(13,27,42,.18), rgba(92,31,43,.28));
}

@media (max-width:980px){
  .hero{padding:40px 0 60px}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-image-wrap{aspect-ratio:16/10;max-height:360px;order:2}
  .hero-content{order:1}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  margin-bottom:36px;
}
.hero-eyebrow-line{display:inline-block;width:48px;height:1px;background:var(--gold)}
.hero-eyebrow span{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
}
.hero-eyebrow strong{color:var(--gold);font-weight:600}

h1.hero-title{
  font-size:clamp(2.4rem,5.5vw,4.8rem);
  font-weight:300;
  line-height:1.1;
  letter-spacing:-.035em;
  margin-bottom:32px;
  max-width:none;
  color:var(--cream);
  background:rgba(13,27,42,.92);
  padding:22px 28px 24px;
}
@media (max-width:900px){
  h1.hero-title{padding:18px 20px 20px}
}
h1.hero-title .amp{
  font-size:0.62em;
  font-style:italic;
  font-weight:300;
  letter-spacing:.02em;
  display:inline-block;
  transform:translateY(-.08em);
  margin:0 .06em;
  color:var(--gold-soft);
}
h1.hero-title em{
  display:block;
  font-size:0.56em;
  font-style:italic;
  font-weight:400;
  line-height:1.2;
  margin-top:14px;
  padding-bottom:.08em;
  color:var(--gold-soft);
  background:none;
  -webkit-text-fill-color:var(--gold-soft);
}
.hero-sub{
  font-size:clamp(1.05rem,1.5vw,1.3rem);
  line-height:1.55;
  color:var(--ink-soft);
  max-width:44ch;
  margin-bottom:40px;
}
.hero-sub em{color:var(--wine);font-style:italic}

.hero-cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}

.btn-primary{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--navy);
  color:var(--cream);
  padding:18px 32px;
  font-size:.92rem;font-weight:500;letter-spacing:.02em;
  position:relative;overflow:hidden;
  transition:.45s var(--ease);
  border:1px solid var(--navy);
}
.btn-primary::before{
  content:"";position:absolute;inset:0;background:var(--wine);
  transform:translateY(101%);transition:.45s var(--ease);z-index:0;
}
.btn-primary > *{position:relative;z-index:1}
.btn-primary:hover{color:var(--cream);border-color:var(--wine)}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary .arrow{transition:transform .45s var(--ease)}
.btn-primary:hover .arrow{transform:translateX(6px)}

.btn-secondary{
  display:inline-flex;align-items:center;gap:14px;
  color:var(--navy);
  padding:18px 4px;
  font-size:.92rem;font-weight:500;letter-spacing:.02em;
  position:relative;
  transition:.4s var(--ease);
}
.btn-secondary::after{
  content:"";position:absolute;left:4px;right:4px;bottom:14px;height:1px;background:var(--navy);
  transform:scaleX(.7);transform-origin:left;transition:.4s var(--ease);
}
.btn-secondary:hover{color:var(--wine)}
.btn-secondary:hover::after{transform:scaleX(1);background:var(--wine)}

/* Hero meta strip — datos institucionales */
.hero-meta{
  margin-top:80px;
  padding-top:36px;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  align-items:start;
}
@media (max-width:780px){.hero-meta{grid-template-columns:repeat(2,1fr);gap:32px}}
.hero-meta-item .num{
  font-family:var(--serif);
  font-size:clamp(2.4rem,4vw,3.5rem);
  font-weight:400;
  color:var(--navy);
  line-height:1;
  margin-bottom:8px;
  font-feature-settings:"onum","lnum" 0;
}
.hero-meta-item .num span{
  font-size:.55em;color:var(--gold);font-style:italic;
  font-weight:300;vertical-align:super;
}
.hero-meta-item .label{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
  line-height:1.4;
}

/* ═══ Section base ═══ */
section{padding:clamp(80px,12vw,160px) 0;position:relative}
.section-mono{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  display:flex;align-items:center;gap:14px;
  margin-bottom:32px;
}
.section-mono::before{
  content:"";display:inline-block;width:36px;height:1px;background:var(--gold);
}
.section-head{margin-bottom:80px;max-width:760px}
.section-head h2 em{color:var(--wine);font-style:italic}
.section-head p{font-size:1.15rem;line-height:1.55;color:var(--ink-soft);margin-top:24px;max-width:62ch}

/* ═══ Problemas — split editorial ═══ */
.problemas{background:var(--paper)}
.problemas-flex{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  border-top:1px solid var(--line);
}
.problema-row{
  display:grid;
  grid-template-columns:80px 1fr auto;
  gap:40px;
  padding:42px 0;
  border-bottom:1px solid var(--line);
  align-items:center;
  transition:padding .45s var(--ease),background .45s var(--ease);
  position:relative;
}
.problema-row:hover{padding-left:24px;background:linear-gradient(to right,rgba(176,141,87,.06),transparent 80%)}
.problema-num{
  font-family:var(--serif);
  font-size:1.15rem;
  color:var(--gold);
  font-style:italic;
  font-weight:500;
  font-feature-settings:"onum";
}
.problema-content h3{
  font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:400;
  margin-bottom:10px;
}
.problema-content p{
  font-size:1.02rem;
  color:var(--muted);
  margin-bottom:0;
  max-width:62ch;
}
.problema-arrow{
  width:48px;height:48px;
  border:1px solid var(--line);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);
  transition:.4s var(--ease);
}
.problema-row:hover .problema-arrow{
  background:var(--navy);color:var(--cream);border-color:var(--navy);
  transform:rotate(-45deg);
}
@media (max-width:680px){
  .problema-row{grid-template-columns:60px 1fr;gap:20px;padding:32px 0}
  .problema-arrow{display:none}
  .problema-row:hover{padding-left:0}
}

/* ═══ Servicios — asymmetric grid ═══ */
.servicios{background:var(--cream)}
.servicios-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.servicio-card{
  background:var(--paper);
  padding:48px 40px;
  position:relative;overflow:hidden;
  transition:.5s var(--ease);
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:340px;
}
.servicio-card.col-4{grid-column:span 4}
.servicio-card.col-6{grid-column:span 6}
.servicio-card.col-8{grid-column:span 8}
@media (max-width:980px){
  .servicio-card.col-4,.servicio-card.col-6,.servicio-card.col-8{grid-column:span 6}
}
@media (max-width:560px){
  .servicio-card.col-4,.servicio-card.col-6,.servicio-card.col-8{grid-column:span 12}
}
.servicio-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .6s var(--ease);
}
.servicio-card:hover{background:var(--navy);color:var(--cream)}
.servicio-card:hover::before{transform:scaleX(1)}
.servicio-card:hover h3,
.servicio-card:hover p,
.servicio-card:hover .servicio-num{color:var(--cream)}
.servicio-card:hover .servicio-num{color:var(--gold)}
.servicio-card:hover .servicio-link{color:var(--gold)}
.servicio-card:hover .servicio-link::after{background:var(--gold)}
.servicio-num{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.2em;
  color:var(--muted-soft);
  margin-bottom:24px;
  transition:.5s var(--ease);
}
.servicio-card h3{
  font-size:clamp(1.5rem,2vw,1.9rem);
  font-weight:500;
  line-height:1.15;
  margin-bottom:18px;
  transition:.5s var(--ease);
}
.servicio-card p{
  font-size:.97rem;
  color:var(--muted);
  margin-bottom:32px;
  line-height:1.55;
  flex-grow:1;
  transition:.5s var(--ease);
}
.servicio-link{
  font-family:var(--mono);
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
  position:relative;padding-bottom:6px;
  transition:.4s var(--ease);width:fit-content;
}
.servicio-link::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--navy);
  transform:scaleX(.4);transform-origin:left;transition:.45s var(--ease);
}
.servicio-card:hover .servicio-link::after{transform:scaleX(1)}

/* ═══ Editorial split — sobre el estudio ═══ */
.editorial{
  background:var(--navy);color:var(--cream);
  position:relative;overflow:hidden;
}
.editorial::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .9  0 0 0 0 .8  0 0 0 0 .6  0 0 0 .035 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.4;pointer-events:none;
}
.editorial .container{position:relative;z-index:1}
.editorial-grid{
  display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:center;
}
@media (max-width:900px){.editorial-grid{grid-template-columns:1fr;gap:50px}}
.editorial-grid h2{color:var(--cream);font-size:clamp(2.2rem,5vw,4rem);font-weight:300}
.editorial-grid h2 em{color:var(--gold-soft);font-style:italic}
.editorial-grid p{color:rgba(244,241,234,.78);font-size:1.05rem;line-height:1.7}
.editorial-grid p:first-of-type::first-letter{
  font-family:var(--serif);
  font-size:4.2em;
  float:left;
  line-height:.9;
  margin:6px 14px 0 0;
  color:var(--gold);
  font-weight:400;
}
.editorial-side .mono{color:var(--gold-soft);margin-bottom:24px}
.editorial-cta{margin-top:36px}
.editorial-cta a{
  color:var(--gold-soft);
  font-family:var(--mono);
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  border-bottom:1px solid rgba(212,182,126,.4);
  padding-bottom:6px;
  transition:.35s var(--ease);
}
.editorial-cta a:hover{color:var(--gold);border-color:var(--gold)}

/* ═══ Pilares — minimal columns ═══ */
.pilares{background:var(--cream-deep)}
.pilares-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);border-left:1px solid var(--line);
}
@media (max-width:900px){.pilares-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.pilares-grid{grid-template-columns:1fr}}
.pilar{
  padding:50px 36px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;
  background:var(--paper);
  transition:.45s var(--ease);
}
.pilar:hover{background:var(--cream)}
.pilar .pilar-num{
  font-family:var(--mono);
  font-size:.72rem;letter-spacing:.2em;
  color:var(--gold);font-weight:500;
  margin-bottom:32px;display:block;
}
.pilar h3{
  font-size:clamp(1.3rem,1.8vw,1.6rem);
  font-weight:500;line-height:1.2;margin-bottom:14px;
}
.pilar h3 em{color:var(--wine);font-style:italic}
.pilar p{font-size:.96rem;color:var(--muted);line-height:1.6;margin:0}

/* ═══ Zonas — territorial ═══ */
.zonas{background:var(--paper);position:relative}
.zonas-grid{
  display:grid;grid-template-columns:6fr 5fr;gap:80px;align-items:center;
}
@media (max-width:980px){.zonas-grid{grid-template-columns:1fr;gap:50px}}
.zonas-lista{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  margin-top:40px;
  border-top:1px solid var(--line);
}
.zonas-lista li{
  list-style:none;
  padding:18px 0;
  font-family:var(--serif);
  font-size:1.4rem;
  font-weight:400;
  color:var(--navy);
  border-bottom:1px solid var(--line);
  display:flex;align-items:baseline;gap:14px;
  transition:.4s var(--ease);
}
.zonas-lista li:hover{padding-left:14px;color:var(--wine)}
.zonas-lista li::before{
  content:"·";color:var(--gold);font-size:1.4rem;line-height:1;
}
.zonas-mapa{
  position:relative;height:520px;
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow:0 30px 70px -30px rgba(13,27,42,.3);
}
.zonas-mapa::before{
  content:"";position:absolute;inset:0;border:1px solid var(--gold);
  margin:14px;pointer-events:none;z-index:2;
  transition:.6s var(--ease);
}
.zonas-mapa:hover::before{margin:6px}
.zonas-mapa iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.85) contrast(.95)}

/* ═══ CTA strip — institutional ═══ */
.cta-strip{
  background:var(--navy);color:var(--cream);
  text-align:center;padding:120px 0;
  position:relative;overflow:hidden;
}
.cta-strip::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .9  0 0 0 0 .8  0 0 0 0 .6  0 0 0 .04 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.45;pointer-events:none;
}
.cta-strip .container{position:relative;z-index:1;max-width:760px}
.cta-strip .mono{margin-bottom:28px;justify-content:center;color:var(--gold-soft)}
.cta-strip .mono::before{display:none}
.cta-strip h2{
  color:var(--cream);
  font-size:clamp(2.4rem,6vw,4.5rem);
  font-weight:300;letter-spacing:-.03em;
  margin-bottom:30px;
}
.cta-strip h2 em{color:var(--gold-soft);font-style:italic}
.cta-strip p{
  color:rgba(244,241,234,.7);
  font-size:1.15rem;line-height:1.5;
  margin-bottom:50px;
}
.cta-strip .hero-cta{justify-content:center}
.cta-strip .btn-primary{
  background:var(--gold);color:var(--navy);border-color:var(--gold);
}
.cta-strip .btn-primary::before{background:var(--cream)}
.cta-strip .btn-primary:hover{color:var(--navy);border-color:var(--cream)}
.cta-strip .btn-secondary{color:var(--cream)}
.cta-strip .btn-secondary::after{background:var(--cream)}
.cta-strip .btn-secondary:hover{color:var(--gold-soft)}
.cta-strip .btn-secondary:hover::after{background:var(--gold-soft)}

/* ═══ FAQ ═══ */
.faq{background:var(--cream)}
.faq-wrap{max-width:840px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--line);
  padding:0;
  transition:.4s var(--ease);
}
.faq-item summary{
  padding:32px 0;
  font-family:var(--serif);
  font-size:clamp(1.15rem,1.8vw,1.5rem);
  font-weight:500;
  color:var(--navy);
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:flex-start;gap:30px;
  line-height:1.25;
  transition:.4s var(--ease);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";display:inline-block;width:18px;height:18px;flex-shrink:0;margin-top:6px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18' fill='none' stroke='%230d1b2a' stroke-width='1.2'><line x1='9' y1='2' x2='9' y2='16'/><line x1='2' y1='9' x2='16' y2='9'/></svg>");
  background-size:contain;transition:transform .4s var(--ease);
}
.faq-item[open] summary::after{transform:rotate(135deg)}
.faq-item[open] summary{color:var(--wine)}
.faq-item-body{
  padding:0 0 36px;color:var(--ink-soft);
  font-size:1.05rem;line-height:1.7;max-width:64ch;
}

/* ═══ Contacto ═══ */
.contacto{background:var(--paper)}
.contacto-grid{
  display:grid;grid-template-columns:5fr 6fr;gap:80px;
}
@media (max-width:900px){.contacto-grid{grid-template-columns:1fr;gap:50px}}
.contacto-info > h3{margin-bottom:36px;font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:500}
.contacto-canal{
  display:grid;grid-template-columns:50px 1fr;gap:24px;
  padding:24px 0;border-bottom:1px solid var(--line-soft);
  align-items:flex-start;
}
.contacto-canal:first-of-type{border-top:1px solid var(--line-soft)}
.contacto-canal .num{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;
  color:var(--gold);font-weight:500;margin-top:8px;
}
.contacto-canal-label{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);margin-bottom:6px;
}
.contacto-canal-value{
  font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--navy);
  line-height:1.3;
}
.contacto-canal-value a{transition:color .35s var(--ease);color:var(--navy)}
.contacto-canal-value a:hover{color:var(--wine)}
.contacto-canal-note{
  font-size:.85rem;color:var(--muted);margin-top:8px;
}

.contacto-form{
  background:var(--navy);color:var(--cream);
  padding:60px 50px;
  position:relative;overflow:hidden;
}
@media (max-width:540px){.contacto-form{padding:40px 26px}}
.contacto-form::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .9  0 0 0 0 .8  0 0 0 0 .6  0 0 0 .035 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.35;pointer-events:none;
}
.contacto-form > *{position:relative;z-index:1}
.contacto-form h3{color:var(--cream);font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:400;margin-bottom:12px}
.contacto-form h3 em{color:var(--gold-soft);font-style:italic}
.contacto-form > p{color:rgba(244,241,234,.7);margin-bottom:36px;font-size:1rem}
.form-field{margin-bottom:22px}
.form-field label{
  display:block;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(212,182,126,.85);margin-bottom:10px;font-weight:500;
}
.form-field input, .form-field textarea, .form-field select{
  width:100%;padding:14px 0;
  border:none;border-bottom:1px solid rgba(244,241,234,.2);
  font-size:1rem;font-family:var(--sans);
  background:transparent;color:var(--cream);
  transition:.35s var(--ease);
}
.form-field input::placeholder, .form-field textarea::placeholder{color:rgba(244,241,234,.35)}
.form-field input:focus, .form-field textarea:focus, .form-field select:focus{
  outline:none;border-bottom-color:var(--gold);
}
.form-field select{cursor:pointer}
.form-field select option{background:var(--navy);color:var(--cream)}
.form-field textarea{resize:vertical;min-height:90px}
.contacto-form button{
  width:100%;margin-top:14px;
  background:var(--gold);color:var(--navy);
  padding:18px;font-size:.92rem;font-weight:600;
  letter-spacing:.05em;text-transform:uppercase;
  border:1px solid var(--gold);
  transition:.4s var(--ease);
  position:relative;overflow:hidden;
}
.contacto-form button::before{
  content:"";position:absolute;inset:0;background:var(--cream);
  transform:translateY(100%);transition:.45s var(--ease);z-index:0;
}
.contacto-form button > *{position:relative;z-index:1}
.contacto-form button:hover::before{transform:translateY(0)}
.form-hint{
  font-size:.78rem;color:rgba(244,241,234,.5);
  text-align:center;margin-top:18px;
}

/* ═══ FOOTER ═══ */
footer{
  background:var(--navy-deep);color:rgba(244,241,234,.55);
  padding:90px 0 36px;
  border-top:1px solid rgba(176,141,87,.15);
}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px;margin-bottom:70px;
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:540px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{height:60px;width:auto;filter:brightness(0) invert(1) opacity(.85);margin-bottom:24px}
.footer-brand p{color:rgba(244,241,234,.65);font-size:.95rem;line-height:1.6;margin-bottom:24px;max-width:34ch}
footer h4{
  color:var(--gold-soft);font-family:var(--mono);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:24px;font-weight:500;
}
footer ul{list-style:none}
footer li{margin-bottom:12px;font-size:.92rem}
footer a{color:rgba(244,241,234,.65);transition:.3s var(--ease)}
footer a:hover{color:var(--gold-soft)}
.footer-bottom{
  border-top:1px solid rgba(176,141,87,.15);
  padding-top:30px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-size:.82rem;color:rgba(244,241,234,.4);
}
.footer-bottom .mono{color:var(--gold-soft)}
.footer-social{display:flex;gap:14px;margin-top:24px}
.footer-social a{
  width:42px;height:42px;
  border:1px solid rgba(176,141,87,.3);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:var(--gold-soft);
  transition:.4s var(--ease);
}
.footer-social a:hover{background:var(--gold);color:var(--navy);border-color:var(--gold);transform:translateY(-2px)}

/* ═══ WhatsApp float — refined ═══ */
.wpp-float{
  position:fixed;bottom:30px;right:30px;
  display:flex;align-items:center;gap:14px;
  background:var(--wpp);color:#fff;
  padding:16px 24px;
  border-radius:999px;
  font-size:.86rem;font-weight:600;
  box-shadow:0 14px 36px -8px rgba(37,211,102,.5);
  z-index:90;
  transition:.45s var(--ease);
  opacity:0;transform:translateY(20px);
}
.wpp-float.show{opacity:1;transform:translateY(0)}
.wpp-float:hover{transform:translateY(-3px);box-shadow:0 18px 44px -8px rgba(37,211,102,.6);color:#fff}
.wpp-float .wpp-icon{
  width:28px;height:28px;background:rgba(255,255,255,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1rem;
}
@media (max-width:540px){
  .wpp-float{padding:14px;right:18px;bottom:18px}
  .wpp-float-text{display:none}
}

/* ═══ Interior page header ═══ */
.page-header{
  background:var(--navy);color:var(--cream);
  padding:90px 0 80px;
  position:relative;overflow:hidden;
}
.page-header::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .9  0 0 0 0 .8  0 0 0 0 .6  0 0 0 .035 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.4;pointer-events:none;
}
.page-header .container{position:relative;z-index:1;max-width:880px}
.page-header h1{color:var(--cream);font-size:clamp(2.6rem,6vw,5.5rem);font-weight:300;letter-spacing:-.03em;margin-bottom:22px;line-height:.98}
.page-header h1 em{color:var(--gold-soft);font-style:italic}
.page-header p{color:rgba(244,241,234,.75);font-size:1.15rem;line-height:1.55;max-width:62ch}
.breadcrumb{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(244,241,234,.5);margin-bottom:30px;
}
.breadcrumb a{color:var(--gold-soft);transition:.3s var(--ease)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span.sep{color:rgba(176,141,87,.5);margin:0 12px}

/* ═══ Servicio interior ═══ */
.servicio-detalle{padding:100px 0 120px;background:var(--cream)}
.servicio-grid{display:grid;grid-template-columns:7fr 4fr;gap:80px;align-items:start}
@media (max-width:980px){.servicio-grid{grid-template-columns:1fr;gap:50px}}
.servicio-body p{font-size:1.1rem;line-height:1.75;margin-bottom:20px;color:var(--ink-soft)}
.servicio-body p:first-of-type::first-letter{
  font-family:var(--serif);
  font-size:4.5em;float:left;
  line-height:.9;margin:6px 14px 0 0;
  color:var(--wine);font-weight:500;font-style:italic;
}
.servicio-body p:first-of-type{font-size:1.18rem;color:var(--ink)}
.servicio-body h2{
  margin-top:64px;margin-bottom:28px;
  font-size:clamp(1.8rem,3vw,2.6rem);font-weight:400;
}
.servicio-body h2 em{color:var(--wine);font-style:italic}
.servicio-body ul{margin-bottom:30px;padding-left:0;list-style:none}
.servicio-body li{
  padding:22px 0 22px 60px;
  position:relative;border-bottom:1px solid var(--line-soft);
  font-size:1.08rem;color:var(--navy);line-height:1.5;
  transition:.4s var(--ease);
}
.servicio-body li:hover{padding-left:74px}
.servicio-body li::before{
  content:counter(li,decimal-leading-zero);
  counter-increment:li;
  position:absolute;left:0;top:22px;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;
  color:var(--gold);font-weight:500;
}
.servicio-body ul{counter-reset:li}
.servicio-body li:last-child{border-bottom:none}

.servicio-sidebar{position:sticky;top:110px;align-self:start}
.servicio-sidebar-card{
  background:var(--navy);color:var(--cream);
  padding:44px 36px;
  position:relative;overflow:hidden;
}
.servicio-sidebar-card::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .9  0 0 0 0 .8  0 0 0 0 .6  0 0 0 .035 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.4;pointer-events:none;
}
.servicio-sidebar-card > *{position:relative;z-index:1}
.servicio-sidebar-card .mono{margin-bottom:18px;color:var(--gold-soft)}
.servicio-sidebar-card .mono::before{display:none}
.servicio-sidebar-card h3{color:var(--cream);font-size:1.6rem;font-weight:400;margin-bottom:14px}
.servicio-sidebar-card p{color:rgba(244,241,234,.75);font-size:.98rem;line-height:1.55;margin-bottom:26px}
.servicio-sidebar-card .btn-primary{
  width:100%;justify-content:center;
  background:var(--gold);color:var(--navy);border-color:var(--gold);
}
.servicio-sidebar-card .btn-primary::before{background:var(--cream)}
.servicio-sidebar-card .btn-primary:hover{color:var(--navy);border-color:var(--cream)}
.servicio-sidebar-card .btn-secondary{
  width:100%;justify-content:center;color:var(--cream);margin-top:12px;
  padding:12px 4px;
}
.servicio-sidebar-card .btn-secondary::after{background:rgba(244,241,234,.4)}

.otros-servicios{margin-top:36px;padding-top:28px;border-top:1px solid rgba(176,141,87,.15)}
.otros-servicios .mono{color:var(--gold-soft);margin-bottom:16px}
.otros-servicios ul{list-style:none}
.otros-servicios li{margin-bottom:10px}
.otros-servicios a{
  color:rgba(244,241,234,.7);font-size:.95rem;
  font-family:var(--serif);font-weight:400;
  display:inline-flex;align-items:center;gap:8px;
  transition:.35s var(--ease);
}
.otros-servicios a:hover{color:var(--gold-soft);padding-left:6px}
.otros-servicios a::before{content:"·";color:var(--gold);margin-right:4px}

/* ═══ Equipo cards ═══ */
.equipo-section{background:var(--cream);padding:100px 0 120px}
.equipo-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:60px;
  max-width:880px;margin:0 auto;
}
@media (max-width:780px){.equipo-grid{grid-template-columns:1fr;gap:48px;max-width:440px}}
.equipo-card{
  position:relative;
  transition:.5s var(--ease);
}
.equipo-foto{
  width:100%;aspect-ratio:3/4;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-soft) 100%);
  position:relative;overflow:hidden;
  display:flex;align-items:flex-end;justify-content:center;
  margin-bottom:22px;
}
.equipo-foto::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .9  0 0 0 0 .8  0 0 0 0 .6  0 0 0 .07 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:.6;
}
.equipo-foto::after{
  content:"";position:absolute;inset:14px;border:1px solid rgba(176,141,87,.4);pointer-events:none;
  transition:.6s var(--ease);
}
.equipo-card:hover .equipo-foto::after{inset:6px}
.equipo-foto img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.equipo-foto .equipo-placeholder{
  position:relative;z-index:1;
  font-family:var(--serif);
  font-size:6rem;color:var(--gold);
  opacity:.5;font-style:italic;
  margin-bottom:30px;
}
.equipo-body{padding:0 4px}
.equipo-card .equipo-titulo{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:12px;font-weight:500;
}
.equipo-card h3{
  font-size:clamp(1.4rem,2vw,1.7rem);
  font-weight:500;line-height:1.2;margin-bottom:14px;
}
.equipo-card p{font-size:.95rem;color:var(--muted);line-height:1.6;margin-bottom:18px}
.equipo-meta{
  display:flex;gap:18px;padding-top:18px;border-top:1px solid var(--line-soft);
}
.equipo-meta a{
  font-family:var(--mono);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--navy);font-weight:500;
  position:relative;padding-bottom:2px;
}
.equipo-meta a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold);
  transform:scaleX(.5);transform-origin:left;transition:.4s var(--ease);
}
.equipo-meta a:hover{color:var(--wine)}
.equipo-meta a:hover::after{transform:scaleX(1);background:var(--wine)}

/* ═══ Page intro / about ═══ */
.intro-section{padding:120px 0;background:var(--cream)}
.intro-grid{display:grid;grid-template-columns:4fr 8fr;gap:80px;align-items:start}
@media (max-width:900px){.intro-grid{grid-template-columns:1fr;gap:40px}}
.intro-side .mono{margin-bottom:18px}
.intro-side h3{font-size:clamp(1.6rem,2.5vw,2.4rem);font-weight:400;line-height:1.1}
.intro-side h3 em{color:var(--wine);font-style:italic}
.intro-content p{font-size:1.15rem;line-height:1.7;color:var(--ink-soft);max-width:62ch}
.intro-content p:first-of-type::first-letter{
  font-family:var(--serif);
  font-size:4.5em;float:left;
  line-height:.9;margin:6px 14px 0 0;
  color:var(--wine);font-weight:500;font-style:italic;
}
.intro-content h4{
  font-family:var(--serif);font-size:1.5rem;font-weight:500;
  margin:48px 0 16px;color:var(--navy);
}
.intro-content ul{padding-left:0;list-style:none;margin-bottom:30px}
.intro-content li{
  position:relative;padding:14px 0 14px 40px;
  border-bottom:1px solid var(--line-soft);
  font-size:1.02rem;line-height:1.5;
}
.intro-content li::before{
  content:"·";position:absolute;left:8px;top:8px;
  font-size:2.4rem;color:var(--gold);line-height:1;
}

/* ═══ Utility ═══ */
.text-center{text-align:center}
.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}
.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}
.dorado{color:var(--gold)}
.wine{color:var(--wine)}

/* ═══ Print ═══ */
@media print{
  .nav,.wpp-float,.cta-strip,.btn-primary,.btn-secondary,.topbar{display:none}
  *{color:#000!important;background:#fff!important}
}

/* ═══ Reduced motion ═══ */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .reveal{
    opacity:1!important;
    transform:none!important;
    transition:none!important;
  }
  .wpp-float{animation:none!important}
  html{scroll-behavior:auto!important}
}

/* ════════════════════════════════════════════════════════════════
   ÁREAS DE PRÁCTICA — sistema de acento dual
   --accent default = gold (jurídico). area-contable lo sobrescribe.
   ════════════════════════════════════════════════════════════════ */

body.area-contable{
  --accent:var(--green);
  --accent-soft:var(--green-soft);
  --accent-deep:var(--green-deep);
}

/* Mono labels institucionales en el acento del área */
body.area-contable .mono,
body.area-contable .section-mono,
body.area-contable .hero-eyebrow strong{ color:var(--green) }

/* Acentos italic editorial (em / i) — en contable usan verde-deep */
body.area-contable em,
body.area-contable i{ color:var(--green-deep) }

/* Números decorativos en cards y pilares */
body.area-contable .pilar-num,
body.area-contable .servicio-num,
body.area-contable .problema-num{ color:var(--green) }

/* Hero title em (la 2ª línea con gradient) — pinta verde */
body.area-contable h1.hero-title em,
body.area-contable .hero-title em{
  background:linear-gradient(120deg, var(--green-deep) 0%, var(--green) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* Editorial side mono y h2 em en area contable */
body.area-contable .editorial em,
body.area-contable .section-head em{ color:var(--green-deep) }

/* Botón primario — fondo verde */
body.area-contable .btn-primary{
  background:var(--green);
  border-color:var(--green);
}
body.area-contable .btn-primary:hover{
  background:var(--green-deep);
  border-color:var(--green-deep);
}
body.area-contable .btn-secondary{
  color:var(--green-deep);
  border-color:var(--green);
}
body.area-contable .btn-secondary:hover{
  background:var(--green);
  color:var(--cream);
}

/* Hover en cards — sombra verde sutil */
body.area-contable .servicio-card:hover,
body.area-contable .problema-row:hover{
  border-color:var(--green);
}

/* Selección de texto en área contable */
body.area-contable ::selection{ background:var(--green); color:var(--cream) }

/* Línea decorativa de eyebrow */
body.area-contable .hero-eyebrow-line{ background:var(--green) }

/* Pilar number underline */
body.area-contable .pilar h3 em{ color:var(--green-deep) }

/* Servicio link → */
body.area-contable .servicio-link{ color:var(--green) }
body.area-contable .servicio-link:hover{ color:var(--green-deep) }

/* Form button submit */
body.area-contable form button[type="submit"]{
  background:var(--green);
}
body.area-contable form button[type="submit"]:hover{
  background:var(--green-deep);
}

/* ════════════════════════════════════════════════════════════════
   CARDS DE ÁREAS EN LA HOME (landing unificada)
   Cards que muestran "Área Jurídica" / "Área Contable" en paralelo
   ════════════════════════════════════════════════════════════════ */
.areas-section{
  padding:clamp(60px,8vh,100px) 0 clamp(80px,12vh,140px);
  background:linear-gradient(180deg, var(--cream) 0%, var(--cream-deep) 60%, var(--cream) 100%);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  position:relative;
}
.areas-section::before{
  content:'';
  position:absolute;
  top:0;left:50%;
  width:1px;height:60px;
  background:linear-gradient(180deg, var(--line) 0%, transparent 100%);
  transform:translateX(-50%);
}
.areas-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(450px,1fr));
  gap:36px;
  margin-top:56px;
}
.area-card{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line-soft);
  border-radius:4px;
  overflow:hidden;
  transition:transform .6s var(--ease-out),box-shadow .6s var(--ease-out),border-color .6s var(--ease-out);
  display:flex;
  flex-direction:column;
  min-height:600px;
}
.area-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 60px -20px rgba(13,27,42,.2);
}
.area-card--juridico:hover{border-color:var(--gold)}
.area-card--contable:hover{border-color:var(--green)}
.area-card-image{
  height:340px;
  background-size:cover;
  background-position:center;
  background-color:var(--navy);  /* fallback si la foto no carga o tiene zonas claras */
  position:relative;
  overflow:hidden;
  flex-shrink:0;
}
.area-card-image::after{
  content:'';
  position:absolute;
  inset:0;
  /* Overlay con tinte navy completo: arriba sutil para que se note la foto,
     abajo dense para legibilidad del label. Garantiza contraste contra fondo cream. */
  background:linear-gradient(180deg, rgba(13,27,42,.18) 0%, rgba(13,27,42,.35) 45%, rgba(13,27,42,.85) 100%);
}
.area-card-image-label{
  position:absolute;
  bottom:20px;left:28px;right:28px;
  z-index:2;
  color:var(--cream);
  font-family:var(--mono);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:flex-end;
}
.area-card-image-name{
  font-family:var(--serif);
  font-style:italic;
  font-size:1rem;
  text-transform:none;
  letter-spacing:-.01em;
  color:rgba(244,241,234,.85);
  font-weight:400;
}
.area-card-body{
  padding:40px 36px 36px;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.area-card-cta-pair{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid var(--line-soft);
  align-items:center;
}
.area-card-cta-pair .btn-mini-wa{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  border-radius:99px;
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:500;
  border:1px solid currentColor;
  transition:all .3s var(--ease);
}
.area-card-cta-pair .btn-mini-wa:hover{
  transform:translateX(2px);
}
.area-card--juridico .btn-mini-wa{color:var(--gold-deep)}
.area-card--juridico .btn-mini-wa:hover{background:var(--gold);color:var(--cream);border-color:var(--gold)}
.area-card--contable .btn-mini-wa{color:var(--green-deep)}
.area-card--contable .btn-mini-wa:hover{background:var(--green);color:var(--cream);border-color:var(--green)}
.area-card-eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:14px;
}
.area-card--juridico .area-card-eyebrow,
.area-card--juridico .area-card-image-label{ color:var(--gold) }
.area-card--contable .area-card-eyebrow,
.area-card--contable .area-card-image-label{ color:var(--green) }
.area-card h3{
  font-size:clamp(1.7rem,3vw,2.4rem);
  margin-bottom:14px;
  line-height:1.1;
}
.area-card h3 em{ font-style:italic }
.area-card--juridico h3 em{ color:var(--gold-deep) }
.area-card--contable h3 em{ color:var(--green-deep) }
.area-card-list{
  list-style:none;
  margin:18px 0 22px;
  padding:0;
}
.area-card-list li{
  padding:7px 0;
  border-bottom:1px solid var(--line-soft);
  font-size:.95rem;
  color:var(--ink-soft);
  display:flex;
  align-items:center;
  gap:8px;
}
.area-card-list li::before{
  content:'·';
  font-size:1.2em;
  line-height:1;
}
.area-card--juridico .area-card-list li::before{ color:var(--gold) }
.area-card--contable .area-card-list li::before{ color:var(--green) }
.area-card-list li:last-child{ border-bottom:none }
.area-card-cta{
  margin-top:auto;
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding-bottom:6px;
  border-bottom:1px solid transparent;
  transition:all .4s var(--ease);
  width:fit-content;
}
.area-card--juridico .area-card-cta{ color:var(--gold-deep) }
.area-card--juridico .area-card-cta:hover{ border-bottom-color:var(--gold) }
.area-card--contable .area-card-cta{ color:var(--green-deep) }
.area-card--contable .area-card-cta:hover{ border-bottom-color:var(--green) }
.area-card-cta span.arrow{ transition:transform .4s var(--ease) }
.area-card-cta:hover span.arrow{ transform:translateX(6px) }

@media (max-width:640px){
  .areas-grid{grid-template-columns:1fr}
  .area-card-image{height:260px}
  .area-card-body{padding:28px 22px 26px}
  .area-card{min-height:0}
}

/* ════════════════════════════════════════════════════════════════
   BLOQUE PROFESIONAL DESTACADO (Cra. Echeverría en /contable/,
   equipo jurídico en /juridico/)
   ════════════════════════════════════════════════════════════════ */
.pro-feature{
  padding:clamp(70px,10vh,120px) 0;
  background:var(--cream-deep);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.pro-feature-grid{
  display:grid;
  grid-template-columns:minmax(280px, 380px) 1fr;
  gap:60px;
  align-items:center;
  max-width:1100px;
  margin:0 auto;
}
.pro-feature-avatar{
  aspect-ratio:4/5;
  border-radius:6px;
  display:grid;place-items:center;
  position:relative;
  overflow:hidden;
}
.area-contable .pro-feature-avatar{
  background:linear-gradient(135deg, var(--green-deep) 0%, var(--green) 60%, var(--green-soft) 100%);
}
.area-juridico .pro-feature-avatar{
  background:linear-gradient(135deg, var(--navy-deep) 0%, var(--navy) 60%, var(--navy-soft) 100%);
}
.pro-feature-avatar-initials{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(5rem,10vw,8rem);
  letter-spacing:-.04em;
  color:rgba(244,241,234,.95);
  line-height:1;
}
.pro-feature-avatar-badge{
  position:absolute;
  bottom:18px;left:18px;right:18px;
  display:flex;justify-content:space-between;align-items:flex-end;
  color:var(--cream);
  font-family:var(--mono);
  font-size:.66rem;
  letter-spacing:.2em;
  text-transform:uppercase;
}
.pro-feature-body .mono{
  margin-bottom:18px;
}
.pro-feature-body h2{
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.05;
  margin-bottom:24px;
}
.pro-feature-body p{
  font-size:1.05rem;
  line-height:1.6;
  margin-bottom:18px;
  color:var(--ink-soft);
  max-width:60ch;
}
.pro-feature-badges{
  display:flex;flex-wrap:wrap;gap:8px;
  margin:24px 0 28px;
}
.pro-feature-badges .badge{
  font-family:var(--mono);
  font-size:.65rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:99px;
  border:1px solid currentColor;
  font-weight:500;
}
.area-contable .pro-feature-badges .badge{color:var(--green-deep);background:var(--green-pale)}
.area-juridico .pro-feature-badges .badge{color:var(--gold-deep);background:rgba(212,182,126,.18)}
.pro-feature-cta{
  display:flex;flex-wrap:wrap;gap:14px;
  align-items:center;
}
.pro-feature-cta-wa{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  border-radius:99px;
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--cream);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.area-contable .pro-feature-cta-wa{background:var(--green)}
.area-contable .pro-feature-cta-wa:hover{background:var(--green-deep);transform:translateY(-2px)}
.area-juridico .pro-feature-cta-wa{background:var(--navy)}
.area-juridico .pro-feature-cta-wa:hover{background:var(--navy-deep);transform:translateY(-2px)}
.pro-feature-cta-tel{
  font-family:var(--mono);
  font-size:.85rem;
  letter-spacing:.05em;
  color:var(--muted);
}
.pro-feature-cta-tel strong{color:var(--ink)}

/* Equipo destacado (2 cards) - para /juridico/ */
.team-feature{
  padding:clamp(70px,10vh,120px) 0;
  background:var(--cream-deep);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.team-feature-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(400px,1fr));
  gap:36px;
  margin-top:48px;
}
.team-pro-card{
  background:var(--paper);
  border:1px solid var(--line-soft);
  border-radius:4px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .5s var(--ease-out),border-color .5s var(--ease-out);
}
.team-pro-card:hover{transform:translateY(-4px);border-color:var(--gold)}
.team-pro-img{
  aspect-ratio:1/1;
  background-size:cover;
  background-position:center top;
  background-color:var(--navy);
}
.team-pro-body{
  padding:28px;
}
.team-pro-card h3{font-size:1.5rem;margin-bottom:6px}
.team-pro-card .mono{margin-bottom:14px}
.team-pro-card p{font-size:.95rem;line-height:1.55;color:var(--ink-soft)}
.team-pro-wa{
  margin-top:18px;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;
  border-radius:99px;
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--gold-deep);
  border:1px solid var(--gold);
  transition:all .3s var(--ease);
}
.team-pro-wa:hover{background:var(--gold);color:var(--cream)}

@media (max-width:760px){
  .pro-feature-grid{grid-template-columns:1fr;gap:36px}
  .pro-feature-avatar{max-width:280px;justify-self:center}
}
