/* ============================================
   Porno et Sexe — Néon Discret
   Noir mat + Rose néon + Violet électrique · Mobile-first
   ============================================ */

:root{
  /* Palette Néon Discret */
  --noir:           #0F0A14;
  --noir-deep:      #000000;
  --noir-soft:      #1A0F24;
  --violet-deep:    #3D1F66;
  --violet:         #9B59FF;
  --violet-light:   #B57FFF;
  --rose-neon:      #FF1B8D;
  --rose-hot:       #FF4FA8;
  --rose-soft:      #FFA0CD;
  --cyan-glow:      #00E0FF;
  --creme:          #F5EAF5;
  --creme-soft:     #D8C3D8;
  --line:           rgba(255, 27, 141, .25);
  --shadow-sm:      0 2px 8px rgba(0, 0, 0, .4);
  --shadow-md:      0 8px 24px rgba(0, 0, 0, .5);
  --shadow-lg:      0 16px 48px rgba(0, 0, 0, .7);
  --glow-rose:      0 0 24px rgba(255, 27, 141, .4);
  --glow-violet:    0 0 28px rgba(155, 89, 255, .35);

  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Inter', system-ui, -apple-system, sans-serif;

  --container: 1200px;
  --container-narrow: 1040px;
  --gutter: 1.25rem;
  --section-y: clamp(3rem, 7vw, 6rem);
  --radius: 6px;
  --radius-lg: 14px;
}

/* ============ RESET ============ */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--creme);
  background:var(--noir);
  -webkit-font-smoothing:antialiased;
}
img,svg{ display:block; max-width:100%; height:auto; }
a{ color:var(--rose-neon); text-decoration:none; }
a:hover{ color:var(--rose-hot); }
button{ font-family:inherit; cursor:pointer; }
ol,ul{ padding-left:1.4rem; }

/* ============ TYPO ============ */
h1,h2,h3{
  font-family:var(--serif);
  color:var(--creme);
  line-height:1.15;
  font-weight:600;
  letter-spacing:-.01em;
  margin:0 0 .75em;
}
h1{ font-size:clamp(2rem, 5.5vw, 3.5rem); font-weight:600; }
h2{ font-size:clamp(1.65rem, 3.5vw, 2.4rem); margin-top:0; }
h3{ font-size:clamp(1.2rem, 2.2vw, 1.5rem); color:var(--rose-soft); }
p{ margin:0 0 1em; }
strong{ color:var(--rose-neon); font-weight:600; }
em{ color:var(--violet-light); font-style:italic; }

::selection{ background:var(--rose-neon); color:var(--noir); }

/* ============ AGE BANNER ============ */
.age-banner{
  background:var(--noir-deep);
  color:var(--rose-hot);
  text-align:center;
  font-size:.78rem;
  padding:.5rem 1rem;
  letter-spacing:.02em;
  border-bottom:1px solid var(--rose-neon);
}
.age-banner strong{ color:var(--rose-neon); font-weight:700; }

/* ============ CONTAINER ============ */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.container-narrow{ max-width:var(--container-narrow); }

/* ============ HERO ============ */
.hero{
  position:relative;
  background:
    radial-gradient(ellipse 80% 60% at 80% 30%, rgba(155,89,255,.35) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 30% 80%, rgba(255,27,141,.25) 0%, transparent 60%),
    linear-gradient(135deg, var(--noir-deep) 0%, var(--noir-soft) 50%, var(--violet-deep) 100%);
  color:var(--creme);
  overflow:hidden;
}
.hero-image{
  position:relative;
  width:100%;
  aspect-ratio:3/4;
  max-height:65vh;
  overflow:hidden;
}
.hero-image::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg,
    rgba(15,10,20,.0) 0%,
    rgba(15,10,20,.0) 55%,
    rgba(15,10,20,.85) 100%);
  pointer-events:none;
}
.hero-image img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 25%;
}
.hero-content{
  position:relative;
  padding:2rem var(--gutter) 3rem;
  text-align:center;
  max-width:680px;
  margin:0 auto;
}
.brand{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.1rem;
  color:var(--rose-neon);
  letter-spacing:.15em;
  text-transform:uppercase;
  margin:0 0 .8rem;
  text-shadow:0 0 12px rgba(255,27,141,.6);
}
.hero h1{
  color:var(--creme);
  font-size:clamp(2.1rem, 6vw, 3.4rem);
  font-weight:500;
  text-shadow:0 0 20px rgba(0,0,0,.6);
}
.hero h1 .accent{
  color:var(--rose-neon);
  font-style:italic;
  font-weight:600;
  text-shadow:0 0 18px rgba(255,27,141,.7);
}
.hero-sub{
  font-size:1.1rem;
  color:var(--creme-soft);
  max-width:560px;
  margin:0 auto 2rem;
  line-height:1.55;
}
.phone-display{
  margin-top:1.6rem;
  display:flex; flex-direction:column;
  gap:.3rem;
}
.phone-number{
  font-family:var(--serif);
  font-size:1.85rem;
  font-weight:600;
  color:var(--rose-neon);
  letter-spacing:.04em;
  text-shadow:0 0 16px rgba(255,27,141,.5);
}
.phone-meta{
  font-size:.85rem;
  color:var(--creme-soft);
  opacity:.85;
}

