/* =========================================================
   THE CAMPOS FIRM — ABOUT.CSS
   ========================================================= */

/* ---------- HERO ---------- */
.campos-about .s-hero{
  background:var(--navy);
  position:relative;
  overflow:hidden;
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 520px;
}

.campos-about .hero-gold-bar{
  position:absolute;
  top:0;
  right:520px;
  width:4px;
  height:120px;
  background:var(--gold);
  z-index:3;
}

.campos-about .hero-left{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:80px 72px 80px 80px;
  position:relative;
  z-index:2;
}

.campos-about .hero-eyebrow{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:32px;
}

.campos-about .hero-eyebrow::before{
  content:"";
  display:block;
  width:40px;
  height:1px;
  background:var(--gold);
}

.campos-about .hero-eyebrow span{
  font-size:11px;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
}

.campos-about .hero-left h1{
  font-size:clamp(52px,6vw,88px);
  font-weight:300;
  line-height:1;
  color:var(--white);
  margin-bottom:32px;
  letter-spacing:-.01em;
}

.campos-about .hero-left h1 em{
  font-style:italic;
  color:var(--gold);
  font-weight:400;
}

.campos-about .hero-lead{
  font-size:17px;
  line-height:1.8;
  color:rgba(255,255,255,.65);
  max-width:480px;
  margin-bottom:56px;
}

.campos-about .hero-stats{
  display:flex;
  gap:0;
  border-top:1px solid var(--border-dk);
  padding-top:40px;
}

.campos-about .hero-stat{
  flex:1;
  padding-right:40px;
  border-right:1px solid var(--border-dk);
}

.campos-about .hero-stat:last-child{
  border-right:none;
  padding-right:0;
  padding-left:40px;
}

.campos-about .hero-stat:not(:first-child):not(:last-child){
  padding-left:40px;
}

.campos-about .hero-stat-num{
  font-size:56px;
  font-weight:600;
  color:var(--gold);
  line-height:1;
  letter-spacing:-.02em;
}

.campos-about .hero-stat-label{
  font-size:12px;
  font-weight:500;
  color:rgba(255,255,255,.5);
  margin-top:6px;
  letter-spacing:.05em;
}

.campos-about .hero-photo-col{
  position:relative;
  overflow:hidden;
}

.campos-about .hero-photo-col img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
}

.campos-about .hero-photo-col::before{
  content:"";
  position:absolute;
  top:40px;
  left:-16px;
  right:40px;
  bottom:-16px;
  border:2px solid var(--gold);
  z-index:2;
  pointer-events:none;
}

.campos-about .hero-nameplate{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:40px 40px 40px 32px;
  background:linear-gradient(to top, rgba(13,27,42,.95) 0%, rgba(13,27,42,.6) 60%, transparent 100%);
  z-index:3;
}

.campos-about .hero-nameplate h2{
  font-size:36px;
  font-weight:600;
  color:var(--white);
  line-height:1.1;
}

.campos-about .hero-nameplate p{
  font-size:12px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gold);
  margin-top:8px;
}

/* ---------- CREDENTIALS BAND ---------- */
.campos-about .s-creds{
  background:var(--gold);
  padding:0;
}

.campos-about .creds-inner{
  display:flex;
  align-items:stretch;
}

.campos-about .cred-item{
  flex:1;
  padding:28px 36px;
  display:flex;
  align-items:center;
  gap:16px;
  border-right:1px solid rgba(28,18,8,.12);
  transition:background .2s;
}

.campos-about .cred-item:last-child{
  border-right:none;
}

.campos-about .cred-item:hover{
  background:rgba(0,0,0,.06);
}

.campos-about .cred-icon{
  font-size:22px;
  flex-shrink:0;
}

.campos-about .cred-text strong{
  display:block;
  font-size:13px;
  font-weight:700;
  color:var(--dark);
  line-height:1.2;
}

.campos-about .cred-text span{
  font-size:11px;
  color:rgba(28,18,8,.6);
}

/* ---------- BIO ---------- */
.campos-about .s-bio{
  background:var(--dark);
  padding:120px 80px;
  position:relative;
}

