/* ============================================
   NAYT PROD - Composants spécifiques
   ============================================ */

/* ===== HERO HOMEPAGE ===== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding-top:var(--header-h);
}
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-bg img,.hero-bg video{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.hero-bg::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,.4) 0%,rgba(10,10,10,.7) 50%,var(--black) 100%),
             linear-gradient(90deg,rgba(10,10,10,.6) 0%,transparent 50%);
  z-index:1;
}
.hero-content{
  position:relative;
  z-index:2;
  width:100%;
  padding:var(--sp-20) 0;
}
.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:var(--sp-3);
  padding:.5rem 1.25rem;
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(10px);
  border:1px solid var(--border);
  border-radius:var(--r-full);
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--white);
  margin-bottom:var(--sp-8);
}
.hero-eyebrow .dot{
  width:8px;
  height:8px;
  background:var(--teal);
  border-radius:50%;
  box-shadow:0 0 10px var(--teal);
  animation:pulse 1.5s ease-in-out infinite;
}
.hero-title{
  font-size:clamp(3rem,9vw,9rem);
  line-height:.9;
  letter-spacing:-.03em;
  margin-bottom:var(--sp-8);
  font-weight:700;
}
.hero-title .word{display:inline-block;overflow:hidden}
.hero-title em{font-style:italic;font-weight:400;color:var(--teal)}
.hero-subtitle{
  font-size:clamp(1rem,1.5vw,1.25rem);
  color:var(--text-muted);
  max-width:580px;
  margin-bottom:var(--sp-10);
  line-height:1.7;
}
.hero-actions{
  display:flex;
  gap:var(--sp-4);
  flex-wrap:wrap;
  margin-bottom:var(--sp-16);
}
.hero-scroll-indicator{
  position:absolute;
  bottom:var(--sp-8);
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--sp-2);
  color:var(--text-dim);
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  z-index:2;
}
.scroll-line{
  width:1px;
  height:60px;
  background:linear-gradient(180deg,transparent,var(--white));
  position:relative;
  overflow:hidden;
}
.scroll-line::after{
  content:'';
  position:absolute;
  top:-30px;
  left:0;
  width:100%;
  height:30px;
  background:var(--teal);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{
  0%{top:-30px}
  100%{top:60px}
}

/* ===== STATS BAR ===== */
.stats-bar{
  padding:var(--sp-16) 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--sp-8);
}
@media (max-width:768px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--sp-10)}
}
.stat-item{text-align:center;position:relative}
.stat-item:not(:last-child)::after{
  content:'';
  position:absolute;
  right:0;
  top:20%;
  height:60%;
  width:1px;
  background:var(--border);
}
@media (max-width:768px){
  .stat-item:not(:last-child)::after{display:none}
}
.stat-number{
  font-family:var(--font-display);
  font-size:clamp(2.5rem,5vw,4.5rem);
  font-weight:700;
  background:var(--gradient-brand);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  margin-bottom:var(--sp-2);
}
.stat-label{
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--text-muted);
}

/* ===== SERVICES GRID ===== */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-6);
}
@media (max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:600px){
  .services-grid{grid-template-columns:1fr}
}
.service-card{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:var(--sp-10);
  overflow:hidden;
  transition:all .5s var(--ease);
  cursor:pointer;
  min-height:340px;
  display:flex;
  flex-direction:column;
}
.service-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:var(--gradient-brand-soft);
  opacity:0;
  transition:opacity .5s var(--ease);
}
.service-card::after{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:2px;
  background:var(--gradient-brand);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .5s var(--ease);
}
.service-card:hover{
  border-color:transparent;
  transform:translateY(-8px);
}
.service-card:hover::before{opacity:1}
.service-card:hover::after{transform:scaleX(1)}
.service-card > *{position:relative;z-index:1}
.service-icon{
  width:64px;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,169,157,.1);
  border:1px solid rgba(0,169,157,.2);
  border-radius:var(--r-md);
  color:var(--teal);
  margin-bottom:var(--sp-6);
  transition:all var(--t-base);
}
.service-card:hover .service-icon{
  background:var(--gradient-brand);
  color:var(--white);
  border-color:transparent;
  transform:scale(1.1) rotate(-5deg);
}
.service-icon svg{width:28px;height:28px}
.service-category{
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--teal);
  margin-bottom:var(--sp-3);
}
.service-card h3{
  font-size:var(--fs-2xl);
  margin-bottom:var(--sp-3);
  color:var(--white);
}
.service-card p{
  color:var(--text-muted);
  font-size:var(--fs-sm);
  margin-bottom:var(--sp-6);
  flex-grow:1;
}
.service-link{
  display:inline-flex;
  align-items:center;
  gap:var(--sp-2);
  color:var(--teal);
  font-size:var(--fs-sm);
  font-weight:500;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.service-link svg{
  width:16px;
  height:16px;
  transition:transform var(--t-base);
}
.service-card:hover .service-link svg{transform:translateX(6px)}

/* ===== MARQUEE ===== */
.marquee{
  position:relative;
  overflow:hidden;
  padding:var(--sp-12) 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--bg-soft);
}
.marquee-track{
  display:flex;
  gap:var(--sp-16);
  animation:marqueeScroll 40s linear infinite;
  width:max-content;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{
  flex-shrink:0;
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:600;
  color:var(--text-dim);
  letter-spacing:-.02em;
  display:flex;
  align-items:center;
  gap:var(--sp-16);
}
.marquee-item::after{
  content:'✦';
  color:var(--teal);
  font-size:.6em;
}
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ===== CLIENTS LOGOS ===== */
.clients-section{
  padding:var(--sp-20) 0;
  background:var(--bg-soft);
}
.clients-title{
  text-align:center;
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:var(--sp-12);
}
.clients-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:var(--sp-8);
  align-items:center;
}
@media (max-width:900px){
  .clients-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:520px){
  .clients-grid{grid-template-columns:repeat(2,1fr)}
}
.client-logo{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:var(--sp-6);
  font-family:var(--font-display);
  font-weight:600;
  font-size:var(--fs-xl);
  color:var(--gray-500);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:all var(--t-base);
  text-align:center;
  min-height:90px;
  filter:grayscale(100%);
  opacity:.6;
}
.client-logo:hover{
  filter:grayscale(0%);
  opacity:1;
  border-color:var(--teal);
  color:var(--white);
  transform:translateY(-4px);
}

