:root{
  /* Brandboard Abogacía Activa */
  --brand: #264722;     /* verde oscuro */
  --brand-dark: #376d31;/* verde más claro */
  --bg: #F7F7F8;        /* blanco roto */
  --surface: #FFFFFF;
  --muted-surface: #F7F7F8;
  --gray: #B5B5BF;      /* gris */
  --text: #0F172A;

  --border: rgba(15, 23, 42, .10);
  --muted: rgba(15, 23, 42, .65);

  --radius: 18px;
  --shadow: 0 10px 35px rgba(15, 23, 42, .08);

  --font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --nav-height: 86px;
  --anchor-offset: calc(var(--nav-height) + 0px);
  --proposals-subnav-offset: calc(var(--nav-height) + 6px);
}

html { scroll-behavior: smooth; }
body{
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
}

/* aplicar a CUALQUIER elemento con id, no sólo section */
section[id],
header[id],
div[id].proposals-header{
  scroll-margin-top: var(--anchor-offset);
}

.section-pad{
  padding: 72px 0;
}

@media (max-width: 991.98px){
  .section-pad{
    padding: 60px 0;
  }
}

@media (max-width: 767.98px){
  .section-pad{
    padding: 52px 0;
  }
}

.section-alt{ background: var(--surface); }

.section-title{
  font-weight: 650;
  letter-spacing: -0.02em;
  margin: 0;
}

.glass-nav{
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}

/* =========================
   NAVBAR
========================= */

#mainNav{
  min-height: 86px;
}

#mainNav .navbar-nav{
  gap: .4rem;
}

#mainNav .nav-link{
  font-size: .80rem;
  font-weight: 600;
  letter-spacing: .05em;
  padding: .65rem .85rem;
  text-transform: uppercase;
  color: rgba(15,23,42,.72) !important;
  transition: color .2s ease;
}

#mainNav .nav-link:hover{
  color: var(--brand) !important;
}

#mainNav .nav-link.active{
  color: var(--brand) !important;
}

#mainNav .btn{
  font-size: .80rem;
  font-weight: 700;
  letter-spacing: .05em;
  padding: .55rem 1rem;
  border-radius: 10px;
}

.brand-logo{
  height: 54px;
  width: auto;
  object-fit: contain;
}

.nav-link{
  color: rgba(17,24,39,.75) !important;
  font-weight: 500;
}
.nav-link:hover{ color: var(--brand-dark) !important; }
.nav-link.active{ color: var(--brand) !important; }

.btn.btn-primary{
  background: var(--brand);
  border-color: var(--brand);
}

.btn.btn-primary:hover{
  background: var(--brand-dark);
  border-color: var(--brand-dark);
}

.badge-soft{
  background: color-mix(in srgb, var(--brand) 12%, transparent);
  color: #fff;
  border: 1px solid color-mix(in srgb, var(--brand) 30%, transparent);
  backdrop-filter: blur(10px);
}

/* =========================
   HERO V2
========================= */

.hero-v2{
  position: relative;
  background: #000;
}

.hero-v2-carousel,
.hero-v2-carousel .carousel-inner,
.hero-v2-carousel .carousel-item{
  height: clamp(560px, 72dvh, 760px);
  min-height: 88svh;
}

.hero-v2-carousel .carousel-item{
  position: relative;
}

.hero-v2-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.hero-v2-overlay{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      90deg,
      rgba(0, 0, 0, 0.72) 0%,
      rgba(0, 0, 0, 0.58) 34%,
      rgba(0, 0, 0, 0.28) 62%,
      rgba(0, 0, 0, 0.14) 100%
    ),
    linear-gradient(
      180deg,
      rgba(0,0,0,.18) 0%,
      rgba(0,0,0,.30) 100%
    );
}

.hero-v2-caption{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  z-index: 2;
}

.hero-v2-content{
  max-width: 760px;
  color: #fff;
  padding-top: 90px;
  padding-bottom: 80px;
}

