.campos-services{
  background: var(--cream);
  color: var(--dark);
}

/* INTRO */
.campos-services .s-intro{
  background: var(--navy);
  padding: 100px 80px 80px;
  position: relative;
  overflow: hidden;
}

.campos-services .s-intro::before{
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(to right, var(--gold) 0%, transparent 60%);
}

.campos-services .s-intro::after{
  content: "J";
  position: absolute;
  right: 60px;
  top: -40px;
  font-family: var(--font-heading);
  font-size: 480px;
  font-weight: 700;
  color: rgba(201,168,76,.04);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.campos-services .intro-inner{
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: end;
  position: relative;
  z-index: 1;
}

.campos-services .intro-eyebrow{
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
}

.campos-services .intro-eyebrow::before{
  content: "";
  width: 40px;
  height: 1px;
  background: var(--gold);
}

.campos-services .intro-eyebrow span{
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
}

.campos-services .intro-left h1{
  font-size: clamp(52px, 5.5vw, 82px);
  font-weight: 300;
  color: var(--white);
  line-height: 1;
  letter-spacing: -.01em;
}

.campos-services .intro-left h1 em{
  font-style: italic;
  color: var(--gold);
}

.campos-services .intro-right p{
  font-size: 17px;
  line-height: 1.85;
  color: rgba(255,255,255,.55);
  margin-bottom: 40px;
}

.campos-services .intro-pills{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.campos-services .intro-pill{
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  border: 1px solid var(--gold-line);
  padding: 9px 20px;
  transition: background .3s ease, color .3s ease, border-color .3s ease;
}

.campos-services .intro-pill:hover{
  background: var(--gold);
  color: var(--dark);
  border-color: var(--gold);
}

/* STICKY NAV */
.campos-services .s-nav{
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--dark);
  border-bottom: 1px solid var(--border-dk);
}

.campos-services .nav-inner{
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: stretch;
  overflow-x: auto;
  scrollbar-width: none;
}

.campos-services .nav-inner::-webkit-scrollbar{
  display: none;
}

.campos-services .nav-link{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 28px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
  border-right: 1px solid rgba(255,255,255,.04);
  white-space: nowrap;
  position: relative;
  transition: color .3s ease;
}

.campos-services .nav-link::after{
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s ease;
}

.campos-services .nav-link:hover,
.campos-services .nav-link.active{
  color: var(--white);
}

.campos-services .nav-link:hover::after,
.campos-services .nav-link.active::after{
  transform: scaleX(1);
}

.campos-services .nav-link.active{
  color: var(--gold);
}

.campos-services .nav-num{
  font-family: var(--font-heading);
  font-size: 19px;
  font-weight: 300;
  color: var(--gold);
  opacity: .35;
  transition: opacity .3s ease;
}

.campos-services .nav-link:hover .nav-num,
.campos-services .nav-link.active .nav-num{
  opacity: 1;
}

/* SERVICES */
.campos-services .s-service{
  position: relative;
}

.campos-services .svc-header{
  width: 100%;
  border: 0;
  background: transparent;
  display: grid;
  grid-template-columns: 72px 1fr auto;
  align-items: center;
  gap: 36px;
  padding: 64px 80px;
  cursor: pointer;
  transition: background .25s ease;
  user-select: none;
  text-align: left;
}

.campos-services .svc-header:hover{
  filter: brightness(1.03);
}

.campos-services .svc-icon-wrap,
.campos-services .card-icon{
  border: 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.campos-services .svc-icon-wrap{
  width: 72px;
  height: 72px;
}

.campos-services .card-icon{
  width: 48px;
  height: 48px;
  margin-bottom: 18px;
}

.campos-services .svc-icon-wrap img{
  width: 40px;
  height: 40px;
  object-fit: contain;
  display: block;
}

.campos-services .card-icon img{
  width: 28px;
  height: 28px;
  object-fit: contain;
  display: block;
}

.campos-services .svc-title-wrap h2{
  font-size: clamp(34px, 3.5vw, 54px);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -.01em;
}

.campos-services .svc-title-wrap h2 em{
  font-style: italic;
}

.campos-services .svc-tagline{
  font-size: 14px;
  line-height: 1.65;
  margin-top: 8px;
  max-width: 540px;
}

.campos-services .svc-toggle{
  width: 52px;
  height: 52px;
  border: 1px solid;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  line-height: 1;
  flex-shrink: 0;
}

.campos-services .svc-toggle-icon{
  display: block;
  transition: transform .35s ease;
}

.campos-services .svc-header[aria-expanded="true"] .svc-toggle-icon{
  transform: rotate(45deg);
}

.campos-services .svc-body{
  max-height: 0;
  overflow: hidden;
  transition: max-height .6s ease;
}

.campos-services .svc-content{
  padding: 0 80px 72px;
}

.campos-services .svc-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 48px;
}

.campos-services .svc-card{
  padding: 36px 32px;
  position: relative;
  overflow: hidden;
  transition: background .25s ease;
}

.campos-services .svc-card::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s ease;
}

