/* =====================================================
   רות איפרגן · style.css v3
   ===================================================== */

/* ── TOKENS ─────────────────────────────────────────── */
:root {
  --bg:      #fdfaf8;
  --cream:   #f8f2ef;
  --blush:   #fce8ed;
  --surface: #ffffff;
  --dark:    #5c2840;
  --dark2:   #723454;
  --ink:     #3a1a28;
  --ink2:    #7a5468;
  --muted:   #b09098;
  --line:    #eedde4;
  --wine:    #a85878;
  --wine2:   #c07090;
  --rose:    #e898a8;
  --rose-lt: #f5c8d2;
  --gold:    #c9a070;
  --gold-lt: #dfc090;

  /* ── static tokens – never flip in dark mode (used for always-dark surfaces) */
  --wine-s:  #a85878;
  --wine2-s: #c07090;

  --fh:  'Noto Serif Hebrew', Georgia, serif;
  --fa:  'Playfair Display', Georgia, serif;   /* accent/italic */
  --fb:  'Heebo', sans-serif;

  --ease:     cubic-bezier(.22,1,.36,1);
  --ease-in:  cubic-bezier(.55,0,.8,0);
  --hh:       68px;
  --mw:       1160px;

  /* Always light – bridal site never goes dark */
  color-scheme: only light;
}

/* ── RESET ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--fb);font-weight:300;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
@media(prefers-reduced-motion:no-preference){
  body{transition:background-color .4s,color .4s}
}
img,video{display:block;max-width:100%}
a{color:inherit}
button{cursor:pointer;font-family:inherit}
ul,ol{list-style:none}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ── SELECTION ───────────────────────────────────────── */
::selection{background:var(--wine);color:#fff}
::-moz-selection{background:var(--wine);color:#fff}

/* ── SCROLLBAR (Webkit) ──────────────────────────────── */
::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--rose-lt);border-radius:50px}
::-webkit-scrollbar-thumb:hover{background:var(--rose)}

/* ── SKIP LINK ───────────────────────────────────────── */
.skip-link{
  position:fixed;top:-120%;right:1rem;z-index:9999;
  padding:.6rem 1.2rem;background:var(--wine);color:#fff;
  border-radius:50px;font-size:.875rem;font-weight:600;
  text-decoration:none;transition:top .2s var(--ease);
}
.skip-link:focus{top:1rem}

/* ── CURSOR ──────────────────────────────────────────── */
.cursor{
  pointer-events:none;position:fixed;z-index:9990;
  width:10px;height:10px;border-radius:50%;
  background:var(--rose);
  transform:translate(-50%,-50%);
  transition:transform .08s,background .2s,width .25s var(--ease),height .25s var(--ease);
  mix-blend-mode:multiply;
}
.cursor.grow{width:40px;height:40px;background:var(--rose-lt)}
@media(hover:none){.cursor{display:none}}

/* ── TYPOGRAPHY ──────────────────────────────────────── */
.eyebrow{
  display:inline-block;
  font-family:var(--fa);font-size:clamp(.92rem,1.6vw,1.05rem);font-weight:600;font-style:italic;
  letter-spacing:.05em;color:var(--gold);
  margin-bottom:.9rem;
}
h1{font-family:var(--fh);font-weight:900;line-height:1.05;
   font-size:clamp(3.2rem,10vw,7.5rem)}
h2{font-family:var(--fh);font-weight:700;line-height:1.12;
   font-size:clamp(2rem,5vw,3.8rem)}
h3{font-family:var(--fh);font-weight:700;line-height:1.25;
   font-size:clamp(1.2rem,2.5vw,1.65rem)}
p{color:var(--ink2)}

/* ── SECTION HEADS ───────────────────────────────────── */
.sh{text-align:center;max-width:600px;margin:0 auto clamp(3rem,6vw,5rem)}
.sh h2{margin-top:.5rem}
.sh-sub{margin-top:.75rem;font-size:1rem;color:var(--muted)}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.9rem 2.2rem;border-radius:50px;
  font-family:var(--fb);font-size:.875rem;font-weight:700;
  letter-spacing:.04em;text-decoration:none;border:none;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;
  position:relative;overflow:hidden;cursor:pointer;
}
/* ripple */
.btn::after{
  content:'';position:absolute;border-radius:50%;
  width:0;height:0;background:rgba(255,255,255,.25);
  left:50%;top:50%;transform:translate(-50%,-50%);
  transition:width .5s var(--ease),height .5s var(--ease),opacity .5s;
  opacity:0;
}
.btn.ripple::after{width:300px;height:300px;opacity:1;
  transition:width .6s var(--ease),height .6s var(--ease),opacity .4s .1s}