.hero-v2-kicker{
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: .48rem .8rem;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
  color: rgba(255,255,255,.96);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 1.15rem;
}

.hero-v2-title{
  margin: 0;
  font-size: clamp(3rem, 6vw, 5.6rem);
  line-height: .9;
  letter-spacing: -0.07em;
  font-weight: 900;
  text-transform: none;
  color: #fff;
  text-wrap: balance;
}

.hero-v2-subtitle{
  margin: 1.25rem 0 0;
  max-width: 34ch;
  color: rgba(255,255,255,.88);
  font-size: clamp(1.05rem, 1.5vw, 1.35rem);
  line-height: 1.48;
  font-weight: 500;
}

.hero-v2-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 2rem;
}

.btn-hero-primary{
  min-height: 50px;
  padding: .85rem 1.35rem;
  border-radius: 14px;
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(38, 71, 34, 0.22);
}

.btn-hero-secondary{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: .85rem 1.35rem;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  backdrop-filter: blur(8px);
  transition: all .2s ease;
}

.btn-hero-secondary:hover{
  background: rgba(255,255,255,.16);
  color: #fff;
  border-color: rgba(255,255,255,.3);
}

/* Controls */
.hero-v2-control{
  width: 7%;
  opacity: 1;
  z-index: 3;
}

.hero-v2-arrow{
  width: 52px;
  height: 52px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  font-size: 2rem;
  line-height: 1;
  backdrop-filter: blur(8px);
  transition: all .2s ease;
}

.hero-v2-control:hover .hero-v2-arrow{
  background: rgba(255,255,255,.18);
  transform: scale(1.04);
}

/* Indicators */
.hero-v2-indicators{
  z-index: 4;
  margin-bottom: 48px;
  gap: 8px;
}

.hero-v2-indicators [data-bs-target]{
  width: 10px;
  height: 10px;
  margin: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.46);
  opacity: 1;
  transition: all .2s ease;
}

.hero-v2-indicators .active{
  width: 28px;
  background: #fff;
}

/* Responsive */
@media (max-width: 767.98px){
  .hero-v2-carousel,
  .hero-v2-carousel .carousel-inner,
  .hero-v2-carousel .carousel-item{
    height: clamp(620px, 78vh, 760px);
  }

  .hero-v2-overlay{
    background:
      linear-gradient(
        180deg,
        rgba(0,0,0,.30) 0%,
        rgba(0,0,0,.55) 58%,
        rgba(0,0,0,.72) 100%
      );
  }

  .hero-v2-content{
    padding-top: 96px;
    padding-bottom: 96px;
  }

  .hero-v2-kicker{
    font-size: .74rem;
    margin-bottom: .95rem;
  }

  .hero-v2-title{
    font-size: 2.65rem;
    line-height: .9;
    max-width: 10ch;
  }

  .hero-v2-subtitle{
    margin-top: 1rem;
    font-size: 1rem;
    max-width: 26ch;
    line-height: 1.45;
  }

  .hero-v2-actions{
    gap: 10px;
    margin-top: 1.5rem;
  }

  .btn-hero-primary,
  .btn-hero-secondary{
    min-height: 46px;
    padding: .78rem 1rem;
    font-size: .95rem;
  }

  .hero-v2-arrow{
    width: 42px;
    height: 42px;
    font-size: 1.7rem;
  }

  .hero-v2-control{
    display: none !important;
  }

  .hero-v2-indicators{
    margin-bottom: 32px;
  }

  .hero-v2-img-amantia{
    object-position: 78% center;
  }
}

@media (prefers-reduced-motion: reduce){
  .hero-v2-carousel .carousel-item{
    transition: none !important;
  }
}

@media (max-width: 991.98px){
  .hero-v2-img-amantia{
    object-position: 78% center;
  }
}

/* =========================
   NOSOTROS V2
========================= */

.about-v2{
  background: var(--bg);
}

