/* ===== Pal Massage Therapy — luxury spa theme ===== */
:root{
  --cream:#FBF6F2;
  --cream-2:#F4EAE4;
  --blush:#E7C9CF;
  --blush-soft:#F3DCDF;
  --mauve:#B98DA8;
  --mauve-deep:#8E5E7E;
  --plum:#3C2536;
  --plum-soft:#5A3C50;
  --gold:#C2A36B;
  --gold-soft:#E4D2AE;
  --ink:#2A1B26;
  --muted:#7B6470;
  --line:rgba(60,37,54,.12);
  --white:#fff;
  --shadow:0 18px 50px -24px rgba(60,37,54,.45);
  --shadow-sm:0 8px 24px -16px rgba(60,37,54,.45);
  --r:18px;
  --maxw:1180px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Jost',-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* soft atmospheric glows + grain, not a flat gradient */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(40rem 30rem at 12% -8%, rgba(231,201,207,.55), transparent 60%),
    radial-gradient(46rem 34rem at 108% 8%, rgba(185,141,168,.30), transparent 55%),
    radial-gradient(50rem 40rem at 50% 120%, rgba(226,210,174,.30), transparent 60%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  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='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-.01em;color:var(--plum)}
.eyebrow{
  font-family:var(--sans);font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-deep);font-weight:600;margin-bottom:.9rem;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);
  vertical-align:middle;margin-right:.7rem;transform:translateY(-3px)}
.serif-italic{font-style:italic;color:var(--mauve-deep)}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-weight:500;font-size:.95rem;letter-spacing:.02em;
  padding:.95rem 1.8rem;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,background .35s,color .35s;
}
.btn-primary{background:var(--plum);color:var(--cream);box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow);background:var(--plum-soft)}
.btn-ghost{background:transparent;color:var(--plum);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--mauve);color:var(--mauve-deep);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),#d8be8a);color:#42371d}
.btn-gold:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* ===== header ===== */
.site-head{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(12px);
  background:rgba(251,246,242,.7);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.brand{font-family:var(--serif);font-size:1.45rem;color:var(--plum);letter-spacing:.01em}
.brand b{font-weight:600}
.brand span{color:var(--mauve-deep);font-style:italic}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.92rem;color:var(--plum-soft);position:relative;padding:.2rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1.5px;background:var(--gold);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.menu-btn{display:none;background:none;border:0;font-size:1.5rem;color:var(--plum);cursor:pointer}

/* ===== hero ===== */
.hero{position:relative;padding:6.5rem 0 5rem;text-align:center}
.hero .leaf{position:absolute;opacity:.5;pointer-events:none}
.hero h1{font-size:clamp(2.8rem,7vw,5.4rem);margin:.4rem 0 1.2rem}
.hero h1 em{font-style:italic;color:var(--mauve-deep)}
.hero p.lead{font-size:1.18rem;color:var(--muted);max-width:38rem;margin:0 auto 2.2rem}
.hero .actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero .trust{margin-top:2.6rem;font-size:.85rem;letter-spacing:.06em;color:var(--mauve-deep)}
.hero .trust b{color:var(--plum)}

/* ===== section shell ===== */
.section{padding:5rem 0}
.section-head{max-width:42rem;margin-bottom:3rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,4.5vw,3.1rem)}
.section-head p{color:var(--muted);margin-top:1rem;font-size:1.05rem}

/* ===== service cards ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  padding:2.2rem 1.9rem;box-shadow:var(--shadow-sm);
  transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s;position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--blush),var(--mauve),var(--gold))}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.2rem;
  background:linear-gradient(135deg,var(--blush-soft),var(--cream-2));font-size:1.5rem}
.card h3{font-size:1.45rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.96rem}
.card .more{margin-top:1.2rem;font-size:.85rem;letter-spacing:.04em;color:var(--mauve-deep);font-weight:600}

/* ===== about ===== */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center}
.about .portrait{
  aspect-ratio:4/5;border-radius:var(--r);background:
    linear-gradient(160deg,var(--mauve),var(--plum));position:relative;overflow:hidden;box-shadow:var(--shadow)}
