/* ==========================================================================
   Section : Hero
   Adapte du composant 21st.dev "FinancialHero".
   - Fond en grille avec masque radial qui fond les bords
   - Texte gauche : titre + accent colore + description + CTA fleche
   - Visuel droite : 2 smartphones flottants qui se croisent (-6deg / +6deg)
   - Animations d'entree CSS (fade-up sur texte, slide-in sur phones)
   - Respect de prefers-reduced-motion
   ========================================================================== */

.tme-hero{
  position:relative;
  background:var(--bg);
  overflow:hidden;
  padding:var(--sp-20) 0;
  min-height:80vh;
  display:flex;
  align-items:center;
}

.tme-hero__grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity:.85;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at center, #000 25%, transparent 95%);
  mask-image: radial-gradient(ellipse 70% 60% at center, #000 25%, transparent 95%);
  pointer-events:none;
}

.tme-hero__fade{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg,
    var(--bg) 0%,
    rgba(242,242,242,0) 25%,
    rgba(242,242,242,0) 75%,
    var(--bg) 100%);
  pointer-events:none;
}

.tme-hero__inner{
  position:relative;
  display:grid;
  grid-template-columns: 1.15fr 1fr;
  gap: var(--sp-10);
  align-items:center;
  z-index:1;
}

.tme-hero__content{
  max-width:560px;
}

.tme-hero__title{
  font-size: clamp(2.25rem, 4.8vw, 4rem);
  font-weight: var(--fw-extra);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--text);
  margin: 0 0 var(--sp-5);
}
.tme-hero__title span{
  color: var(--primary);
  display: inline-block;
}

.tme-hero__desc{
  font-size: var(--fs-md);
  line-height: 1.65;
  color: var(--muted);
  margin: 0 0 var(--sp-8);
  max-width: 560px;
}

.tme-hero__cta{
  display:inline-flex;
  align-items:center;
  gap: var(--sp-3);
  background: var(--primary);
  color: #fff;
  padding: 16px 28px;
  border-radius: var(--rd-sm);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  letter-spacing: .04em;
  text-decoration: none;
  transition: background var(--tr-base), transform var(--tr-base), box-shadow var(--tr-base);
}
.tme-hero__cta:hover{
  background: var(--primary-2);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: var(--sh-md);
}
.tme-hero__cta svg{
  width: 18px;
  height: 18px;
  transition: transform var(--tr-base);
}
.tme-hero__cta:hover svg{
  transform: translateX(4px);
}

.tme-hero__visual{
  position: relative;
  height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tme-hero__phone{
  position: absolute;
  width: 200px;
  height: auto;
  filter: drop-shadow(0 30px 40px rgba(0,0,0,.22));
  transition: transform var(--tr-slow);
  cursor: pointer;
}
.tme-hero__phone--back{
  transform: rotate(-6deg) translateX(38px);
  z-index: 1;
}
.tme-hero__phone--front{
  transform: rotate(6deg) translateX(-38px);
  z-index: 2;
}
.tme-hero__phone--back:hover{
  transform: rotate(-3deg) translateX(38px) translateY(-12px);
}
.tme-hero__phone--front:hover{
  transform: rotate(3deg) translateX(-38px) translateY(-12px);
}

/* ── Animations d'entree ───────────────────────────────── */
@keyframes tme-hero-fadeup{
  from{ opacity:0; transform: translateY(24px); }
  to  { opacity:1; transform: translateY(0); }
}
@keyframes tme-hero-phone-back{
  from{ opacity:0; transform: rotate(-6deg) translateX(90px); }
  to  { opacity:1; transform: rotate(-6deg) translateX(38px); }
}
@keyframes tme-hero-phone-front{
  from{ opacity:0; transform: rotate(6deg) translateX(0); }
  to  { opacity:1; transform: rotate(6deg) translateX(-38px); }
}

.tme-hero__title{ animation: tme-hero-fadeup .6s ease forwards; }
.tme-hero__desc { animation: tme-hero-fadeup .6s ease .15s forwards; opacity:0; }
.tme-hero__cta  { animation: tme-hero-fadeup .6s ease .30s forwards; opacity:0; }
.tme-hero__phone--back { animation: tme-hero-phone-back  .8s cubic-bezier(.2,.7,.3,1) .40s forwards; opacity:0; }
.tme-hero__phone--front{ animation: tme-hero-phone-front .8s cubic-bezier(.2,.7,.3,1) .55s forwards; opacity:0; }

/* ── Reduced motion ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce){
  .tme-hero__title,
  .tme-hero__desc,
  .tme-hero__cta,
  .tme-hero__phone--back,
  .tme-hero__phone--front{
    animation: none !important;
    opacity: 1 !important;
  }
  .tme-hero__phone--back { transform: rotate(-6deg) translateX(38px); }
  .tme-hero__phone--front{ transform: rotate(6deg) translateX(-38px); }
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 1024px){
  .tme-hero__inner{
    grid-template-columns: 1fr;
    gap: var(--sp-10);
    text-align: center;
  }
  .tme-hero__content{
    margin: 0 auto;
  }
  .tme-hero__desc{
    margin-left: auto;
    margin-right: auto;
  }
  .tme-hero__visual{
    height: 380px;
  }
  .tme-hero__phone{
    width: 180px;
  }
}

@media (max-width: 640px){
  .tme-hero{
    padding: var(--sp-12) 0;
    min-height: auto;
  }
  .tme-hero__visual{
    height: 320px;
  }
  .tme-hero__phone{
    width: 150px;
  }
  .tme-hero__phone--back  { transform: rotate(-6deg) translateX(40px); }
  .tme-hero__phone--front { transform: rotate(6deg) translateX(-40px); }
  @keyframes tme-hero-phone-back{
    from{ opacity:0; transform: rotate(-6deg) translateX(80px); }
    to  { opacity:1; transform: rotate(-6deg) translateX(40px); }
  }
  @keyframes tme-hero-phone-front{
    from{ opacity:0; transform: rotate(6deg) translateX(0); }
    to  { opacity:1; transform: rotate(6deg) translateX(-40px); }
  }
}