/* JS-appended ripple span (click-position-accurate) */
.ripple-fx{
  position:absolute;border-radius:50%;
  width:6px;height:6px;pointer-events:none;
  background:rgba(255,255,255,.4);
  transform:translate(-50%,-50%) scale(0);
  animation:rippleFx .7s var(--ease) forwards;
}
@keyframes rippleFx{to{transform:translate(-50%,-50%) scale(55);opacity:0}}
.btn:hover{transform:translateY(-3px) scale(1.02)}
.btn:active{transform:translateY(0) scale(.98)}

.btn-primary{
  background:linear-gradient(135deg,var(--wine-s),var(--wine2-s));
  color:#fff;
  box-shadow:0 6px 24px rgba(168,88,120,.35);
}
.btn-primary:hover{box-shadow:0 14px 40px rgba(168,88,120,.5)}

.btn-ghost-light{
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.4);
}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.1)}

.btn-outline{
  background:transparent;color:var(--wine);
  border:2px solid var(--wine);
}
.btn-outline:hover{background:var(--wine);color:#fff}

.btn-dark{
  background:var(--dark);color:#fff;
  border:1.5px solid rgba(255,255,255,.15);
}
.btn-dark:hover{background:var(--dark2);border-color:rgba(255,255,255,.4)}

.btn-wa{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:.95rem 2rem;border-radius:50px;
  background:#25D366;color:#fff;font-weight:700;font-size:.9rem;
  text-decoration:none;
  box-shadow:0 6px 24px rgba(37,211,102,.3);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(37,211,102,.45)}

.btn-lg{padding:1.1rem 2.8rem;font-size:1rem}
.btn-full{width:100%;justify-content:center}
.m-btn{display:inline-block} /* magnetic wrapper */

/* ── IMAGE PLACEHOLDERS ──────────────────────────────── */
/* Looks like intentional color-blocked art direction */
.ph{
  width:100%;height:100%;position:relative;
  background:linear-gradient(135deg,#f5dde2 0%,#fce8ec 40%,#f0c8d0 100%);
  overflow:hidden;
  transition:background .4s;
}
.ph::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 80%,rgba(232,93,117,.18) 0%,transparent 60%),
    radial-gradient(ellipse 60% 80% at 90% 10%,rgba(201,146,42,.15) 0%,transparent 60%);
}
/* small badge – only visible to dev, not intrusive */
.ph[data-label]::after{
  content:attr(data-label);
  position:absolute;bottom:.6rem;right:.6rem;
  background:rgba(255,255,255,.85);backdrop-filter:blur(6px);
  color:var(--wine-s);font-size:.55rem;font-weight:700;
  letter-spacing:.06em;padding:.25rem .6rem;border-radius:50px;
  line-height:1.4;max-width:160px;text-align:right;
  pointer-events:none;
}
/* dark variant */
.ph-dark{
  background:linear-gradient(135deg,#5c2840 0%,#3c1830 50%,#723454 100%);
}
.ph-dark::before{
  background:
    radial-gradient(ellipse at 30% 80%,rgba(232,93,117,.25) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 20%,rgba(201,146,42,.2) 0%,transparent 50%);
}
/* portrait variant (tall) */
.ph-portrait{
  background:linear-gradient(160deg,#f8e8e0 0%,#f2d8e0 50%,#e8c8d0 100%);
}

/* ── DARK MODE: placeholder overrides ───────────────── */
/* ── REVEAL ──────────────────────────────────────────── */
.rv{
  opacity:0;transform:translateY(32px) scale(.98);
  transition:opacity .85s var(--ease),transform .85s var(--ease);
  transition-delay:var(--d,0s);
}
.rv.on{opacity:1;transform:none}
/* slide-from-side variants */
.rv-l{opacity:0;transform:translateX(48px) scale(.98);transition:opacity .85s var(--ease),transform .85s var(--ease);transition-delay:var(--d,0s)}
.rv-r{opacity:0;transform:translateX(-48px) scale(.98);transition:opacity .85s var(--ease),transform .85s var(--ease);transition-delay:var(--d,0s)}
.rv-l.on,.rv-r.on{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1!important;transform:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ── HEADER ──────────────────────────────────────────── */
.site-header{
  position:fixed;top:0;right:0;left:0;z-index:200;
  height:var(--hh);
  background:rgba(250,248,245,.95);
  backdrop-filter:blur(20px) saturate(1.6);
  -webkit-backdrop-filter:blur(20px) saturate(1.6);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.sc{
  border-color:var(--line);
  box-shadow:0 4px 32px rgba(44,26,36,.05);
}

.hi{
  max-width:var(--mw);margin:0 auto;
  padding:0 clamp(1rem,4vw,2rem);
  height:100%;display:flex;align-items:center;
  justify-content:space-between;gap:1.5rem;
}

.brand{display:flex;flex-direction:column;text-decoration:none;line-height:1.25;flex-shrink:0}
.brand-n{font-family:var(--fh);font-size:1.3rem;font-weight:700;color:var(--ink);letter-spacing:.01em}
.brand-s{font-family:var(--fa);font-style:italic;font-size:.82rem;letter-spacing:.04em;color:var(--gold);font-weight:600}

.main-nav ul{display:flex;align-items:center;gap:clamp(.7rem,2vw,1.75rem)}
.main-nav a{
  font-family:var(--fb);font-size:.82rem;font-weight:500;
  text-decoration:none;color:var(--ink2);
  position:relative;transition:color .2s;
}
.main-nav a::after{
  content:'';position:absolute;bottom:-2px;right:0;left:0;
  height:2px;background:var(--wine);border-radius:2px;
  transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease);
}
.main-nav a:hover{color:var(--wine)}
.main-nav a:hover::after{transform:scaleX(1)}

.nav-cta{
  padding:.5rem 1.4rem;
  background:linear-gradient(135deg,var(--wine-s),var(--wine2-s));
  color:#fff!important;border-radius:50px;
  box-shadow:0 4px 16px rgba(168,88,120,.3);
  transition:box-shadow .2s,transform .2s!important;
}
.nav-cta::after{display:none!important}
.nav-cta:hover{box-shadow:0 8px 28px rgba(168,88,120,.5)!important;transform:translateY(-2px)!important}

.nav-toggle{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;padding:.5rem;flex-shrink:0;
}
.nb{
  display:block;width:22px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .3s var(--ease),opacity .2s;
}

@media(max-width:780px){
  .nav-toggle{display:flex}
  .main-nav{
    position:fixed;top:var(--hh);right:0;left:0;
    background:var(--surface);border-bottom:1px solid var(--line);
    padding:1.75rem clamp(1rem,4vw,2rem) 2.5rem;
    display:none;box-shadow:0 20px 60px rgba(44,26,36,.1);
  }
  .main-nav.open{display:block;z-index:100} /* above deco-bg */
  .main-nav ul{flex-direction:column;align-items:flex-start;gap:.2rem}
  .main-nav a{display:block;padding:.7rem 0;font-size:1rem}
  .nav-cta{display:inline-block;margin-top:1rem;padding:.7rem 1.6rem}
  .nav-toggle[aria-expanded=true] .nb:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded=true] .nb:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded=true] .nb:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ── HERO ────────────────────────────────────────────── */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:center;justify-content:center;
  padding-top:var(--hh);overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 85%,rgba(210,130,155,.38) 0%,transparent 55%),
    radial-gradient(ellipse 60% 50% at 80% 10%,rgba(245,200,215,.28) 0%,transparent 50%),
    linear-gradient(160deg,#f8e8ec 0%,#fdf0f3 55%,#f5dde5 100%);
  animation:hbreathe 10s ease-in-out infinite;
}
@keyframes hbreathe{
  0%,100%{filter:brightness(1) saturate(1)}
  50%{filter:brightness(1.08) saturate(1.2)}
}
/* actual photo replaces .hero-bg - add <img> sibling to .hero-overlay */
.hero-bg img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  animation:hzoom 14s ease-out forwards;
}
@keyframes hzoom{from{transform:scale(1.06)}to{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(170deg,rgba(253,238,242,.75) 0%,rgba(252,232,238,.42) 50%,rgba(240,210,222,.68) 100%);
}
/* large rotating diamond — atmospheric hero background element */
.hero-deco{
  position:absolute;z-index:1;
  width:clamp(8rem,18vw,16rem);
  color:rgba(232,93,117,.07);
  top:8%;left:4%;
  user-select:none;pointer-events:none;
  animation:hspin 55s linear infinite;
  overflow:visible;
}
@keyframes hspin{to{transform:rotate(360deg)}}

.hero-content{
  position:relative;z-index:2;
  max-width:var(--mw);width:100%;
  padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,2rem);
  text-align:center;
}
.hero-content .eyebrow{color:var(--wine)}
.hero-title{
  color:var(--ink);margin-bottom:1.5rem;
  text-shadow:0 2px 20px rgba(255,255,255,.7);
}
.hero-title .line{display:block}
.hero-title .thin{
  font-weight:300;color:var(--wine);
  font-size:clamp(2.4rem,7.5vw,5.8rem);
}
.hero-sub{
  color:var(--ink2);
  font-size:clamp(1rem,2vw,1.15rem);
  font-weight:300;max-width:52ch;
  margin:0 auto 2.75rem;line-height:1.8;
}
.hero-btns{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;
  transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.scd{  /* scroll chevron dot — renamed to avoid collision with .sd deco base */
  width:5px;height:5px;border-radius:50%;
  background:rgba(92,40,64,.45);
  animation:scd 2s ease-in-out infinite;
}
@keyframes scd{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(10px);opacity:1}}
.st{display:block;width:1px;height:36px;background:linear-gradient(to bottom,rgba(92,40,64,.4),transparent)}

