:root{
  --bg:#fbf7f4;
  --bg-alt:#f3e9e3;
  --ink:#2c2422;
  --muted:#8a7c74;
  --rose:#c98a7a;
  --rose-dark:#a96b5c;
  --gold:#b9986a;
  --line:#e6d8cf;
  --white:#fff;
  --radius:14px;
  --shadow:0 18px 40px -20px rgba(80,50,40,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Heebo",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-weight:300;
}
h1,h2,h3,.brand-name{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;line-height:1.15}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1140px,92vw);margin-inline:auto}
.narrow{width:min(720px,92vw)}
.section{padding:92px 0}
.section-alt{background:var(--bg-alt)}
.seo-block{background:var(--bg-alt);padding:.8rem 0;text-align:center;font-size:.82rem;color:var(--muted);border-bottom:1px solid var(--line)}
.seo-block p{margin:0;line-height:1.5}
.eyebrow{
  text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;
  color:var(--gold);font-weight:500;margin-bottom:.6rem
}
.eyebrow.center,.center{text-align:center}
.section-title{font-size:clamp(2rem,4vw,3rem);text-align:center;margin-bottom:2.4rem}
.section-title.left{text-align:start;margin-bottom:1.2rem}
.muted{color:var(--muted)}
.note{text-align:center;color:var(--muted);font-size:.92rem;margin-top:1.8rem}

/* sticky top wrapper (header + promo banner) */
.site-top{position:sticky;top:0;z-index:50}

/* header */
.site-header{
  position:relative;z-index:10;
  background:rgba(251,247,244,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s, background .3s
}
.site-header.scrolled{
  background:rgba(251,247,244,.97);
  box-shadow:0 4px 24px -8px rgba(44,36,34,.15)
}
.nav{display:flex;align-items:center;justify-content:flex-end;position:relative;height:114px;transition:height .3s;gap:1.8rem}
.site-header.scrolled .nav{height:80px}
.brand{
  display:flex;align-items:center;gap:.6rem;
  position:absolute;left:50%;transform:translateX(-50%)
}
.brand-fallback{display:flex;align-items:center;gap:.7rem}
.brand-mark{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#9b7a4a,var(--gold) 55%,#dfc07a);
  color:#fff;display:grid;place-items:center;font-family:"Cormorant Garamond",serif;
  font-size:1.35rem;font-weight:600
}
.brand-info{display:flex;flex-direction:column;line-height:1.1}
.brand-name{
  font-family:"Cormorant Garamond",serif;font-size:.95rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink)
}
.brand-tagline{
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);font-weight:400;margin-top:.1rem
}
.nav-links{display:flex;align-items:center;gap:1.8rem}
.nav-links>a{font-size:.95rem;letter-spacing:.02em;position:relative;padding:.2rem 0}
.nav-links>a::after{
  content:"";position:absolute;inset-inline-start:0;bottom:-3px;height:1.5px;width:0;
  background:var(--rose);transition:width .25s
}
.nav-links>a:hover::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* language switch */
.lang-switch{position:relative}
.lang-btn{
  display:flex;align-items:center;gap:.4rem;background:none;border:1px solid var(--line);
  padding:.45rem .8rem;border-radius:999px;cursor:pointer;font:inherit;font-size:.85rem;color:var(--ink)
}
.lang-btn svg{transition:transform .25s}
.lang-switch.open .lang-btn svg{transform:rotate(180deg)}
.lang-menu{
  position:absolute;inset-inline-end:0;top:120%;list-style:none;
  background:var(--white);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);min-width:150px;padding:.4rem;opacity:0;visibility:hidden;
  transform:translateY(-6px);transition:.2s;z-index:20;
}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu button{
  width:100%;text-align:start;background:none;border:0;padding:.6rem .8rem;
  border-radius:8px;cursor:pointer;font:inherit;font-size:.92rem;color:var(--ink)
}
.lang-menu button:hover,.lang-menu button.active{background:var(--bg-alt);color:var(--rose-dark)}

/* hero */
.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  background-color:#e9d4ca;
  background-image:url('assets/hero-poster.jpg');
  background-size:cover;background-position:center top;
  overflow:hidden
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 75% 30%,rgba(201,138,122,.35),transparent 55%);
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;opacity:0;
  transition:opacity .8s ease
}
.hero-video.loaded{opacity:1}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(15,10,8,.55) 0%,
    rgba(15,10,8,.35) 50%,
    rgba(15,10,8,.7) 100%
  )
}
.hero-content{position:relative;z-index:2}
.hero.has-video{background-color:#1e120e}
.hero-content{position:relative;max-width:680px;padding:60px 0}

/* hero text — base */
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);margin:.4rem 0 1.1rem}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:1.15rem;color:#5c4c45;margin-bottom:2.2rem;max-width:540px}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* hero text over video */
.hero.has-video h1{
  color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.5);
}
.hero.has-video .hero-sub{
  color:rgba(255,255,255,.88);
  text-shadow:0 1px 8px rgba(0,0,0,.4);
}
.hero.has-video .eyebrow{
  color:var(--gold);
  letter-spacing:.28em;
}
.hero.has-video .btn-ghost{
  border-color:rgba(255,255,255,.7);
  color:#fff;
  backdrop-filter:blur(4px);
}
.hero.has-video .btn-ghost:hover{
  background:rgba(255,255,255,.15);
  border-color:#fff;
}
.hero.has-video .btn-primary{
  box-shadow:0 12px 30px -10px rgba(0,0,0,.5);
}