@media(min-width:900px){
  .hero{
    display:grid;
    grid-template-columns:4fr 7fr;
    align-items:stretch;
    max-height:620px;
    overflow:hidden;
  }
  .hero-image{
    aspect-ratio:auto;
    max-height:620px;
    height:100%;
    grid-column:1;
    overflow:hidden;
  }
  .hero-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 25%;
  }
  .hero-image::after{
    background:linear-gradient(90deg,
      rgba(15,10,20,0) 60%,
      rgba(15,10,20,.7) 100%);
  }
  .hero-content{
    grid-column:2;
    display:flex;
    flex-direction:column;
    justify-content:center;
    text-align:left;
    padding:2.5rem 3rem;
    max-width:none;
  }
  .hero h1{ font-size:clamp(2rem, 3.2vw, 2.6rem); margin-bottom:.5em; line-height:1.18; }
  .hero-sub{ margin:0 0 1.3rem; font-size:1.05rem; }
  .phone-display{ align-items:flex-start; margin-top:1rem; }
  .phone-number{ font-size:1.55rem; }
  .brand{ margin-bottom:.6rem; font-size:1rem; }
  .btn-cta-primary{ align-self:flex-start; }
}
@media(min-width:1280px){
  .hero-content{ padding:3rem 4rem; }
  .hero h1{ font-size:2.7rem; }
}

/* ============ BOUTONS CTA ============ */
.btn-cta-primary,
.btn-cta-secondary,
.btn-cta-final{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:1rem 1.8rem;
  font-family:var(--sans);
  font-weight:600;
  font-size:1.05rem;
  border-radius:var(--radius-lg);
  border:none;
  cursor:pointer;
  text-decoration:none;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  letter-spacing:.01em;
}
.btn-icon{ font-size:1.2em; line-height:1; }

.btn-cta-primary{
  background:linear-gradient(135deg, var(--rose-neon) 0%, var(--violet) 100%);
  color:var(--noir);
  box-shadow:var(--glow-rose), inset 0 1px 0 rgba(255,255,255,.25);
  font-size:1.15rem;
  padding:1.1rem 2rem;
  font-weight:700;
}
.btn-cta-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 32px rgba(255,27,141,.6), var(--glow-violet);
  color:var(--noir-deep);
}

.btn-cta-secondary{
  background:transparent;
  color:var(--rose-neon);
  border:2px solid var(--rose-neon);
  box-shadow:var(--glow-rose);
}
.btn-cta-secondary:hover{
  background:var(--rose-neon);
  color:var(--noir);
  transform:translateY(-2px);
}

.btn-cta-final{
  background:linear-gradient(135deg, var(--rose-neon) 0%, var(--violet) 100%);
  color:var(--noir);
  font-size:1.2rem;
  padding:1.2rem 2.4rem;
  box-shadow:var(--glow-rose), 0 8px 28px rgba(0,0,0,.4);
  font-weight:700;
}
.btn-cta-final:hover{
  transform:translateY(-2px);
  box-shadow:0 0 40px rgba(255,27,141,.7), var(--glow-violet);
  color:var(--noir-deep);
}