/* ── PROOF BAND ──────────────────────────────────────── */
.proof-band{background:var(--blush);padding:clamp(3rem,5vw,4.5rem) clamp(1rem,4vw,2rem)}
.proof-inner{
  max-width:var(--mw);margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:1.25rem;
}
.proof-item{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  text-align:center;padding:2rem 1rem;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:20px;
  transition:background .3s,border-color .3s,transform .35s var(--ease);
}
.proof-item:hover{
  background:var(--rose-lt);
  border-color:var(--rose);
  transform:translateY(-4px);
}
.proof-num{
  font-family:var(--fh);font-size:clamp(2.2rem,5vw,3.8rem);
  font-weight:900;color:var(--wine);line-height:1;
}
.proof-label{
  font-size:.68rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink2);
}

/* ── SERVICES ────────────────────────────────────────── */
.services-section{
  padding:clamp(5rem,10vw,9rem) clamp(1rem,4vw,2rem);
}
.si{max-width:var(--mw);margin:0 auto}
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));
  gap:clamp(1.5rem,3vw,2.5rem);
}
.svc-card{
  display:flex;flex-direction:column;
  background:var(--surface);
  border-radius:24px;overflow:hidden;
  border:1px solid var(--line);
  transition:box-shadow .4s var(--ease),transform .4s var(--ease);
  will-change:transform;
}
.svc-card:hover{
  box-shadow:0 28px 64px rgba(168,88,120,.13);
  transform:translateY(-6px);
}
.svc-img{aspect-ratio:4/5;overflow:hidden;position:relative}
.svc-img .ph{height:100%}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-card:hover .svc-img img{transform:scale(1.06)}
.svc-tag{
  position:absolute;top:1rem;right:1rem;
  background:linear-gradient(135deg,var(--wine-s),var(--wine2-s));
  color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;padding:.3rem .9rem;border-radius:50px;
}
.svc-body{
  padding:clamp(1.75rem,3vw,2.5rem);
  display:flex;flex-direction:column;gap:1rem;flex:1;
}
.svc-body h3{color:var(--ink)}
.svc-body p{font-size:.95rem}
.feat-list{display:flex;flex-direction:column;gap:.5rem}
.feat-list li{
  padding-right:1.4rem;position:relative;
  font-size:.85rem;color:var(--ink2);
}
.feat-list li::before{
  content:'';position:absolute;right:0;top:.58em;
  width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--rose),var(--wine));
}
.svc-body .m-btn{margin-top:auto}