.about .portrait::after{content:"P";position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--serif);font-size:9rem;color:rgba(255,255,255,.16)}
.about blockquote{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--plum);
  line-height:1.4;margin:1.4rem 0;border-left:2px solid var(--gold);padding-left:1.2rem}

/* ===== pricing ===== */
.price-block{background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:1.6rem}
.price-block summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  padding:1.7rem 2rem;background:linear-gradient(90deg,var(--cream-2),transparent)}
.price-block summary::-webkit-details-marker{display:none}
.price-block summary h3{font-size:1.6rem}
.price-block summary .from{font-size:.85rem;color:var(--mauve-deep);letter-spacing:.04em}
.price-block[open] summary{border-bottom:1px solid var(--line)}
.price-rows{padding:.6rem 2rem 1.7rem}
.price-row{display:flex;justify-content:space-between;gap:1rem;padding:1rem 0;border-bottom:1px dashed var(--line)}
.price-row:last-child{border-bottom:0}
.price-row .name{font-weight:500;color:var(--plum)}
.price-row .desc{font-size:.86rem;color:var(--muted);margin-top:.15rem}
.price-row .amt{font-family:var(--serif);font-size:1.25rem;color:var(--mauve-deep);white-space:nowrap}
.addon-head{font-family:var(--sans);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--mauve-deep);margin:1.4rem 0 .2rem;font-weight:600}
.tag-free{font-size:.7rem;letter-spacing:.06em;background:var(--gold-soft);color:#5b4a1f;
  padding:.15rem .55rem;border-radius:999px;text-transform:uppercase;font-weight:600}

/* ===== reviews (masonry, variable heights) ===== */
.reviews-masonry{columns:3;column-gap:1.3rem}
.review{break-inside:avoid;margin-bottom:1.3rem;background:var(--white);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.review img{width:100%}
.review .body{padding:1.3rem 1.4rem}
.review .stars{color:var(--gold);letter-spacing:.1em;margin-bottom:.5rem}
.review .who{font-weight:600;color:var(--plum);font-size:.92rem;margin-top:.6rem}
.review .src{font-size:.74rem;color:var(--muted);letter-spacing:.05em}

/* ===== blog ===== */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.post{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .4s}
.post:hover{transform:translateY(-5px)}
.post .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--blush-soft),var(--cream-2))}
.post .pad{padding:1.5rem 1.5rem 1.7rem}
.post h3{font-size:1.25rem;line-height:1.25;margin-bottom:.5rem}
.post p{color:var(--muted);font-size:.9rem}
.post .date{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mauve-deep);margin-bottom:.6rem}

/* ===== CTA band ===== */
.cta{margin:2rem 0 0;border-radius:28px;background:linear-gradient(150deg,var(--plum),var(--mauve-deep));
  color:var(--cream);text-align:center;padding:4.5rem 2rem;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta h2{color:var(--cream);font-size:clamp(2rem,5vw,3.2rem)}
.cta p{opacity:.85;max-width:34rem;margin:1rem auto 2rem}

/* ===== footer ===== */
.site-foot{padding:4rem 0 2.5rem;border-top:1px solid var(--line);margin-top:5rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem}
.foot-grid p{color:var(--muted);font-size:.92rem;margin-top:.8rem;max-width:24rem}
.foot-col h4{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--plum);margin-bottom:1rem;font-family:var(--sans);font-weight:600}
.foot-col a{display:block;color:var(--muted);font-size:.92rem;padding:.3rem 0;transition:color .25s}
.foot-col a:hover{color:var(--mauve-deep)}
.foot-bottom{margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:var(--muted);font-size:.82rem}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== responsive ===== */
@media(max-width:900px){
  .cards,.posts{grid-template-columns:1fr 1fr}
  .reviews-masonry{columns:2}
  .about{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:640px){
  .nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;background:var(--cream);
    padding:1.5rem 24px 2rem;gap:1.2rem;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s;box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .menu-btn{display:block}
  .cards,.posts{grid-template-columns:1fr}
  .reviews-masonry{columns:1}
  .foot-grid{grid-template-columns:1fr;gap:1.8rem}
  .section{padding:3.5rem 0}
}

/* ===== responsive enhancements v2 (all-device) ===== */
@media (max-width:1000px){
  .cards,.posts{grid-template-columns:repeat(2,1fr)}
  .reviews-masonry{columns:2}
}
@media (max-width:880px){
  .menu-btn{display:block}
  .nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;background:var(--cream);
    padding:1.5rem 24px 2rem;gap:1.1rem;border-bottom:1px solid var(--line);
    transform:translateY(-150%);transition:transform .4s;box-shadow:var(--shadow);z-index:60}
  .nav-links.open{transform:none}
  .about{grid-template-columns:1fr;gap:2rem}
  .about .portrait{max-width:420px;margin:0 auto}
}
@media (max-width:760px){
  .section{padding:3.5rem 0}
  .section-head{margin-bottom:2.2rem}
  .foot-grid{grid-template-columns:1fr;gap:1.8rem}
  .price-block summary{padding:1.3rem 1.3rem}
  .price-block summary h3{font-size:1.3rem}
  .price-rows{padding:.4rem 1.3rem 1.4rem}
  .cta{padding:3.2rem 1.3rem;border-radius:22px}
}
@media (max-width:620px){
  .wrap{padding:0 18px}
  .cards,.posts{grid-template-columns:1fr}
  .reviews-masonry{columns:1}
  .hero{padding:3.6rem 0 2.8rem}
  .hero p.lead{font-size:1.05rem}
  .hero .actions{flex-direction:column;align-items:stretch}
  .hero .actions .btn{width:100%;justify-content:center}
  .nav-cta .btn-primary{padding:.65rem 1rem;font-size:.82rem}
  .price-row{flex-wrap:wrap}
  .price-row .amt{margin-top:.15rem}
  .brand{font-size:1.18rem}
  .btn{padding:.85rem 1.5rem}
}
@media (max-width:380px){
  .brand span{display:none}
  .nav-cta .btn-primary{font-size:.78rem;padding:.6rem .85rem}
}