.campos-about .s-bio::before{
  content:'"';
  position:absolute;
  top:40px;
  right:80px;
  font-size:400px;
  font-weight:700;
  color:rgba(201,168,76,.04);
  line-height:1;
  user-select:none;
  pointer-events:none;
}

.campos-about .bio-inner{
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:100px;
  align-items:start;
}

.campos-about .bio-left{
  position:sticky;
  top:40px;
}

.campos-about .bio-eyebrow{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:28px;
}

.campos-about .bio-eyebrow::before{
  content:"";
  width:36px;
  height:1px;
  background:var(--gold);
}

.campos-about .bio-eyebrow span{
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
}

.campos-about .bio-left h2{
  font-size:clamp(40px,4vw,62px);
  font-weight:300;
  color:var(--white);
  line-height:1.1;
  margin-bottom:40px;
}

.campos-about .bio-left h2 em{
  font-style:italic;
  color:var(--gold);
}

.campos-about .bio-quote{
  border-left:2px solid var(--gold);
  padding-left:24px;
  font-family:var(--font-heading);
  font-style:italic;
  font-size:21px;
  line-height:1.65;
  color:rgba(255,255,255,.85);
  margin-bottom:40px;
}

.campos-about .bio-quote cite{
  display:block;
  font-style:normal;
  font-family:var(--font-body);
  font-size:10px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold);
  margin-top:14px;
}

.campos-about .bio-right{
  padding-top:8px;
}

.campos-about .bio-p{
  font-size:16px;
  line-height:1.9;
  color:rgba(255,255,255,.65);
  margin-bottom:24px;
}

.campos-about .bio-p strong{
  color:rgba(255,255,255,.9);
  font-weight:600;
}

.campos-about .bio-checklist{
  list-style:none;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 32px;
  margin:40px 0;
  padding:32px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border-dk);
}

.campos-about .bio-checklist li{
  font-size:13px;
  font-weight:500;
  color:rgba(255,255,255,.75);
  display:flex;
  align-items:center;
  gap:10px;
}

.campos-about .bio-checklist li::before{
  content:"";
  width:16px;
  height:16px;
  flex-shrink:0;
  background:var(--gold);
  border-radius:2px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath d='M1 5l3.5 3.5L11 1' stroke='%23fff' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  background-size:9px;
}

.campos-about .bio-cta{
  display:inline-flex;
  align-items:center;
  gap:16px;
  background:var(--gold);
  color:var(--dark);
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:18px 36px;
  transition:all .25s;
}

.campos-about .bio-cta:hover{
  background:#b8962e;
}

.campos-about .bio-cta-arrow{
  font-size:18px;
  transition:transform .2s;
}

.campos-about .bio-cta:hover .bio-cta-arrow{
  transform:translateX(4px);
}

/* ---------- MISSION ---------- */
.campos-about .s-mission{
  background:var(--white);
  position:relative;
  overflow:hidden;
}

.campos-about .s-mission::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(to right, var(--gold) 0%, transparent 60%);
}

.campos-about .mission-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
}

.campos-about .mission-left{
  background:var(--navy);
  padding:96px 72px;
}

.campos-about .mission-left-eyebrow{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:24px;
}

.campos-about .mission-left-eyebrow::before{
  content:"";
  width:32px;
  height:1px;
  background:var(--gold);
}

.campos-about .mission-left h2{
  font-size:clamp(36px,3.5vw,52px);
  font-weight:300;
  color:var(--white);
  line-height:1.1;
  margin-bottom:32px;
}

.campos-about .mission-left h2 em{
  font-style:italic;
  color:var(--gold);
}

.campos-about .mission-left p{
  font-size:15px;
  line-height:1.85;
  color:rgba(255,255,255,.6);
}

.campos-about .mission-left p + p{
  margin-top:16px;
}

.campos-about .mission-right{
  padding:96px 72px;
  background:var(--beige);
}

.campos-about .value-item{
  padding:28px 0;
  border-bottom:1px solid var(--border-lt);
  display:flex;
  gap:24px;
  align-items:flex-start;
}

.campos-about .value-item:first-child{
  padding-top:0;
}

.campos-about .value-item:last-child{
  border-bottom:none;
  padding-bottom:0;
}

.campos-about .value-num{
  font-size:48px;
  font-weight:300;
  color:var(--gold);
  line-height:1;
  width:52px;
  flex-shrink:0;
  letter-spacing:-.03em;
}