/* ── GALLERY ─────────────────────────────────────────── */
.gallery-section{
  background:var(--cream);
  padding:clamp(5rem,10vw,9rem) clamp(1rem,4vw,2rem);
}
.gi{max-width:var(--mw);margin:0 auto}
.gallery-section .sh h2,.gallery-section .eyebrow{color:var(--ink)}
.gallery-section .sh h2{color:var(--ink)}
.gallery-section .sh-sub{color:var(--ink2)}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:280px;
  gap:10px;
}
.g-tall{grid-row:span 2}
.g-item{
  position:relative;overflow:hidden;border-radius:16px;
  cursor:pointer;
}
.g-item::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(160deg,transparent 30%,rgba(168,88,120,.72) 100%);
  opacity:0;transition:opacity .4s var(--ease);
}
.g-item:hover::after,.g-item:focus::after{opacity:1}
.g-item .ph{height:100%;transition:transform .6s var(--ease)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.g-item:hover .ph,.g-item:hover img{transform:scale(1.07)}
.g-tag{
  position:absolute;bottom:.85rem;right:.85rem;z-index:2;
  background:rgba(255,255,255,.95);color:var(--wine);
  font-size:.62rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:.3rem .85rem;border-radius:50px;
  opacity:0;transform:translateY(6px);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
}
.g-item:hover .g-tag,.g-item:focus .g-tag{opacity:1;transform:none}

@media(max-width:780px){.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:220px}}
@media(max-width:500px){.gallery-grid{grid-template-columns:1fr;grid-auto-rows:270px}.g-tall{grid-row:span 1}}