/* buttons */
.btn{
  display:inline-block;padding:.95rem 2rem;border-radius:999px;font-size:.95rem;
  font-weight:500;letter-spacing:.03em;cursor:pointer;border:1.5px solid transparent;
  transition:transform .2s,box-shadow .2s,background .2s
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--rose);color:#fff;box-shadow:0 12px 26px -12px var(--rose-dark)}
.btn-primary:hover{background:var(--rose-dark)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn.full{width:100%;text-align:center}
.btn-whatsapp{background:#25d366;color:#fff;margin-top:1.4rem;display:inline-flex;align-items:center;justify-content:center;gap:.6rem}
.btn-whatsapp:hover{background:#1ebe5a}

/* services */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.6rem}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.8rem;text-align:center;transition:transform .25s,box-shadow .25s
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card h3{font-size:1.6rem;margin-bottom:.4rem}
.card .price{font-size:1.7rem;color:var(--rose-dark);font-family:"Cormorant Garamond",serif;font-weight:600}
.card .dur{display:block;color:var(--muted);font-size:.85rem;margin:.4rem 0 1rem}
.card p{color:var(--muted);font-size:.95rem}

/* gallery */
.gallery-item{
  position:relative;overflow:hidden;border-radius:var(--radius);
  aspect-ratio:1/1;cursor:zoom-in
}
.gallery-empty{
  grid-column:1/-1;text-align:center;
  padding:4rem 2rem;
  color:var(--muted);font-size:1.1rem;letter-spacing:.04em
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 30%;
  transition:transform .45s ease
}
.gallery-item:hover img{transform:scale(1.06)}

/* lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:200;
  display:none;align-items:center;justify-content:center;padding:1rem
}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:10px}
.lightbox-close{
  position:absolute;top:18px;inset-inline-end:22px;background:none;border:0;
  color:#fff;font-size:2.2rem;cursor:pointer;line-height:1
}
.lightbox-prev,.lightbox-next{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.15);border:0;color:#fff;font-size:2rem;
  cursor:pointer;padding:.6rem 1rem;border-radius:8px
}
.lightbox-prev{inset-inline-start:12px}
.lightbox-next{inset-inline-end:12px}

.insta-cta-block{text-align:center;margin-top:2rem}

/* about */
.about{display:grid;grid-template-columns:1fr 1fr;gap:3.4rem;align-items:center}
.about-img{
  border-radius:var(--radius);min-height:420px;box-shadow:var(--shadow);
  background:linear-gradient(135deg,#d9b8ac,#c98a7a);position:relative;overflow:hidden
}
.about-img img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  position:absolute;inset:0;display:block
}
.about-text p{margin-bottom:1rem;color:#5c4c45}
.badges{list-style:none;margin-top:1.6rem;display:grid;gap:.75rem}
.badges li{
  display:flex;align-items:center;gap:.75rem;
  color:var(--ink);font-size:.95rem
}
.badges li::before{
  content:"";flex-shrink:0;width:22px;height:22px;border-radius:50%;
  background:var(--rose) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath d='M1.5 5L4.5 8L10.5 1.5' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") no-repeat center;
  background-size:11px 9px
}

/* form */
.form{display:grid;gap:1.1rem;margin-top:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form label{display:grid;gap:.4rem;font-size:.9rem;color:var(--muted)}
.form input,.form select,.form textarea{
  font:inherit;font-size:1rem;color:var(--ink);padding:.85rem 1rem;
  border:1px solid var(--line);border-radius:10px;background:var(--white);
  width:100%;box-sizing:border-box;min-width:0
}
.form input[type="date"]{
  -webkit-appearance:none;appearance:none;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:var(--rose);box-shadow:0 0 0 3px rgba(201,138,122,.15)
}

/* contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-list{list-style:none;margin:1.4rem 0;display:grid;gap:1.1rem}
.contact-list li{display:grid;gap:.15rem}
.contact-list strong{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold)}
.contact-map iframe{width:100%;height:380px;border:0;border-radius:var(--radius);box-shadow:var(--shadow)}

/* social links */
.social-links{display:flex;gap:1.2rem;margin-top:1.2rem;flex-wrap:wrap}
.social-link{display:flex;align-items:center;gap:.5rem;color:var(--ink);font-size:.92rem;transition:color .2s}
.social-link:hover{color:var(--rose)}

/* referral banner (inside contact section) */
.referral-banner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.1rem 1.6rem;
  margin-top:2rem;
  flex-wrap:wrap;
}
.referral-banner-info{
  display:flex;
  align-items:center;
  gap:.6rem;
  font-size:1rem;
  font-weight:600;
  color:var(--ink);
}
.referral-offer{
  display:inline-block;
  background:linear-gradient(135deg,var(--rose),var(--gold));
  color:#fff;
  font-weight:600;
  font-size:.9rem;
  padding:.4rem 1.1rem;
  border-radius:999px;
  letter-spacing:.02em;
  white-space:normal;
  word-break:break-word;
  text-align:center;
}
.referral-banner-btn{margin-top:0!important}

/* promo timer banner */
.promo-banner{
  background:linear-gradient(90deg,var(--rose-dark) 0%,var(--gold) 100%);
  color:#fff;
  padding:.45rem 1rem;
  position:relative;
  z-index:1;
  text-align:center;
}
.promo-banner-inner{
  display:inline-flex;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
  justify-content:center;
}
.promo-label{font-size:.82rem;font-weight:500;letter-spacing:.01em}
/* clock */
.promo-clock{
  display:flex;
  align-items:center;
  gap:3px;
}
.promo-clock-unit{
  display:flex;
  flex-direction:column;
  align-items:center;
  background:rgba(0,0,0,.22);
  border-radius:5px;
  padding:.15rem .5rem;
  min-width:34px;
}
.promo-clock-num{
  font-size:1.15rem;
  font-weight:700;
  line-height:1.1;
  font-variant-numeric:tabular-nums;
  letter-spacing:.02em;
}
.promo-clock-lbl{
  font-size:.5rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  opacity:.85;
}
.promo-clock-sep{
  font-size:1rem;
  font-weight:700;
  margin-bottom:.7rem;
  opacity:.7;
}
.promo-banner-cta{
  color:#fff;
  font-weight:600;
  border:1px solid rgba(255,255,255,.6);
  border-radius:999px;
  padding:.25rem 1rem;
  font-size:.78rem;
  white-space:nowrap;
  transition:background .2s;
}
.promo-banner-cta:hover{background:rgba(255,255,255,.2)}
.promo-banner-close{
  position:absolute;
  inset-inline-end:.7rem;
  top:50%;
  transform:translateY(-50%);
  background:none;
  border:none;
  color:rgba(255,255,255,.8);
  font-size:1.1rem;
  cursor:pointer;
  padding:.2rem .4rem;
  line-height:1;
}
.promo-banner-close:hover{color:#fff}

/* footer */
.site-footer{background:var(--ink);color:#e9ddd6;padding:34px 0}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem;font-size:.9rem}
.footer-social{display:flex;gap:1rem}
.footer-social a{color:#e9ddd6;opacity:.7;transition:opacity .2s}
.footer-social a:hover{opacity:1}

/* ===== zone desservie ===== */
.zone-section{background:var(--bg)}
.zone-desc{text-align:center;margin-bottom:2rem;font-size:.98rem}
.zone-cities{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;
  margin-top:1.2rem
}
.zone-chip{
  background:var(--white);border:1.5px solid var(--line);
  border-radius:999px;padding:.45rem 1.2rem;
  font-size:.88rem;color:var(--ink);letter-spacing:.04em;
  font-family:"Heebo",sans-serif;direction:rtl
}
.zone-chip--all{
  background:var(--primary);border-color:var(--primary);
  color:#fff;font-weight:600
}

/* brand logo */
.brand-logo{height:100px;width:auto;object-fit:contain;transition:height .3s}
.site-header.scrolled .brand-logo{height:68px}

/* floating whatsapp */
@keyframes wa-pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.12)}
}
@keyframes wa-ring{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(1.9);opacity:0}
}
.float-whatsapp{
  position:fixed;inset-inline-end:22px;bottom:22px;width:56px;height:56px;
  background:#25d366;color:#fff;border-radius:50%;display:grid;place-items:center;
  box-shadow:0 8px 24px -6px rgba(37,211,102,.5);z-index:60;
  animation:wa-pulse 1.6s ease-in-out infinite;
  will-change:transform
}
.float-whatsapp::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:#25d366;z-index:-1;
  animation:wa-ring 1.6s ease-out infinite
}
.float-whatsapp:hover{animation:none;transform:scale(1.08)}
.float-whatsapp:hover::before{animation:none}

/* ===== WhatsApp chat bubble ===== */
@keyframes wa-bubble-in{
  from{opacity:0;transform:translateY(16px) scale(.93)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes typing-dot{
  0%,60%,100%{transform:translateY(0);opacity:.35}
  30%{transform:translateY(-5px);opacity:1}
}
.wa-bubble{
  position:fixed;inset-inline-end:90px;bottom:22px;
  width:290px;background:#fff;border-radius:16px;
  box-shadow:0 12px 40px rgba(0,0,0,.22);z-index:61;
  overflow:hidden;
  animation:wa-bubble-in .38s cubic-bezier(.22,.68,0,1.2) both;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif
}
/* header */
.wa-bubble-header{
  background:#075e54;padding:.6rem .9rem;
  display:flex;align-items:center;gap:.7rem;position:relative
}
.wa-bubble-close{
  position:absolute;top:6px;inset-inline-end:8px;
  background:none;border:none;color:rgba(255,255,255,.65);
  font-size:1.2rem;cursor:pointer;line-height:1;padding:2px 8px;
  transition:color .15s
}
.wa-bubble-close:hover{color:#fff}
.wa-bubble-avatar{
  width:40px;height:40px;border-radius:50%;
  flex-shrink:0;position:relative;overflow:visible
}
.wa-bubble-avatar img{
  width:40px;height:40px;border-radius:50%;
  object-fit:cover;object-position:top;display:block
}
.wa-online-dot{
  position:absolute;bottom:1px;inset-inline-end:1px;
  width:11px;height:11px;border-radius:50%;
  background:#25d366;border:2px solid #075e54
}
.wa-bubble-info strong{
  display:block;color:#fff;font-size:.9rem;font-weight:600;line-height:1.2
}
.wa-bubble-info span{color:rgba(255,255,255,.72);font-size:.73rem}
/* chat body — WhatsApp wallpaper bg */
.wa-bubble-body{
  background:#e5ddd5;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9b99a' fill-opacity='0.15'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  padding:.85rem .9rem;min-height:72px;
  display:flex;flex-direction:column;gap:.5rem
}
.wa-bubble-msg-wrap{display:flex;flex-direction:column;align-items:flex-start}
/* typing indicator */
.wa-bubble-typing{
  background:#fff;border-radius:0 10px 10px 10px;
  padding:.55rem .75rem;display:inline-flex;gap:5px;align-items:center;
  box-shadow:0 1px 2px rgba(0,0,0,.12)
}
.wa-bubble-typing span{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:#90a4ae;animation:typing-dot 1.3s infinite ease-in-out
}
.wa-bubble-typing span:nth-child(2){animation-delay:.18s}
.wa-bubble-typing span:nth-child(3){animation-delay:.36s}
/* message bubble */
.wa-bubble-msg{
  background:#fff;border-radius:0 10px 10px 10px;
  padding:.6rem .75rem .4rem;font-size:.875rem;line-height:1.5;
  color:#111;max-width:100%;
  box-shadow:0 1px 2px rgba(0,0,0,.12);
  position:relative
}
/* little tail on the bubble */
.wa-bubble-msg::before{
  content:'';position:absolute;top:0;inset-inline-start:-8px;
  width:0;height:0;
  border-top:8px solid #fff;
  border-inline-start:8px solid transparent
}
.wa-bubble-meta{
  display:flex;align-items:center;justify-content:flex-end;
  gap:.3rem;margin-top:.25rem
}
.wa-bubble-time{font-size:.68rem;color:#999}
.wa-bubble-check{font-size:.72rem;color:#4fc3f7;letter-spacing:-.05em}
/* CTA button */
.wa-bubble-cta{
  display:flex;align-items:center;justify-content:center;gap:.45rem;
  background:#25d366;color:#fff;
  padding:.75rem;font-size:.88rem;font-weight:600;
  text-decoration:none;letter-spacing:.01em;transition:background .15s
}
.wa-bubble-cta::before{content:'';display:inline-block;width:18px;height:18px;flex-shrink:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 32 32' fill='white' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 3C9 3 3.5 8.5 3.5 15.5c0 2.4.7 4.7 1.9 6.7L3 29l7-1.8c1.9 1 4 1.6 6 1.6 7 0 12.5-5.5 12.5-12.5S23 3 16 3z'/%3E%3C/svg%3E") center/contain no-repeat}
.wa-bubble-cta:hover{background:#1ebe5a;color:#fff}
/* quiz */
.wa-bubble-quiz{padding:.7rem .9rem .5rem;background:#e5ddd5}
.wa-quiz-q{font-size:.82rem;color:#555;margin-bottom:.55rem;text-align:center}
.wa-quiz-btns{display:flex;gap:.5rem;justify-content:center}
.wa-quiz-btn{
  flex:1;padding:.55rem .4rem;border:none;border-radius:50px;
  background:#fff;color:#111;font-size:.8rem;font-weight:600;
  cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.12);
  transition:background .15s,transform .1s
}
.wa-quiz-btn:hover{background:#25d366;color:#fff;transform:scale(1.04)}
/* LTR message tail (FR/EN/RU) */
.wa-bubble-msg--ltr::before{
  inset-inline-start:auto;inset-inline-end:-8px;
  border-top:8px solid #fff;
  border-inline-start:none;
  border-inline-end:8px solid transparent
}
/* ===== Online + spots badge ===== */
@keyframes badge-in{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes dot-blink{
  0%,100%{opacity:1}
  50%{opacity:.3}
}
.online-badge{
  position:fixed;inset-inline-end:18px;bottom:88px;
  background:#fff;border-radius:50px;
  padding:.38rem .85rem .38rem .65rem;
  display:flex;align-items:center;gap:.45rem;
  box-shadow:0 4px 18px rgba(0,0,0,.14);
  z-index:59;cursor:default;
  animation:badge-in .4s .5s cubic-bezier(.22,.68,0,1.2) both;
  white-space:nowrap
}
.online-badge-dot{
  width:9px;height:9px;border-radius:50%;
  background:#25d366;flex-shrink:0;
  animation:dot-blink 2s infinite
}
.online-badge-text{
  font-size:.75rem;font-weight:500;color:#222;
  letter-spacing:.01em
}
@media(max-width:560px){
  .online-badge{inset-inline-end:12px;bottom:82px;font-size:.72rem}
}

/* WhatsApp bubble — mobile */
@media(max-width:560px){
  .wa-bubble{
    /* popup au-dessus du bouton flottant, pas en pleine largeur */
    inset-inline-end:8px;
    bottom:90px;
    width:calc(100vw - 16px);
    max-width:320px;
    border-radius:16px;
  }
  /* bug 3 — boutons quiz en colonne pour éviter le wrap sur petits écrans */
  .wa-quiz-btns{flex-direction:column}
  .wa-quiz-btn{width:100%}
}
.float-whatsapp.bar-up{bottom:78px;transition:transform .2s, bottom .4s cubic-bezier(.22,.68,0,1.2)}

/* ===== hero social proof badge ===== */
.hero-proof{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:1.2rem;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:50px;padding:.4rem 1rem;backdrop-filter:blur(8px)}
.hero-proof-stars{color:#d4a843;font-size:.95rem;letter-spacing:.05em}
.hero-proof-text{font-size:.83rem;color:rgba(255,255,255,.9)}

/* ===== hero scarcity ===== */
.hero-scarcity{margin-top:.9rem;font-size:.8rem;
  color:rgba(255,255,255,.55);letter-spacing:.1em;text-transform:uppercase}

/* ===== trust strip ===== */
.trust-strip{background:var(--white);border-bottom:1px solid var(--line);overflow:hidden}
.trust-strip-inner{display:flex;align-items:stretch;justify-content:center;flex-wrap:wrap}
.trust-cell{display:flex;align-items:center;gap:.7rem;
  padding:1.15rem 2rem;border-inline-end:1px solid var(--line);font-size:.88rem}
.trust-cell:last-child{border-inline-end:none}
.trust-icon{width:36px;height:36px;border-radius:50%;
  background:var(--bg-alt);display:grid;place-items:center;
  font-size:1rem;flex-shrink:0}
.trust-cell strong{display:block;font-weight:500;color:var(--ink);font-size:.9rem}
.trust-cell span{color:var(--muted);font-size:.8rem}
@media(max-width:640px){
  .trust-strip-inner{flex-direction:column}
  .trust-cell{border-inline-end:none;border-bottom:1px solid var(--line)}
  .trust-cell:last-child{border-bottom:none}
}

/* ===== scroll reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .65s ease,transform .65s ease}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .65s ease,transform .65s ease}
.reveal-right.visible{opacity:1;transform:none}

/* ===== stats ===== */
.section-stats{
  background:linear-gradient(135deg,var(--ink) 0%,#3d2c28 100%);
  padding:64px 0
}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.4rem;text-align:center}
.stat-item{padding:1.6rem 1rem}
.stat-num{
  font-family:"Cormorant Garamond",serif;font-size:3.2rem;font-weight:600;
  color:var(--gold);line-height:1;display:block
}
.stat-label{color:#e9ddd6;font-size:.88rem;letter-spacing:.08em;margin-top:.5rem;display:block}

/* ===== All sections always visible — reveal only on sub-elements ===== */
section{opacity:1 !important;transform:none !important}
.hero-content,.hero-visual{opacity:1 !important;transform:none !important}

/* ===== reviews — 3-column vertical scroll ===== */
.reviews-carousel-wrapper{
  margin-top:.5rem
}
/* reviewsGrid (#reviews-track) IS the 3-col grid container */
.reviews-track{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.4rem;
  height:660px;
  overflow:hidden
}
.reviews-col{
  overflow:hidden;
  height:100%;
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(to bottom,transparent,#000 10%,#000 90%,transparent)
}
.reviews-col-track{
  display:flex;flex-direction:column;gap:1.2rem;
  will-change:transform
}
.review-card{
  flex-shrink:0;width:100%;
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem 1.6rem;display:flex;flex-direction:column;gap:.6rem
}
.stars{color:var(--gold);font-size:1.1rem;letter-spacing:.1em}
.review-text{color:#5c4c45;font-size:.97rem;line-height:1.7;flex:1}
.review-author{font-weight:500;font-size:.9rem;color:var(--ink)}
.review-service{font-size:.8rem;color:var(--muted)}

/* ===== FAQ ===== */
.faq-list{display:grid;gap:.8rem;margin-top:.5rem}
.faq-item{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden
}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.2rem 1.4rem;background:none;border:0;cursor:pointer;font:inherit;
  font-size:1rem;font-weight:500;color:var(--ink);text-align:start
}
.faq-q svg{flex-shrink:0;transition:transform .3s;color:var(--rose)}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;
  padding:0 1.4rem;color:#5c4c45;font-size:.96rem;line-height:1.7
}
.faq-item.open .faq-a{max-height:300px;padding:0 1.4rem 1.2rem}

/* ===== responsive ===== */
@media(max-width:860px){
  /* Nav */
  .nav-toggle{display:flex}
  .nav{height:80px}
  .site-header.scrolled .nav{height:64px}
  .brand{left:50%;transform:translateX(-50%)}
  .brand-logo{height:64px}
  .site-header.scrolled .brand-logo{height:50px}
  .nav-links{
    position:absolute;inset-inline:0;top:80px;background:var(--bg);
    flex-direction:column;align-items:flex-start;gap:1.2rem;padding:1.6rem 6vw;
    border-bottom:1px solid var(--line);transform:translateY(-130%);
    transition:transform .35s;height:auto;z-index:20;
  }
  .site-header.scrolled .nav-links{top:64px}
  .nav-links.open{transform:none}

  /* Layout */
  .about,.contact{grid-template-columns:1fr}
  .about-img{min-height:260px;order:-1}
  .form-row{grid-template-columns:1fr}
  .section{padding:64px 0}

  /* Services */
  .cards{grid-template-columns:1fr}

  /* Gallery */
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr)) !important}
  .gallery-filters{gap:.4rem}
  .filter-btn{padding:.4rem .9rem;font-size:.8rem}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-num{font-size:2.4rem}

  /* Process */
  .steps-grid{grid-template-columns:1fr;gap:0}
  .step:not(:last-child)::after{
    top:auto;bottom:0;inset-inline-start:50%;inset-inline-end:auto;
    width:40px;height:1px
  }

  /* Reviews */
  .reviews-track{grid-template-columns:repeat(2,1fr);height:580px}
  .reviews-col:nth-child(3){display:none}

  /* Contact */
  .contact-map iframe{height:260px}

  /* Referral banner */
  .referral-banner{flex-direction:column;align-items:flex-start;gap:.8rem}
  .referral-banner-btn{width:100%;justify-content:center}
  .referral-offer{display:block;width:100%;box-sizing:border-box;white-space:normal;text-align:center}

  /* Footer */
  .footer-inner{flex-direction:column;align-items:center;gap:.8rem;text-align:center}
  .footer-social{justify-content:center}

  /* Lang switch — always visible, top-right corner on mobile */
  .lang-switch{
    position:absolute;
    inset-inline-start:6vw;   /* right:6vw in RTL, left:6vw in LTR */
    top:50%;
    transform:translateY(-50%)
  }
  /* Dropdown stays within viewport */
  .lang-menu{
    inset-inline-start:0;
    inset-inline-end:auto
  }
}

/* promo banner on mobile — 1 ligne */
@media(max-width:640px){
  .promo-banner{padding:.35rem .5rem}
  .promo-banner-inner{
    flex-wrap:nowrap;
    gap:.35rem;
    padding:0 1.6rem 0 0;
    justify-content:center;
    overflow:hidden;
  }
  .promo-label{font-size:.72rem}
  .promo-banner-cta{font-size:.7rem;padding:.2rem .6rem}
  .promo-clock{gap:1px}
  .promo-clock-unit{min-width:24px;padding:.1rem .3rem}
  .promo-clock-num{font-size:.88rem}
  .promo-clock-lbl{font-size:.42rem}
  .promo-clock-sep{font-size:.85rem}
}

@media(max-width:560px){
  /* Nav */
  .nav{height:70px}
  .site-header.scrolled .nav{height:56px}
  .brand-logo{height:52px}
  .site-header.scrolled .brand-logo{height:42px}
  .nav-links{top:70px}

  /* Form date */
  .form input[type="date"]{font-size:.8rem;padding:.85rem .7rem}

  /* Hero */
  .hero{min-height:72vh}
  .hero-content{padding:36px 0}
  .hero h1{font-size:clamp(1.9rem,9vw,3rem)}
  .hero-sub{font-size:.98rem}
  .hero-actions{gap:.6rem}
  .btn{padding:.8rem 1.4rem;font-size:.88rem}

  /* Stats */
  .section-stats{padding:48px 0}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .stat-num{font-size:2rem}
  .stat-item{padding:.9rem .6rem}
  .stat-label{font-size:.78rem}

  /* Services */
  .card{padding:1.6rem 1.2rem}
  .card h3{font-size:1.35rem}
  .card .price{font-size:1.45rem}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr !important;gap:.8rem}
  .filter-btn{padding:.35rem .7rem;font-size:.74rem}
  .ba-handle{width:52px}
  .ba-btn{width:42px;height:42px}

  /* Process */
  .step{padding:1.6rem 1rem}
  .step-num{font-size:2.2rem}
  .step p{max-width:100%}

  /* Reviews */
  .reviews-track{grid-template-columns:1fr;height:480px}
  .reviews-col:not(:first-child){display:none}
  .review-card{padding:1.4rem 1.4rem}

  /* Contact */
  .contact-map iframe{height:220px}

  /* Section spacing */
  .section{padding:52px 0}
  .section-title{margin-bottom:1.8rem}

  /* Sticky bar */
  .sticky-bar{padding:.8rem 5vw}
}

@media(max-width:380px){
  .brand-logo{height:46px}
  .gallery-filters{gap:.25rem}
  .filter-btn{padding:.3rem .55rem;font-size:.7rem}
  .stats-grid{grid-template-columns:1fr}
  .stat-num{font-size:2.4rem}
  .hero h1{font-size:clamp(1.7rem,10vw,2.6rem)}
}

[dir="rtl"] .badges li,[dir="rtl"] .nav-links>a::after{/* logical props handle most RTL */}

/* singles grid */
.singles-grid{margin-top:1rem}

/* ===== before/after slider ===== */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.4rem;margin-top:.5rem
}
.ba-slider{
  position:relative;overflow:hidden;border-radius:var(--radius);
  aspect-ratio:4/3;cursor:ew-resize;user-select:none;touch-action:pan-y;
  box-shadow:0 8px 32px -12px rgba(80,50,40,.2)
}
.ba-slider img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;pointer-events:none;display:block
}
.ba-before{clip-path:inset(0 50% 0 0)}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;
  width:44px;transform:translateX(-50%);
  display:flex;align-items:center;justify-content:center;
  cursor:ew-resize;z-index:10
}
.ba-handle::before{
  content:"";position:absolute;top:0;bottom:0;left:50%;
  width:2px;background:rgba(255,255,255,.88);transform:translateX(-50%)
}
.ba-btn{
  width:36px;height:36px;border-radius:50%;
  background:#fff;box-shadow:0 2px 14px rgba(0,0,0,.3);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--ink);position:relative;z-index:1
}
.ba-label{
  position:absolute;bottom:10px;
  background:rgba(0,0,0,.48);color:#fff;
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.22rem .55rem;border-radius:999px;pointer-events:none;
  backdrop-filter:blur(4px)
}
.ba-label-l{left:10px}
.ba-label-r{right:10px}

/* ===== marquee ===== */
.marquee-strip{
  background:var(--rose);overflow:hidden;
  padding:.55rem 0;white-space:nowrap
}
.marquee-inner{
  display:inline-flex;
  animation:marquee-scroll 26s linear infinite
}
.marquee-inner span{
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.9);padding:0 1rem
}
.marquee-inner .sep{color:rgba(255,255,255,.4);padding:0}
@keyframes marquee-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ===== sticky booking bar ===== */
.sticky-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:80;
  background:var(--ink);color:#e9ddd6;
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 5vw;gap:1rem;
  transform:translateY(110%);
  transition:transform .45s cubic-bezier(.22,.68,0,1.2);
  border-top:1px solid rgba(255,255,255,.08)
}
.sticky-bar.visible{transform:translateY(0)}
.sticky-bar-text{font-size:.82rem;letter-spacing:.05em;opacity:.75;white-space:nowrap}
.btn-sm{padding:.5rem 1.4rem !important;font-size:.82rem !important}
@media(max-width:560px){
  .sticky-bar{flex-direction:column;gap:.4rem;text-align:center;padding:.9rem 5vw}
  .float-whatsapp{bottom:1.5rem}
}


/* ===== hero word animation ===== */
.hero h1 .hw{
  display:inline-block;
  opacity:0;
  transform:translateY(18px);
  animation:hw-in .65s cubic-bezier(.22,.68,0,1.2) forwards
}
@keyframes hw-in{
  to{opacity:1;transform:none}
}

/* ===== cursor sparkle ===== */
.sparkle{
  position:fixed;pointer-events:none;border-radius:50%;
  background:var(--gold);opacity:.8;z-index:9999;
  transform:translate(-50%,-50%);
  animation:sparkle-out .65s ease forwards
}
@keyframes sparkle-out{
  0%  {opacity:.8;transform:translate(-50%,-50%) translate(0,0) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) translate(var(--dx),var(--dy)) scale(0)}
}

/* ===== gallery filters ===== */
.gallery-filters{
  display:flex;justify-content:center;gap:.6rem;flex-wrap:wrap;
  margin-bottom:1.8rem
}
.filter-btn{
  background:none;border:1.5px solid var(--line);border-radius:999px;
  padding:.5rem 1.3rem;font:inherit;font-size:.85rem;letter-spacing:.04em;
  color:var(--muted);cursor:pointer;
  transition:background .2s,border-color .2s,color .2s
}
.filter-btn:hover{border-color:var(--rose);color:var(--rose-dark)}
.filter-btn.active{background:var(--rose);border-color:var(--rose);color:#fff}

/* ===== process steps ===== */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:0;margin-top:.5rem
}
.step{
  text-align:center;padding:2.2rem 1.8rem;position:relative
}
.step:not(:last-child)::after{
  content:"";position:absolute;
  top:3.2rem;inset-inline-end:0;
  width:1px;height:28px;
  background:var(--line)
}
.step-num{
  font-family:"Cormorant Garamond",serif;font-size:2.8rem;font-weight:600;
  color:var(--gold);opacity:.4;line-height:1;display:block;margin-bottom:.9rem
}
.step h3{font-size:1.25rem;margin-bottom:.6rem}
.step p{color:var(--muted);font-size:.93rem;line-height:1.65;max-width:260px;margin-inline:auto}
@media(max-width:700px){
  .step:not(:last-child)::after{
    top:auto;bottom:0;inset-inline-end:50%;
    width:28px;height:1px
  }
}

/* ===== intro / loading screen ===== */
.site-intro{
  position:fixed;inset:0;z-index:2000;
  background:radial-gradient(ellipse at 50% 45%,#fff8f4 0%,var(--bg) 75%);
  display:flex;align-items:center;justify-content:center;
}
/* Fondu de sortie */
.site-intro.done{
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .9s .3s ease-out,visibility 0s 1.2s,pointer-events 0s 1.2s
}
.intro-inner{
  position:relative;
  display:flex;flex-direction:column;align-items:center;
  animation:intro-rise .8s .08s cubic-bezier(.22,.68,0,1.2) both
}

/* Wrapper du tracé */
.intro-draw-wrap{
  position:relative;
  width:min(280px,70vw);
  display:inline-block
}


/* Stylo de microblading */
.intro-pen{
  position:absolute;
  top:38%;left:0;
  transform:translate(-42%,-85%) rotate(28deg);
  animation:pen-trace 1.8s .3s cubic-bezier(.4,0,.2,1) forwards;
  pointer-events:none;z-index:2;
  filter:drop-shadow(0 2px 5px rgba(0,0,0,.3)) drop-shadow(0 0 5px rgba(185,152,106,.55))
}

/* Sortie — tout l'écran fond */
.site-intro.done .intro-logo-img{
  animation:logo-exit .5s ease-in both
}
.site-intro.done .intro-fallback,
.site-intro.done .intro-inner::after,
.site-intro.done .intro-pen{
  animation:elem-fade .4s ease-in both
}

.intro-inner::after{
  content:"";display:block;
  height:1px;margin:.8rem auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  animation:intro-line .6s .55s ease-out both
}
.intro-logo-img{
  width:100%;height:auto;object-fit:contain;
  animation:logo-draw 1.8s .3s cubic-bezier(.4,0,.2,1) both
}
.intro-fallback{align-items:center;gap:1.1rem}
.intro-mark{
  width:72px;height:72px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#9b7a4a,var(--gold) 55%,#dfc07a);
  color:#fff;display:grid;place-items:center;
  font-family:"Cormorant Garamond",serif;font-size:2.2rem;font-weight:600
}
.intro-text{display:flex;flex-direction:column;align-items:flex-start}
.intro-name{
  font-family:"Cormorant Garamond",serif;font-size:2rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink)
}
.intro-sub{
  font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-top:.25rem
}
@keyframes intro-rise{
  from{opacity:0;transform:translateY(22px) scale(.9)}
  to  {opacity:1;transform:none}
}
/* Tracé diagonal calqué sur l'angle du stylo (≈28° de la verticale) */
@keyframes logo-draw{
  from{clip-path:polygon(0% 0%, 0% 0%, -53% 100%, 0% 100%)}
  to  {clip-path:polygon(0% 0%, 100% 0%, 153% 100%, 0% 100%)}
}
/* Sortie : logo déjà tracé, on le fait fondre */
@keyframes logo-exit{
  from{clip-path:polygon(0% 0%, 100% 0%, 153% 100%, 0% 100%);opacity:1;filter:none}
  to  {clip-path:polygon(0% 0%, 100% 0%, 153% 100%, 0% 100%);opacity:0;filter:blur(3px)}
}
@keyframes pen-trace{
  from{left:2%;opacity:0}
  6%  {opacity:1}
  93% {opacity:1}
  to  {left:98%;opacity:0}
}
@keyframes intro-line{
  from{width:0;opacity:0}
  to  {width:170px;opacity:1}
}
@keyframes elem-fade{
  from{opacity:1}
  to  {opacity:0}
}

/* ===== Privacy link ===== */
.privacy-link{
  background:none;border:none;cursor:pointer;
  font:inherit;font-size:.8rem;color:var(--muted);
  text-decoration:underline;padding:0;
  transition:color .2s
}
.privacy-link:hover{color:var(--rose)}

/* ===== Privacy modal ===== */
.privacy-modal{
  display:none;position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.55);
  align-items:center;justify-content:center;padding:1.5rem
}
.privacy-modal.open{display:flex}
.privacy-modal-inner{
  background:var(--white);border-radius:var(--radius);
  max-width:560px;width:100%;max-height:80vh;overflow-y:auto;
  padding:2.5rem 2rem;position:relative;
  box-shadow:0 20px 60px rgba(0,0,0,.18)
}
.privacy-close{
  position:absolute;top:1rem;right:1rem;
  background:none;border:none;cursor:pointer;
  font-size:1.2rem;color:var(--muted);
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:background .2s
}
.privacy-close:hover{background:var(--bg)}
#privacyContent h2{font-size:1.3rem;color:var(--ink);margin-bottom:1rem}
#privacyContent h3{font-size:1rem;font-weight:600;color:var(--ink);margin:1.2rem 0 .4rem}
#privacyContent p{font-size:.93rem;color:#5c4c45;line-height:1.7;margin-bottom:.6rem}

/* ===== SHABBAT OVERLAY ===== */
#shabbatOverlay{
  position:fixed;inset:0;z-index:999999;
  overflow:hidden;           /* bug 6 — étoiles ne débordent pas */
  touch-action:none;         /* bug 2 — iOS Safari : bloque le scroll sous l'overlay */
  background:
    linear-gradient(160deg,rgba(10,5,22,.88) 0%,rgba(20,10,40,.82) 40%,rgba(8,18,35,.90) 100%),
    url('assets/about_shania.jpg') center center / cover no-repeat;
  display:flex;align-items:center;justify-content:center;
  text-align:center;direction:rtl;
}
.shabbat-stars{
  position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 10% 15%,#fff 0%,transparent 100%),
    radial-gradient(1px 1px at 25% 40%,rgba(255,255,255,.7) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 10%,#fff 0%,transparent 100%),
    radial-gradient(1px 1px at 60% 30%,rgba(255,255,255,.6) 0%,transparent 100%),
    radial-gradient(1px 1px at 75% 55%,#fff 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 20%,rgba(255,255,255,.8) 0%,transparent 100%),
    radial-gradient(1px 1px at 90% 70%,rgba(255,255,255,.5) 0%,transparent 100%),
    radial-gradient(1px 1px at 35% 80%,#fff 0%,transparent 100%),
    radial-gradient(1px 1px at 55% 65%,rgba(255,255,255,.7) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 15% 75%,rgba(255,255,255,.6) 0%,transparent 100%),
    radial-gradient(1px 1px at 70% 85%,#fff 0%,transparent 100%),
    radial-gradient(1px 1px at 50% 50%,rgba(255,255,255,.4) 0%,transparent 100%);
  pointer-events:none;
  animation:stars-twinkle 4s ease-in-out infinite alternate;
}
@keyframes stars-twinkle{0%{opacity:.7}100%{opacity:1}}
.shabbat-content{
  position:relative;z-index:1;
  padding:2.5rem 2rem;
  max-width:480px;width:90%;
  max-height:100vh;max-height:100svh; /* bug 1 — fallback + modern */
  overflow-y:auto;                    /* bug 1 — scroll si contenu dépasse (landscape) */
  -webkit-overflow-scrolling:touch;   /* bug 1 — momentum scroll iOS */
  scrollbar-width:none;               /* cacher scrollbar sur Firefox */
}
.shabbat-content::-webkit-scrollbar{display:none} /* cacher scrollbar Chrome/Safari */
.shabbat-candles{
  font-size:2.8rem;
  margin-bottom:1.2rem;
  animation:candle-flicker 2.5s ease-in-out infinite;
  display:block;
  filter:drop-shadow(0 0 12px rgba(255,200,80,.6));
}
@keyframes candle-flicker{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 12px rgba(255,200,80,.6))}
  33%{transform:scale(1.04) rotate(1deg);filter:drop-shadow(0 0 18px rgba(255,200,80,.9))}
  66%{transform:scale(.97) rotate(-1deg);filter:drop-shadow(0 0 8px rgba(255,200,80,.4))}
}
.shabbat-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,9vw,5rem);
  font-weight:600;
  color:#d4a96a;
  margin:0 0 .6rem;
  letter-spacing:.04em;
  text-shadow:0 0 40px rgba(212,169,106,.3);
}
.shabbat-sub{
  font-size:clamp(1rem,3vw,1.2rem);
  color:rgba(255,255,255,.75);
  margin:0 0 1.4rem;
  font-weight:300;
  letter-spacing:.02em;
}
.shabbat-divider{
  width:60px;height:1px;
  background:linear-gradient(90deg,transparent,#d4a96a,transparent);
  margin:0 auto 1.4rem;
}
.shabbat-time{
  font-size:.95rem;
  color:rgba(255,255,255,.6);
  margin:0;letter-spacing:.03em;
}
.shabbat-time-val{
  font-size:1.35rem;
  color:#e8c97a;
  margin:.3rem 0 1.4rem;
  font-weight:500;
  letter-spacing:.06em;
}
.shabbat-time-val span{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;
}
.shabbat-footer{
  font-size:.88rem;
  color:rgba(255,255,255,.4);
  margin:0;
  letter-spacing:.04em;
}
/* Navigation buttons (Waze / Apple Maps) */
.nav-btns{display:flex;gap:.6rem;margin-top:.8rem;flex-wrap:wrap}
.nav-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:6px;font-size:.82rem;font-weight:500;text-decoration:none;transition:opacity .2s}
.nav-btn:hover{opacity:.85}
.nav-btn-waze{background:#33ccff;color:#fff}
.nav-btn-apple{background:#555;color:#fff}

/* bug 1 — layout compact en landscape (hauteur < 500px) */
@media(max-height:500px){
  .shabbat-content{padding:1rem 1.5rem}
  .shabbat-candles{font-size:1.8rem;margin-bottom:.5rem}
  .shabbat-title{margin-bottom:.3rem}
  .shabbat-sub{margin-bottom:.6rem}
  .shabbat-divider{margin-bottom:.6rem}
  .shabbat-time-val{margin:.15rem 0 .6rem}
}