.campos-about .value-text h3{
  font-size:15px;
  font-weight:700;
  color:var(--dark);
  margin-bottom:6px;
}

.campos-about .value-text p{
  font-size:14px;
  line-height:1.7;
  color:var(--mid);
}

/* ---------- PRACTICE ---------- */
.campos-about .s-practice{
  background:var(--cream);
  padding:100px 80px;
}

.campos-about .practice-inner{
  max-width:1280px;
  margin:0 auto;
}

.campos-about .practice-top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:56px;
  padding-bottom:40px;
  border-bottom:1px solid var(--sand);
}

.campos-about .practice-eyebrow{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-dk);
  margin-bottom:12px;
}

.campos-about .practice-eyebrow::before{
  content:"";
  width:32px;
  height:1px;
  background:var(--gold);
}

.campos-about .practice-top h2{
  font-size:clamp(36px,3.5vw,54px);
  font-weight:300;
  color:var(--dark);
  line-height:1.05;
}

.campos-about .practice-top h2 em{
  font-style:italic;
  color:var(--gold-dk);
}

.campos-about .practice-link{
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dark);
  padding-bottom:4px;
  border-bottom:1px solid var(--gold);
  white-space:nowrap;
  flex-shrink:0;
}

.campos-about .practice-link:hover{
  color:var(--gold-dk);
}

.campos-about .practice-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:var(--sand);
}

.campos-about .p-card{
  background:var(--navy);
  padding:44px 36px 36px;
  display:flex;
  flex-direction:column;
  position:relative;
  overflow:hidden;
  transition:background .3s;
}

.campos-about .p-card::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s ease;
}

.campos-about .p-card:hover{
  background:#112336;
}

.campos-about .p-card:hover::after{
  transform:scaleX(1);
}

.campos-about .p-card-num{
  font-size:60px;
  font-weight:300;
  color:rgba(201,168,76,.15);
  line-height:1;
  margin-bottom:-10px;
  letter-spacing:-.02em;
}

.campos-about .p-card h3{
  font-size:24px;
  font-weight:600;
  color:var(--white);
  line-height:1.2;
  margin-bottom:12px;
}

.campos-about .p-card p{
  font-size:13px;
  line-height:1.75;
  color:rgba(255,255,255,.55);
  flex:1;
  margin-bottom:20px;
}

.campos-about .p-tags{
  display:flex;
  flex-wrap:wrap;
  gap:5px;
}

.campos-about .p-tag{
  font-size:10px;
  font-weight:600;
  letter-spacing:.06em;
  color:rgba(201,168,76,.7);
  background:rgba(201,168,76,.08);
  border:1px solid rgba(201,168,76,.15);
  padding:4px 10px;
}

/* ---------- TESTIMONIALS ---------- */
.campos-about .s-testimonials{
  background:var(--dark);
  padding:100px 80px;
}

.campos-about .test-inner{
  max-width:1280px;
  margin:0 auto;
}

.campos-about .test-header{
  text-align:center;
  margin-bottom:64px;
}

.campos-about .test-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:14px;
  margin-bottom:20px;
}

.campos-about .test-eyebrow span{
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
}

.campos-about .test-eyebrow::before,
.campos-about .test-eyebrow::after{
  content:"";
  display:block;
  width:36px;
  height:1px;
  background:var(--gold);
}

.campos-about .test-header h2{
  font-size:clamp(32px,3.5vw,50px);
  font-weight:300;
  color:var(--white);
  line-height:1.1;
}

.campos-about .test-header h2 em{
  font-style:italic;
  color:var(--gold);
}

.campos-about .test-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:rgba(201,168,76,.1);
  margin-bottom:48px;
}

.campos-about .t-card{
  background:#1a1208;
  padding:40px 36px;
  display:flex;
  flex-direction:column;
  gap:20px;
  border-top:2px solid transparent;
  transition:border-color .2s;
}

.campos-about .t-card:hover{
  border-color:var(--gold);
}

.campos-about .t-stars{
  color:var(--gold);
  font-size:13px;
  letter-spacing:3px;
}