/* ── PROCESS ─────────────────────────────────────────── */
.process-section{
  background:var(--cream);
  padding:clamp(5rem,10vw,9rem) clamp(1rem,4vw,2rem);
}
.pi{max-width:var(--mw);margin:0 auto}
.proc-list{max-width:720px;margin:0 auto}
.proc-step{
  display:grid;grid-template-columns:90px 1fr;
  gap:2rem;padding:3rem 0;
  border-bottom:1px solid var(--line);align-items:start;
}
.proc-step:first-child{padding-top:0}
.proc-step:last-child{border:none;padding-bottom:0}
.proc-num{
  font-family:var(--fh);font-size:5.5rem;font-weight:900;
  background:linear-gradient(135deg,var(--rose-lt),var(--blush));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;line-height:1;user-select:none;
}
.proc-body h3{margin-bottom:.6rem}
.proc-body p{font-size:.95rem}

/* ── ABOUT ───────────────────────────────────────────── */
.about-section{
  background:var(--surface);
  border-top:1px solid var(--line);
  padding:
    clamp(5rem,10vw,9rem)
    max(clamp(1rem,4vw,2rem),calc((100% - var(--mw)) / 2));
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,7vw,7rem);align-items:center;
}
.about-img{
  aspect-ratio:3/4;border-radius:24px;overflow:hidden;position:relative;
}
.about-img .ph{height:100%}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-img::before{
  content:'';position:absolute;
  inset:-14px -14px 14px 14px;z-index:-1;
  border-radius:24px;
  background:linear-gradient(135deg,var(--blush),var(--rose-lt));
}
.about-txt{display:flex;flex-direction:column;gap:1.3rem}
.about-txt h2{margin-top:.25rem}
.about-lead{font-size:clamp(1rem,2vw,1.15rem);color:var(--ink);font-weight:500;line-height:1.7}
.about-q{
  display:flex;gap:.5rem;align-items:flex-start;
  padding:1.35rem 1.5rem;background:var(--blush);
  border-radius:14px;border-right:3px solid var(--rose);
}
.about-q-mark{
  font-family:var(--fh);font-size:4rem;
  color:var(--rose);line-height:.65;flex-shrink:0;
}
.about-q p{font-size:.95rem;font-style:italic;color:var(--ink2)}
.about-txt .m-btn{align-self:flex-start;margin-top:.5rem}

@media(max-width:780px){
  .about-section{grid-template-columns:1fr;padding:clamp(4rem,8vw,6rem) clamp(1rem,4vw,2rem)}
  .about-img{max-width:340px;margin:0 auto;width:100%}
  .about-img::before{display:none}
}

/* ── TESTIMONIALS ────────────────────────────────────── */
.test-section{
  background:var(--blush);
  padding:clamp(5rem,10vw,9rem) clamp(1rem,4vw,2rem);
}
.ti{max-width:var(--mw);margin:0 auto}
.test-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));
  gap:clamp(1.25rem,3vw,2rem);
}
.test-card{
  background:var(--surface);border:1px solid rgba(232,93,117,.15);
  border-radius:24px;padding:clamp(1.75rem,3vw,2.5rem);
  display:flex;flex-direction:column;gap:1.25rem;
  position:relative;overflow:hidden;
  transition:box-shadow .4s var(--ease),transform .4s var(--ease);
  will-change:transform;
}
.test-card::before{
  content:'';position:absolute;top:0;right:0;height:3px;
  width:40%;background:linear-gradient(90deg,transparent,var(--rose));
  transition:width .5s var(--ease);
}
.test-card:hover{box-shadow:0 20px 52px rgba(168,88,120,.1);transform:translateY(-5px)}
.test-card:hover::before{width:100%}
.test-av{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--blush),var(--rose-lt));
  border:2px solid var(--rose-lt);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
  font-size:.55rem;font-weight:700;color:var(--wine);
  text-align:center;line-height:1.4;padding:.3rem;
}
.test-av img{width:100%;height:100%;object-fit:cover}
blockquote{display:flex;flex-direction:column;gap:.75rem}
blockquote::before{
  content:'\201C';font-family:var(--fh);font-size:4rem;
  color:var(--rose);line-height:.65;
}
blockquote p{font-size:.9rem;font-style:italic;color:var(--ink2);line-height:1.8}
blockquote footer{margin-top:.15rem}
blockquote cite{font-style:normal;display:flex;flex-direction:column;gap:.1rem}
blockquote cite strong{font-size:.88rem;font-weight:700;color:var(--ink)}
.rev-d{font-size:.7rem;color:var(--muted)}

