/* ===== PORTFOLIO — sections pinned éditoriales ===== */

/* En-tête */
.port-head {
  padding-top: clamp(3rem, 9vh, 7rem);
  padding-bottom: clamp(2rem, 5vh, 4rem);
}
.port-eyebrow { display: block; margin-bottom: 1.4rem; }
.port-h1 {
  font-size: clamp(3rem, 11vw, 9rem);
  line-height: .92;
  letter-spacing: -.045em;
}
.port-lead {
  margin-top: 1.6rem;
  max-width: 46ch;
  color: var(--gray);
  font-size: clamp(1rem, 1.2vw, 1.1rem);
}

/* Une section = un projet plein écran */
.pin {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-block: clamp(3rem, 8vh, 7rem);
  border-top: 1px solid rgba(255, 255, 255, .08);
}
.pin-grid {
  display: flex;
  align-items: center;
  gap: clamp(2rem, 5vw, 5.5rem);
  width: 100%;
}
/* alternance gauche/droite */
.pin:nth-child(even) .pin-grid { flex-direction: row-reverse; }

.pin-text  { flex: 1 1 0; min-width: 0; }
.pin-media { flex: 1.25 1 0; min-width: 0; }

/* Chiffre géant — ghost numeral */
.pin-num {
  display: block;
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(3rem, 9vw, 8rem);
  line-height: .8;
  letter-spacing: -.04em;
  color: transparent;
  -webkit-text-stroke: 1.5px var(--accent, var(--lime));
  text-stroke: 1.5px var(--accent, var(--lime));
  margin-bottom: 1.2rem;
}
.pin-title {
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  line-height: 1;
  letter-spacing: -.03em;
  margin-bottom: 1rem;
}
.pin-desc {
  color: var(--light);
  max-width: 44ch;
  line-height: 1.7;
  margin-bottom: 1.8rem;
}

/* Méta en ligne (marginalia) */
.pin-aside {
  display: flex;
  align-items: baseline;
  gap: 1.8rem;
  flex-wrap: wrap;
  margin-bottom: 1.8rem;
}
.pin-meta {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--white);
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.pin-meta b { color: var(--gray); font-weight: 400; font-size: .62rem; letter-spacing: .14em; }
.pin-tags {
  list-style: none;
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}
.pin-tags li {
  font-family: var(--mono);
  font-size: .6rem;
  padding: .25rem .55rem;
  border: 1px solid rgba(255, 255, 255, .12);
  color: var(--light);
  border-radius: 3px;
}

/* Lien projet */
.pin-cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--sans);
  font-size: .82rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--white);
  padding-block: .35rem;
}
.pin-cta span { transition: transform .35s var(--spring); }
.pin-cta::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 1px;
  background: var(--accent, var(--lime));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s var(--ease);
}
.pin-cta:hover::after { transform: scaleX(1); }
.pin-cta:hover span   { transform: translateX(4px); }

/* Média : mockup navigateur avec aperçu live */
.pin-media {
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 40px 90px rgba(0, 0, 0, .55),
              0 0 60px color-mix(in srgb, var(--accent, var(--lime)) 16%, transparent);
  transition: transform .5s var(--ease), box-shadow .5s var(--ease);
}
.pin:hover .pin-media { transform: translateY(-6px); }
.pin-bar {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .55rem .8rem;
  background: var(--dark2);
  border-bottom: 1px solid rgba(255, 255, 255, .06);
}
.pbd { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.pbd.r { background: #ff5f57; }
.pbd.y { background: #febc2e; }
.pbd.g { background: #28c840; }
.pin-url {
  flex: 1;
  font-family: var(--mono);
  font-size: .62rem;
  color: var(--gray);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pin-badge {
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent, var(--lime));
  border: 1px solid color-mix(in srgb, var(--accent, var(--lime)) 40%, transparent);
  padding: .15rem .45rem;
  border-radius: 3px;
}
.pin-viewport {
  position: relative;
  overflow: hidden;
  background: #0d0d12;
}
.pin-viewport iframe {
  width: 1440px;
  height: 900px;
  border: 0;
  transform-origin: top left;
  pointer-events: none;
  display: block;
}
.pin-img { display: block; width: 100%; height: auto; }

/* Bloc « À venir » — slim, pas plein écran */
.pin-soon {
  padding-block: clamp(3rem, 6vw, 5rem);
  border-top: 1px solid rgba(255, 255, 255, .08);
}
.soon-list {
  list-style: none;
  margin-top: 1.5rem;
}
.soon-item {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.4rem 0;
  border-top: 1px solid rgba(255, 255, 255, .08);
  color: var(--gray);
}
.soon-cat {
  font-family: var(--mono);
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--accent, var(--lime));
  min-width: 8rem;
}
.soon-name { font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--light); flex: 1; }
.soon-dots { font-family: var(--mono); opacity: .5; }

/* Clôture */
.port-end {
  padding-block: clamp(4rem, 9vw, 8rem);
  border-top: 1px solid rgba(255, 255, 255, .08);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.5rem;
}
.port-end-line {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(1.8rem, 5vw, 3.4rem);
  line-height: 1.05;
  letter-spacing: -.03em;
}

/* RESPONSIVE */
@media (max-width: 860px) {
  .pin { min-height: 0; padding-block: clamp(3rem, 9vw, 5rem); }
  .pin-grid,
  .pin:nth-child(even) .pin-grid { flex-direction: column; align-items: stretch; gap: 2rem; }
  .pin-media { order: 2; }
}