.section-kicker{
  display: inline-block;
  margin-bottom: .8rem;
  color: var(--brand);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.about-v2-title{
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: .94;
  letter-spacing: -0.05em;
  font-weight: 900;
  color: #182033;
  margin-bottom: 1.15rem;
}

.about-v2-text p{
  margin: 0 0 1rem;
  color: rgba(15, 23, 42, 0.72);
  font-size: clamp(1.02rem, 1.1vw, 1.18rem);
  line-height: 1.62;
}

/* =========================
   ABOUT FEATURES CLEAN
========================= */

.about-feature{
  padding-right: 20px;
}

.about-feature-head{
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: .8rem;
}

.about-feature-head i{
  flex: 0 0 auto;
  font-size: 1.55rem;
  color: var(--brand);
  line-height: 1;
}

.about-feature h3{
  margin: 0;
  font-size: 1.28rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #172033;
  line-height: 1.05;
}

.about-feature p{
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(15,23,42,.72);
}

@media (max-width: 767.98px){
  .about-feature{
    padding-right: 0;
  }

  .about-feature-head{
    gap: 10px;
    margin-bottom: .7rem;
  }

  .about-feature-head i{
    font-size: 1.35rem;
  }

  .about-feature h3{
    font-size: 1.1rem;
  }

  .about-feature p{
    font-size: .98rem;
    line-height: 1.55;
  }
}

@media (max-width: 991.98px){
  .about-v2-title{
    max-width: 12ch;
  }
}

/* =========================
   FIX ALTURA · NOSOTROS
========================= */

#nosotros{
  min-height: calc(100vh - 86px);
  display: flex;
  align-items: center;
}

#nosotros .container{
  width: 100%;
}

@media (max-width: 767.98px){
  #nosotros{
    min-height: auto;
    display: block;
  }
}

/* =========================
   PROPUESTAS · CARDS
========================= */

.axis-banner{
  width: 100%;
  display: block;
  background: var(--brand);
  color: #fff;
  border-radius: 0;
  padding: 1.1rem 1.2rem;
  font-size: clamp(1.25rem, 2.2vw, 2.2rem);
  line-height: .95;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(38, 71, 34, 0.12);
  text-wrap: balance;
}

.proposals-subtitle{
  margin: 1rem 0 0;
  max-width: 1200px;
  padding-left: 1.35rem;
  color: rgba(15, 23, 42, 0.76);
  font-size: clamp(1rem, 1.2vw, 1.18rem);
  line-height: 1.5;
  font-weight: 600;
}

.proposals-header{
  scroll-margin-top: calc(var(--anchor-offset) + 8px);
}

.proposal-card{
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 1.65rem;
  border-radius: 24px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    border-color .22s ease,
    background-color .22s ease,
    color .22s ease;
}

.proposal-card h3{
  margin: 0 0 .8rem;
  font-size: clamp(1.3rem, 1.2vw, 1.42rem);
  line-height: .98;
  font-weight: 800;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  color: #1b1f24;
  text-wrap: balance;
  transition: color .22s ease;
}

.proposal-card p{
  margin: 0 0 1.2rem;
  flex-grow: 1;
  color: rgba(15, 23, 42, 0.72);
  font-size: .98rem;
  line-height: 1.55;
  transition: color .22s ease;
}

.proposal-link{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-top: auto;
  color: var(--brand);
  font-size: .8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  transition: color .22s ease;
}

.proposal-card--clickable{
  cursor: pointer;
}

@media (hover: hover) and (pointer: fine){
  .proposal-card--clickable:hover,
  .proposal-card--clickable:focus-visible{
    transform: translateY(-5px);
    background: var(--brand-dark);
    border-color: var(--brand-dark);
    box-shadow: 0 22px 42px rgba(38, 71, 34, 0.18);
    outline: none;
  }

  .proposal-card--clickable:hover h3,
  .proposal-card--clickable:hover p,
  .proposal-card--clickable:hover .proposal-link,
  .proposal-card--clickable:focus-visible h3,
  .proposal-card--clickable:focus-visible p,
  .proposal-card--clickable:focus-visible .proposal-link{
    color: #fff;
  }

  .proposal-card:hover .proposal-link::after,
  .proposal-card:focus-visible .proposal-link::after{
    transform: translateX(4px);
  }
}