/* ============ TRUST BAR ============ */
.trust-bar{
  background:var(--noir-soft);
  border-top:1px solid var(--rose-neon);
  border-bottom:1px solid var(--rose-neon);
  padding:2rem 0;
  position:relative;
}
.trust-bar::before,
.trust-bar::after{
  content:'';
  position:absolute; left:0; right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--rose-neon), var(--violet), transparent);
}
.trust-bar::before{ top:-1px; }
.trust-bar::after{ bottom:-1px; }
.trust-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  text-align:center;
}
@media(min-width:720px){
  .trust-grid{ grid-template-columns:repeat(3,1fr); }
}
.trust-item{ padding:0 .5rem; }
.trust-icon{
  display:inline-block;
  font-size:2rem;
  margin-bottom:.5rem;
}
.trust-title{
  font-size:1.15rem;
  font-family:var(--serif);
  color:var(--rose-neon);
  margin:0 0 .3rem;
  font-weight:600;
}
.trust-item p{
  font-size:.92rem;
  color:var(--creme-soft);
  margin:0;
  line-height:1.45;
}

/* ============ SECTIONS ============ */
.section{ padding:var(--section-y) 0; background:var(--noir); }
.section-alt{ background:var(--noir-soft); }
.section h2{
  position:relative;
  padding-bottom:.6rem;
  margin-bottom:1.6rem;
  color:var(--creme);
}
.section h2::after{
  content:'';
  position:absolute;
  left:0; bottom:0;
  width:80px; height:3px;
  background:linear-gradient(90deg, var(--rose-neon) 0%, var(--violet) 100%);
  box-shadow:0 0 12px rgba(255,27,141,.5);
}
.section p{
  color:var(--creme-soft);
  font-size:1.05rem;
  line-height:1.75;
}
@media(min-width:900px){
  .section p{ font-size:1.12rem; line-height:1.78; }
  .section h2{ font-size:2.1rem; }
}
@media(min-width:1280px){
  .section p{ font-size:1.15rem; }
  .section h2{ font-size:2.3rem; }
}

/* ============ FIGURE MOOD ============ */
.figure-mood{
  margin:0;
  width:100%;
  overflow:hidden;
  position:relative;
}
.figure-mood img{
  width:100%;
  height:auto;
  max-height:520px;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
}

/* ============ SPÉCIALITÉS ============ */
.specialty{
  margin:2rem 0;
  padding:1.6rem 1.8rem;
  background:var(--noir-soft);
  border-left:4px solid var(--rose-neon);
  border-radius:0 var(--radius) var(--radius) 0;
  box-shadow:var(--shadow-sm), inset 0 0 0 1px rgba(255,27,141,.1);
  position:relative;
}
.section-alt .specialty{
  background:var(--noir);
}
.specialty h3{
  font-style:italic;
  margin-bottom:.6rem;
  color:var(--rose-soft);
  text-shadow:0 0 8px rgba(255,160,205,.3);
}
.specialty p:last-child{ margin-bottom:0; }
.specialty em{
  display:block;
  margin:.5rem 0;
  padding:.5rem 1rem;
  border-left:2px solid var(--violet);
  background:rgba(155,89,255,.1);
  font-size:.98rem;
  color:var(--violet-light);
}

/* ============ STEPS ============ */
.steps{
  list-style:none;
  padding:0;
  counter-reset:step;
  margin:1.5rem 0;
}
.steps li{
  counter-increment:step;
  position:relative;
  padding:1rem 1rem 1rem 3.6rem;
  margin:.8rem 0;
  background:var(--noir-soft);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  font-size:1rem;
  color:var(--creme-soft);
}
.section-alt .steps li{ background:var(--noir); }
.steps li strong{ color:var(--rose-neon); }
.steps li::before{
  content:counter(step);
  position:absolute;
  left:.8rem; top:50%; transform:translateY(-50%);
  width:2rem; height:2rem;
  background:linear-gradient(135deg, var(--rose-neon) 0%, var(--violet) 100%);
  color:var(--noir);
  font-family:var(--serif);
  font-size:1.1rem; font-weight:700;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--glow-rose);
}
.inline-num{
  font-family:var(--serif);
  font-weight:600;
  color:var(--rose-neon);
  white-space:nowrap;
  border-bottom:2px solid var(--rose-neon);
}

/* ============ CTA MID ============ */
.cta-mid{
  background:linear-gradient(135deg, var(--violet-deep) 0%, var(--noir) 100%);
  padding:2.5rem 0;
  text-align:center;
  color:var(--creme);
  position:relative;
}
.cta-mid::before{
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse at center, rgba(255,27,141,.1) 0%, transparent 70%);
  pointer-events:none;
}
.cta-mid-text{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.5rem;
  color:var(--rose-soft);
  margin:0 0 1.2rem;
  position:relative;
}

