:root{
  --bg:#F7F3EE; --bg-alt:#EFE2DD; --ink:#2B2623; --ink-soft:#79706A;
  --card:#FCFAF7; --line:#E7DCD2;
  --accent:#e43392; --accent-dark:#c81e7b; --accent-tint:#FBDCEC;
  /* contact (anchor) block */
  --c-bg:#2B2623; --c-ink:#F6F1EA; --c-soft:#B7ADA2;
  --c-card:#FBF7F1; --c-cardink:#2B2623; --c-input:#ffffff; --c-line:#E7DCD2;
}
[data-theme="dark"]{
  --bg:#1A1714; --bg-alt:#221E1A; --ink:#F4EFE8; --ink-soft:#A89E93;
  --card:#26211C; --line:#39332C;
  --accent:#ff4da3; --accent-dark:#e43392; --accent-tint:#3A2230;
  --c-bg:#120F0D; --c-ink:#F6F1EA; --c-soft:#B7ADA2;
  --c-card:#221E1B; --c-cardink:#F4EFE8; --c-input:#171411; --c-line:#3A332C;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Wix Madefor Text',sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-weight:400;transition:background .4s ease,color .4s ease}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
h1,h2,h3,h4{font-family:'Wix Madefor Display',sans-serif;line-height:1.08;letter-spacing:-.02em;font-weight:600}
a{color:inherit}
::selection{background:var(--accent);color:#fff}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:'Wix Madefor Text';font-weight:600;font-size:1rem;background:var(--accent);color:#fff;border:1px solid var(--accent);padding:15px 30px;border-radius:50px;text-decoration:none;cursor:pointer;transition:background .28s,border-color .28s,transform .28s}
.btn:hover{background:var(--accent-dark);border-color:var(--accent-dark);transform:translateY(-2px)}
.btn--lg{font-size:1.05rem;padding:17px 34px}
.label{font-family:'Wix Madefor Text';font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.74rem;color:var(--accent)}

/* nav + theme toggle */
nav{display:flex;align-items:center;justify-content:space-between;padding:22px 0;position:relative;z-index:3;gap:16px}
.logo-img{height:42px;width:auto;display:block}
.logo-on-dark{display:none}
[data-theme="dark"] .logo-on-light{display:none}
[data-theme="dark"] .logo-on-dark{display:block}
[data-theme="dark"] .logo-on-dark{filter:brightness(0) invert(1)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-cta{font-weight:600;font-size:.92rem;text-decoration:none;color:var(--ink);border-bottom:1.5px solid var(--accent);padding-bottom:3px;transition:color .2s}
.nav-cta:hover{color:var(--accent)}
.theme-toggle{display:inline-flex;align-items:center;gap:3px;background:var(--bg-alt);border:1px solid var(--line);border-radius:50px;padding:4px}
.theme-toggle button{border:none;background:transparent;width:30px;height:28px;border-radius:50px;display:grid;place-items:center;cursor:pointer;color:var(--ink-soft);transition:background .25s,color .25s}
.theme-toggle button svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8}
.theme-toggle button.active{background:var(--ink);color:var(--bg)}

/* hero */
.hero{padding:46px 0 60px;position:relative;overflow:hidden}
.glow{position:absolute;border-radius:50%;filter:blur(70px);z-index:0;pointer-events:none}
.glow-peach{width:320px;height:320px;background:radial-gradient(circle,rgba(244,200,170,.45),transparent 70%);bottom:-50px;left:-110px;animation:drift 18s ease-in-out infinite reverse}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-26px)}}

.cluster{position:absolute;inset:0;z-index:1;pointer-events:none}
.cluster canvas{width:100%;height:100%;display:block}
.breath-quote{position:absolute;left:72%;top:50%;transform:translate(-50%,-50%);width:clamp(190px,18vw,280px);text-align:center;font-family:'Wix Madefor Display';font-style:italic;z-index:2}
.need-rot{overflow:hidden;height:4rem;display:flex;align-items:center;justify-content:center}
.need-item{width:100%}
.need-item{font-size:clamp(1rem,1.65vw,1.45rem);font-weight:600;color:var(--ink);line-height:1.2;letter-spacing:-.01em;will-change:transform,opacity;text-shadow:0 1px 8px var(--bg),0 0 12px var(--bg)}

