/* ===== Reset et base ===== */
* {margin:0; padding:0; box-sizing:border-box;}
html, body {height:100%; background:#000; color:#fff; font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial; overflow-x:hidden;}
p {font-size:20px; max-width:720px; line-height:1.6;}

/* ===== Liens ===== */
a {color:inherit; text-decoration:none;}
.shop-link {
  display:inline-block; margin-top:20px;
  padding:12px 20px; background:#ff66ff; color:#000; font-weight:700; border-radius:8px;
  transition:transform .3s, filter .3s;
}
.shop-link:hover { transform:translateY(-3px); filter:brightness(.9); }

/* ===== Intro stack (NOIR + ROSE) ===== */
.intro-stack {
  position:fixed; inset:0; width:100%; height:200vh;
  transform:translateY(0); transition:transform 1s cubic-bezier(.7,0,.3,1);
  z-index:50; overflow:hidden;
}
.panel {height:100vh; width:100%;}
.panel--black {background:#000; display:flex; flex-direction:column; justify-content:center; padding-left:50px;}
.panel--pink {background:#ff66ff;}

.title {
  font-size:5rem; font-weight:800; letter-spacing:.02em; color:#fff; margin-bottom:20px;
}
.roulette {overflow:hidden; position:relative;}
.words {
  position:absolute; top:0; left:0; display:flex; flex-direction:column; font-size:4rem;
  font-weight:800; color:violet; will-change:transform;
}
.words span {display:block; white-space:nowrap; line-height:1.1; padding:0 .1em;}

/* ===== Site principal ===== */
main {position:relative; z-index:1;}
section {
  min-height:100vh; padding:80px 10%; display:flex; flex-direction:column; justify-content:center;
  background:#000; color:#fff;
}
h1,h2,h3 {margin-bottom:20px;}
h1 {font-size:4rem;}
h2 {font-size:2.2rem; color:#ff66ff;}

/* ===== Services ===== */
.services .cards {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(230px,1fr)); gap:20px; margin-top:12px;
}
.card {
  background:#111; border:1px solid #ff66ff; padding:20px; border-radius:12px; transition:transform .3s;
}
.card:hover {transform:translateY(-6px);}

/* ===== Portfolio ===== */
/* ===== Portfolio ===== */
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 20px;
}

.portfolio-item {
  position: relative; /* pour overlay et positionnement interne */
  background: #111;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 600;
  min-height: 200px; /* hauteur minimum pour la grille */
  border-radius: 12px;
  border: 1px solid #ff66ff;
  overflow: hidden; /* empêche le contenu de dépasser */
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.portfolio-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 20px rgba(255, 102, 255, 0.4);
}

.portfolio-item .img,
.portfolio-item video {
  width: 100%;
  height: 100%;
  object-fit: cover; /* garde le ratio et couvre le bloc */
  display: block;
  border-radius: 12px;
  transition: transform 0.3s ease;
}

/* Centrage parfait pour le contenu texte si présent */
.portfolio-item .content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 2;
}

.portfolio-item:hover {transform:translateY(-6px);}

/* ===== Formulaire ===== */
form {display:flex; flex-direction:column; gap:14px; max-width:420px;}
input, textarea {
  padding:12px 14px; border:none; border-radius:10px; outline:none; background:#111; color:#fff;
}
button {
  background:#ff66ff; border:none; padding:12px 14px; border-radius:10px; font-weight:700; cursor:pointer; transition:filter .2s;
}
button:hover {filter:brightness(.9);}

.contact-note {margin-top:15px; font-size:0.9rem; color:#aaa;}
.contact-note a {color:#ff66ff; text-decoration:underline;}

/* ===== Responsive ===== */
@media (max-width:1024px){
  .title {font-size:4rem;}
  .words {font-size:3rem;}
  section {padding:60px 8%;}
}
@media (max-width:768px){
  .title {font-size:3rem;}
  .words {font-size:2.5rem;}
  .services .cards, .portfolio-grid {grid-template-columns:1fr;}
}
@media (max-width:480px){
  .title {font-size:2.5rem;}
  .words {font-size:2rem;}
  section {padding:50px 5%;}
}