/* ===== TESTIMONIALS ===== */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-6);
}
@media (max-width:900px){.testimonials-grid{grid-template-columns:1fr}}
.testimonial-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:var(--sp-8);
  position:relative;
  transition:all var(--t-base);
}
.testimonial-card::before{
  content:'"';
  position:absolute;
  top:1rem;
  right:2rem;
  font-family:var(--font-display);
  font-size:6rem;
  line-height:1;
  color:var(--teal);
  opacity:.2;
}
.testimonial-card:hover{
  border-color:var(--border-strong);
  transform:translateY(-4px);
}
.testimonial-stars{
  display:flex;
  gap:2px;
  margin-bottom:var(--sp-4);
  color:var(--teal);
}
.testimonial-stars svg{width:18px;height:18px;fill:currentColor}
.testimonial-text{
  font-size:var(--fs-base);
  color:var(--text);
  margin-bottom:var(--sp-6);
  line-height:1.7;
}
.testimonial-author{
  display:flex;
  align-items:center;
  gap:var(--sp-3);
  padding-top:var(--sp-4);
  border-top:1px solid var(--border);
}
.testimonial-avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--gradient-brand);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-weight:600;
  color:var(--white);
}
.testimonial-author-info h6{
  font-family:var(--font-body);
  font-size:var(--fs-sm);
  color:var(--white);
  margin-bottom:2px;
}
.testimonial-author-info span{
  font-size:var(--fs-xs);
  color:var(--text-dim);
}

/* ===== CTA BANNER ===== */
.cta-banner{
  position:relative;
  padding:var(--sp-32) 0;
  text-align:center;
  overflow:hidden;
}
.cta-banner::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at center,rgba(0,169,157,.2),transparent 70%);
}
.cta-banner-content{position:relative;z-index:1;max-width:780px;margin:0 auto}
.cta-banner h2{
  font-size:clamp(2.5rem,6vw,5rem);
  margin-bottom:var(--sp-6);
}
.cta-banner p{
  font-size:var(--fs-lg);
  color:var(--text-muted);
  margin-bottom:var(--sp-10);
}

/* ===== PORTFOLIO GRID ===== */
.portfolio-filters{
  display:flex;
  justify-content:center;
  gap:var(--sp-2);
  flex-wrap:wrap;
  margin-bottom:var(--sp-12);
}
.filter-btn{
  padding:.7rem 1.5rem;
  background:transparent;
  border:1px solid var(--border);
  border-radius:var(--r-full);
  color:var(--text-muted);
  font-size:var(--fs-sm);
  font-weight:500;
  letter-spacing:.05em;
  text-transform:uppercase;
  transition:all var(--t-base);
}
.filter-btn:hover,.filter-btn.active{
  background:var(--gradient-brand);
  color:var(--white);
  border-color:transparent;
}

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-6);
}
@media (max-width:900px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.portfolio-grid{grid-template-columns:1fr}}
.portfolio-item{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--r-lg);
  overflow:hidden;
  cursor:pointer;
  transition:transform var(--t-base);
}
.portfolio-item.featured{grid-column:span 2;aspect-ratio:8/5}
@media (max-width:600px){.portfolio-item.featured{grid-column:span 1;aspect-ratio:4/5}}
.portfolio-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s var(--ease);
}
.portfolio-item:hover img{transform:scale(1.08)}
.portfolio-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,.95));
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:var(--sp-8);
  opacity:0;
  transition:opacity var(--t-base);
}
.portfolio-item:hover .portfolio-overlay{opacity:1}
.portfolio-category{
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--teal);
  margin-bottom:var(--sp-2);
}
.portfolio-overlay h4{
  font-size:var(--fs-2xl);
  color:var(--white);
  margin-bottom:var(--sp-2);
}