.hero .label{margin-bottom:24px;display:inline-block}
.hero h1{font-size:clamp(2.6rem,6.6vw,4.6rem);font-weight:600;max-width:13ch;letter-spacing:-.03em}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:500}
.hero p.lead{font-size:clamp(1.05rem,2.1vw,1.26rem);color:var(--ink-soft);max-width:42ch;margin:26px 0 32px}

.grab-card{max-width:460px;perspective:1400px}
.flip-inner{position:relative;display:grid;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.22,.7,.25,1)}
.grab-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-face{grid-area:1/1;position:relative;backface-visibility:hidden;-webkit-backface-visibility:hidden;background:var(--card);border:1px solid var(--line);border-radius:22px;padding:24px 26px}
.flip-back{transform:rotateY(180deg);padding-top:32px}
.flip-back-btn{position:absolute;top:12px;left:14px;background:transparent;border:none;font-family:'Wix Madefor Text';font-weight:600;font-size:.85rem;color:var(--ink-soft);cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .2s}
.flip-back-btn:hover{color:var(--accent)}
.front-grid{display:grid;grid-template-columns:78px 1fr;gap:18px;align-items:center}
.pdf-mock{width:78px;height:auto;display:block;filter:drop-shadow(0 6px 14px rgba(0,0,0,.10));transition:transform .5s ease}
.grab-card:hover .pdf-mock{transform:translateY(-3px) rotate(-3deg)}
.gtitle{font-family:'Wix Madefor Display';font-weight:600;font-size:1.06rem;margin-bottom:6px;display:flex;align-items:center;gap:9px}
.gtitle svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.7;flex:0 0 auto}
.gsub{font-size:.9rem;color:var(--ink-soft);margin-bottom:14px;line-height:1.45}
.flip-hint{font-size:.74rem;color:var(--ink-soft);margin-top:10px;font-style:italic;opacity:.75}
.hero-alt{display:inline-block;margin-top:10px;color:var(--ink-soft);font-size:.86rem;text-decoration:none;font-weight:500}
.hero-alt u{color:var(--accent);text-decoration-thickness:1.5px;text-underline-offset:2px}
.hero-alt:hover{color:var(--ink)}
.back-prompt{font-family:'Wix Madefor Display';font-weight:600;font-size:1.04rem;margin-bottom:14px;color:var(--ink)}
.hero-grab{display:flex;flex-direction:column;gap:10px}
.hero-grab input{font-family:'Wix Madefor Text';font-size:.98rem;padding:13px 18px;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.hero-grab input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,51,146,.22)}
.hero-grab .btn{margin-top:2px}
.grab-note{font-size:.78rem;color:var(--ink-soft);margin-top:12px}
.grab-success{display:none;flex-direction:column;align-items:flex-start;gap:14px}
.grab-success.show{display:flex;animation:pop .5s ease}
.grab-success b{font-family:'Wix Madefor Display';font-size:1.05rem;display:block}
.grab-success small{display:block;font-size:.86rem;color:var(--ink-soft);margin-top:4px}
.grab-success .btn{margin-top:2px}

