.portes-flow{
  position:relative;
  padding:14vh 4vw;
  max-width:1600px;
  margin:0 auto;
  border-top:1px solid var(--line);
  overflow:hidden;
}

.portes-flow::before{
  content:"";
  position:absolute;
  inset:8vh auto auto -10vw;
  width:min(560px,55vw);
  height:min(560px,55vw);
  border-radius:999px;
  background:radial-gradient(circle, rgba(var(--accent-rgb,234,88,12),.2), transparent 63%);
  filter:blur(18px);
  pointer-events:none;
}

.portes-flow .section-title{
  max-width:1180px;
  overflow:visible;
}

.portes-experience{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);
  gap:clamp(24px,4vw,60px);
  align-items:stretch;
}

.portes-map{
  position:relative;
  min-height:640px;
  border:1px solid var(--line-strong);
  border-radius:30px;
  overflow:hidden;
  background:var(--bg-elevated-2);
  box-shadow:0 46px 130px -90px rgba(0,0,0,.9);
}

.portes-map img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.92) brightness(.72);
  transform:scale(1.035);
  transition:transform 1.1s var(--ease), filter .45s var(--ease);
}

.portes-map:hover img{
  transform:scale(1.075);
  filter:saturate(1.06) brightness(.86);
}

.map-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.18), transparent 16%),
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.72));
}

.map-pin{
  position:absolute;
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:999px;
  padding:10px 14px 10px 10px;
  background:rgba(0,0,0,.44);
  color:#fffaf4;
  font-family:var(--font-mono);
  font-size:10px;
  font-weight:900;
  letter-spacing:.13em;
  text-transform:uppercase;
  backdrop-filter:blur(14px);
  cursor:pointer;
  transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);
}

.map-pin span{
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
}

.map-pin:hover,
.map-pin.is-active{
  transform:translateY(-4px) scale(1.04);
  border-color:var(--accent);
  background:rgba(var(--accent-rgb,234,88,12),.72);
  box-shadow:0 16px 38px -18px var(--accent-glow);
}

.map-pin::after{
  content:"";
  position:absolute;
  left:23px;
  top:100%;
  width:1px;
  height:70px;
  background:linear-gradient(var(--accent), transparent);
  opacity:.7;
}

.map-pin.p1{left:8%;top:12%}
.map-pin.p2{right:11%;top:24%}
.map-pin.p3{left:19%;bottom:22%}
.map-pin.p4{right:12%;bottom:15%}

.portes-panel{
  position:relative;
  display:grid;
  grid-template-rows:minmax(380px,1fr) auto;
  gap:18px;
}

.portes-photo{
  position:absolute;
  inset:0 0 156px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:30px;
  background:var(--bg-elevated-2);
  opacity:0;
  transform:translateY(18px) scale(.97);
  transition:opacity .42s var(--ease), transform .55s var(--ease), border-color .35s var(--ease);
}

.portes-photo.is-active{
  opacity:1;
  transform:translateY(0) scale(1);
  border-color:rgba(var(--accent-rgb,234,88,12),.48);
}

.portes-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.98) brightness(.9);
  transform:scale(1.03);
}

.portes-copy{
  position:relative;
  align-self:end;
  margin-top:auto;
  padding:24px;
  border:1px solid var(--line-strong);
  border-radius:24px;
  background:rgba(255,255,255,.045);
  backdrop-filter:blur(16px);
}

.portes-kicker{
  display:block;
  margin-bottom:12px;
  font-family:var(--font-mono);
  font-size:10px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
}

.portes-copy h3{
  font-size:clamp(28px,3vw,44px);
  line-height:1;
  margin-bottom:12px;
  color:var(--fg);
}

.portes-copy p{
  color:var(--fg-muted);
  line-height:1.65;
}

@media(max-width:980px){
  .portes-experience{
    grid-template-columns:1fr;
  }
  .portes-map{
    min-height:520px;
  }
  .portes-panel{
    min-height:560px;
  }
}

@media(max-width:640px){
  .portes-flow{
    padding:10vh 24px;
  }
  .portes-flow .section-title{
    font-size:clamp(40px,12vw,58px);
  }
  .portes-map{
    min-height:480px;
    border-radius:24px;
  }
  .map-pin{
    max-width:150px;
    white-space:normal;
    line-height:1.1;
  }
  .map-pin::after{
    height:44px;
  }
  .portes-panel{
    min-height:500px;
  }
  .portes-photo{
    inset:0 0 168px;
    border-radius:24px;
  }
  .portes-copy{
    padding:20px;
  }
}