/* ── FAQ ─────────────────────────────────────────────── */
.faq-section{
  padding:clamp(5rem,10vw,9rem) clamp(1rem,4vw,2rem);
}
.faq-inner{max-width:var(--mw);margin:0 auto}
.faq-list{max-width:700px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:first-child{border-top:1px solid var(--line)}
.faq-btn{
  display:flex;justify-content:space-between;align-items:center;
  width:100%;padding:1.4rem 0;background:none;border:none;
  font-family:var(--fh);font-size:1.1rem;font-weight:700;
  color:var(--ink);text-align:right;cursor:pointer;gap:1rem;
  transition:color .2s;
}
.faq-btn:hover{color:var(--wine)}
.faq-ico{
  width:30px;height:30px;flex-shrink:0;border-radius:50%;
  border:2px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:1.2rem;font-weight:300;line-height:1;
  transition:border-color .25s,background .25s,transform .35s var(--ease),color .2s;
}
.faq-btn[aria-expanded=true] .faq-ico{
  background:var(--wine);border-color:var(--wine);
  color:#fff;transform:rotate(45deg);
}
.faq-btn[aria-expanded=true]{color:var(--wine)}
.faq-body{
  max-height:0;overflow:hidden;
  transition:max-height .45s var(--ease);
}
.faq-body.open{max-height:400px}
.faq-body p{padding-bottom:1.5rem;font-size:.95rem;line-height:1.85}

/* ── CONTACT ─────────────────────────────────────────── */
.contact-section{
  background:linear-gradient(160deg,var(--blush) 0%,var(--cream) 60%,var(--blush) 100%);
  padding:clamp(5rem,10vw,9rem) clamp(1rem,4vw,2rem);
}
.ci{
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;
  gap:2.5rem;
}
/* contact intro (replaces old .ct) */
.c-intro{text-align:center}
.c-intro h2{color:var(--ink);margin-top:.5rem}
.c-intro .eyebrow{color:var(--wine)}
.c-intro-sub{
  color:var(--ink2);font-size:1rem;
  max-width:50ch;margin:.75rem auto 0;line-height:1.85;
}
.ct{display:flex;flex-direction:column;gap:1.4rem}
.ct h2{color:var(--ink);margin-top:.25rem}
.ct .eyebrow{color:var(--wine)}
.ct p{color:var(--ink2);font-size:.95rem}
.ct .m-btn{align-self:flex-start}

/* form */
.c-form{
  background:var(--surface);
  border-radius:24px;
  padding:clamp(1.75rem,4vw,2.75rem);
  display:flex;flex-direction:column;gap:1.25rem;
}
.f-h{font-family:var(--fh);font-size:1.6rem;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:540px){.f-row{grid-template-columns:1fr}}
.f-g{display:flex;flex-direction:column;gap:.45rem}
.f-g label{font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--ink2)}
.req{color:var(--wine)}
.f-g input,.f-g select,.f-g textarea{
  width:100%;padding:.8rem 1.1rem;
  background:var(--bg);border:2px solid var(--line);
  border-radius:12px;font-family:var(--fb);
  font-size:.9rem;font-weight:300;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;direction:rtl;
}
.f-g input::placeholder,.f-g textarea::placeholder{color:var(--muted);font-size:.85rem}
.f-g input:focus,.f-g select:focus,.f-g textarea:focus{
  outline:none;border-color:var(--wine);
  box-shadow:0 0 0 4px rgba(168,88,120,.1);
}
.f-g textarea{resize:vertical;min-height:100px}
.f-consent{display:flex;flex-direction:column;gap:.75rem}
.f-check{display:flex;align-items:flex-start;gap:.65rem}
.f-check input[type=checkbox]{
  width:18px;height:18px;flex-shrink:0;margin-top:.15rem;
  accent-color:var(--wine);cursor:pointer;
}
.f-check label{font-size:.78rem;color:var(--ink2);line-height:1.6;cursor:pointer}
.f-check label a{color:var(--wine);text-decoration:underline}
.priv-note{
  font-size:.7rem;color:var(--muted);line-height:1.65;
  padding:.75rem 1rem;background:var(--cream);
  border-radius:8px;border-right:3px solid var(--rose-lt);
}
.f-status{font-size:.85rem;min-height:1.4em;text-align:center}
.f-status.ok{color:#2d7a3a;font-weight:700}
.f-status.err{color:var(--wine-s);font-weight:700}
/* ── CTA STRIP ───────────────────────────────────────── */
.cta-strip{
  /* Soft rose gradient — light & bridal */
  background:linear-gradient(135deg,var(--rose-lt) 0%,var(--rose) 55%,var(--wine2-s) 100%);
  padding:clamp(4rem,8vw,7rem) clamp(1rem,4vw,2rem);
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:center;gap:2rem;text-align:center;
  position:relative;overflow:hidden;
}
.cta-strip::before{
  content:'';position:absolute;
  width:clamp(320px,60vw,700px);height:clamp(320px,60vw,700px);
  border-radius:50%;
  background:rgba(255,255,255,.07);
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:ctag 7s ease-in-out infinite;
}
@keyframes ctag{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.18)}}
.cta-txt{
  font-family:var(--fh);
  font-size:clamp(1.6rem,4vw,2.8rem);
  font-weight:900;color:var(--ink);position:relative;
}
.cta-txt strong{color:var(--wine)}