/* stats / counters */
.stats{padding:24px 0 70px;position:relative}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid var(--line);padding-top:40px}
.stat .num{display:inline-block;font-family:'Wix Madefor Display';font-weight:700;font-size:clamp(2.2rem,4.5vw,3.2rem);letter-spacing:-.03em;line-height:1;transform-origin:left center}
.stat .num.pulse{animation:numpulse .55s ease}
@keyframes numpulse{0%{transform:scale(1)}38%{transform:scale(1.16);color:var(--accent)}100%{transform:scale(1)}}
@media(max-width:880px){.stat .num{transform-origin:center}}
.stat .cap{font-size:.92rem;color:var(--ink-soft);margin-top:8px;font-weight:500}
.reviews{margin-top:26px;font-size:1rem;color:var(--ink-soft);font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.reviews .stars{color:var(--accent);letter-spacing:3px;font-size:1.05rem}
.reviews .rev-num{font-family:'Wix Madefor Display';font-weight:700;color:var(--ink)}

/* trust marquee */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;background:var(--bg)}
.trust-track{display:inline-flex;padding:18px 0;animation:marquee 38s linear infinite}
.trust-track span{display:inline-flex;align-items:center;font-family:'Wix Madefor Display';font-weight:500;font-size:1rem;color:var(--ink)}
.trust-track i{font-style:normal;color:var(--accent);margin:0 30px;font-size:.7rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* sections + alternating tones */
section{padding:92px 0;position:relative;transition:background .4s ease}
.tone-a{background:var(--bg)}
.tone-b{background:var(--bg-alt)}
.sec-title{font-size:clamp(2rem,4.6vw,3rem);font-weight:600;max-width:18ch;margin:14px 0 16px;letter-spacing:-.025em}
.sec-intro{font-size:1.12rem;color:var(--ink-soft);max-width:50ch}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:40px 34px;transition:transform .35s,border-color .35s}
.card:hover{transform:translateY(-6px);border-color:var(--accent)}
.card .ico{width:52px;height:52px;border-radius:14px;background:var(--accent-tint);display:grid;place-items:center;margin-bottom:26px}
.card .ico svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.6}
.card h3{font-size:1.4rem;font-weight:600;margin-bottom:12px}
.card p{color:var(--ink-soft);font-size:1.02rem}

.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.tier{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:34px 30px;transition:transform .3s,border-color .3s}
.tier:hover{transform:translateY(-4px);border-color:var(--accent)}
.tier .step{font-family:'Wix Madefor Display';font-size:1rem;font-weight:700;color:var(--accent);letter-spacing:.15em}
.tier h3{font-size:1.4rem;margin:16px 0 10px;font-weight:600}
.tier p{color:var(--ink-soft);font-size:.99rem}
.tier .dom{display:inline-block;margin-top:20px;font-size:.76rem;font-weight:600;letter-spacing:.05em;color:var(--accent);background:var(--accent-tint);padding:6px 13px;border-radius:50px}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:58px}
.step-item{padding-top:26px;border-top:1px solid var(--line)}
.step-item .num{font-family:'Wix Madefor Display';font-size:1.05rem;font-weight:700;color:var(--accent);letter-spacing:.1em;display:block;margin-bottom:18px}
.step-item h3{font-size:1.35rem;font-weight:600;margin-bottom:11px}
.step-item p{color:var(--ink-soft)}

.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:52px}
.quote{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:38px 34px}
.stars{color:var(--accent);font-size:.95rem;letter-spacing:4px;margin-bottom:20px}
.quote p{font-family:'Wix Madefor Display';font-size:1.32rem;font-weight:500;line-height:1.4;margin-bottom:22px;letter-spacing:-.01em}
.quote .who{font-weight:600;font-size:.98rem}
.quote .who span{display:block;color:var(--ink-soft);font-weight:400;font-size:.88rem;margin-top:2px}