.proposal-link::after{
  content: "→";
  transition: transform .18s ease;
}

/* =========================
   MODAL BACKDROP
========================= */

.modal-backdrop.show{
  opacity: .38;
}

/* =========================
   MODAL · NUEVO LENGUAJE
========================= */

.proposal-modal-modern{
  position: relative;
  border: 0;
  border-radius: 30px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.18);
}

.proposal-modal-inner{
  padding: 2rem;
}

.proposal-modal-close{
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 5;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: #f1f3f2;
  color: rgba(15, 23, 42, 0.45);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all .2s ease;
}

.proposal-modal-close:hover{
  background: #e9ecea;
  color: rgba(15, 23, 42, 0.82);
}

.proposal-modal-close span{
  font-size: 1.8rem;
  line-height: 1;
  margin-top: -2px;
}

/* =========================
   CABECERA
========================= */

.proposal-modal-hero{
  padding-right: 4rem;
  margin-bottom: 2rem;
}

@media (min-width: 1200px) {
  .proposal-modal-hero{
    display: grid;
    grid-template-columns: minmax(0, 720px) 1fr;
    column-gap: 2.5rem;
    align-items: end;
    padding-right: 5rem;
  }

  .proposal-modal-summary{
    max-width: 32ch;
    justify-self: end;
    align-self: end;
    margin-bottom: .35rem;
  }
}

.proposal-modal-title-wrap{
  min-width: 0;
}

.proposal-modal-kicker{
  margin-bottom: .5rem;
  color: rgba(15, 23, 42, 0.36);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

#proposalModalLabel{
  margin: 0;
  max-width: 10ch;
  color: #1a1d22;
  font-size: clamp(2.6rem, 4vw, 4.5rem);
  line-height: .88;
  font-weight: 900;
  letter-spacing: -0.075em;
  text-transform: uppercase;
  text-wrap: balance;
}

.proposal-modal-summary{
  margin: 0;
  max-width: 42ch;
  color: rgba(15, 23, 42, 0.66);
  font-size: 1.15rem;
  line-height: 1.5;
  font-weight: 600;
}

/* =========================
   PUNTOS
========================= */

.proposal-points-modern{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: .95rem;
}

.proposal-points-modern li{
  position: relative;
  padding-left: 1rem;
  color: #2a2f35;
  font-size: 1.02rem;
  line-height: 1.45;
  font-weight: 600;
}

.proposal-points-modern li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .58em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--brand-dark);
}

/* =========================
   COPY
========================= */

.proposal-modal-copy-modern{
  max-width: 58ch;
  color: rgba(15, 23, 42, 0.76);
  font-size: 1.08rem;
  line-height: 1.75;
  font-weight: 500;
  text-wrap: pretty;
}

/* =========================
   RESPONSIVE
========================= */

@media (min-width: 1200px) {
  #proposalModal .modal-dialog {
    max-width: 1180px;
  }
}

@media (max-width: 991.98px){

  #proposalModalLabel{
    max-width: none;
  }

  .proposal-modal-copy-modern{
    max-width: none;
  }
}

@media (max-width: 767.98px){
  .proposal-modal-inner{
    padding: 1.2rem;
  }

  .proposal-modal-hero{
    padding-right: 3.2rem;
    margin-bottom: 1.35rem;
  }

  #proposalModalLabel{
    font-size: 2.1rem;
    line-height: .9;
  }

  .proposal-modal-summary{
    font-size: 1rem;
    line-height: 1.45;
  }

  .proposal-modal-copy-modern{
    font-size: 1rem;
    line-height: 1.65;
  }

  .proposal-modal-close{
    top: 14px;
    right: 14px;
    width: 38px;
    height: 38px;
  }
}