/* ── FOOTER ──────────────────────────────────────────── */
.site-footer{
  background:var(--blush);
  border-top:1px solid var(--line);
  padding:clamp(2.5rem,5vw,4rem) clamp(1rem,4vw,2rem);
}
.fi{
  max-width:var(--mw);margin:0 auto;
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:space-between;gap:1.5rem;
}
.f-brand{display:flex;flex-direction:column;gap:.15rem}
.f-brand strong{font-family:var(--fh);font-size:1.15rem;font-weight:700;color:var(--ink)}
.f-brand span{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--wine)}
.f-nav ul{display:flex;flex-wrap:wrap;gap:1.25rem}
.f-nav a{font-size:.8rem;color:var(--ink2);text-decoration:none;transition:color .2s}
.f-nav a:hover{color:var(--wine)}
.f-copy{font-size:.72rem;color:var(--muted)}

:target{scroll-margin-top:calc(var(--hh) + 2rem)}

/* ══ PER-SECTION DECORATIVES ════════════════════════════
   Each section contains its own .sdeco block (position:absolute)
   with makeup-themed SVG/glyph elements coloured to match the
   section background. JS counter-parallax via data-px attribute.
   ════════════════════════════════════════════════════════ */

/* Sections need position:relative to contain absolute .sdeco */
.proof-band,.services-section,.gallery-section,.process-section,
.about-section,.test-section,.faq-section,.contact-section,.cta-strip{
  position:relative;
}

/* Deco container – sits at z:0, content wrappers at z:1 */
.sdeco{
  position:absolute;inset:0;z-index:0;
  pointer-events:none;user-select:none;overflow:hidden;
}
.sdeco>div{position:absolute;will-change:transform}

/* Hero extras (direct positioned children, z:1 = above overlay) */
.hero-xd{
  position:absolute;z-index:1;
  pointer-events:none;user-select:none;will-change:transform;
}

/* Content wrappers lifted above deco */
.si,.gi,.pi,.ti,.ci,.faq-inner,.proof-inner,
.about-img,.about-txt,.cta-txt,.cta-strip>.m-btn{
  position:relative;z-index:1;
}

/* ── Shared element base ───────────────────────────────── */
.sd{display:block}

/* Eyelash fan SVG */
.sd-lash{animation:sdSway 11s ease-in-out infinite;transform-origin:50% 88%}

/* Rose petal SVG */
.sd-petal {animation:sdDrift  19s ease-in-out infinite}
.sd-petal2{animation:sdDrift  27s ease-in-out infinite;animation-delay:-8s}

/* Lipstick silhouette SVG */
.sd-lip{animation:sdDrift2 23s ease-in-out infinite}

/* Engagement ring SVG */
.sd-ring{animation:sdDrift 21s ease-in-out infinite;animation-delay:-6s}

/* Diamond / gem SVG */
.sd-diamond{animation:sdDrift2 16s ease-in-out infinite;animation-delay:-3s}

/* Gel nail-polish bottle SVG */
.sd-nail{animation:sdDrift2 26s ease-in-out infinite;animation-delay:-14s}

/* ── Colour presets per section type ───────────────────── */
/* Light-rose sections: hero, gallery, contact, proof */
.sd-dk  {color:var(--wine);   opacity:.09}
.sd-dk.g{color:var(--gold);   opacity:.07}
.sd-dk.w{color:var(--rose);   opacity:.10}

