/* ============================================
   Annuaire Sexe & Porno — Tabac & Whisky
   Tabac brun + Whisky doré + Brique brûlée + Ambre + Crème ivoire · Mobile-first
   ============================================ */

:root{
  --tabac:          #4A2E1F;
  --tabac-deep:     #2E1C12;
  --tabac-soft:     #6B4530;
  --whisky:         #C19660;
  --whisky-light:   #D4B27A;
  --whisky-deep:    #9C7240;
  --brique:         #A0432D;
  --brique-deep:    #7A2F1F;
  --ambre:          #D17B3F;
  --ambre-light:    #E8A268;
  --creme:          #F4E8D5;
  --creme-warm:     #EDD9B8;
  --noir-fume:      #1A1410;
  --noir-deep:      #0E0A07;
  --line:           rgba(193, 150, 96, .25);
  --line-strong:    rgba(193, 150, 96, .45);
  --shadow-sm:      0 2px 8px rgba(26, 20, 16, .35);
  --shadow-md:      0 8px 24px rgba(26, 20, 16, .55);
  --shadow-lg:      0 16px 48px rgba(26, 20, 16, .7);
  --glow-whisky:    0 0 22px rgba(193, 150, 96, .45);
  --glow-ambre:     0 0 22px rgba(209, 123, 63, .45);

  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Manrope', 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;
  --radius-xl: 24px;
}

*,*::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-fume);
  -webkit-font-smoothing:antialiased;
}
img,svg{ display:block; max-width:100%; height:auto; }
a{ color:var(--whisky); text-decoration:none; }
a:hover{ color:var(--whisky-light); }
button{ font-family:inherit; cursor:pointer; }
ol,ul{ padding-left:1.4rem; }

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(--whisky); font-style:italic; }
p{ margin:0 0 1em; }
strong{ color:#FFFFFF; font-weight:600; }
em{ color:var(--whisky-light); font-style:italic; }

::selection{ background:var(--whisky); color:var(--noir-fume); }

.age-banner{
  background:var(--noir-deep);
  color:var(--ambre);
  text-align:center;
  font-size:.78rem;
  padding:.5rem 1rem;
  letter-spacing:.02em;
  border-bottom:1px solid var(--whisky);
}
.age-banner strong{ color:var(--whisky); font-weight:700; }

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

.hero{
  position:relative;
  background:
    radial-gradient(ellipse at top right, rgba(193,150,96,.5) 0%, transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(160,67,45,.45) 0%, transparent 60%),
    linear-gradient(135deg, var(--noir-fume) 0%, var(--tabac) 50%, var(--brique) 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(26,20,16,0) 0%, rgba(26,20,16,0) 55%, rgba(26,20,16,.85) 100%);
  pointer-events:none;
}
.hero-image img{ width:100%; height:100%; object-fit:cover; object-position:center 25%; filter:contrast(1.05) saturate(1.05); }
.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(--whisky);
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 .8rem;
  text-shadow:0 0 12px rgba(193,150,96,.4);
}
.hero h1{
  color:#FFFFFF;
  font-size:clamp(2.1rem, 6vw, 3.4rem);
  font-weight:600;
  text-shadow:0 2px 18px rgba(0,0,0,.6);
}
.hero h1 .accent{
  color:var(--whisky);
  font-style:italic;
  font-weight:700;
  text-shadow:0 0 18px rgba(193,150,96,.55);
}
.hero-sub{
  font-size:1.1rem;
  color:var(--creme-warm);
  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:700;
  color:#FFFFFF;
  letter-spacing:.04em;
  text-shadow:0 0 18px rgba(193,150,96,.45);
}
.phone-meta{ font-size:.85rem; color:var(--creme-warm); 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 30%; }
  .hero-image::after{
    background:linear-gradient(90deg, rgba(26,20,16,0) 60%, rgba(26,20,16,.55) 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; }
}

.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:700;
  font-size:1.05rem;
  border-radius:var(--radius-xl);
  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(--whisky) 0%, var(--brique) 100%);
  color:#FFFFFF;
  box-shadow:var(--glow-whisky), inset 0 1px 0 rgba(255,255,255,.25);
  font-size:1.15rem;
  padding:1.1rem 2rem;
}
.btn-cta-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 32px rgba(193,150,96,.65), inset 0 1px 0 rgba(255,255,255,.25);
  color:#FFFFFF;
}

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