.campos-services .svc-card:hover::before{
  transform: scaleX(1);
}

.campos-services .card-num{
  font-family: var(--font-heading);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .1em;
  margin-bottom: 10px;
  display: block;
}

.campos-services .card-title{
  font-size: 22px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 10px;
}

.campos-services .card-desc{
  font-size: 13px;
  line-height: 1.75;
  margin-bottom: 14px;
}

.campos-services .card-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.campos-services .card-tag{
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 4px 10px;
}

.campos-services .svc-footer{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding-top: 32px;
  border-top: 1px solid;
}

.campos-services .svc-note{
  font-size: 14px;
  line-height: 1.75;
  max-width: 560px;
}

.campos-services .svc-cta{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 17px 36px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background .25s ease, color .25s ease;
}

.campos-services .svc-divider{
  height: 1px;
  margin: 0 80px;
}

.campos-services .svc-divider--gold{
  background: var(--border-dk);
}

.campos-services .svc-divider--light{
  background: rgba(28,18,8,.08);
}

.campos-services .svc-divider--beige{
  background: rgba(28,18,8,.07);
}

.campos-services .svc-divider--gold-soft{
  background: rgba(201,168,76,.07);
}

/* THEMES */
.campos-services #migracion{
  background: var(--navy);
}
.campos-services #migracion .svc-header{ border-bottom: 1px solid var(--border-dk); }
.campos-services #migracion .svc-icon-wrap,
.campos-services #migracion .card-icon{ border-color: var(--gold-line); background: rgba(201,168,76,.06); }
.campos-services #migracion .svc-title-wrap h2,
.campos-services #migracion .card-title{ color: var(--white); }
.campos-services #migracion .svc-title-wrap h2 em{ color: var(--gold); }
.campos-services #migracion .svc-tagline,
.campos-services #migracion .card-desc{ color: rgba(255,255,255,.5); }
.campos-services #migracion .svc-toggle{ border-color: var(--gold-line); color: var(--gold); }
.campos-services #migracion .svc-card{ background: rgba(255,255,255,.02); border: 1px solid var(--border-dk); }
.campos-services #migracion .svc-card:hover{ background: rgba(255,255,255,.04); }
.campos-services #migracion .svc-card::before{ background: var(--gold); }
.campos-services #migracion .card-num{ color: rgba(201,168,76,.4); }
.campos-services #migracion .card-tag{ background: rgba(201,168,76,.09); color: rgba(201,168,76,.75); border: 1px solid rgba(201,168,76,.15); }
.campos-services #migracion .svc-footer{ border-color: var(--border-dk); }
.campos-services #migracion .svc-note{ color: rgba(255,255,255,.45); }
.campos-services #migracion .svc-note strong{ color: rgba(255,255,255,.85); }
.campos-services #migracion .svc-cta{ background: var(--gold); color: var(--dark); }
.campos-services #migracion .svc-cta:hover{ background: var(--gold-dk); }

.campos-services #visas{
  background: var(--white);
}
.campos-services #visas .svc-header{ border-bottom: 1px solid var(--border-lt); }
.campos-services #visas .svc-icon-wrap,
.campos-services #visas .card-icon{ border-color: var(--border-lt); background: var(--cream); }
.campos-services #visas .svc-title-wrap h2,
.campos-services #visas .card-title{ color: var(--dark); }
.campos-services #visas .svc-title-wrap h2 em{ color: var(--gold-dk); }
.campos-services #visas .svc-tagline,
.campos-services #visas .card-desc,
.campos-services #visas .svc-note{ color: var(--mid); }
.campos-services #visas .svc-toggle{ border-color: var(--border-lt); color: var(--dark); }
.campos-services #visas .svc-card{ background: var(--cream); border: 1px solid var(--border-lt); }
.campos-services #visas .svc-card:hover{ background: var(--beige); }
.campos-services #visas .svc-card::before{ background: var(--gold-dk); }
.campos-services #visas .card-num{ color: rgba(168,136,58,.3); }
.campos-services #visas .card-tag{ background: rgba(168,136,58,.07); color: var(--gold-dk); border: 1px solid rgba(168,136,58,.14); }
.campos-services #visas .svc-footer{ border-color: var(--border-lt); }
.campos-services #visas .svc-note strong{ color: var(--dark); }
.campos-services #visas .svc-cta{ background: var(--navy); color: var(--white); }
.campos-services #visas .svc-cta:hover{ background: var(--dark); }