/* Light sections: services, process, faq (off-white bg) */
.sd-lt  {color:var(--wine-s);opacity:.08}
.sd-lt.r{color:var(--rose);  opacity:.09}

/* Blush sections: testimonials */
.sd-bl  {color:var(--wine-s);opacity:.09}
.sd-bl.r{color:var(--rose);  opacity:.12}

/* Surface/white sections: about */
.sd-sf  {color:var(--wine-s);opacity:.07}
.sd-sf.r{color:var(--rose);  opacity:.08}

/* ── Keyframes ─────────────────────────────────────────── */
@keyframes sdSway {
  0%,100%{transform:rotate(-7deg)  scaleX(1)}
  50%    {transform:rotate(7deg)   scaleX(1.04) translateX(4px)}
}
@keyframes sdDrift{
  0%,100%{transform:translate(0,0)        rotate(0deg)}
  20%    {transform:translate(11px,-18px) rotate(13deg)}
  55%    {transform:translate(-8px,9px)   rotate(-9deg)}
  80%    {transform:translate(6px,-5px)   rotate(6deg)}
}
@keyframes sdDrift2{
  0%,100%{transform:translate(0,0)       rotate(-6deg)}
  35%    {transform:translate(5px,-15px) rotate(6deg)}
  65%    {transform:translate(-4px,9px)  rotate(-7deg)}
}

/* ── Small screens ─────────────────────────────────────── */
@media(max-width:600px){
  .sdeco>div:nth-child(3){display:none}
  .sd-lash{width:68px!important}
}

/* ── Reduced motion ────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .sdeco>div,.hero-xd,.sd{animation:none!important}
}


/* ── COOKIE CONSENT BANNER ───────────────────────────── */
.cookie-banner{
  position:fixed;bottom:0;right:0;left:0;z-index:8000;
  background:var(--surface);
  border-top:2px solid var(--line);
  box-shadow:0 -8px 40px rgba(44,26,36,.12);
  padding:1.1rem clamp(1rem,4vw,2rem);
  transform:translateY(110%);
  transition:transform .55s var(--ease);
}
.cookie-banner.cb-visible{transform:translateY(0)}
.cookie-inner{
  max-width:var(--mw);margin:0 auto;
  display:flex;flex-wrap:wrap;align-items:center;
  gap:.85rem 1.5rem;justify-content:space-between;
}
.cookie-txt{flex:1;min-width:200px;display:flex;flex-direction:column;gap:.25rem}
.cookie-txt strong{font-family:var(--fb);font-size:.88rem;font-weight:700;color:var(--ink)}
.cookie-txt p{font-size:.76rem;color:var(--muted);line-height:1.6;margin:0}
.cookie-txt a{color:var(--wine);text-decoration:underline;transition:color .2s}
.cookie-txt a:hover{color:var(--rose)}
.cookie-btns{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;flex-shrink:0}
.cookie-btns .btn{padding:.65rem 1.6rem;font-size:.8rem;min-height:44px}
.cookie-more{
  font-size:.76rem;color:var(--muted);text-decoration:underline;
  transition:color .2s;white-space:nowrap;
}
.cookie-more:hover{color:var(--wine)}
@media(max-width:540px){
  .cookie-inner{flex-direction:column;align-items:stretch}
  .cookie-btns{width:100%}
  .cookie-btns .btn{flex:1;justify-content:center}
}

/* ── TOUCH TARGETS ≥ 44px (WCAG 2.5.5) ──────────────── */
@media(max-width:780px){
  .nav-toggle{min-width:44px;min-height:44px;padding:.65rem}
}
.faq-btn{min-height:44px}
.f-g input,.f-g select,.f-g textarea{min-height:44px}
.f-g select{min-height:44px}

/* ── PROCESS: collapse big number col on small screens ── */
@media(max-width:520px){
  .proc-step{grid-template-columns:1fr;gap:.75rem;padding:2rem 0}
  .proc-num{
    font-size:3.8rem;
    filter:drop-shadow(0 1px 5px rgba(0,0,0,.22));
  }
}

/* ── FORM: per-field inline error messages ───────────── */
.f-err{
  display:block;font-size:.72rem;color:var(--wine-s);
  font-weight:700;min-height:1em;
  transition:opacity .2s;
}
.f-err:empty{opacity:0}
/* make the status classes consistent (JS uses success/error) */
.f-status.success,.f-status.ok{color:#2d7a3a;font-weight:700}
.f-status.error,.f-status.err{color:var(--wine-s);font-weight:700}
@media print{.site-header,.cta-strip,.c-form{display:none}body{color:#000;background:#fff}}