/* ============ TÉMOIGNAGES ============ */
.testimonials{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  margin-top:2rem;
}
@media(min-width:760px){
  .testimonials{ grid-template-columns:repeat(3,1fr); }
}
.testimonial{
  margin:0;
  padding:1.8rem 1.5rem;
  background:var(--noir-soft);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  text-align:center;
  position:relative;
  border:1px solid var(--line);
}
.testimonial img,
.avatar-fallback{
  width:90px; height:90px;
  border-radius:50%;
  margin:0 auto 1rem;
  border:3px solid var(--rose-neon);
  box-shadow:var(--glow-rose);
  object-fit:cover;
}
.avatar-fallback{
  background:linear-gradient(135deg, var(--rose-neon) 0%, var(--violet) 100%);
  color:var(--noir);
  font-family:var(--serif);
  font-size:2.4rem;
  font-weight:600;
  display:flex;
  align-items:center;
  justify-content:center;
}
.testimonial blockquote{
  margin:0 0 1rem;
  padding:0;
}
.testimonial blockquote p{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  line-height:1.55;
  color:var(--creme);
  margin:0;
}
.testimonial figcaption{
  font-size:.9rem;
  color:var(--rose-soft);
  font-weight:500;
  letter-spacing:.02em;
}
.testimonial figcaption strong{ color:var(--rose-neon); }

/* ============ NOTE ÉTOILES ============ */
.rating{
  font-size:1.05rem;
  color:var(--rose-neon);
  letter-spacing:.15em;
  margin:.3rem 0 .6rem;
  text-shadow:0 0 8px rgba(255,27,141,.4);
}

/* ============ FAQ ============ */
.faq-item{
  margin:.5rem 0;
  background:var(--noir-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:box-shadow .2s ease;
}
.section-alt .faq-item{ background:var(--noir); }
.faq-item[open]{ box-shadow:var(--shadow-sm), 0 0 0 1px rgba(255,27,141,.3); }
.faq-item summary{
  cursor:pointer;
  list-style:none;
  padding:1.1rem 3rem 1.1rem 1.4rem;
  position:relative;
  background:transparent;
  transition:background .2s ease;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:'+';
  position:absolute;
  right:1.2rem; top:50%; transform:translateY(-50%);
  font-family:var(--serif);
  font-size:1.8rem;
  font-weight:300;
  color:var(--rose-neon);
  transition:transform .25s ease;
  line-height:1;
}
.faq-item[open] summary::after{
  transform:translateY(-50%) rotate(45deg);
  color:var(--rose-hot);
}
.faq-item summary:hover{ background:rgba(255,27,141,.05); }
.faq-item summary h3{
  display:inline;
  font-family:var(--sans);
  font-size:1rem;
  font-weight:600;
  color:var(--creme);
  margin:0;
}
.faq-item > p{
  padding:0 1.4rem 1.2rem;
  margin:0;
  color:var(--creme-soft);
  font-size:.98rem;
  line-height:1.65;
}

/* ============ CTA FINAL ============ */
.cta-final{
  background:
    radial-gradient(ellipse at top, rgba(155,89,255,.4) 0%, transparent 60%),
    radial-gradient(ellipse at bottom, rgba(255,27,141,.3) 0%, transparent 60%),
    linear-gradient(180deg, var(--noir-deep) 0%, var(--noir) 100%);
  color:var(--creme);
  padding:5rem 0 4rem;
  text-align:center;
  position:relative;
}
.cta-final::before{
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--rose-neon) 50%, transparent 100%);
}
.cta-final-title{
  font-family:var(--serif);
  font-style:italic;
  color:var(--rose-soft);
  font-size:clamp(1.8rem, 4.5vw, 2.8rem);
  font-weight:500;
  margin-bottom:.8rem;
  margin-top:0;
  text-shadow:0 0 18px rgba(255,160,205,.4);
}
.cta-final-sub{
  color:var(--creme-soft);
  font-size:1.1rem;
  margin-bottom:2rem;
}
.cta-final-phone{
  font-family:var(--serif);
  font-size:clamp(2rem, 6vw, 3.2rem);
  font-weight:600;
  color:var(--rose-neon);
  letter-spacing:.05em;
  margin:.5rem 0 .3rem;
  text-shadow:0 0 24px rgba(255,27,141,.6);
}
.cta-final-meta{
  color:var(--creme-soft);
  opacity:.8;
  font-size:.95rem;
  margin-bottom:2rem;
}