/* contact anchor */
.contact{background:var(--c-bg);color:var(--c-ink)}
.contact .label{color:var(--accent)}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start}
.contact h2{font-size:clamp(2rem,4.8vw,3.1rem);color:var(--c-ink);font-weight:600;margin:14px 0 18px;max-width:14ch;letter-spacing:-.025em}
.contact .lead{color:var(--c-soft);font-size:1.12rem;max-width:40ch;margin-bottom:34px}
.contact ul{list-style:none;display:flex;flex-direction:column;gap:15px}
.contact ul li{display:flex;gap:13px;align-items:center;color:var(--c-ink);font-size:1.02rem}
.contact ul li svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:2;flex:0 0 auto}
form.enquiry{background:var(--c-card);border-radius:24px;padding:40px}
form.enquiry .row{display:flex;gap:16px}
form.enquiry .field{margin-bottom:18px;flex:1}
form.enquiry label{display:block;font-weight:600;font-size:.88rem;margin-bottom:8px;color:var(--c-cardink)}
form.enquiry label .opt{font-weight:400;opacity:.7}
form.enquiry input,form.enquiry select,form.enquiry textarea{width:100%;font-family:'Wix Madefor Text';font-size:1rem;color:var(--c-cardink);background:var(--c-input);border:1px solid var(--c-line);border-radius:12px;padding:14px 16px;transition:border-color .2s,box-shadow .2s}
form.enquiry input:focus,form.enquiry select:focus,form.enquiry textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,51,146,.22)}
form.enquiry textarea{resize:vertical;min-height:92px}
form.enquiry .btn{width:100%;margin-top:6px}
form.enquiry .reassure{text-align:center;font-size:.84rem;color:var(--c-cardink);opacity:.7;margin-top:15px}
.enq-success{display:none;text-align:center;padding:40px 16px;color:var(--c-cardink)}
.enq-success .big{font-family:'Wix Madefor Display';font-size:1.85rem;font-weight:700;color:var(--c-cardink);margin-bottom:10px;line-height:1.15}
.enq-success p{color:var(--c-cardink);opacity:.78;font-size:1rem;line-height:1.5;max-width:38ch;margin:0 auto}
.enq-success.show{display:block;animation:pop .5s ease}
@keyframes pop{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}