/* ===== PRICING / PACKS ===== */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-6);
  align-items:stretch;
}
@media (max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.pricing-card{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:var(--sp-10);
  display:flex;
  flex-direction:column;
  transition:all var(--t-base);
}
.pricing-card.popular{
  border-color:var(--teal);
  background:linear-gradient(180deg,rgba(0,169,157,.05),var(--bg-card));
  transform:scale(1.05);
}
@media (max-width:900px){.pricing-card.popular{transform:scale(1)}}
.pricing-card.popular::before{
  content:'PLUS POPULAIRE';
  position:absolute;
  top:-12px;
  left:50%;
  transform:translateX(-50%);
  background:var(--gradient-brand);
  color:var(--white);
  padding:.4rem 1rem;
  border-radius:var(--r-full);
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  white-space:nowrap;
}
.pricing-card:hover{transform:translateY(-8px)}
.pricing-card.popular:hover{transform:scale(1.05) translateY(-8px)}
@media (max-width:900px){.pricing-card.popular:hover{transform:translateY(-8px)}}
.pricing-name{
  font-family:var(--font-mono);
  font-size:var(--fs-sm);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--teal);
  margin-bottom:var(--sp-3);
}
.pricing-title{
  font-size:var(--fs-3xl);
  margin-bottom:var(--sp-4);
}
.pricing-desc{
  color:var(--text-muted);
  font-size:var(--fs-sm);
  margin-bottom:var(--sp-8);
  min-height:50px;
}
.pricing-features{
  list-style:none;
  flex-grow:1;
  margin-bottom:var(--sp-8);
}
.pricing-features li{
  display:flex;
  align-items:flex-start;
  gap:var(--sp-3);
  padding:var(--sp-3) 0;
  font-size:var(--fs-sm);
  color:var(--text);
  border-bottom:1px solid var(--border);
}
.pricing-features li:last-child{border-bottom:none}
.pricing-features svg{
  width:18px;
  height:18px;
  color:var(--teal);
  flex-shrink:0;
  margin-top:2px;
}

/* ===== STEPS / PROCESS ===== */
.process-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--sp-6);
  position:relative;
}
@media (max-width:900px){.process-steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.process-steps{grid-template-columns:1fr}}
.process-step{
  position:relative;
  padding:var(--sp-6);
}
.step-number{
  font-family:var(--font-display);
  font-size:5rem;
  font-weight:700;
  background:var(--gradient-brand);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  margin-bottom:var(--sp-4);
}
.step-title{
  font-size:var(--fs-xl);
  margin-bottom:var(--sp-3);
}
.step-desc{
  font-size:var(--fs-sm);
  color:var(--text-muted);
}

/* ===== FAQ ===== */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--border);
  padding:var(--sp-2) 0;
}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:var(--sp-6) 0;
  font-family:var(--font-display);
  font-size:var(--fs-xl);
  color:var(--white);
  text-align:left;
  transition:color var(--t-fast);
}
.faq-question:hover{color:var(--teal)}
.faq-icon{
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  border-radius:50%;
  flex-shrink:0;
  transition:all var(--t-base);
}
.faq-icon::before,.faq-icon::after{
  content:'';
  position:absolute;
  background:var(--white);
  transition:all var(--t-base);
}
.faq-icon::before{width:12px;height:1.5px}
.faq-icon::after{width:1.5px;height:12px}
.faq-item.active .faq-icon{
  background:var(--gradient-brand);
  border-color:transparent;
  transform:rotate(180deg);
}
.faq-item.active .faq-icon::after{transform:scaleY(0)}
.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height var(--t-base);
}
.faq-answer-inner{
  padding:0 0 var(--sp-6);
  color:var(--text-muted);
  line-height:1.8;
}
.faq-item.active .faq-answer{max-height:500px}

/* ===== INFO CARDS (contact) ===== */
.info-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-4);
  margin-bottom:var(--sp-12);
}
@media (max-width:768px){.info-cards{grid-template-columns:1fr}}
.info-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:var(--sp-8);
  text-align:center;
  transition:all var(--t-base);
}
.info-card:hover{
  border-color:var(--teal);
  transform:translateY(-4px);
  box-shadow:var(--shadow-glow);
}
.info-card-icon{
  width:60px;
  height:60px;
  margin:0 auto var(--sp-4);
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--gradient-brand-soft);
  border-radius:50%;
  color:var(--teal);
}
.info-card-icon svg{width:24px;height:24px}
.info-card h5{
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:var(--sp-3);
}
.info-card p,.info-card a{
  color:var(--white);
  font-size:var(--fs-base);
  line-height:1.7;
  display:block;
}
.info-card a:hover{color:var(--teal)}