.campos-services #familiar{
  background: var(--beige);
}
.campos-services #familiar .svc-header{ border-bottom: 1px solid var(--border-lt); }
.campos-services #familiar .svc-icon-wrap{ border-color: rgba(28,18,8,.12); background: var(--sand); }
.campos-services #familiar .card-icon{ border-color: var(--border-lt); background: var(--cream); }
.campos-services #familiar .svc-title-wrap h2,
.campos-services #familiar .card-title{ color: var(--dark); }
.campos-services #familiar .svc-title-wrap h2 em{ color: var(--gold-dk); }
.campos-services #familiar .svc-tagline,
.campos-services #familiar .card-desc,
.campos-services #familiar .svc-note{ color: var(--mid); }
.campos-services #familiar .svc-toggle{ border-color: rgba(28,18,8,.12); color: var(--dark); }
.campos-services #familiar .svc-card{ background: var(--white); border: 1px solid var(--border-lt); box-shadow: 0 2px 14px rgba(0,0,0,.04); }
.campos-services #familiar .svc-card:hover{ background: var(--cream); }
.campos-services #familiar .svc-card::before{ background: var(--gold-dk); }
.campos-services #familiar .card-num{ color: rgba(168,136,58,.28); }
.campos-services #familiar .card-tag{ background: rgba(168,136,58,.07); color: var(--gold-dk); border: 1px solid rgba(168,136,58,.14); }
.campos-services #familiar .svc-footer{ border-color: var(--border-lt); }
.campos-services #familiar .svc-note strong{ color: var(--dark); }
.campos-services #familiar .svc-cta{ background: var(--navy); color: var(--white); }
.campos-services #familiar .svc-cta:hover{ background: var(--dark); }

.campos-services #civil{
  background: var(--dark);
}
.campos-services #civil .svc-header{ border-bottom: 1px solid rgba(201,168,76,.08); }
.campos-services #civil .svc-icon-wrap,
.campos-services #civil .card-icon{ border-color: rgba(201,168,76,.15); background: rgba(201,168,76,.05); }
.campos-services #civil .svc-title-wrap h2,
.campos-services #civil .card-title{ color: var(--white); }
.campos-services #civil .svc-title-wrap h2 em{ color: var(--gold); }
.campos-services #civil .svc-tagline,
.campos-services #civil .card-desc{ color: rgba(255,255,255,.48); }
.campos-services #civil .svc-toggle{ border-color: rgba(201,168,76,.18); color: var(--gold); }
.campos-services #civil .svc-card{ background: rgba(255,255,255,.025); border: 1px solid rgba(201,168,76,.09); }
.campos-services #civil .svc-card:hover{ background: rgba(255,255,255,.04); }
.campos-services #civil .svc-card::before{ background: var(--gold); }
.campos-services #civil .card-num{ color: rgba(201,168,76,.3); }
.campos-services #civil .card-tag{ background: rgba(201,168,76,.08); color: rgba(201,168,76,.65); border: 1px solid rgba(201,168,76,.12); }
.campos-services #civil .svc-footer{ border-color: rgba(201,168,76,.08); }
.campos-services #civil .svc-note{ color: rgba(255,255,255,.4); }
.campos-services #civil .svc-note strong{ color: rgba(255,255,255,.8); }
.campos-services #civil .svc-cta{ background: var(--gold); color: var(--dark); }
.campos-services #civil .svc-cta:hover{ background: var(--gold-dk); }

.campos-services #accidentes{
  background: var(--cream);
}
.campos-services #accidentes .svc-header{ border-bottom: 1px solid var(--border-lt); }
.campos-services #accidentes .svc-icon-wrap,
.campos-services #accidentes .card-icon{ border-color: var(--sand); background: var(--beige); }
.campos-services #accidentes .svc-title-wrap h2,
.campos-services #accidentes .card-title{ color: var(--dark); }
.campos-services #accidentes .svc-title-wrap h2 em{ color: var(--gold-dk); }
.campos-services #accidentes .svc-tagline,
.campos-services #accidentes .card-desc,
.campos-services #accidentes .svc-note{ color: var(--mid); }
.campos-services #accidentes .svc-toggle{ border-color: var(--border-lt); color: var(--dark); }
.campos-services #accidentes .svc-card{ background: var(--white); border: 1px solid var(--sand); }
.campos-services #accidentes .svc-card:hover{ background: var(--beige); }
.campos-services #accidentes .svc-card::before{ background: var(--gold); }
.campos-services #accidentes .card-num{ color: rgba(168,136,58,.22); }
.campos-services #accidentes .card-tag{ background: rgba(201,168,76,.07); color: var(--gold-dk); border: 1px solid rgba(201,168,76,.14); }
.campos-services #accidentes .svc-footer{ border-color: var(--border-lt); }
.campos-services #accidentes .svc-note strong{ color: var(--dark); }
.campos-services #accidentes .svc-cta{ background: var(--navy); color: var(--white); }
.campos-services #accidentes .svc-cta:hover{ background: var(--dark); }