/* ===== blog pages ===== */
.page-head{padding:4rem 0 1rem;text-align:center}
.back-link{font-size:.85rem;color:var(--mauve-deep);letter-spacing:.04em}
.back-link:hover{color:var(--plum)}
.article-meta{color:var(--muted);font-size:.85rem;letter-spacing:.05em;margin-top:.8rem}
.article-hero-img{display:block;max-width:46rem;width:100%;margin:1.6rem auto 0;border-radius:var(--r);box-shadow:var(--shadow-sm)}
.article{max-width:46rem;margin:0 auto;padding:1.5rem 0 1rem}
.article-body{font-size:1.06rem;line-height:1.8;color:#3c2b37}
.article-body h2,.article-body h3{font-family:var(--serif);color:var(--plum);line-height:1.2;margin:2rem 0 .7rem}
.article-body h3{font-size:1.4rem}
.article-body p{margin:0 0 1.15rem}
.article-body ul,.article-body ol{margin:0 0 1.2rem 1.3rem}
.article-body li{margin:.35rem 0}
.article-body a{color:var(--mauve-deep);text-decoration:underline}
.article-cta{margin:2.5rem 0 1rem;padding:2rem;text-align:center;background:linear-gradient(150deg,var(--blush-soft),var(--cream-2));border-radius:var(--r)}
.article-cta p{font-family:var(--serif);font-size:1.3rem;color:var(--plum);margin-bottom:1.1rem}
.view-all-wrap{text-align:center;margin-top:2.6rem}
a.post{color:inherit;display:block}

/* ===== message builder ===== */
.mb-modal{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding:5vh 16px}
.mb-modal.open{display:flex}
.mb-backdrop{position:absolute;inset:0;background:rgba(42,27,38,.55);backdrop-filter:blur(4px)}
.mb-panel{position:relative;z-index:1;width:100%;max-width:560px;background:var(--cream);border:1px solid var(--line);
  border-radius:22px;box-shadow:var(--shadow);padding:2rem 1.9rem 2.2rem;max-height:90vh;overflow:auto}
.mb-close{position:absolute;top:1rem;right:1.1rem;background:none;border:0;font-size:1.7rem;line-height:1;color:var(--muted);cursor:pointer}
.mb-close:hover{color:var(--plum)}
.mb-head{margin-bottom:1.4rem}
.mb-head h3{font-size:1.7rem;margin:.2rem 0 .4rem}
.mb-head p{color:var(--muted);font-size:.95rem}
.mb-field{margin-bottom:1.2rem}
.mb-field>label{display:block;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mauve-deep);font-weight:600;margin-bottom:.6rem}
.mb-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.mb-input{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:var(--white);
  border:1px solid var(--line);border-radius:12px;padding:.7rem .85rem}