/* =========================
   PROPUESTAS · INTRO
========================= */

.proposals-intro{
  margin-bottom: 1.1rem;
}

.proposals-main-title{
  margin: 0;
}

/* =========================
   PROPUESTAS · SUBNAV STICKY
========================= */

.proposals-subnav-wrap{
  position: sticky;
  top: var(--proposals-subnav-offset);
  z-index: 25;
  margin-bottom: 2rem;
  padding: .65rem 0 .85rem;
  background:
    linear-gradient(
      to bottom,
      rgba(247,247,248,0.96) 0%,
      rgba(247,247,248,0.92) 72%,
      rgba(247,247,248,0.00) 100%
    );
  backdrop-filter: blur(10px);
}

.proposals-sticky-nav{
  display: flex;
  gap: .75rem;
  overflow-x: auto;
  padding: 0;
  scrollbar-width: none;
}

.proposals-sticky-nav::-webkit-scrollbar{
  display: none;
}

.proposal-chip{
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .78rem 1.05rem;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,0.82);
  color: rgba(15, 23, 42, 0.68);
  text-decoration: none;
  font-size: .84rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
  backdrop-filter: blur(8px);
  transition:
    background .2s ease,
    color .2s ease,
    border-color .2s ease,
    transform .2s ease,
    box-shadow .2s ease;
}

.proposal-chip:hover,
.proposal-chip:focus-visible{
  background: #fff;
  color: var(--brand);
  border-color: rgba(38, 71, 34, 0.18);
  transform: translateY(-1px);
  outline: none;
}

.proposal-chip.is-active{
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
  box-shadow: 0 14px 28px rgba(38, 71, 34, 0.16);
}

@media (max-width: 767.98px){
  .proposals-subnav-wrap{
    top: 68px;
    margin-bottom: 1.5rem;
    padding: .55rem 0 .75rem;
  }

  .proposal-chip{
    min-height: 40px;
    padding: .68rem .9rem;
    font-size: .8rem;
  }

}

@media (max-width: 991.98px){
  .proposals-subnav-wrap{
    display: none;
  }
}

/* =========================
   AMANTÍA · DARK SECTION
========================= */

.amantia-dark{
  position: relative;
  background: var(--brand);
  color: #fff;
  overflow: hidden;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding: 72px 0;
}

.amantia-dark .row{
  width: 100%;
  align-items: center;
}

.amantia-dark::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(700px 300px at 15% 20%, rgba(38, 71, 34, 0.28), transparent 60%),
    radial-gradient(900px 420px at 85% 80%, rgba(55, 109, 49, 0.16), transparent 60%);
  pointer-events: none;
}

.amantia-dark .container{
  position: relative;
  z-index: 1;
}

.amantia-dark .section-kicker{
  color: rgba(255,255,255,.72);
}

.amantia-dark .section-title,
.amantia-dark h2{
  color: #fff;
}

.amantia-dark p{
  color: rgba(255,255,255,.78);
}

.amantia-dark .lead{
  color: rgba(255,255,255,.9);
}

.amantia-photo{
  position: relative;
  min-height: clamp(360px, 42vw, 500px);
  height: 100%;
  border-radius: 28px;
  overflow: hidden;
  background-image: url("../img/amantia.jpg");
  background-size: cover;
  background-position: center;
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
}

.amantia-photo::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.18) 100%);
}

.amantia-dark .amantia-signature{
  margin-top: 1.6rem;
  color: rgba(255,255,255,.92);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .02em;
}