/* TRADUCCIONES */
.campos-services .s-traducciones{
  background: var(--gold);
  padding: 52px 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}

.campos-services .trad-left h3{
  font-size: 38px;
  font-weight: 400;
  color: var(--dark);
  line-height: 1.1;
}

.campos-services .trad-left h3 em{
  font-style: italic;
}

.campos-services .trad-left p{
  font-size: 14px;
  color: rgba(26,18,8,.55);
  margin-top: 6px;
}

.campos-services .trad-price{
  text-align: center;
  flex-shrink: 0;
}

.campos-services .trad-amount{
  font-family: var(--font-heading);
  font-size: 68px;
  font-weight: 600;
  color: var(--dark);
  line-height: 1;
  letter-spacing: -.02em;
}

.campos-services .trad-unit{
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(26,18,8,.45);
  margin-top: 4px;
}

.campos-services .trad-cta{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: var(--navy);
  color: var(--white);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 17px 34px;
  flex-shrink: 0;
  transition: background .25s ease;
}

.campos-services .trad-cta:hover{
  background: var(--dark);
}

/* FINAL CTA */
.campos-services .s-final{
  background: var(--navy);
  padding: 100px 80px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.campos-services .s-final::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gold);
}

.campos-services .final-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}

.campos-services .final-eyebrow span{
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
}

.campos-services .final-eyebrow::before,
.campos-services .final-eyebrow::after{
  content: "";
  display: block;
  width: 32px;
  height: 1px;
  background: var(--gold-line);
}

.campos-services .s-final h2{
  font-size: clamp(40px, 4.5vw, 66px);
  font-weight: 300;
  color: var(--white);
  line-height: 1.05;
  margin-bottom: 18px;
  position: relative;
  z-index: 1;
}

.campos-services .s-final h2 em{
  font-style: italic;
  color: var(--gold);
}

.campos-services .s-final > p{
  font-size: 16px;
  color: rgba(255,255,255,.45);
  margin-bottom: 48px;
  position: relative;
  z-index: 1;
}

.campos-services .final-actions{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.campos-services .final-btn-p,
.campos-services .final-btn-s{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 18px 44px;
}

.campos-services .final-btn-p{
  background: var(--gold);
  color: var(--dark);
  transition: background .25s ease;
}

.campos-services .final-btn-p:hover{
  background: var(--gold-dk);
}

.campos-services .final-btn-s{
  background: transparent;
  color: rgba(255,255,255,.6);
  border: 1px solid rgba(255,255,255,.12);
  transition: border-color .25s ease, color .25s ease;
}

.campos-services .final-btn-s:hover{
  border-color: var(--gold-line);
  color: var(--gold);
}

.campos-services .final-phone{
  display: block;
  margin-top: 28px;
  font-family: var(--font-heading);
  font-size: 30px;
  font-weight: 600;
  color: rgba(255,255,255,.28);
  letter-spacing: -.01em;
  transition: color .25s ease;
  position: relative;
  z-index: 1;
}

.campos-services .final-phone:hover{
  color: var(--gold);
}

/* RESPONSIVE */
@media (max-width: 1100px){
  .campos-services .svc-grid{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 960px){
  .campos-services .intro-inner{
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .campos-services .s-intro{
    padding: 72px 40px 56px;
  }

  .campos-services .svc-header{
    padding: 48px 40px;
  }

  .campos-services .svc-content{
    padding: 0 40px 56px;
  }

  .campos-services .svc-divider{
    margin: 0 40px;
  }

  .campos-services .s-traducciones{
    padding: 48px 40px;
    flex-direction: column;
    text-align: center;
  }

  .campos-services .s-final{
    padding: 72px 40px;
  }
}

@media (max-width: 768px){
  .campos-services .svc-header{
    grid-template-columns: 48px 1fr auto;
    gap: 16px;
    padding: 40px 24px;
  }

  .campos-services .svc-icon-wrap{
    width: 48px;
    height: 48px;
  }

  .campos-services .svc-content{
    padding: 0 24px 48px;
  }

  .campos-services .svc-grid{
    grid-template-columns: 1fr;
  }

  .campos-services .svc-footer{
    flex-direction: column;
    align-items: flex-start;
  }

  .campos-services .nav-link{
    padding: 16px 18px;
    font-size: 10px;
  }

  .campos-services .s-intro{
    padding: 64px 24px 48px;
  }

  .campos-services .svc-divider{
    margin: 0 24px;
  }
}