.campos-about .t-text{
  font-family:var(--font-heading);
  font-style:italic;
  font-size:18px;
  line-height:1.7;
  color:rgba(255,255,255,.8);
  flex:1;
}

.campos-about .t-author{
  display:flex;
  align-items:center;
  gap:14px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.06);
}

.campos-about .t-avatar{
  width:44px;
  height:44px;
  background:var(--navy);
  border:1px solid rgba(201,168,76,.2);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  font-weight:600;
  color:var(--gold);
  flex-shrink:0;
}

.campos-about .t-meta strong{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--white);
}

.campos-about .t-meta span{
  font-size:12px;
  color:rgba(255,255,255,.4);
}

.campos-about .test-google{
  text-align:center;
}

.campos-about .google-link{
  display:inline-flex;
  align-items:center;
  gap:12px;
  background:transparent;
  border:1px solid var(--border-dk);
  padding:14px 28px;
  transition:border-color .2s, background .2s;
}

.campos-about .google-link:hover{
  border-color:var(--gold);
  background:rgba(201,168,76,.05);
}

.campos-about .google-stars{
  color:var(--gold);
  font-size:14px;
  letter-spacing:2px;
}

.campos-about .google-text{
  font-size:13px;
  font-weight:600;
  color:var(--white);
}

/* ---------- CONTACT ---------- */
.campos-about .s-contact{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:500px;
}

.campos-about .contact-left{
  background:var(--navy);
  padding:96px 80px;
  position:relative;
  overflow:hidden;
}

.campos-about .contact-left::before{
  content:'17';
  position:absolute;
  bottom:-20px;
  right:-10px;
  font-size:300px;
  font-weight:700;
  color:rgba(201,168,76,.04);
  line-height:1;
  user-select:none;
}

.campos-about .contact-eyebrow{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:20px;
}

.campos-about .contact-eyebrow::before{
  content:"";
  width:32px;
  height:1px;
  background:var(--gold);
}

.campos-about .contact-left h2{
  font-size:clamp(36px,3.5vw,56px);
  font-weight:300;
  color:var(--white);
  line-height:1.05;
  margin-bottom:48px;
}

.campos-about .contact-left h2 em{
  font-style:italic;
  color:var(--gold);
}

.campos-about .contact-info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px 40px;
  position:relative;
  z-index:1;
}

.campos-about .ci-block h3{
  font-size:10px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:10px;
}

.campos-about .ci-block p,
.campos-about .ci-block a{
  font-size:15px;
  line-height:1.75;
  color:rgba(255,255,255,.7);
}

.campos-about .ci-block a:hover{
  color:var(--gold);
}

.campos-about .ci-block strong{
  color:var(--white);
  font-weight:600;
}

.campos-about .ci-sub{
  display:block;
  font-size:11px;
  color:rgba(255,255,255,.3);
  margin-top:4px;
}

.campos-about .contact-right{
  background:var(--beige);
  padding:96px 80px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
}

.campos-about .contact-right::before{
  content:"";
  position:absolute;
  top:40px;
  bottom:40px;
  left:0;
  width:3px;
  background:linear-gradient(to bottom, var(--gold) 0%, transparent 100%);
}

.campos-about .cta-label{
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-dk);
  margin-bottom:20px;
}

.campos-about .contact-right h3{
  font-size:clamp(34px,3vw,48px);
  font-weight:400;
  color:var(--dark);
  line-height:1.1;
  margin-bottom:20px;
}

.campos-about .contact-right h3 em{
  font-style:italic;
  color:var(--gold-dk);
}

.campos-about .contact-right p{
  font-size:15px;
  line-height:1.75;
  color:var(--mid);
  margin-bottom:40px;
  max-width:380px;
}

.campos-about .cta-phone{
  font-size:40px;
  font-weight:600;
  color:var(--dark);
  letter-spacing:-.01em;
  display:block;
  margin-bottom:24px;
  transition:color .2s;
}

.campos-about .cta-phone:hover{
  color:var(--gold-dk);
}

.campos-about .cta-btn{
  display:inline-flex;
  align-items:center;
  gap:14px;
  background:var(--navy);
  color:var(--white);
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:18px 36px;
  align-self:flex-start;
  transition:background .2s;
}

.campos-about .cta-btn:hover{
  background:var(--dark);
}