@media (max-width: 991.98px){
  .amantia-dark{
    min-height: auto;
    padding: 72px 0;
    display: block;
  }

  .amantia-dark .container{
    width: 100%;
    max-width: 860px;
  }

  .amantia-dark .row{
    display: block;
    margin: 0;
  }

  .amantia-dark .col-lg-5,
  .amantia-dark .col-lg-7{
    width: 100%;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 12px;
    padding-right: 12px;
  }

  .amantia-dark .col-lg-5{
    margin-bottom: 2rem;
  }

  .amantia-photo{
    width: 100%;
    max-width: 100%;
    min-height: 520px;
    margin: 0 auto;
    border-radius: 28px;
    background-position: center top;
  }

  .amantia-dark .section-kicker,
  .amantia-dark .section-title,
  .amantia-dark p,
  .amantia-dark .lead{
    text-align: center;
  }

    .amantia-dark .section-kicker{
    display: block;
    text-align: center;
  }

  .amantia-dark .section-title{
    margin-bottom: 1rem;
  }
}

@media (max-width: 767.98px){
  .amantia-dark{
    min-height: auto;
    padding: 56px 0;
  }

  .amantia-dark .container{
    width: 100%;
  }

  .amantia-dark .col-lg-5,
  .amantia-dark .col-lg-7{
    max-width: 380px;
    padding-left: 10px;
    padding-right: 10px;
  }

  .amantia-dark .col-lg-5{
    margin-bottom: 1.5rem;
  }

    .amantia-dark .section-kicker{
    display: block;
    text-align: center;
  }

  .amantia-photo{
    min-height: 320px;
    border-radius: 22px;
  }
}

/* =========================
   MEDIOS V3
========================= */

.media-v3{
  background: var(--bg);
}

.media-v3-head{
  margin-bottom: 2rem;
  max-width: 860px;
}

.media-v3-title{
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: .95;
  letter-spacing: -0.05em;
  font-weight: 900;
  color: #182033;
  margin-bottom: .9rem;
}

.media-v3-subtitle{
  margin: 0;
  color: rgba(15, 23, 42, 0.72);
  font-size: clamp(1rem, 1.15vw, 1.12rem);
  line-height: 1.6;
  max-width: 60ch;
}

/* DESTACADA */
.media-feature{
  display: grid;
  grid-template-columns: 1.15fr .95fr;
  gap: 0;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.08);
  margin-bottom: 2rem;
}

.media-feature-thumb{
  display: block;
  min-height: 100%;
  background: #dfe5df;
}

.media-feature-thumb img{
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  display: block;
}

.media-feature-body{
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 2rem;
}

.media-feature-meta{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.media-feature-source{
  color: var(--brand);
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.media-feature-date{
  color: rgba(15, 23, 42, 0.46);
  font-size: .88rem;
  font-weight: 600;
}

.media-feature-title{
  margin: 0 0 1rem;
  color: #182033;
  font-size: clamp(1.8rem, 2.3vw, 2.8rem);
  line-height: .96;
  letter-spacing: -0.05em;
  font-weight: 900;
  text-wrap: balance;
}

.media-feature-text{
  margin: 0 0 1.4rem;
  color: rgba(15, 23, 42, 0.74);
  font-size: 1.02rem;
  line-height: 1.7;
  max-width: 52ch;
}

.media-feature-link{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: var(--brand);
  text-decoration: none;
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.media-feature-link::after{
  content: "→";
  transition: transform .18s ease;
}

.media-feature:hover .media-feature-link::after{
  transform: translateX(4px);
}

/* GRID */
.media-card{
  display: flex;
  flex-direction: column;
  min-height: 100%;
  border-radius: 24px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,.96);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
  overflow: hidden;
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    border-color .22s ease;
}

.media-card:hover{
  transform: translateY(-4px);
  border-color: rgba(38, 71, 34, 0.16);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.08);
}

.media-card-thumb{
  display: block;
  width: 100%;
  height: 200px;
  overflow: hidden;
  background: #e8ece8;
}

.media-card-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.media-card:hover .media-card-thumb img{
  transform: scale(1.05);
}

.media-card-body{
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 1.35rem;
}

.media-card-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .9rem;
}

