:root{
  --cream:#f8f2e9;
  --cream-2:#f2e9da;
  --card:#efe5d4;
  --card-2:#f4ecdd;
  --band:#e8dcc6;
  --ink:#4b4138;
  --ink-soft:#6e6052;
  --muted:#9c8c75;
  --gold:#b08a55;
  --gold-deep:#9a7642;
  --gold-soft:#c8a878;
  --line:rgba(120,96,62,.18);
  --line-soft:rgba(120,96,62,.1);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(60% 50% at 80% 0%, #fbf6ee, transparent 70%),
    linear-gradient(180deg,#f9f3ea,#f3ebdc);
  background-attachment:fixed;
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--gold);color:#fff}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px;position:relative;z-index:2}
.serif{font-family:var(--serif)}

/* palm shadow accent */
.palm{position:absolute;top:-40px;left:-80px;width:420px;opacity:.07;color:var(--gold-deep);pointer-events:none;z-index:0}

/* ---------- NAV ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 40px;transition:.4s;border-bottom:1px solid transparent;
}
nav.scrolled{background:rgba(248,242,233,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:13px 40px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:18px;letter-spacing:.34em;font-weight:500;color:var(--gold-deep);text-transform:uppercase}
.brand .mono{font-size:20px;letter-spacing:0;border:1px solid var(--gold);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-weight:500;color:var(--gold-deep)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{color:var(--ink-soft);text-decoration:none;font-size:12px;letter-spacing:.16em;text-transform:uppercase;transition:.3s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:.35s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-cta{border:1px solid var(--gold);color:var(--gold-deep)!important;padding:10px 22px;border-radius:40px}
.nav-cta:hover{background:var(--gold);color:#fff!important}
.nav-cta::after{display:none}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:6px}
.burger span{display:block;width:26px;height:1.5px;background:var(--ink);transition:.3s}

/* ---------- HERO ---------- */
header{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:120px 0 80px}
.hero-inner{position:relative;z-index:3;max-width:760px}
.hero-mono{font-family:var(--serif);font-size:46px;color:var(--gold-deep);border:1.5px solid var(--gold);border-radius:50%;width:96px;height:96px;display:flex;align-items:center;justify-content:center;margin:0 auto 30px;font-weight:500;letter-spacing:.02em}
.hero-title{font-family:var(--serif);font-weight:400;font-size:clamp(44px,9vw,92px);line-height:1;letter-spacing:.12em;text-transform:uppercase;
  background:linear-gradient(180deg,#bd9760,#977340);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-eyebrow{font-size:13px;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);margin:22px 0 0}
.hero-divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:30px auto 26px;color:var(--gold)}
.hero-divider::before,.hero-divider::after{content:"";width:60px;height:1px;background:var(--gold);opacity:.6}
.hero-divider span{font-size:8px}
.hero-sub{font-size:18px;color:var(--ink-soft);max-width:520px;margin:0 auto 40px;line-height:1.7}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center;justify-content:center}
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-size:12px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;
  padding:16px 32px;border-radius:48px;transition:.4s;border:1px solid var(--gold);}
.btn-primary{background:var(--gold-deep);color:#fff;border-color:var(--gold-deep)}
.btn-primary:hover{background:var(--gold);transform:translateY(-2px);box-shadow:0 16px 36px -14px rgba(154,118,66,.6)}
.btn-ghost{color:var(--gold-deep);background:transparent}
.btn-ghost:hover{background:rgba(176,138,85,.1)}

/* opening offer badge */
.offer-badge{position:absolute;top:120px;right:6%;z-index:4;width:130px;height:130px;border-radius:50%;
  border:1px solid var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  background:rgba(255,255,255,.4);color:var(--gold-deep);transform:rotate(-8deg)}
.offer-badge .o1{font-size:9px;letter-spacing:.22em;text-transform:uppercase}
.offer-badge .o2{font-family:var(--serif);font-size:40px;line-height:.9;margin:2px 0}
.offer-badge .o3{font-size:8px;letter-spacing:.18em;text-transform:uppercase;max-width:90px}

/* ---------- SECTION HEAD ---------- */
.section-head{text-align:center;margin-bottom:60px}
.section-head .eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:14px}
.section-head .eyebrow::before,.section-head .eyebrow::after{content:"";width:40px;height:1px;background:var(--gold)}
.section-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5vw,58px);line-height:1.08;color:var(--ink);margin-top:14px;letter-spacing:.04em}
.section-head h2 em{font-style:italic;color:var(--gold-deep)}
.section-head p{color:var(--ink-soft);max-width:560px;margin:16px auto 0;font-size:16px}