.mb-input:focus{outline:none;border-color:var(--mauve)}
textarea.mb-preview{resize:vertical;line-height:1.5;color:var(--plum-soft)}
.mb-services{display:flex;flex-direction:column;gap:.9rem;max-height:230px;overflow:auto;border:1px solid var(--line);border-radius:14px;padding:.9rem 1rem;background:var(--white)}
.mb-svc-name{font-family:var(--serif);font-size:1.05rem;color:var(--plum);margin-bottom:.35rem}
.mb-check{display:flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--plum-soft);padding:.2rem 0;cursor:pointer}
.mb-check input{accent-color:var(--mauve-deep);width:16px;height:16px}
.mb-radios{display:flex;gap:.5rem;flex-wrap:wrap}
.mb-pill{position:relative}
.mb-pill input{position:absolute;opacity:0}
.mb-pill span{display:inline-block;padding:.5rem 1rem;border:1px solid var(--line);border-radius:999px;font-size:.88rem;color:var(--plum-soft);cursor:pointer;transition:.25s}
.mb-pill input:checked+span{background:var(--plum);color:var(--cream);border-color:var(--plum)}
.mb-send{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem}
.mb-send .btn{flex:1;justify-content:center;min-width:150px}
.mb-toast{margin-top:1rem;font-size:.88rem;color:var(--mauve-deep);background:var(--blush-soft);border-radius:12px;padding:.7rem .9rem}
.cf-turnstile{margin-top:.4rem}
@media(max-width:560px){.mb-row{grid-template-columns:1fr}.mb-panel{padding:1.6rem 1.2rem 1.8rem}}

/* ===== per-channel branded send buttons ===== */
.mb-channel-btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;border:1px solid;border-radius:999px;transition:filter .2s,transform .2s}
.mb-channel-btn:hover{filter:brightness(.93);transform:translateY(-1px)}
.mb-channel-btn .mb-ic{display:inline-flex;align-items:center}
.mb-channel-btn .mb-ic svg{display:block;width:18px;height:18px}
.mb-channel-btn span{line-height:1}

/* ===== outcall surcharge: front-page callout ===== */
.outcall-note{display:flex;align-items:center;gap:1rem;margin-top:1.6rem;padding:1.1rem 1.4rem;
  background:var(--blush-soft);border:1px solid var(--line);border-radius:16px}
.outcall-note p{margin:0;color:var(--plum-soft);font-size:.97rem;line-height:1.5}
.outcall-badge{flex:none;display:inline-flex;align-items:center;justify-content:center;min-width:64px;height:44px;
  padding:0 .9rem;border-radius:12px;background:var(--plum);color:var(--cream);
  font-family:var(--serif);font-size:1.25rem;font-weight:600;letter-spacing:.01em}
@media(max-width:560px){.outcall-note{flex-direction:column;align-items:flex-start;gap:.7rem}}

/* ===== outcall surcharge: builder live summary ===== */
.mb-summary{margin:-.4rem 0 .2rem}
.mb-surcharge-line{display:none;align-items:center;gap:.6rem;font-size:.9rem;color:var(--mauve-deep);margin-bottom:.5rem}
.mb-sur-badge{display:inline-flex;align-items:center;background:var(--plum);color:var(--cream);
  font-weight:600;border-radius:999px;padding:.18rem .6rem;font-size:.82rem}
.mb-total-line{font-size:1rem;color:var(--plum)}
.mb-total-line strong{font-family:var(--serif);font-size:1.15rem;color:var(--plum)}

/* ===== brand logo ===== */
.brand-logo{height:38px;width:auto;display:block}