.media-card-source{
  color: var(--brand);
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.media-card-date{
  color: rgba(15, 23, 42, 0.46);
  font-size: .82rem;
  font-weight: 600;
  white-space: nowrap;
}

.media-card-title{
  margin: 0 0 .8rem;
  color: #182033;
  font-size: clamp(1.18rem, 1.1vw, 1.42rem);
  line-height: 1.04;
  font-weight: 800;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

.media-card-text{
  margin: 0 0 1.1rem;
  flex-grow: 1;
  color: rgba(15, 23, 42, 0.72);
  font-size: .97rem;
  line-height: 1.6;
}

.media-card-link{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-top: auto;
  color: var(--brand);
  text-decoration: none;
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.media-card-link::after{
  content: "→";
  transition: transform .18s ease;
}

.media-card:hover .media-card-link::after{
  transform: translateX(4px);
}

@media (max-width: 991.98px){
  .media-feature{
    grid-template-columns: 1fr;
  }

  .media-feature-thumb img{
    min-height: 300px;
  }
}

@media (max-width: 767.98px){
  .media-v3-head{
    margin-bottom: 1.6rem;
  }

  .media-feature{
    border-radius: 24px;
    margin-bottom: 1.5rem;
  }

  .media-feature-thumb img{
    min-height: 240px;
  }

  .media-feature-body{
    padding: 1.2rem;
  }

  .media-feature-meta,
  .media-card-top{
    flex-direction: column;
    align-items: flex-start;
    gap: .35rem;
  }

  .media-card{
    border-radius: 20px;
  }

  .media-card-thumb{
    height: 190px;
  }

  .media-card-body{
    padding: 1.15rem;
  }
}

/* =========================
   CONTACTO CON FOTO
========================= */

.contact-bg{
  position: relative;
  padding: 72px 0 64px;
  background: url("../img/hero-3.jpg") center/cover no-repeat;
  color: #fff;
  overflow: hidden;
}

/* overlay oscuro */

.contact-overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.75);
}

/* container */

.contact-container{
  position: relative;
  z-index: 2;
  max-width: 900px;
}

/* header */

.contact-head{
  text-align: center;
  margin-bottom: 40px;
}

.contact-kicker{
  color: rgba(255,255,255,.8);
}

.contact-title{
  font-size: clamp(2.4rem,4vw,4.2rem);
  line-height: .9;
  font-weight: 900;
  letter-spacing: -0.06em;
  margin-bottom: 1rem;
}

.contact-subtitle{
  color: rgba(255,255,255,.8);
  font-size: 1.1rem;
  max-width: 820px;
  margin: 0 auto;
  line-height: 1.6;
}

/* form */

.contact-form{
  background: rgba(255,255,255,.96);
  border-radius: 26px;
  padding: 32px;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
}

/* grid */

.contact-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.contact-field{
  display: flex;
  flex-direction: column;
}

.contact-field-full{
  grid-column: 1 / -1;
}

/* labels */

.contact-field label{
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(15,23,42,.7);
  margin-bottom: .5rem;
}

/* inputs */

.contact-field input,
.contact-field textarea{
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.15);
  padding: 14px 16px;
  font-size: 1rem;
  transition: all .2s ease;
}

.contact-field input:focus,
.contact-field textarea:focus{
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(38,71,34,.12);
}

/* button */

.contact-actions{
  margin-top: 25px;
  display: flex;
  justify-content: center;
}

.contact-btn{
  background: var(--brand);
  border: none;
  padding: 14px 26px;
  border-radius: 12px;
  color: #fff;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
  font-size: .85rem;
  transition: all .2s ease;
}

.contact-btn:hover{
  background: var(--brand-dark);
  transform: translateY(-1px);
}

/* responsive */

@media (max-width:768px){

.contact-bg{
  padding: 90px 0;
}

.contact-form{
  padding: 22px;
}

.contact-grid{
  grid-template-columns: 1fr;
}

.contact-actions{
  display: flex;
  justify-content: center;
}

.contact-btn{
  width: 100%;
}

}