footer{background:var(--bg-alt);border-top:1px solid var(--line);padding:64px 0 38px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:44px;margin-bottom:46px}
.foot-grid h4{font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:18px;color:var(--ink-soft)}
.foot-grid a{display:block;text-decoration:none;margin-bottom:10px;font-weight:500;transition:color .2s}
.foot-grid a:hover{color:var(--accent)}
.foot-logo{height:34px;width:auto;margin-bottom:16px}
.foot-brands a{font-family:'Wix Madefor Display';font-weight:600;font-size:1.04rem}
.foot-brands a small{font-family:'Wix Madefor Text';display:block;font-size:.78rem;color:var(--ink-soft);font-weight:400;margin-top:1px}
.foot-bottom{border-top:1px solid var(--line);padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem;color:var(--ink-soft)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
.hero .label,.hero h1,.hero .lead,.hero .grab-card{opacity:0;animation:rise .8s ease forwards}
.hero .label{animation-delay:.05s}.hero h1{animation-delay:.18s}.hero .lead{animation-delay:.36s}.hero .grab-card{animation-delay:.54s}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

@media(max-width:880px){
  .cards,.tiers,.steps,.quotes{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:44px}
  .foot-grid{grid-template-columns:1fr 1fr}
  form.enquiry .row{flex-direction:column;gap:0}
  .nav-cta{display:none}
  section{padding:66px 0}
  .cluster{opacity:.55}
  .breath-quote{display:none}
  .stat-row{grid-template-columns:1fr;gap:28px;text-align:center}
}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}form.enquiry{padding:28px 22px}}
@media(prefers-reduced-motion:reduce){.trust-track,.glow{animation:none}}
.scales-sec{overflow:hidden}
.scales-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.scales-sec .wrap{position:relative;z-index:2}
html{scroll-snap-type:y proximity}
.scales-sec,.snap,.contact{scroll-snap-align:start}
@media(max-width:880px){html{scroll-snap-type:none}}
.front-eyebrow{display:inline-block;font-family:'Wix Madefor Text';font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--accent);background:var(--accent-tint);padding:5px 11px;border-radius:50px;margin-bottom:13px}
.front-title{font-family:'Wix Madefor Display';font-weight:600;font-size:1.55rem;line-height:1.08;letter-spacing:-.018em;margin-bottom:13px;color:var(--ink)}
.front-sub{font-size:.96rem;color:var(--ink-soft);margin-bottom:18px;line-height:1.45}
.flip-front{display:flex;align-items:center}
.contact{overflow:hidden}
.contact-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip-group .chip{font-family:'Wix Madefor Text';font-weight:500;font-size:.9rem;background:transparent;color:var(--c-cardink);border:1.5px solid var(--c-line);border-radius:50px;padding:9px 16px;cursor:pointer;transition:background .2s,border-color .2s,color .2s,transform .15s}
.chip-group .chip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.chip-group .chip.selected{background:var(--accent);color:#fff;border-color:var(--accent)}
.chip-group.error{animation:chipshake .35s ease}
@keyframes chipshake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.contact-floormask{position:absolute;left:0;width:100%;background:var(--c-bg);z-index:1;display:none;pointer-events:none}

/* Animation explanation pill + shared modal */
.anim-info-btn{position:absolute;bottom:18px;right:24px;z-index:5;
  font-family:'Wix Madefor Text';font-size:.72rem;font-weight:500;letter-spacing:.02em;
  background:var(--c-card);color:var(--ink-soft);border:1px solid var(--c-line);
  padding:6px 13px 6px 11px;border-radius:50px;cursor:pointer;
  opacity:.55;transition:opacity .2s, background .2s, color .2s, border-color .2s;
  display:inline-flex;align-items:center;gap:6px;line-height:1}
.anim-info-btn:hover,.anim-info-btn:focus-visible{opacity:1;background:var(--accent-tint);color:var(--accent);border-color:var(--accent);outline:none}
.anim-info-btn .info-mark{width:14px;height:14px;border-radius:50%;border:1px solid currentColor;
  display:inline-grid;place-items:center;font-style:italic;font-weight:600;font-size:.62rem;line-height:1}
.anim-info-btn.contact{right:auto;left:24px;
  background:rgba(247,243,238,0.06);color:rgba(247,243,238,0.65);border-color:rgba(247,243,238,0.18)}
.anim-info-btn.contact:hover{background:rgba(247,243,238,0.16);color:#fff;border-color:rgba(247,243,238,0.5)}
/* Modal */
.tp-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:24px}
.tp-modal.open{display:flex;animation:tpModalIn .25s ease}
@keyframes tpModalIn{from{opacity:0}to{opacity:1}}
.tp-modal-bg{position:absolute;inset:0;background:rgba(0,0,0,0.45);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);cursor:pointer}
.tp-modal-card{position:relative;background:var(--bg);color:var(--ink);padding:34px 30px 26px;
  border-radius:20px;max-width:540px;width:100%;max-height:82vh;overflow:auto;
  box-shadow:0 24px 60px rgba(0,0,0,0.32);font-family:'Wix Madefor Text';animation:tpCardIn .3s ease}
@keyframes tpCardIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.tp-modal-close{position:absolute;top:14px;right:18px;background:transparent;border:none;
  font-size:1.6rem;line-height:1;cursor:pointer;color:var(--ink-soft);padding:4px 10px;border-radius:50%;transition:background .15s,color .15s}
.tp-modal-close:hover{background:var(--accent-tint);color:var(--accent)}
.tp-modal-title{font-family:'Wix Madefor Display';font-size:1.55rem;font-weight:700;margin:0 0 16px 0;
  color:var(--ink);line-height:1.18;padding-right:32px}