.btn-cta-final{
  background:linear-gradient(135deg, var(--whisky) 0%, var(--ambre) 100%);
  color:var(--noir-fume);
  font-size:1.2rem;
  padding:1.2rem 2.4rem;
  box-shadow:var(--glow-whisky), 0 8px 28px rgba(0,0,0,.6);
}
.btn-cta-final:hover{
  transform:translateY(-2px);
  box-shadow:0 0 38px rgba(193,150,96,.75), 0 8px 28px rgba(0,0,0,.6);
  color:var(--noir-fume);
}

.trust-bar{
  background:var(--tabac-deep);
  border-top:1px solid var(--whisky);
  border-bottom:1px solid var(--whisky);
  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(--whisky), var(--ambre), var(--brique), 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; filter:drop-shadow(0 0 12px rgba(193,150,96,.5)); }
.trust-title{
  font-size:1.15rem;
  font-family:var(--serif);
  color:var(--whisky);
  margin:0 0 .3rem;
  font-weight:700;
}
.trust-item p{ font-size:.92rem; color:var(--creme-warm); margin:0; line-height:1.45; }

.section{ padding:var(--section-y) 0; background:var(--noir-fume); }
.section-alt{ background:var(--tabac-deep); }
.section h2{
  position:relative;
  padding-bottom:.6rem;
  margin-bottom:1.6rem;
  color:#FFFFFF;
}
.section h2::after{
  content:'';
  position:absolute;
  left:0; bottom:0;
  width:80px; height:3px;
  background:linear-gradient(90deg, var(--whisky) 0%, var(--brique) 100%);
}
.section p{ color:var(--creme-warm); font-size:1.05rem; line-height:1.75; }
.section p strong{ color:#FFFFFF; }
@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{ margin:0; width:100%; overflow:hidden; }
.figure-mood img{
  width:100%; height:auto;
  max-height:520px;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
}

.specialty{
  margin:2rem 0;
  padding:1.6rem 1.8rem;
  background:var(--tabac);
  border-left:4px solid var(--whisky);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  box-shadow:var(--shadow-sm);
}
.section-alt .specialty{ background:var(--tabac-soft); }
.specialty h3{ font-style:italic; margin-bottom:.6rem; color:var(--whisky); }
.specialty p{ color:var(--creme-warm); }
.specialty p:last-child{ margin-bottom:0; }
.specialty strong{ color:#FFFFFF; }

.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(--tabac);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  font-size:1rem;
  color:var(--creme-warm);
  border:1px solid var(--line);
}
.section-alt .steps li{ background:var(--tabac-soft); }
.steps li strong{ color:#FFFFFF; }
.steps li::before{
  content:counter(step);
  position:absolute;
  left:.8rem; top:50%; transform:translateY(-50%);
  width:2rem; height:2rem;
  background:linear-gradient(135deg, var(--whisky) 0%, var(--ambre) 100%);
  color:var(--noir-fume);
  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-whisky);
}
.inline-num{
  font-family:var(--serif);
  font-weight:700;
  color:var(--whisky);
  white-space:nowrap;
  border-bottom:2px solid var(--ambre);
}

.cta-mid{
  background:linear-gradient(135deg, var(--brique-deep) 0%, var(--noir-fume) 50%, var(--whisky-deep) 100%);
  padding:2.5rem 0;
  text-align:center;
  color:#FFFFFF;
  position:relative;
}
.cta-mid::before{
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse at center, rgba(193,150,96,.2) 0%, transparent 70%);
  pointer-events:none;
}
.cta-mid-text{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.5rem;
  color:#FFFFFF;
  margin:0 0 1.2rem;
  position:relative;
  text-shadow:0 0 18px rgba(193,150,96,.4);
}