.campos-about .cta-note{
  font-size:12px;
  color:var(--mid);
  margin-top:16px;
}

.campos-about .cta-note span{
  color:var(--gold-dk);
  font-weight:600;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1100px){
  .campos-about .s-hero{
    grid-template-columns:1fr 540px;
  }

  .campos-about .practice-grid,
  .campos-about .test-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width: 960px){
  .campos-about .s-hero{
    grid-template-columns:1fr;
    min-height:auto;
  }

  .campos-about .hero-photo-col{
    min-height:520px;
    order:-1;
  }

  .campos-about .hero-photo-col::before,
  .campos-about .hero-gold-bar{
    display:none;
  }

  .campos-about .hero-left{
    padding:60px 40px;
  }

  .campos-about .bio-inner,
  .campos-about .mission-grid,
  .campos-about .s-contact{
    grid-template-columns:1fr;
  }

  .campos-about .bio-left{
    position:static;
  }

  .campos-about .contact-info-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 768px){
  .campos-about .s-bio,
  .campos-about .s-practice,
  .campos-about .s-testimonials{
    padding:72px 32px;
  }

  .campos-about .mission-left,
  .campos-about .mission-right,
  .campos-about .contact-left,
  .campos-about .contact-right{
    padding:64px 32px;
  }

  .campos-about .hero-stats{
    flex-direction:column;
    gap:24px;
  }

  .campos-about .hero-stat{
    border-right:none;
    border-bottom:1px solid var(--border-dk);
    padding:0 0 24px 0;
  }

  .campos-about .hero-stat:last-child{
    border-bottom:none;
    padding:0;
  }

  .campos-about .creds-inner{
    flex-direction:column;
  }

  .campos-about .cred-item{
    border-right:none;
    border-bottom:1px solid rgba(28,18,8,.12);
  }

  .campos-about .cred-item:last-child{
    border-bottom:none;
  }

  .campos-about .bio-checklist{
    grid-template-columns:1fr;
  }

  .campos-about .practice-grid,
  .campos-about .test-grid{
    grid-template-columns:1fr;
  }
}

/* =========================================================
   ABOUT — ANIMATIONS
   ========================================================= */

/* Safe default: visible if JS fails */
.campos-about .reveal,
.campos-about .reveal-left,
.campos-about .reveal-right,
.campos-about .reveal-scale,
.campos-about .hero-fade,
.campos-about .stagger-item {
  opacity: 1;
  transform: none;
  transition:
    opacity .85s ease,
    transform .85s cubic-bezier(.22,.61,.36,1),
    filter .85s ease;
  will-change: opacity, transform, filter;
}

.campos-about.js-reveal .reveal {
  opacity: 0;
  transform: translateY(36px);
}

.campos-about.js-reveal .reveal-left {
  opacity: 0;
  transform: translateX(-38px);
}

.campos-about.js-reveal .reveal-right {
  opacity: 0;
  transform: translateX(38px);
}

.campos-about.js-reveal .reveal-scale {
  opacity: 0;
  transform: scale(.965);
  filter: blur(3px);
}

.campos-about.js-reveal .hero-fade {
  opacity: 0;
  transform: translateY(24px);
}

.campos-about.js-reveal .stagger-item {
  opacity: 0;
  transform: translateY(24px);
}

.campos-about.js-reveal .is-visible {
  opacity: 1;
  transform: none;
  filter: none;
}

/* Stagger timings */
.campos-about .delay-1 { transition-delay: .08s; }
.campos-about .delay-2 { transition-delay: .16s; }
.campos-about .delay-3 { transition-delay: .24s; }
.campos-about .delay-4 { transition-delay: .32s; }
.campos-about .delay-5 { transition-delay: .40s; }
.campos-about .delay-6 { transition-delay: .48s; }

/* Elegant hover */
.campos-about .p-card,
.campos-about .t-card,
.campos-about .cred-item {
  transition:
    transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease,
    background-color .28s ease;
}

.campos-about .hero-photo-col img,
.campos-about .p-card,
.campos-about .t-card {
  transform-origin: center center;
}

.campos-about .hero-photo-col:hover img {
  transform: scale(1.02);
  transition: transform 1.2s ease;
}