.tp-modal-body{color:var(--ink-soft);line-height:1.62;font-size:.96rem;margin-bottom:22px}
.tp-modal-body p{margin:0 0 14px 0}
.tp-modal-body p:last-child{margin-bottom:0}
.tp-modal-body em{color:var(--ink);font-style:italic}
.tp-modal-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.tp-modal-controls{display:flex;gap:10px;align-items:center;padding-top:18px;border-top:1px solid var(--c-line)}
.tp-modal-controls.hidden{display:none}
.tp-modal-toggle{font-family:'Wix Madefor Text';font-weight:600;font-size:.88rem;
  background:var(--accent);color:#fff;border:0;padding:10px 20px;border-radius:50px;cursor:pointer;transition:opacity .15s}
.tp-modal-toggle:hover{opacity:.92}
/* Footer Privacy / Terms — clickable buttons in place of inert text */
.foot-link-btn{background:transparent;border:0;font:inherit;color:inherit;cursor:pointer;padding:0;
  text-decoration:underline;text-decoration-color:rgba(247,243,238,0.3);text-underline-offset:3px;
  transition:color .15s,text-decoration-color .15s}
.foot-link-btn:hover{color:var(--accent);text-decoration-color:var(--accent)}


/* ===========================================================
 * PLAN BUILDER — wizard page styles
 * =========================================================== */
.plan-builder-page nav .btn-ghost{font-size:.92rem;padding:9px 16px}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--c-line);text-decoration:none;display:inline-block;font-family:'Wix Madefor Text';font-weight:600;padding:11px 22px;border-radius:50px;transition:background .15s,border-color .15s}
.btn-ghost:hover{background:var(--c-card);border-color:var(--ink)}

.wizard-shell{padding:46px 0 80px}
.wizard-header{max-width:720px;margin-bottom:28px}
.wizard-header h1{font-family:'Wix Madefor Display';font-size:clamp(1.65rem,3.4vw,2.4rem);line-height:1.1;font-weight:800;margin:8px 0 14px;letter-spacing:-.01em;color:var(--ink)}
.wizard-lead{color:var(--ink-soft);font-size:1.02rem;line-height:1.6;max-width:62ch}

.wizard-progress{margin:18px 0 10px;max-width:720px}
.wp-bar{height:6px;background:var(--c-line);border-radius:6px;overflow:hidden}
.wp-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-dark));border-radius:6px;transition:width .35s cubic-bezier(.2,.7,.2,1)}
.wp-meta{display:flex;justify-content:space-between;margin-top:8px;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);text-transform:uppercase}
.wp-meta span:last-child{color:var(--accent)}

.wizard-form{max-width:720px}
.wizard-step{display:none;animation:wizStepIn .35s ease}
.wizard-step.active{display:block}
@keyframes wizStepIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.step-eyebrow{font-size:.74rem;font-weight:700;letter-spacing:.08em;color:var(--accent);text-transform:uppercase;margin-bottom:8px}
.wizard-step h2{font-family:'Wix Madefor Display';font-weight:800;font-size:clamp(1.5rem,2.8vw,2rem);line-height:1.12;letter-spacing:-.01em;margin:0 0 6px;color:var(--ink)}
.step-sub{color:var(--accent-dark);font-weight:600;font-size:1.02rem;margin:0 0 28px}

.q-block{margin-bottom:26px}
.q-label{display:block;font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:9px;line-height:1.4}
.q-hint{color:var(--ink-soft);font-size:.88rem;margin:-4px 0 10px;line-height:1.45}
.q-opt{color:var(--ink-soft);font-weight:500;font-size:.88em}