/* ---------- INTRO ---------- */
.intro{padding:120px 0 30px;text-align:center}
.intro .lead{font-family:var(--serif);font-style:italic;font-size:clamp(26px,4vw,40px);line-height:1.35;color:var(--ink);max-width:820px;margin:0 auto}
.intro .lead em{color:var(--gold-deep);font-style:italic}

/* ---------- TREATMENTS ---------- */
.treatments{padding:100px 0}
.treat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.treat-card{background:var(--card-2);border:1px solid var(--line-soft);border-radius:14px;padding:38px 32px;transition:.4s}
.treat-card:hover{transform:translateY(-5px);box-shadow:0 24px 50px -28px rgba(120,90,50,.35);border-color:var(--line)}
.treat-ic{width:62px;height:62px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:20px;background:rgba(255,255,255,.4)}
.treat-ic svg{width:30px;height:30px}
.treat-card h3{font-family:var(--serif);font-weight:500;font-size:24px;color:var(--ink);margin-bottom:10px;letter-spacing:.02em}
.treat-card p{color:var(--ink-soft);font-size:14.5px}

/* ---------- PRICE LIST ---------- */
.prices{padding:60px 0 110px;position:relative}
.price-ribbon{text-align:center;margin-bottom:50px}
.price-ribbon span{display:inline-block;border:1px solid var(--gold);color:var(--gold-deep);border-radius:40px;padding:9px 26px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;background:rgba(255,255,255,.5)}
.price-grid{column-count:2;column-gap:26px}
.price-cat{background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:0 0 18px;overflow:hidden;break-inside:avoid;-webkit-column-break-inside:avoid;margin-bottom:26px}
.cat-head{display:flex;align-items:center;gap:16px;padding:24px 30px 18px}
.cat-ic{width:50px;height:50px;min-width:50px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);background:rgba(255,255,255,.45)}
.cat-ic svg{width:26px;height:26px}
.cat-head h3{font-family:var(--serif);font-weight:500;font-size:23px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}
.cat-cols{display:grid;grid-template-columns:1fr 64px 76px 86px;gap:8px;padding:0 30px 8px;border-bottom:1px solid var(--line);}
.cat-cols span{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.3}
.cat-cols span:first-child{text-align:left}
.cat-row{display:grid;grid-template-columns:1fr 64px 76px 86px;gap:8px;padding:13px 30px;align-items:center;border-bottom:1px solid var(--line-soft)}
.cat-row:last-child{border-bottom:none}
.s-name{font-size:14.5px;color:var(--ink)}
.s-dur{font-size:13px;color:var(--ink-soft);text-align:center}
.s-std{font-size:14px;color:var(--ink-soft);text-align:center}
.s-off{font-family:var(--serif);font-size:19px;color:var(--gold-deep);text-align:center;font-weight:500}
.cat-package{margin:14px 22px 4px;background:var(--band);border-radius:10px;padding:14px 18px}
.cat-package .pk-title{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:10px}
.cat-package .pk-row{display:grid;grid-template-columns:1fr 76px 86px;gap:8px;align-items:center;padding:5px 0}
.cat-package .pk-row .s-name{font-size:13.5px}