/* ============ FOOTER ============ */
.site-footer{
  background:var(--noir-deep);
  color:var(--creme-soft);
  padding:3rem 0 7.5rem;
  font-size:.88rem;
  line-height:1.55;
  border-top:1px solid var(--rose-neon);
}
.footer-legal{
  max-width:760px;
  margin:0 auto 1rem;
  text-align:center;
  color:var(--creme-soft);
  opacity:.85;
}
.footer-legal strong{ color:var(--rose-neon); }
.footer-pricing{
  text-align:center;
  color:var(--rose-soft);
  margin:0 auto 1.6rem;
  font-weight:500;
}
.footer-nav{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:1rem 1.8rem;
  margin:1.5rem 0;
  padding:1.5rem 0;
  border-top:1px solid rgba(255,27,141,.2);
  border-bottom:1px solid rgba(255,27,141,.2);
}
.footer-nav a{
  color:var(--rose-soft);
  font-size:.9rem;
  letter-spacing:.02em;
}
.footer-nav a:hover{ color:var(--rose-neon); }
.footer-copyright{
  text-align:center;
  margin:1rem 0 0;
  font-size:.82rem;
  color:var(--creme-soft);
  opacity:.7;
}
@media(min-width:720px){
  .site-footer{ padding-bottom:3rem; }
}

/* ============ STICKY CTA ============ */
.sticky-cta{
  position:fixed;
  left:.6rem; right:.6rem; bottom:.6rem;
  display:flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.95rem 1rem;
  background:linear-gradient(135deg, var(--rose-neon) 0%, var(--violet) 100%);
  color:var(--noir);
  font-weight:700;
  font-size:.95rem;
  border-radius:var(--radius-lg);
  box-shadow:0 -4px 24px rgba(255,27,141,.5), 0 6px 16px rgba(0,0,0,.4);
  z-index:99;
  transition:transform .3s ease, opacity .3s ease;
  text-decoration:none;
  letter-spacing:.01em;
}
.sticky-cta strong{ color:var(--noir-deep); font-weight:800; }
.sticky-cta:hover{ color:var(--noir); }
.sticky-icon{ font-size:1.2rem; }
.sticky-cta:not(.is-visible){
  transform:translateY(120%);
  opacity:0;
  pointer-events:none;
}
@media(min-width:1024px){
  .sticky-cta{
    left:auto; right:1.5rem; bottom:1.5rem;
    max-width:340px;
    padding:1rem 1.4rem;
  }
}

/* ============ PAGES INTERNES ============ */
.site-header{
  background:var(--noir-deep);
  border-bottom:1px solid var(--rose-neon);
  padding:1rem 0;
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.site-header__brand{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.3rem;
  color:var(--rose-neon);
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  text-shadow:0 0 12px rgba(255,27,141,.5);
}
.site-header__brand:hover{ color:var(--rose-hot); }
.site-header__back{
  font-family:var(--sans);
  font-size:.9rem;
  color:var(--creme-soft);
  text-decoration:none;
  border:1px solid var(--rose-neon);
  padding:.5rem 1rem;
  border-radius:var(--radius);
  transition:background .2s ease;
}
.site-header__back:hover{
  background:var(--rose-neon);
  color:var(--noir);
}

.page-legal{
  padding:3rem 0 5rem;
  background:var(--noir);
}
.page-legal h1{
  font-family:var(--serif);
  color:var(--creme);
  font-size:clamp(1.8rem, 4.5vw, 2.6rem);
  margin:0 0 .5rem;
  font-weight:600;
  line-height:1.2;
}
.page-legal__lede{
  color:var(--creme-soft);
  font-size:1.05rem;
  margin:0 0 2.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--line);
}
.page-legal h2{
  font-family:var(--serif);
  color:var(--rose-neon);
  font-size:1.35rem;
  margin:2rem 0 .8rem;
  font-weight:600;
  text-shadow:0 0 8px rgba(255,27,141,.3);
}
.page-legal h2::after{ display:none; }
.page-legal p,
.page-legal li{
  color:var(--creme-soft);
  font-size:1rem;
  line-height:1.7;
}
.page-legal ul,
.page-legal ol{
  padding-left:1.4rem;
  margin:.5rem 0 1.2rem;
}
.page-legal address{
  font-style:normal;
  background:var(--noir-soft);
  padding:1rem 1.2rem;
  border-left:3px solid var(--rose-neon);
  border-radius:0 var(--radius) var(--radius) 0;
  margin:1rem 0;
  color:var(--creme);
}
.page-legal a{
  color:var(--rose-neon);
  text-decoration:underline;
  text-decoration-color:var(--violet);
  text-underline-offset:3px;
}
.page-legal a:hover{ color:var(--rose-hot); }
.page-legal strong{ color:var(--rose-neon); }
.page-legal .meta-info{
  font-size:.85rem;
  color:var(--creme-soft);
  opacity:.7;
  margin-top:3rem;
  padding-top:1rem;
  border-top:1px solid var(--line);
  font-style:italic;
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  margin:2rem 0;
}
@media(min-width:720px){
  .contact-grid{ grid-template-columns:repeat(2,1fr); }
}
.contact-card{
  background:var(--noir-soft);
  padding:1.5rem;
  border-radius:var(--radius-lg);
  border-left:4px solid var(--rose-neon);
}
.contact-card h2{
  margin-top:0 !important;
  font-size:1.2rem !important;
  color:var(--rose-neon) !important;
}
.contact-card p{ margin:.4rem 0; }