.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(--tabac);
  border-radius:var(--radius-xl);
  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(--whisky);
  box-shadow:var(--glow-whisky);
  object-fit:cover;
}
.avatar-fallback{
  background:linear-gradient(135deg, var(--brique) 0%, var(--whisky-deep) 100%);
  color:#FFFFFF;
  font-family:var(--serif);
  font-size:2.4rem;
  font-weight:700;
  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(--whisky);
  font-weight:500;
  letter-spacing:.02em;
}
.testimonial figcaption strong{ color:#FFFFFF; }

.rating{
  font-size:1.05rem;
  color:var(--ambre);
  letter-spacing:.15em;
  margin:.3rem 0 .6rem;
  text-shadow:0 0 12px rgba(209,123,63,.45);
}

.faq-item{
  margin:.5rem 0;
  background:var(--tabac);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.section-alt .faq-item{ background:var(--tabac-soft); }
.faq-item[open]{ box-shadow:var(--shadow-sm); border-color:var(--line-strong); }
.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(--whisky);
  transition:transform .25s ease;
  line-height:1;
}
.faq-item[open] summary::after{
  transform:translateY(-50%) rotate(45deg);
  color:var(--ambre);
}
.faq-item summary:hover{ background:rgba(193,150,96,.06); }
.faq-item summary h3{
  display:inline;
  font-family:var(--sans);
  font-size:1rem;
  font-weight:600;
  color:#FFFFFF;
  margin:0;
  font-style:normal;
}
.faq-item > p{
  padding:0 1.4rem 1.2rem;
  margin:0;
  color:var(--creme-warm);
  font-size:.98rem;
  line-height:1.65;
}
.faq-item > p strong{ color:#FFFFFF; }

.cta-final{
  background:
    radial-gradient(ellipse at top, rgba(193,150,96,.45) 0%, transparent 60%),
    radial-gradient(ellipse at bottom, rgba(160,67,45,.4) 0%, transparent 60%),
    linear-gradient(180deg, var(--noir-deep) 0%, var(--tabac) 100%);
  color:#FFFFFF;
  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(--whisky) 50%, transparent 100%);
}
.cta-final-title{
  font-family:var(--serif);
  font-style:italic;
  color:var(--whisky);
  font-size:clamp(1.8rem, 4.5vw, 2.8rem);
  font-weight:600;
  margin-bottom:.8rem;
  margin-top:0;
  text-shadow:0 0 22px rgba(193,150,96,.55);
}
.cta-final-sub{
  color:var(--creme-warm);
  font-size:1.1rem;
  margin-bottom:2rem;
}
.cta-final-phone{
  font-family:var(--serif);
  font-size:clamp(2rem, 6vw, 3.2rem);
  font-weight:700;
  color:#FFFFFF;
  letter-spacing:.05em;
  margin:.5rem 0 .3rem;
  text-shadow:0 0 26px rgba(193,150,96,.5);
}
.cta-final-meta{ color:var(--creme-warm); opacity:.85; font-size:.95rem; margin-bottom:2rem; }

.site-footer{
  background:var(--noir-deep);
  color:var(--creme-warm);
  padding:3rem 0 7.5rem;
  font-size:.88rem;
  line-height:1.55;
  border-top:1px solid var(--line);
}
.footer-legal{ max-width:760px; margin:0 auto 1rem; text-align:center; opacity:.9; }
.footer-legal strong{ color:var(--whisky); }
.footer-pricing{ text-align:center; color:var(--whisky); 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 var(--line);
  border-bottom:1px solid var(--line);
}
.footer-nav a{ color:var(--whisky); font-size:.9rem; letter-spacing:.02em; }
.footer-nav a:hover{ color:#FFFFFF; }
.footer-copyright{ text-align:center; margin:1rem 0 0; font-size:.82rem; opacity:.7; font-style:italic; font-family:var(--serif); }
@media(min-width:720px){ .site-footer{ padding-bottom:3rem; } }

.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(--whisky) 0%, var(--brique) 100%);
  color:#FFFFFF;
  font-weight:700;
  font-size:.95rem;
  border-radius:var(--radius-xl);
  box-shadow:0 -4px 24px rgba(193,150,96,.45), 0 6px 16px rgba(0,0,0,.6);
  z-index:99;
  transition:transform .3s ease, opacity .3s ease;
  text-decoration:none;
  letter-spacing:.01em;
}
.sticky-cta strong{ color:#FFFFFF; font-weight:800; }
.sticky-cta:hover{ color:#FFFFFF; }
.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;
  }
}