/* package highlight card */
.pkg-promo{background:linear-gradient(160deg,#efe4d2,#e7dac2);border:1px solid var(--line);border-radius:16px;padding:40px 34px;break-inside:avoid;-webkit-column-break-inside:avoid;margin-bottom:26px}
.pkg-promo .pk-ic{width:58px;height:58px;border-radius:50%;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;color:var(--gold-deep);margin-bottom:20px}
.pkg-promo .pk-ic svg{width:28px;height:28px}
.pkg-promo h3{font-family:var(--serif);font-size:30px;color:var(--ink);letter-spacing:.05em;margin-bottom:8px}
.pkg-promo .pk-sub{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--gold-deep);margin-bottom:6px}
.pkg-promo .pk-lead{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:20px}
.pkg-promo p{font-size:14px;color:var(--ink-soft)}

/* ---------- ABOUT ---------- */
.about{padding:110px 0;background:linear-gradient(180deg,transparent,rgba(232,220,198,.4),transparent)}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
.about-photo{position:relative;aspect-ratio:4/5;border-radius:14px;overflow:hidden;background:linear-gradient(160deg,#e6d8bf,#d8c5a4)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo .frame{position:absolute;inset:14px;border:1px solid rgba(255,255,255,.5);pointer-events:none;border-radius:4px}
.about .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.about h2{font-family:var(--serif);font-weight:400;font-size:clamp(32px,4.4vw,54px);line-height:1.1;margin:14px 0 24px}
.about h2 em{font-style:italic;color:var(--gold-deep)}
.about p{color:var(--ink-soft);font-size:16px;margin-bottom:18px;max-width:560px}
.about .name{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--gold-deep);margin-top:12px}
.about .role{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ---------- TESTIMONIALS ---------- */
.testi{padding:100px 0;text-align:center}
.testi-track{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.testi-card{background:var(--card-2);border:1px solid var(--line-soft);border-radius:14px;padding:34px 30px;text-align:left;transition:.4s}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 22px 46px -28px rgba(120,90,50,.32)}
.testi-card .stars{color:var(--gold);letter-spacing:3px;font-size:14px;margin-bottom:16px}
.testi-card p{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink);line-height:1.5;margin-bottom:22px}
.testi-card .who{font-size:14px;font-weight:600;color:var(--ink)}
.testi-card .age{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:3px}

/* ---------- TRUST ---------- */
.trust{padding:70px 0}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:50px 0}
.trust-item{display:flex;gap:18px;align-items:flex-start}
.trust-item .t-ic{width:46px;height:46px;min-width:46px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.trust-item .t-ic svg{width:22px;height:22px}
.trust-item h4{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);margin-bottom:6px}
.trust-item p{font-size:14px;color:var(--ink-soft)}

/* ---------- CTA ---------- */
.cta{padding:120px 0;text-align:center}
.cta-card{background:linear-gradient(160deg,#efe4d2,#e7dac2);border:1px solid var(--line);border-radius:20px;padding:70px 40px;position:relative;overflow:hidden}
.cta-card .o-pill{display:inline-block;border:1px solid var(--gold);color:var(--gold-deep);border-radius:40px;padding:7px 20px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:24px;background:rgba(255,255,255,.5)}
.cta h2{font-family:var(--serif);font-weight:400;font-size:clamp(38px,6vw,76px);line-height:1.02;margin-bottom:20px;color:var(--ink)}
.cta h2 em{font-style:italic;color:var(--gold-deep)}
.cta p{color:var(--ink-soft);font-size:17px;max-width:500px;margin:0 auto 36px}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);padding:56px 0 36px}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:40px}
.foot-brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:16px;letter-spacing:.3em;color:var(--gold-deep);text-transform:uppercase}
.foot-brand .mono{border:1px solid var(--gold);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;letter-spacing:0;font-size:16px}
.foot-tag{color:var(--muted);font-size:14px;margin-top:12px;max-width:280px}
.foot-col h5{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.foot-col a{display:block;color:var(--ink-soft);text-decoration:none;font-size:14px;margin-bottom:10px;transition:.3s}
.foot-col a:hover{color:var(--gold-deep)}
.foot-bottom{margin-top:46px;padding-top:24px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:12.5px}

/* reveal */
.js .reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:60;background:rgba(248,242,233,.98);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;opacity:0;visibility:hidden;transition:.4s}
.mobile-menu.open{opacity:1;visibility:visible}
.mm-backdrop{position:absolute;inset:0;z-index:0}
.mobile-menu a{color:var(--ink);text-decoration:none;font-family:var(--serif);font-style:italic;font-size:30px;transition:.3s;position:relative;z-index:1}
.mobile-menu a:hover{color:var(--gold-deep)}
.mobile-menu .close{position:absolute;top:18px;right:24px;font-size:40px;color:var(--gold-deep);cursor:pointer;line-height:1;z-index:2;background:none;border:0;padding:4px 12px}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
body.menu-open{overflow:hidden}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .treat-grid,.testi-track,.trust-grid{grid-template-columns:1fr 1fr}
  .price-grid{column-count:1}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .about-photo{max-width:320px;margin:0 auto}
}
@media(max-width:760px){
  .nav-links{display:none}.burger{display:flex}
  .wrap{padding:0 22px}
  nav{padding:14px 22px;background:rgba(248,242,233,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  nav.scrolled{padding:12px 22px}
  .brand{font-size:15px;letter-spacing:.26em}
  .offer-badge{top:84px;right:18px;width:104px;height:104px;padding:0 6px}
  .offer-badge .o1{font-size:7.5px;letter-spacing:.1em}
  .offer-badge .o2{font-size:30px}
  .offer-badge .o3{font-size:6.5px;letter-spacing:.08em;max-width:80px}
  header{min-height:auto;padding:140px 0 70px}
  .intro{padding:70px 0 10px}
  .treatments,.testi{padding:70px 0}
  .treat-grid,.testi-track,.trust-grid{grid-template-columns:1fr;gap:16px}
  .treat-card{padding:30px 26px}
  .prices{padding:40px 0 70px}
  .price-cat{border-radius:14px}
  .cat-head{padding:20px 20px 14px;gap:13px}
  .cat-head h3{font-size:20px}
  .cat-cols,.cat-row{grid-template-columns:1fr 50px 56px 64px;gap:6px;padding-left:20px;padding-right:20px}
  .cat-cols span{font-size:8.5px}
  .s-name{font-size:13px}.s-dur{font-size:11.5px}.s-std{font-size:12.5px}.s-off{font-size:16px}
  .cat-package .pk-row{grid-template-columns:1fr 56px 64px}
  .about{padding:70px 0}
  .cta{padding:80px 0}
  .cta-card{padding:50px 26px}
  footer{padding:46px 0 30px}
  .foot-grid{flex-direction:column;gap:30px}
  .foot-bottom{flex-direction:column;text-align:left;gap:8px}
}
@media(max-width:380px){
  .cat-cols,.cat-row{grid-template-columns:1fr 44px 48px 56px;padding-left:16px;padding-right:16px}
  .s-name{font-size:12px}
}
/* ============================================================
   REAL STUDIO PHOTOGRAPHY (added: photo integration)
   ============================================================ */

/* ---------- HERO: photo background + readable light text ---------- */
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(38,30,20,.42),rgba(38,30,20,.5) 55%,rgba(34,27,18,.64))}
header .palm{color:#fff;opacity:.06}
.hero-mono{color:#f4ead7;border-color:rgba(255,255,255,.7)}
.hero-title{background:linear-gradient(180deg,#ffffff,#f0dcbd);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-eyebrow{color:rgba(255,255,255,.82)}
.hero-sub{color:rgba(255,255,255,.9)}
.hero-divider{color:#e7c79a}
.hero-divider::before,.hero-divider::after{background:#e7c79a;opacity:.7}
header .btn-ghost{color:#fff;border-color:rgba(255,255,255,.65);background:rgba(255,255,255,.06)}
header .btn-ghost:hover{background:rgba(255,255,255,.16)}
.offer-badge{background:rgba(255,255,255,.82);border-color:var(--gold);
  box-shadow:0 12px 30px -16px rgba(0,0,0,.5);backdrop-filter:blur(2px)}

/* light nav while sitting over the hero photo (desktop only) */
@media(min-width:761px){
  nav:not(.scrolled) .brand,
  nav:not(.scrolled) .brand .mono{color:#f6ecd9;border-color:rgba(255,255,255,.55)}
  nav:not(.scrolled) .nav-links a{color:rgba(255,255,255,.9)}
  nav:not(.scrolled) .nav-links a:hover{color:#fff}
  nav:not(.scrolled) .nav-cta{border-color:rgba(255,255,255,.75);color:#fff!important}
  nav:not(.scrolled) .nav-cta:hover{background:#fff;color:var(--gold-deep)!important}
}

/* ---------- TREATMENT cards: real photo in place of icon ---------- */
.treat-photo{border-radius:10px;overflow:hidden;margin-bottom:22px;aspect-ratio:4/3;
  background:linear-gradient(160deg,#e6d8bf,#d8c5a4)}
.treat-photo img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.treat-card:hover .treat-photo img{transform:scale(1.05)}

/* ---------- STUDIO GALLERY ---------- */
.gallery{padding:30px 0 100px}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gallery-item{margin:0;border-radius:14px;overflow:hidden;border:1px solid var(--line-soft);
  aspect-ratio:4/5;background:linear-gradient(160deg,#e6d8bf,#d8c5a4)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.gallery-item:hover img{transform:scale(1.07)}

/* ---------- CONTACT / CTA with consultation photo ---------- */
.cta-card{display:grid;grid-template-columns:.82fr 1.18fr;gap:50px;align-items:center;
  text-align:left;padding:48px}
.cta-photo{border-radius:14px;overflow:hidden;aspect-ratio:4/5;
  background:linear-gradient(160deg,#e6d8bf,#d8c5a4)}
.cta-photo img{width:100%;height:100%;object-fit:cover;display:block}
.cta-content .btn-row{justify-content:flex-start}
.cta-content p{margin:0 0 36px;max-width:none}
.btn-location{display:inline-flex;align-items:center;gap:9px;margin-top:24px;text-decoration:none;
  font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;
  padding:13px 26px;border-radius:48px;border:1px solid var(--gold);
  color:var(--gold-deep);background:rgba(176,138,85,.05);transition:.4s}
.btn-location:hover{background:var(--gold);color:#fff;
  transform:translateY(-2px);box-shadow:0 14px 32px -14px rgba(154,118,66,.55)}
.btn-location svg{width:15px;height:15px;flex:none}

/* ---------- responsive for the new photo blocks ---------- */
@media(max-width:980px){
  .gallery-grid{grid-template-columns:1fr 1fr}
  .cta-card{grid-template-columns:1fr;gap:32px;text-align:center;padding:40px 32px}
  .cta-photo{max-width:360px;width:100%;margin:0 auto}
  .cta-content .btn-row{justify-content:center}
  .cta-content p{margin:0 auto 32px;max-width:500px}
}
@media(max-width:760px){
  .gallery{padding:10px 0 70px}
  .gallery-grid{grid-template-columns:1fr;gap:14px}
  .gallery-item{aspect-ratio:5/6}
  .treat-photo{aspect-ratio:16/10}
  .cta-card{padding:30px 22px}
}

/* Meet Yuliia photo — let the (pre-cropped 4:5) image set its own height.
   Fixes the photo not appearing on mobile where aspect-ratio + height:100%
   could resolve to zero height inside the centered grid item. */
.about-photo{aspect-ratio:auto}
.about-photo img{height:auto;display:block}