.wizard-chips{display:flex;flex-wrap:wrap;gap:8px;transition:transform .15s}
.wizard-chips.shake{animation:wizShake .38s ease}
@keyframes wizShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.wizard-chips.error{outline:2px dashed var(--accent);outline-offset:6px;border-radius:8px}
.wizard-chips button{
  font-family:'Wix Madefor Text';font-size:.94rem;font-weight:500;
  background:var(--c-card);color:var(--ink);
  border:1.5px solid var(--c-line);
  padding:9px 16px;border-radius:50px;cursor:pointer;
  transition:background .15s,border-color .15s,color .15s,transform .08s;
  line-height:1.2
}
.wizard-chips button:hover{border-color:var(--ink)}
.wizard-chips button.selected{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.wizard-chips button.selected:hover{background:var(--accent-dark);border-color:var(--accent-dark)}

.wizard-form input[type="text"],
.wizard-form input[type="email"],
.wizard-form input[type="tel"],
.wizard-form textarea{
  width:100%;font-family:'Wix Madefor Text';font-size:1rem;
  background:var(--c-card);color:var(--ink);
  border:1.5px solid var(--c-line);
  padding:13px 16px;border-radius:12px;
  transition:border-color .15s,background .15s;
  box-sizing:border-box
}
.wizard-form input:focus,.wizard-form textarea:focus{outline:none;border-color:var(--accent);background:var(--bg)}
.wizard-form input.error,.wizard-form textarea.error{border-color:var(--accent);background:var(--accent-tint)}
.wizard-form textarea{resize:vertical;min-height:88px;line-height:1.5}

.consent-block label{display:flex;gap:12px;align-items:flex-start;cursor:pointer;color:var(--ink-soft);font-size:.95rem;line-height:1.5}
.consent-block input[type="checkbox"]{width:20px;height:20px;flex:0 0 20px;margin-top:2px;accent-color:var(--accent);cursor:pointer}
.consent-block label:hover{color:var(--ink)}
.consent-block.error{outline:2px solid var(--accent);outline-offset:6px;border-radius:8px;animation:wizShake .38s ease}
.consent-block.error label{color:var(--accent-dark)}
.consent-block.error::after{content:"Please tick to confirm before submitting";display:block;margin-top:8px;color:var(--accent);font-size:.86rem;font-weight:600}

.wizard-nav{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:18px 0;
  border-top:1px solid var(--c-line);margin-top:24px;
  position:sticky;bottom:0;background:var(--bg);
  z-index:5;
  /* shadow above to lift off content as it scrolls under */
  box-shadow:0 -8px 16px -8px rgba(43,38,35,0.06);
}
.wizard-nav .btn[disabled]{opacity:.35;cursor:not-allowed}

.wizard-success{max-width:640px;padding:48px 0 20px;animation:wizStepIn .4s ease}
.wizard-success .label{display:inline-block;color:var(--accent);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
.wizard-success h2{font-family:'Wix Madefor Display';font-size:clamp(2rem,4vw,2.8rem);line-height:1.05;font-weight:800;letter-spacing:-.015em;margin:0 0 16px;color:var(--ink)}
.wizard-success p{color:var(--ink-soft);font-size:1.05rem;line-height:1.6;margin-bottom:26px;max-width:54ch}
.wizard-success .btn{margin-bottom:18px}
.wizard-success .success-foot{font-size:.92rem;color:var(--ink-soft);margin:0}
.wizard-success .success-foot a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

@media(max-width:680px){
  .wizard-shell{padding:30px 0 50px}
  .wizard-header h1{font-size:1.55rem}
  .wizard-chips button{font-size:.88rem;padding:8px 14px}
  .wizard-nav{flex-direction:row}
  .wizard-nav .btn{padding:11px 18px;font-size:.95rem}
}
/* ===========================================================
 * CALENDAR BOOKING WIDGET
 * Appended to css/style.css
 * =========================================================== */

.cal-widget{
  max-width:520px;
  margin:32px 0 8px;
  border:1.5px solid var(--c-line);
  border-radius:18px;
  padding:24px;
  background:var(--c-card);
}

.cal-month-row{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;
}
.cal-month-label{
  font-family:'Wix Madefor Display';font-weight:700;font-size:1.08rem;color:var(--ink);
}
.cal-nav{
  width:36px;height:36px;border-radius:50%;border:1.5px solid var(--c-line);
  background:transparent;color:var(--ink);font-size:1.4rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:background .15s,border-color .15s,color .15s;
  font-family:'Wix Madefor Text';font-weight:600;
}
.cal-nav:hover:not(:disabled){background:var(--accent-tint);border-color:var(--accent);color:var(--accent)}
.cal-nav:disabled{opacity:.3;cursor:not-allowed}

.cal-dow{
  display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;
}
.cal-dow span{
  text-align:center;font-size:.72rem;font-weight:600;letter-spacing:.05em;
  color:var(--ink-soft);text-transform:uppercase;
}

.cal-days{
  display:grid;grid-template-columns:repeat(7,1fr);gap:4px;
}
.cal-day{
  aspect-ratio:1;min-height:36px;
  border:1.5px solid transparent;background:transparent;border-radius:8px;
  color:var(--ink);font-family:'Wix Madefor Text';font-size:.95rem;font-weight:500;
  cursor:pointer;display:grid;place-items:center;
  transition:background .12s,border-color .12s,color .12s;padding:0;
}
.cal-day:not(:disabled):hover{background:var(--accent-tint);color:var(--accent-dark)}
.cal-day:disabled{opacity:.28;cursor:not-allowed;color:var(--ink-soft)}
.cal-day.has-slots{border-color:var(--c-line)}
.cal-day.today:not(:disabled){font-weight:700;border-color:var(--accent);color:var(--accent)}
.cal-day.selected{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;font-weight:700}
.cal-day.empty{visibility:hidden;cursor:default}

.cal-panel{
  margin-top:22px;padding-top:22px;border-top:1px solid var(--c-line);
  animation:calPanelIn .26s ease;
}
@keyframes calPanelIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.cal-panel-title{
  font-family:'Wix Madefor Display';font-weight:700;font-size:1.04rem;
  color:var(--ink);margin:0 0 6px;line-height:1.25;
}
.cal-panel-sub{
  font-size:.9rem;color:var(--ink-soft);margin:0 0 16px;line-height:1.5;
}

.cal-slots{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:6px;
}
.cal-slot{
  padding:9px 6px;font-family:'Wix Madefor Text';font-size:.88rem;font-weight:600;
  border:1.5px solid var(--c-line);background:transparent;border-radius:50px;
  color:var(--ink);cursor:pointer;text-align:center;
  transition:background .12s,border-color .12s,color .12s,transform .08s;
}
.cal-slot:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}

.cal-form-panel input,
.cal-form-panel textarea{
  width:100%;font-family:'Wix Madefor Text';font-size:1rem;
  padding:12px 14px;border:1.5px solid var(--c-line);border-radius:12px;
  background:var(--bg);color:var(--ink);margin-bottom:10px;box-sizing:border-box;
  transition:border-color .15s,background .15s;
}
.cal-form-panel input:focus,
.cal-form-panel textarea:focus{outline:none;border-color:var(--accent)}
.cal-form-panel input.error,
.cal-form-panel textarea.error{border-color:var(--accent);background:var(--accent-tint)}
.cal-form-panel textarea{resize:vertical;min-height:72px;line-height:1.5}

.cal-form-actions{
  display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:12px;
}
.cal-form-actions .btn{padding:11px 22px;font-size:.95rem}

.cal-success-panel{padding:12px 0 4px}
.cal-success-panel .cal-panel-title{color:var(--accent-dark)}
.cal-success-panel .btn{margin-top:14px;display:inline-block}
.cal-success-panel p{font-size:.95rem;color:var(--ink-soft);line-height:1.5;margin:0 0 10px}

.cal-error{
  margin-top:14px;padding:14px 16px;border-radius:12px;
  background:var(--accent-tint);color:var(--accent-dark);
  font-size:.9rem;line-height:1.55;
}
.cal-error a{color:var(--accent-dark);text-decoration:underline;font-weight:600}

@media(max-width:520px){
  .cal-widget{padding:18px}
  .cal-day{font-size:.86rem;min-height:32px}
  .cal-form-actions{flex-direction:column-reverse;align-items:stretch}
  .cal-form-actions .btn{width:100%;text-align:center;justify-content:center}
}

/* booking section intro on wizard success */
.booking-intro{
  margin:48px 0 12px;
  padding-top:36px;
  border-top:1px solid var(--c-line);
  max-width:560px;
}
.booking-intro .label{margin-bottom:10px;display:inline-block}
.booking-intro h3{
  font-family:'Wix Madefor Display';font-weight:800;font-size:1.6rem;line-height:1.15;
  letter-spacing:-.01em;margin:6px 0 12px;color:var(--ink);
}
.booking-intro p{
  font-size:1rem;color:var(--ink-soft);line-height:1.55;margin:0;
  max-width:54ch;
}