.site-header{
  background:linear-gradient(135deg, var(--tabac-deep) 0%, var(--brique-deep) 100%);
  border-bottom:1px solid var(--whisky);
  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:#FFFFFF;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  text-shadow:0 0 12px rgba(0,0,0,.3);
}
.site-header__brand:hover{ color:var(--whisky); }
.site-header__back{
  font-family:var(--sans);
  font-size:.9rem;
  color:#FFFFFF;
  text-decoration:none;
  border:1px solid var(--whisky);
  padding:.5rem 1rem;
  border-radius:var(--radius);
  background:rgba(255,255,255,.08);
}
.site-header__back:hover{ background:var(--whisky); color:var(--noir-fume); }

.page-legal{ padding:3rem 0 5rem; background:var(--noir-fume); }
.page-legal h1{
  font-family:var(--serif);
  color:#FFFFFF;
  font-size:clamp(1.8rem, 4.5vw, 2.6rem);
  margin:0 0 .5rem;
  font-weight:600;
}
.page-legal__lede{
  color:var(--creme-warm);
  font-size:1.05rem;
  margin:0 0 2.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--line);
  font-style:italic;
  font-family:var(--serif);
}
.page-legal h2{
  font-family:var(--serif);
  color:var(--whisky);
  font-size:1.35rem;
  margin:2rem 0 .8rem;
  font-weight:600;
  font-style:normal;
}
.page-legal h2::after{ display:none; }
.page-legal p, .page-legal li{ color:var(--creme-warm); 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(--tabac);
  padding:1rem 1.2rem;
  border-left:3px solid var(--whisky);
  border-radius:0 var(--radius) var(--radius) 0;
  margin:1rem 0;
  color:var(--creme);
}
.page-legal a{
  color:var(--whisky);
  text-decoration:underline;
  text-decoration-color:var(--ambre);
  text-underline-offset:3px;
}
.page-legal a:hover{ color:var(--whisky-light); }
.page-legal strong{ color:#FFFFFF; }
.page-legal .meta-info{
  font-size:.85rem;
  color:var(--creme-warm);
  opacity:.7;
  margin-top:3rem;
  padding-top:1rem;
  border-top:1px solid var(--line);
  font-style:italic;
}

.age-gate{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex; align-items:center; justify-content:center;
  padding:1rem;
  background:rgba(14,10,7,.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  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(--tabac) 0%, var(--tabac-deep) 100%);
  border:1px solid var(--whisky);
  border-radius:var(--radius-xl);
  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(193,150,96,.3), inset 0 1px 0 rgba(255,255,255,.05);
  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(--whisky);
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 1rem;
}
.age-gate__title{
  font-family:var(--serif);
  font-size:clamp(1.5rem, 4.5vw, 2rem);
  color:#FFFFFF;
  margin:0 0 1rem;
  font-weight:600;
  font-style:normal;
}
.age-gate__text{ color:var(--creme-warm); font-size:.98rem; line-height:1.55; margin:0 0 1.6rem; }
.age-gate__text strong{ color:#FFFFFF; }
.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:700;
  border:none;
  border-radius:var(--radius-xl);
  cursor:pointer;
  text-decoration:none;
  transition:transform .15s ease, box-shadow .2s ease;
}
.age-gate__btn--yes{
  background:linear-gradient(135deg, var(--whisky) 0%, var(--brique) 100%);
  color:#FFFFFF;
  box-shadow:var(--glow-whisky), inset 0 1px 0 rgba(255,255,255,.25);
}
.age-gate__btn--yes:hover{
  transform:translateY(-2px);
  box-shadow:0 0 32px rgba(193,150,96,.7), inset 0 1px 0 rgba(255,255,255,.25);
}
.age-gate__btn--no{
  background:transparent;
  color:var(--creme-warm);
  border:1px solid var(--line);
  font-weight:500;
}
.age-gate__btn--no:hover{ background:var(--tabac-soft); color:var(--whisky); }
.age-gate__legal{ margin:1.4rem 0 0; font-size:.78rem; color:var(--creme-warm); 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; }

.page-404{display:flex;align-items:center;justify-content:center;min-height:70vh;text-align:center;padding:40px 20px}
.page-404 h1{font-size:clamp(3rem,10vw,6rem);color:var(--whisky);margin:0 0 12px;letter-spacing:.05em}
.page-404 h1::after{display:none}
.page-404 h2{margin:0 0 20px;font-size:1.5rem;color:#FFFFFF}
.page-404 p{color:var(--creme-warm);max-width:480px;margin:0 auto 28px}

:focus-visible{ outline:3px solid var(--whisky); 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;
  }
}
