/*
Theme Name: Spray Tan by Nina
Theme URI: https://spraytanbynina.co.za/
Author: Digitrix Media
Author URI: https://www.digitrix.co.za
Description: Custom one-page landing theme for Spray Tan by Nina, a boutique spray tan studio in Pretoria East. Built-in Bookly booking modal and Trustindex Google-reviews integration. Set this as the front page after activating.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: spray-tan-by-nina
*/

  :root{
    --cream:#FCEFF1;
    --cream-2:#F8E1E6;
    --plum:#3A2129;
    --plum-2:#4A2C35;
    --rose:#C97689;        /* primary action */
    --rose-bright:#E7A6B6; /* highlight on dark */
    --rose-deep:#A84E66;   /* headings accent on light */
    --blush:#F2C9D2;
    --ink:#4A2A33;
    --line:rgba(74,42,51,.13);
    --r:clamp(1rem,2vw,1.6rem);
    --display:'Fraunces',Georgia,serif;
    --body:'Figtree',-apple-system,sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);background:var(--cream);color:var(--ink);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
  ::selection{background:var(--rose);color:#fff}
  img{display:block;max-width:100%}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1200px;margin:0 auto;padding:0 clamp(1.2rem,4vw,3rem)}
  .eyebrow{font-family:var(--body);font-weight:600;letter-spacing:.32em;text-transform:uppercase;font-size:.7rem;color:var(--rose-deep);display:inline-flex;align-items:center;gap:.7rem}
  .eyebrow::before{content:"";width:32px;height:1px;background:var(--rose)}
  h1,h2,h3{font-family:var(--display);font-weight:400;line-height:1.05;letter-spacing:-.01em}
  .reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  /* NAV */
  nav{position:fixed;top:0;left:0;right:0;z-index:60;padding:1.3rem 0;transition:.5s ease}
  .nav-wrap{display:flex;align-items:center;justify-content:space-between}
  nav.scrolled{background:rgba(252,239,241,.85);backdrop-filter:blur(14px);padding:.8rem 0;box-shadow:0 10px 40px -28px rgba(58,33,41,.5)}
  .brand{font-family:var(--display);font-size:1.18rem;color:#fff;transition:.4s;letter-spacing:.01em;line-height:1;white-space:nowrap}
  .brand em{font-style:italic;color:var(--rose-bright)}
  nav.scrolled .brand{color:var(--plum)}
  @media(max-width:380px){.brand{font-size:1rem}}
  .navlinks{display:flex;gap:2rem;align-items:center}
  .navlinks a{font-size:.86rem;font-weight:500;color:rgba(255,255,255,.88);transition:.3s;position:relative}
  nav.scrolled .navlinks a{color:var(--ink)}
  .navlinks a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--rose);transition:.35s}
  .navlinks a:not(.btn):hover::after{width:100%}
  .btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--rose);color:#fff!important;padding:.7rem 1.4rem;border-radius:100px;font-weight:600;font-size:.85rem;transition:.4s cubic-bezier(.2,.7,.2,1);border:none;cursor:pointer;box-shadow:0 10px 30px -12px rgba(201,118,137,.75)}
  .btn:hover{background:var(--rose-deep);transform:translateY(-2px);box-shadow:0 16px 36px -12px rgba(168,78,102,.8)}
  .btn.ghost{background:transparent;color:#fff!important;border:1px solid rgba(255,255,255,.45);box-shadow:none}
  .btn.ghost:hover{background:rgba(255,255,255,.14);border-color:#fff;transform:translateY(-2px)}
  .btn.dark{background:var(--plum);box-shadow:0 10px 30px -12px rgba(58,33,41,.6)}
  .btn.dark:hover{background:#2a1620}
  .menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;z-index:70}
  .menu-toggle span{width:26px;height:2px;background:#fff;transition:.3s;border-radius:2px}
  nav.scrolled .menu-toggle span{background:var(--plum)}

  /* HERO */
  .hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;overflow:hidden;background:var(--plum)}
  .hero .hero-inner{width:100%}
  .hero video,.hero .hero-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;z-index:0}
  .hero-poster{background:url('https://spraytanbynina.co.za/wp-content/uploads/2026/06/PHOTO-2026-06-01-10-30-41-642x1024.jpg') center 28%/cover}
  .hero-glow{position:absolute;inset:-20%;z-index:1;pointer-events:none;mix-blend-mode:screen;
    background:
      radial-gradient(42% 52% at 22% 28%,rgba(231,166,182,.30),transparent 62%),
      radial-gradient(48% 58% at 82% 72%,rgba(201,118,137,.26),transparent 62%),
      radial-gradient(38% 42% at 62% 18%,rgba(248,225,230,.18),transparent 62%);
    animation:drift 16s ease-in-out infinite alternate}
  @keyframes drift{0%{transform:translate(0,0) scale(1)}50%{transform:translate(3%,-2%) scale(1.08)}100%{transform:translate(-3%,2%) scale(1.04)}}
  .hero-veil{position:absolute;inset:0;z-index:2;background:linear-gradient(105deg,rgba(34,18,26,.94) 0%,rgba(58,33,41,.8) 42%,rgba(92,52,66,.5) 78%,rgba(120,70,86,.34) 100%)}
  .hero-grain{position:absolute;inset:0;z-index:3;opacity:.45;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E")}
  .hero-inner{position:relative;z-index:4;padding-top:6rem;text-align:left}
  .hero-inner .eyebrow{justify-content:flex-start}
  .hero-cta{justify-content:flex-start}
  .hero::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(to top,rgba(34,18,26,.55),transparent 38%)}
  .hero .eyebrow{color:var(--rose-bright)}.hero .eyebrow::before{background:var(--rose-bright)}
  .hero h1{color:#fff;font-size:clamp(2.1rem,5.2vw,4.3rem);margin:1.3rem 0;max-width:20ch;font-weight:300}
  .hero h1 em{font-style:italic;color:var(--rose-bright)}
  .hero .lede{color:rgba(255,255,255,.85);font-size:clamp(1rem,1.6vw,1.2rem);max-width:46ch;margin-bottom:2.2rem}
  .hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
  .hero .word{display:inline-block;opacity:0;transform:translateY(110%)}
  .hero.loaded .word{animation:rise .9s cubic-bezier(.2,.8,.2,1) forwards}
  @keyframes rise{to{opacity:1;transform:none}}
  .scroll-cue{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:5;color:rgba(255,255,255,.6);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.6rem}
  .scroll-cue .line{width:1px;height:40px;background:linear-gradient(rgba(255,255,255,.6),transparent);animation:cue 2s ease-in-out infinite}
  @keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

  /* MARQUEE */
  .marquee{background:var(--plum);color:var(--cream);padding:1.1rem 0;overflow:hidden;white-space:nowrap;border-top:1px solid rgba(255,255,255,.08)}
  .marquee-track{display:inline-flex;gap:3rem;animation:scroll 26s linear infinite}
  .marquee span{font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--rose-bright);display:inline-flex;align-items:center;gap:3rem}
  .marquee span::after{content:"✦";color:rgba(255,255,255,.3);font-style:normal}
  @keyframes scroll{to{transform:translateX(-50%)}}

  section{padding:clamp(4.5rem,9vw,8rem) 0;position:relative}
  .sec-head{max-width:60ch}
  .sec-head h2{font-size:clamp(2rem,4.5vw,3.4rem);margin:1.1rem 0 1rem;font-weight:300}
  .sec-head h2 em{font-style:italic;color:var(--rose-deep)}
  .sec-head p{color:#6e4d59;font-size:1.05rem;max-width:52ch}

  /* INTRO */
  .intro{background:var(--cream)}
  .intro-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,5rem);align-items:center}
  .intro-copy h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:300;margin:1rem 0 1.4rem}
  .intro-copy p{color:#6e4d59;margin-bottom:1rem}
  .trust{display:flex;flex-direction:column;gap:.7rem;margin-top:2.2rem}
  .trust-item{display:flex;align-items:center;gap:.8rem;font-size:.92rem;font-weight:500;color:var(--ink)}
  .trust-item .ti-ic{flex:none;width:36px;height:36px;border-radius:50%;background:var(--blush);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px -8px rgba(168,78,102,.6)}
  .trust-item .ti-ic svg{width:18px;height:18px;fill:var(--rose-deep)}
  .intro-img{position:relative}
  .intro-img img{border-radius:var(--r);box-shadow:0 40px 80px -40px rgba(58,33,41,.45);width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center 18%}
  .intro-img .badge{position:absolute;bottom:-26px;left:-26px;background:var(--rose);color:#fff;width:120px;height:120px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-family:var(--display);font-style:italic;box-shadow:0 20px 40px -16px rgba(201,118,137,.7);animation:spin-soft 24s linear infinite}
  @keyframes spin-soft{to{transform:rotate(360deg)}}
  .intro-img .badge b{font-size:1.5rem}
  .intro-img .badge small{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;font-family:var(--body);font-style:normal}

  /* WORK */
  .work{background:var(--plum);color:var(--cream)}
  .work .eyebrow{color:var(--rose-bright)}.work .eyebrow::before{background:var(--rose-bright)}
  .work .sec-head h2{color:#fff}.work .sec-head h2 em{color:var(--rose-bright)}
  .work .sec-head p{color:rgba(252,239,241,.72)}
  .reel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:3rem}
  .reel{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:9/14;cursor:pointer;background:#2a1620;transition:.5s cubic-bezier(.2,.7,.2,1)}
  .reel img{width:100%;height:100%;object-fit:cover;transition:.7s cubic-bezier(.2,.7,.2,1)}
  .reel:hover{transform:translateY(-6px);box-shadow:0 30px 60px -24px rgba(0,0,0,.6)}
  .reel:hover img{transform:scale(1.07)}
  .reel::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(42,22,32,.85),transparent 55%)}
  .reel .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;transition:.4s}
  .reel .play::after{content:"";border-left:14px solid #fff;border-top:9px solid transparent;border-bottom:9px solid transparent;margin-left:3px}
  .reel:hover .play{background:var(--rose);border-color:var(--rose);transform:translate(-50%,-50%) scale(1.12)}
  .reel .meta{position:absolute;left:1rem;bottom:1rem;z-index:3}
  .reel .meta b{font-family:var(--display);font-style:italic;font-size:1.1rem;color:#fff;display:block}
  .reel .meta small{color:var(--rose-bright);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase}
  .reel .dur{position:absolute;top:.9rem;right:.9rem;z-index:3;background:rgba(0,0,0,.5);color:#fff;font-size:.68rem;padding:.2rem .5rem;border-radius:6px;backdrop-filter:blur(4px)}

  /* BEFORE / AFTER */
  .ba-sec{background:var(--cream-2)}
  .ba-wrap{max-width:760px;margin:3rem auto 0}
  .ba{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;cursor:ew-resize;user-select:none;box-shadow:0 40px 80px -40px rgba(58,33,41,.5);--pos:50%}
  .ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
  .ba .after{filter:none}
  .ba .before-clip{position:absolute;inset:0;width:var(--pos);overflow:hidden}
  .ba .before-clip img{width:100%;height:100%;filter:saturate(.45) brightness(1.12) contrast(.96)}
  .ba .lbl{position:absolute;top:1rem;z-index:4;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;background:rgba(58,33,41,.6);color:#fff;padding:.3rem .7rem;border-radius:100px;backdrop-filter:blur(4px)}
  .ba .lbl.b{left:1rem}.ba .lbl.a{right:1rem;background:rgba(201,118,137,.85)}
  .ba .handle{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:#fff;z-index:5;transform:translateX(-1px);box-shadow:0 0 14px rgba(0,0,0,.3)}
  .ba .handle::after{content:"⟷";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;background:#fff;color:var(--rose-deep);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 6px 20px rgba(58,33,41,.35)}
  .ba-note{text-align:center;color:#836070;font-size:.85rem;margin-top:1.2rem}

  /* WHY */
  .why{background:var(--cream)}
  .why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:3rem}
  .feat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem;transition:.5s cubic-bezier(.2,.7,.2,1)}
  .feat:hover{transform:translateY(-5px);box-shadow:0 30px 60px -36px rgba(58,33,41,.4);border-color:var(--rose)}
  .feat .ic{width:48px;height:48px;border-radius:12px;background:var(--rose);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.2rem;color:#fff}
  .feat h3{font-size:1.35rem;margin-bottom:.6rem;font-weight:500}
  .feat p{color:#6e4d59;font-size:.95rem}

  /* PRICING */
  .pricing{background:var(--cream-2)}
  .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
  .card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.4rem 2rem;display:flex;flex-direction:column;transition:.5s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden}
  .card.feature{background:var(--plum);color:var(--cream);border-color:var(--plum)}
  .card.feature .tag{position:absolute;top:1.4rem;right:1.4rem;background:var(--rose);color:#fff;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:.3rem .7rem;border-radius:100px}
  .card:hover{transform:translateY(-6px);box-shadow:0 36px 70px -40px rgba(58,33,41,.45)}
  .card h3{font-size:1.5rem;font-weight:500;margin-bottom:.3rem}
  .card .from{font-size:.8rem;color:#836070;text-transform:uppercase;letter-spacing:.12em}
  .card.feature .from{color:var(--rose-bright)}
  .card .amt{font-family:var(--display);font-size:2.8rem;margin:.6rem 0 1.4rem;color:var(--rose-deep);font-weight:500}
  .card.feature .amt{color:var(--rose-bright)}
  .card ul{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:2rem;flex:1}
  .card li{font-size:.92rem;color:#6e4d59;display:flex;gap:.6rem;align-items:flex-start}
  .card.feature li{color:rgba(252,239,241,.85)}
  .card li::before{content:"✧";color:var(--rose);flex-shrink:0}
  .hours{margin-top:3rem;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;text-align:center;color:#6e4d59;font-size:.95rem}
  .hours b{color:var(--rose-deep);font-family:var(--display);font-style:italic;display:block;font-size:1.1rem}

  /* STEPS */
  .steps{background:var(--cream)}
  .step-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem;counter-reset:s}
  .step{position:relative;padding-top:1.5rem}
  .step::before{counter-increment:s;content:"0" counter(s);font-family:var(--display);font-style:italic;font-size:3rem;color:var(--blush);display:block;line-height:1;margin-bottom:.6rem}
  .step h3{font-size:1.2rem;font-weight:500;margin-bottom:.4rem}
  .step p{color:#6e4d59;font-size:.92rem}

  /* ABOUT */
  .about{background:var(--cream-2)}
  .about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:center}
  .about-img img{border-radius:var(--r);width:100%;aspect-ratio:3/4;object-fit:cover;box-shadow:0 40px 80px -44px rgba(58,33,41,.45)}
  .about-copy h2{font-size:clamp(1.9rem,4vw,3rem);font-weight:300;margin:1rem 0 1.2rem}
  .about-copy p{color:#6e4d59;margin-bottom:1rem}
  .about-list{display:flex;flex-wrap:wrap;gap:.7rem;margin:1.4rem 0 2rem}
  .about-list span{background:#fff;border:1px solid var(--line);padding:.5rem 1rem;border-radius:100px;font-size:.84rem;color:var(--rose-deep)}

  /* TESTIMONIALS */
  .testi{background:var(--plum);color:var(--cream);text-align:center;overflow:hidden}
  .testi .eyebrow{color:var(--rose-bright);justify-content:center}
  .testi .stars{color:var(--rose-bright);font-size:1.3rem;letter-spacing:.2em;margin:1.4rem 0 .4rem}
  .tslider{position:relative;max-width:760px;margin:1rem auto 0;min-height:200px}
  .tslide{position:absolute;inset:0;opacity:0;transform:translateY(18px);transition:.7s cubic-bezier(.2,.7,.2,1);pointer-events:none}
  .tslide.on{opacity:1;transform:none;pointer-events:auto;position:relative}
  .tslide p{font-family:var(--display);font-style:italic;font-size:clamp(1.2rem,2.4vw,1.7rem);line-height:1.45;color:#fff;font-weight:300}
  .tslide .who{margin-top:1.4rem;color:var(--rose-bright);font-size:.85rem;letter-spacing:.14em;text-transform:uppercase}
  .tdots{display:flex;gap:.6rem;justify-content:center;margin-top:2.4rem}
  .tdots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.3);cursor:pointer;transition:.3s;padding:0}
  .tdots button.on{background:var(--rose-bright);width:26px;border-radius:100px}

  /* FAQ */
  .faq{background:var(--cream)}
  .faq-list{max-width:820px;margin:3rem auto 0}
  .q{border-bottom:1px solid var(--line)}
  .q button{width:100%;background:none;border:none;text-align:left;padding:1.4rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;font-family:var(--display);font-size:1.15rem;color:var(--ink)}
  .q .plus{flex-shrink:0;width:28px;height:28px;border:1px solid var(--rose);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--rose-deep);transition:.4s;font-family:var(--body)}
  .q.open .plus{background:var(--rose);color:#fff;transform:rotate(135deg)}
  .q .a{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.2,.7,.2,1)}
  .q .a p{padding:0 0 1.4rem;color:#6e4d59;font-size:.96rem}

  /* TIPS */
  .tips{background:var(--cream-2)}
  .tips-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:3rem}
  .tipcard{border-radius:var(--r);padding:2.4rem;border:1px solid var(--line)}
  .tipcard.pre{background:#fff}
  .tipcard img{width:100%;height:clamp(260px,34vw,360px);object-fit:cover;object-position:center 22%;border-radius:calc(var(--r) - .55rem);margin-bottom:1.5rem}
  .tipcard.post{background:var(--plum);color:var(--cream)}
  .tipcard h3{font-size:1.5rem;font-weight:500;margin-bottom:1.2rem;text-align:center}
  .tipcard.post h3{color:var(--rose-bright)}
  .tipcard ul{list-style:none;display:flex;flex-direction:column;gap:.8rem}
  .tipcard li{font-size:.92rem;display:flex;gap:.7rem;align-items:flex-start}
  .tipcard.pre li{color:#6e4d59}.tipcard.post li{color:rgba(252,239,241,.82)}
  .tipcard li::before{content:"→";color:var(--rose);flex-shrink:0}

  /* BOOK */
  .book{background:var(--plum);color:var(--cream);text-align:center;position:relative;overflow:hidden}
  .book .glow{position:absolute;inset:0;background:radial-gradient(50% 60% at 50% 0%,rgba(231,166,182,.28),transparent 70%);pointer-events:none}
  .book .eyebrow{color:var(--rose-bright);justify-content:center}
  .book h2{font-size:clamp(2.2rem,5vw,4rem);font-weight:300;margin:1.2rem auto 1.2rem;max-width:16ch;color:#fff}
  .book h2 em{font-style:italic;color:var(--rose-bright)}
  .book p{color:rgba(252,239,241,.8);max-width:46ch;margin:0 auto 2.2rem}
  .book-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}
  .map{margin-top:3.5rem;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.12);position:relative;z-index:2}
  .map iframe{width:100%;height:300px;border:0;display:block;filter:grayscale(.2)}

  footer{background:#2a1620;color:rgba(252,239,241,.6);padding:3rem 0;text-align:center;font-size:.85rem}
  footer .brand-f{font-family:var(--display);font-style:italic;font-size:1.6rem;color:var(--rose-bright);margin-bottom:.8rem}
  footer a{color:var(--rose-bright)}
  footer .flinks{display:flex;gap:1.5rem;justify-content:center;margin:1rem 0;flex-wrap:wrap}

  /* LIGHTBOX */
  .lightbox{position:fixed;inset:0;z-index:100;background:rgba(42,22,32,.92);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:2rem}
  .lightbox.on{display:flex}
  .lightbox .frame{position:relative;width:auto;max-width:92vw;max-height:88vh;border-radius:var(--r);overflow:hidden;box-shadow:0 40px 100px -30px #000}
  .lightbox .frame img{display:block;width:auto;height:auto;max-width:92vw;max-height:88vh;object-fit:contain}
  .lightbox .note{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(42,22,32,.9));padding:2rem 1.4rem 1.4rem;color:var(--cream);font-size:.85rem;text-align:center}
  .lightbox .close{position:absolute;top:-3rem;right:0;color:#fff;background:none;border:none;font-size:2rem;cursor:pointer}

  /* BOOKING MODAL */
  .modal{position:fixed;inset:0;z-index:90;background:rgba(42,22,32,.55);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding:5vh 1.2rem;overflow-y:auto}
  .modal.on{display:flex}
  .bk{background:var(--cream);width:min(720px,100%);border-radius:var(--r);overflow:hidden;box-shadow:0 50px 120px -40px rgba(42,22,32,.7);animation:pop .5s cubic-bezier(.2,.8,.2,1)}
  @keyframes pop{from{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:none}}
  .bk-head{background:var(--plum);color:#fff;padding:1.6rem 1.8rem;position:relative}
  .bk-head .eyebrow{color:var(--rose-bright)}.bk-head .eyebrow::before{background:var(--rose-bright)}
  .bk-head h3{font-size:1.7rem;font-weight:300;margin-top:.6rem;color:#fff}
  .bk-head h3 em{font-style:italic;color:var(--rose-bright)}
  .bk-close{position:absolute;top:1.1rem;right:1.2rem;background:rgba(255,255,255,.12);border:none;color:#fff;width:34px;height:34px;border-radius:50%;font-size:1.3rem;cursor:pointer;transition:.3s;line-height:1}
  .bk-close:hover{background:var(--rose)}
  .bk-body{padding:1.8rem;overflow-x:auto}
  .bk-field{margin-bottom:1.3rem}
  .bk-field label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--rose-deep);margin-bottom:.5rem}
  .bk-field input,.bk-field select,.bk-field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:12px;background:#fff;font-family:var(--body);font-size:.95rem;color:var(--ink);transition:.3s}
  .bk-field input:focus,.bk-field select:focus,.bk-field textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 3px rgba(201,118,137,.15)}
  .bk-field textarea{resize:vertical;min-height:64px}
  .bk-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .slots{display:flex;flex-wrap:wrap;gap:.5rem}
  .slot{padding:.55rem .9rem;border:1px solid var(--line);border-radius:100px;background:#fff;font-size:.85rem;cursor:pointer;transition:.25s;color:var(--ink)}
  .slot:hover{border-color:var(--rose)}
  .slot.sel{background:var(--rose);color:#fff;border-color:var(--rose)}
  .slot.off{opacity:.35;cursor:not-allowed;text-decoration:line-through}
  .bk-note{font-size:.8rem;color:#836070;background:var(--cream-2);border-radius:12px;padding:.8rem 1rem;margin-bottom:1.3rem}
  .bk-submit{width:100%;justify-content:center;font-size:.95rem;padding:.95rem}
  .bk-alt{text-align:center;font-size:.82rem;color:#836070;margin-top:1rem}
  .bk-alt a{color:var(--rose-deep);font-weight:600}

  /* WHATSAPP */
  .wa{position:fixed;bottom:1.4rem;right:1.4rem;z-index:55;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 36px -10px rgba(37,211,102,.7);transition:.4s;animation:pulse 2.6s infinite}
  .wa:hover{transform:scale(1.08)}
  .wa svg{width:30px;height:30px;fill:#fff}
  @keyframes pulse{0%{box-shadow:0 14px 36px -10px rgba(37,211,102,.7),0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 14px 36px -10px rgba(37,211,102,.7),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 14px 36px -10px rgba(37,211,102,.7),0 0 0 0 rgba(37,211,102,0)}}

  @media(max-width:960px){
    .reel-grid{grid-template-columns:repeat(2,1fr)}
    .price-grid,.step-grid,.why-grid{grid-template-columns:1fr 1fr}
    .intro-grid,.about-grid,.tips-grid{grid-template-columns:1fr;gap:2.5rem}
    .about-grid .about-img{order:-1}
  }
  @media(max-width:640px){
    .navlinks{position:fixed;inset:0;background:var(--plum);flex-direction:column;justify-content:center;gap:1.6rem;transform:translateX(100%);transition:.5s cubic-bezier(.2,.7,.2,1)}
    .navlinks.open{transform:none}
    .navlinks a{color:#fff!important;font-size:1.3rem;font-family:var(--display)}
    .menu-toggle{display:flex}
    .menu-toggle.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
    .menu-toggle.x span:nth-child(2){opacity:0}
    .menu-toggle.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
    .price-grid,.step-grid,.why-grid{grid-template-columns:1fr}
    .intro-img .badge{width:96px;height:96px;left:auto;right:-10px}
  }
  .protip{margin-top:1.6rem;background:#fff;border:1px solid var(--line);border-top:3px solid var(--rose);border-radius:var(--r);padding:1.8rem;text-align:center}.protip h4{font-family:var(--display);font-style:italic;color:var(--rose-deep);font-size:1.3rem;margin-bottom:.5rem;font-weight:500}.protip p{color:#6e4d59;font-size:.92rem;margin-bottom:.5rem}
  .studio{background:var(--cream-2)}
  .studio-shot{position:relative;margin-top:3rem;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:0 50px 95px -52px rgba(58,33,41,.55)}
  .studio-shot img{display:block;width:100%;height:auto}
  .studio-shot::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(201,118,137,.10),transparent 20%,transparent 76%,rgba(58,33,41,.16))}
  .studio-tags{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:1.6rem}
  .studio-tags span{background:#fff;border:1px solid var(--line);color:var(--rose-deep);font-size:.82rem;padding:.45rem 1rem;border-radius:100px}
  .glow-gallery{margin:3rem auto 0;max-width:860px;display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
  .glow-gallery .gitem{border-radius:var(--r);overflow:hidden;position:relative;cursor:pointer;box-shadow:0 24px 50px -34px rgba(0,0,0,.65);background:#2a1620;aspect-ratio:4/3}
  .glow-gallery .gitem img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:.6s cubic-bezier(.2,.7,.2,1)}
  .glow-gallery .gitem:hover img{transform:scale(1.05)}
  .glow-gallery .gitem::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(42,22,32,.45),transparent 42%);opacity:0;transition:.4s}
  .glow-gallery .gitem:hover::after{opacity:1}
  @media(max-width:600px){.glow-gallery{grid-template-columns:1fr;max-width:420px}}
  /* Booking modal: static placeholder (shown only outside WordPress) */
  .bk-placeholder{display:flex;flex-direction:column;gap:.5rem;text-align:center;padding:2.6rem 1.4rem;border:1px dashed var(--line);border-radius:var(--r);background:#fff;color:#836070}
  .bk-placeholder strong{font-family:var(--display);font-style:italic;font-size:1.35rem;color:var(--rose-deep)}
  .bk-placeholder span{font-size:.9rem;line-height:1.5}
  /* ===== Bookly skinned to the blush theme — adjust selectors to your Bookly form type/version ===== */
  .bk-bookly .bookly-form{font-family:var(--body)!important;color:var(--ink)}
  .bk-bookly .bookly-form label,.bk-bookly .bookly-form .bookly-label{color:var(--ink)!important;font-weight:500}
  .bk-bookly .bookly-form select,.bk-bookly .bookly-form input,.bk-bookly .bookly-form textarea{border:1px solid var(--line)!important;border-radius:12px!important;background:#fff!important}
  .bk-bookly .bookly-form .bookly-btn,.bk-bookly .bookly-form button[type=submit],.bk-bookly .bookly-form .bookly-next-step{background:var(--rose)!important;border:none!important;border-radius:100px!important;font-family:var(--body)!important;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem!important;padding:.85rem 1.7rem!important;transition:.3s}
  .bk-bookly .bookly-form .bookly-btn:hover,.bk-bookly .bookly-form button[type=submit]:hover,.bk-bookly .bookly-form .bookly-next-step:hover{background:var(--rose-deep)!important}
  .bk-bookly .bookly-day.bookly-day-active,.bk-bookly .bookly-slot.selected,.bk-bookly .bookly-time-screen .active{background:var(--rose)!important;color:#fff!important;border-color:var(--rose)!important}
  .bk-bookly .bookly-progress-tracker .active,.bk-bookly .bookly-progress-tracker .done{background:var(--rose)!important}
  /* keep the live Bookly form from squashing inside the modal */
  .bk-bookly .bookly-form{max-width:100%!important;margin:0 auto!important}
  .bk-bookly .bookly-form-group,.bk-bookly .bookly-list,.bk-bookly .bookly-box{width:100%!important;float:none!important}
  .bk-bookly select,.bk-bookly input,.bk-bookly textarea{width:100%!important;max-width:100%!important;font-size:16px!important}
  .bk-bookly .bookly-progress-tracker{display:flex!important;flex-wrap:wrap!important;overflow:visible!important}
  .bk-bookly .bookly-progress-tracker>*{min-width:0!important}
  .bk-bookly .bookly-columnizer{column-count:1!important}
  .bk-bookly .bookly-time-screen .bookly-column,.bk-bookly .bookly-time-screen .bookly-cell{width:100%!important;display:block!important;float:none!important}
  .bk-bookly .bookly-calendar,.bk-bookly .picker,.bk-bookly .picker__table,.bk-bookly .picker__frame{width:100%!important;max-width:100%!important}
  .bk-bookly .bookly-clear{clear:both}
  /* Service step tidy-up: hide the empty Category selector + single-provider Staff dropdown.
     (Reliable fix is Bookly > Appearance; these are CSS fallbacks — verify the select name via Inspect.) */
  .bk-bookly .bookly-form-group:has(select[name*="category"]),
  .bk-bookly .bookly-form-group:has(select[name*="staff"]),
  .bk-bookly .bookly-form-group:has(select[name*="employee"]){display:none!important}
  /* keep the active progress step label legible */
  .bk-bookly .bookly-progress-tracker .active,
  .bk-bookly .bookly-progress-tracker .active *{color:#fff!important}
  .ti-reviews{max-width:760px;margin:1.4rem auto 0;font-family:monospace;font-size:.78rem;color:rgba(252,239,241,.4)}
  .ti-placeholder{font-family:var(--body);display:flex;flex-direction:column;gap:.5rem;text-align:center;padding:2.6rem 1.4rem;border:1px dashed rgba(255,255,255,.25);border-radius:var(--r);margin-top:.7rem;color:rgba(252,239,241,.7)}
  .ti-placeholder strong{font-family:var(--display);font-style:italic;font-size:1.35rem;color:var(--rose-bright)}
  .ti-placeholder span{font-size:.85rem;line-height:1.55}
  .prep-poster{max-width:360px;margin:.4rem auto 2.8rem}
  .prep-poster img{width:100%;height:auto;display:block;border-radius:var(--r);box-shadow:0 20px 55px -20px rgba(120,40,70,.4)}
  .terms-page{max-width:720px;margin:0 auto;padding:clamp(4.5rem,9vw,7rem) clamp(1.4rem,5vw,2.4rem) 5rem;line-height:1.85}
  .terms-page h1{font-family:var(--display);font-weight:300;font-size:clamp(2.3rem,5vw,3.2rem);color:var(--ink);margin:.5rem 0 1.7rem;line-height:1.15}
  .terms-page h2{font-family:var(--display);font-style:italic;color:var(--rose-deep);font-size:clamp(1.45rem,2.6vw,1.7rem);margin:3rem 0 1rem;font-weight:500;line-height:1.3}
  .terms-page p{color:#6e4d59;margin-bottom:1.25rem;font-size:1.06rem;line-height:1.85}
  .terms-page .updated{font-size:.9rem;color:#8a6675;margin-top:3.2rem;border-top:1px solid var(--line);padding-top:1.7rem;line-height:1.7}
  .terms-back{display:inline-block;margin-bottom:2rem;color:var(--rose-deep);font-weight:600;text-decoration:none;font-size:.92rem}
  .terms-back:hover{color:var(--rose)}