/* ===== service detail page ===== */
.svc-from{display:inline-block;margin-top:1rem;font-family:var(--serif);font-size:1.15rem;color:var(--mauve-deep)}
.svc-detail{padding-top:1.2rem}
.svc-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:2.4rem;align-items:start}
.svc-body{color:var(--plum-soft);font-size:1.05rem;line-height:1.75}
.svc-body p{margin:0 0 1rem}
.svc-card{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:1.6rem 1.5rem;box-shadow:var(--shadow);position:sticky;top:100px}
.svc-card h3{font-size:1.3rem;margin:0 0 1rem}
.svc-note{margin:1rem 0 1.2rem;font-size:.85rem;color:var(--muted);line-height:1.5}
.svc-cta{width:100%;justify-content:center}
.svc-related{margin-top:3.5rem}
.svc-related h2{text-align:center;margin-bottom:1.6rem}
a.card{text-decoration:none;color:inherit;display:block}
@media(max-width:820px){.svc-grid{grid-template-columns:1fr;gap:1.6rem}.svc-card{position:static}}

/* ===== combo discount line in builder ===== */
.mb-combo-line{display:none;align-items:center;gap:.6rem;font-size:.9rem;color:#2f7d52;margin-bottom:.5rem}
.mb-combo-badge{display:inline-flex;align-items:center;background:#2f7d52;color:#fff;
  font-weight:600;border-radius:999px;padding:.18rem .6rem;font-size:.82rem}

/* ===== service detail rich content blocks ===== */
.svc-block{margin-top:2rem}
.svc-block h2{font-size:1.4rem;margin-bottom:.6rem}
.svc-rich{color:var(--plum-soft);line-height:1.7}
.svc-rich ul{margin:.4rem 0 .6rem;padding-left:1.1rem}
.svc-rich li{margin-bottom:.4rem}
.svc-rich p{margin-bottom:.8rem}
.svc-rich strong{color:var(--plum)}

/* ===== galleries (photo + carousell) ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery-item{position:relative;border-radius:14px;overflow:hidden;background:var(--card,#fff);
  box-shadow:0 6px 20px rgba(60,30,50,.08);display:block;text-decoration:none}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/5;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-cap{position:absolute;left:0;right:0;bottom:0;padding:.6rem .7rem;font-size:.8rem;color:#fff;
  background:linear-gradient(transparent, rgba(40,20,35,.75))}

/* ===== footer social ===== */
.foot-social{display:flex;gap:1rem;margin-top:1rem}
.foot-social a{font-size:.85rem;color:var(--muted);text-decoration:none;border-bottom:1px solid transparent}
.foot-social a:hover{color:var(--plum);border-bottom-color:currentColor}

/* ===== reviews carousel ===== */
.rev-carousel{position:relative;display:flex;align-items:center;gap:.5rem;margin-top:1.5rem}
.rev-viewport{overflow:hidden;flex:1}
.rev-track{display:flex;gap:1rem;will-change:transform}
.rev-card{
  flex:0 0 calc((100% - 2rem) / 3);  /* 3 per view (gap 1rem x2) */
  box-sizing:border-box;height:240px;display:flex;flex-direction:column;
  background:var(--card,#fff);border-radius:16px;padding:1.3rem;
  box-shadow:0 8px 24px rgba(60,30,50,.08);overflow:hidden
}
.rev-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}
.rev-stars{color:#f3a712;letter-spacing:1px;font-size:1rem}
.rev-src{font-size:.72rem;font-weight:600;padding:.15rem .55rem;border-radius:999px}
.rev-src-google{background:#eef3ff;color:#3367d6}
.rev-src-carousell{background:#ffeede;color:#d2620a}
.rev-body{color:var(--plum-soft);line-height:1.6;font-size:.92rem;flex:1;margin:0;overflow:hidden}
.rev-more{align-self:flex-start;background:none;border:none;color:var(--mauve-deep);font-weight:600;
  cursor:pointer;padding:.3rem 0;font-size:.85rem}
.rev-who{margin-top:.5rem;font-weight:600;color:var(--plum)}
.rev-arrow{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1px solid var(--line,#e7dce3);
  background:var(--card,#fff);color:var(--plum);font-size:1.4rem;line-height:1;cursor:pointer;
  box-shadow:0 4px 12px rgba(60,30,50,.08);transition:background .2s}
.rev-arrow:hover{background:var(--blush,#f7eef3)}

@media (max-width:720px){
  .rev-card{flex:0 0 100%;height:auto;min-height:220px}
}

/* ===== review modal ===== */
.rev-modal[hidden]{display:none}
.rev-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.2rem}
.rev-modal-backdrop{position:absolute;inset:0;background:rgba(40,20,35,.55)}
.rev-modal-card{position:relative;max-width:540px;width:100%;background:#fff;border-radius:18px;
  padding:2rem;box-shadow:0 24px 60px rgba(40,20,35,.3)}
.rev-modal-x{position:absolute;top:.8rem;right:1rem;background:none;border:none;font-size:1.6rem;
  color:var(--muted);cursor:pointer;line-height:1}
.rev-modal-stars{color:#f3a712;letter-spacing:2px;font-size:1.1rem;margin-bottom:.8rem}
.rev-modal-body{color:var(--plum-soft);line-height:1.7;margin:0 0 1rem}
.rev-modal-who{font-weight:600;color:var(--plum)}
.rev-modal-src{font-size:.82rem;color:var(--muted)}

/* ===== booking builder styles (restored + sticky page bar) ===== */
.mb-price .mb-old{color:var(--muted);opacity:.7;margin-right:.3rem;text-decoration:line-through}
.mb-price .mb-new{color:#e0566f;font-weight:600}
.mb-missing{font-size:.85rem;color:#b4452f;background:#fbeae6;border:1px solid #f1c9bf;
  padding:.55rem .75rem;border-radius:10px;margin-bottom:.7rem;line-height:1.4}
.mb-channel-btn.mb-disabled,
.mb-channel-btn:disabled{opacity:.45 !important;cursor:not-allowed !important;
  filter:grayscale(.4) !important;pointer-events:none !important}
.mb-time-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.mb-time-row .mb-datetime{flex:1;min-width:180px}
.mb-anytime-pill{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;white-space:nowrap}
.mb-anytime-pill input{accent-color:var(--mauve-deep)}
.mb-datetime:disabled{opacity:.45;cursor:not-allowed}

.nav-book{margin:.35rem 0;display:inline-flex;align-items:center}

/* ===== /book + /whatsapp + /telegram: sticky send bar ===== */
.page-builder{padding-bottom:6.5rem}
.mb-send-sticky{
  position:sticky;bottom:0;left:0;right:0;z-index:50;
  display:flex;gap:.6rem;flex-wrap:wrap;
  background:rgba(250,245,242,.96);backdrop-filter:blur(6px);
  padding:.8rem;margin:0 -.8rem -.8rem;border-top:1px solid var(--line);
  box-shadow:0 -6px 20px rgba(60,30,50,.08)}
.mb-send-sticky .mb-channel-btn{flex:1;min-width:140px}
@media (max-width:720px){
  .mb-send-sticky{position:fixed;margin:0;border-radius:0;padding:.7rem .9rem}
  .page-builder{padding-bottom:7.5rem}
}

/* ===== horizontal carousel (blog posts + photo gallery) ===== */
.hcar{position:relative;display:flex;align-items:center;gap:.5rem;margin-top:1.5rem}
.hcar-track{
  display:flex;gap:1.4rem;flex:1;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:.3rem .2rem 1rem;
  scrollbar-width:none}
.hcar-track::-webkit-scrollbar{display:none}
/* override the grid layouts so they lay out in a row inside the carousel */
.hcar-track.posts{grid-template-columns:none;display:flex}
.hcar-track.gallery-row{display:flex}

/* fixed-width cards so the carousel scrolls one at a time nicely */
.hcar-track .post{flex:0 0 clamp(260px, 80%, 340px);scroll-snap-align:start}
.hcar-track .gallery-item{flex:0 0 clamp(220px, 70%, 280px);scroll-snap-align:start}

.hcar-arrow{flex:0 0 auto;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);background:var(--white,#fff);color:var(--plum);
  font-size:1.4rem;line-height:1;cursor:pointer;box-shadow:0 4px 12px rgba(60,30,50,.08);
  transition:background .2s,opacity .2s}
.hcar-arrow:hover{background:var(--blush,#f7eef3)}
.hcar-arrow:disabled{opacity:.3;cursor:default}

@media (max-width:720px){
  .hcar-arrow{display:none}   /* mobile: swipe only, no arrows */
  .hcar-track .post{flex:0 0 86%}
  .hcar-track .gallery-item{flex:0 0 72%}
}