/* ============ MODAL +18 ============ */
.age-gate{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
  background:rgba(0, 0, 0, .92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  animation:gateFade .25s ease-out;
}
.age-gate[hidden]{ display:none; }
@keyframes gateFade{ from{opacity:0} to{opacity:1} }
.age-gate__panel{
  background:linear-gradient(180deg, var(--noir-soft) 0%, var(--noir) 100%);
  border:1px solid var(--rose-neon);
  border-radius:var(--radius-lg);
  padding:2.2rem 1.6rem;
  max-width:480px;
  width:100%;
  text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.7), 0 0 32px rgba(255,27,141,.3), inset 0 1px 0 rgba(255,27,141,.2);
  animation:gateUp .3s ease-out;
}
@keyframes gateUp{ from{transform:translateY(20px); opacity:0} to{transform:translateY(0); opacity:1} }
.age-gate__brand{
  font-family:var(--serif);
  font-style:italic;
  font-size:1rem;
  color:var(--rose-neon);
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 1rem;
  text-shadow:0 0 12px rgba(255,27,141,.5);
}
.age-gate__title{
  font-family:var(--serif);
  font-size:clamp(1.5rem, 4.5vw, 2rem);
  color:var(--creme);
  margin:0 0 1rem;
  font-weight:600;
}
.age-gate__text{
  color:var(--creme-soft);
  font-size:.98rem;
  line-height:1.55;
  margin:0 0 1.6rem;
}
.age-gate__text strong{ color:var(--rose-neon); }
.age-gate__actions{
  display:flex;
  flex-direction:column;
  gap:.7rem;
}
.age-gate__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.95rem 1.4rem;
  font-family:var(--sans);
  font-size:1rem;
  font-weight:600;
  border:none;
  border-radius:var(--radius-lg);
  cursor:pointer;
  text-decoration:none;
  transition:transform .15s ease, box-shadow .2s ease;
  letter-spacing:.01em;
}
.age-gate__btn--yes{
  background:linear-gradient(135deg, var(--rose-neon) 0%, var(--violet) 100%);
  color:var(--noir);
  box-shadow:var(--glow-rose), inset 0 1px 0 rgba(255,255,255,.25);
  font-weight:700;
}
.age-gate__btn--yes:hover{
  transform:translateY(-2px);
  box-shadow:0 0 32px rgba(255,27,141,.7), var(--glow-violet);
}
.age-gate__btn--no{
  background:transparent;
  color:var(--creme-soft);
  border:1px solid var(--line);
  font-weight:500;
}
.age-gate__btn--no:hover{
  background:var(--noir-soft);
  color:var(--rose-neon);
}
.age-gate__legal{
  margin:1.4rem 0 0;
  font-size:.78rem;
  color:var(--creme-soft);
  opacity:.7;
  line-height:1.45;
}
@media(min-width:520px){
  .age-gate__panel{ padding:2.5rem 2.2rem; }
  .age-gate__actions{ flex-direction:row; justify-content:center; }
  .age-gate__btn{ flex:1; max-width:200px; }
}
body.gate-active{ overflow:hidden; }

/* ============ ACCESSIBILITÉ ============ */
:focus-visible{
  outline:3px solid var(--rose-neon);
  outline-offset:3px;
  border-radius:3px;
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}
