html{scroll-behavior:smooth;}
body{margin:0;font-family:Poppins;background:#f7f5f1;color:#333;}
.header{display:flex;justify-content:space-between;align-items:center;padding:15px;background:white;position:sticky;top:0;z-index:999;box-shadow:0 2px 10px rgba(0,0,0,.1);}
.logo{font-family:'Playfair Display';font-size:22px;}
.verification{font-size:12px;text-align:center;}
.menu-btn{background:transparent;border:0;font-size:26px;cursor:pointer;}

.hero{
height:100vh;
display:flex;
flex-direction:column;
justify-content:center;
align-items:center;
text-align:center;
color:white;
position:relative;
overflow:hidden;

background-image:url("images/hero.jpg");
background-size:cover;
background-position:center top;
background-repeat:no-repeat;
}

.hero::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.45);
}

.hero h1,
.hero p,
.hero /* HERO BUTTON STACK */
.buttons{
display:flex;
flex-direction:column;
align-items:center;
gap:15px;
margin-top:20px;
}

@media(min-width:768px){
.buttons{
flex-direction:column;
}
}

.btn{background:transparent;padding:12px 25px;color:white;text-decoration:none;margin:10px;}
.btn-outline{border:2px solid white;padding:12px 25px;color:white;text-decoration:none;}
.special{padding:60px;text-align:center;}
.floating{font-size:60px;opacity:.1;position:absolute;left:50%;transform:translateX(-50%);}
.service-grid{display:flex;justify-content:center;gap:20px;margin-top:30px;flex-wrap:wrap;}


.spa{background:transparente9;padding:60px;text-align:center;}
.license{width:250px;margin:20px auto;display:block;}
.gallery{padding:60px;text-align:center;}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;}

.reviews{background:#fff;padding:60px;text-align:center;}
.review-slider{display:flex;overflow:auto;gap:20px;}
.review{min-width:250px;background:#f1f1f1;padding:20px;}
.cta{display:flex;justify-content:center;align-items:center;padding:60px;gap:40px;flex-wrap:wrap;}
.cta-img{width:300px;height:300px;background:#ccc;}
footer{background:#222;color:white;text-align:center;padding:30px;}
.footer-links a{color:white;margin:10px;text-decoration:none;}
.verify-footer{margin-top:20px;font-size:12px;}
@media(max-width:768px){.header{flex-direction:column;}.hero{height:70vh;}}

/* LOGO */
.logo img{
height:55px;
width:auto;
display:block;
}

.footer-logo img{
height:70px;
width:auto;
margin-bottom:15px;
}

@media(max-width:768px){
.logo img{height:45px;}
.footer-logo img{height:55px;}
}

/* BOOKING FORM */
.booking-form{
max-width:520px;
margin:25px auto 0;
display:flex;
flex-direction:column;
gap:14px;
text-align:left;
}

.booking-form input,
.booking-form select,
.booking-form textarea{
width:100%;
padding:12px 14px;
border:1px solid rgba(0,0,0,0.15);
border-radius:10px;
font-family:inherit;
font-size:15px;
outline:none;
}

.booking-form textarea{min-height:110px; resize:vertical;}

.booking-row{
display:grid;
grid-template-columns:1fr 1fr;
gap:12px;
}

@media(max-width:520px){
.booking-row{grid-template-columns:1fr;}
}


/* HAMBURGER MENU OPEN STATE */



/* CONTACT SECTION */
.contact{
padding:60px;
text-align:center;
background:#fff;
}

.contact-grid{
max-width:1000px;
margin:25px auto 0;
display:grid;
grid-template-columns:repeat(2, minmax(0, 1fr));
gap:18px;
}

.contact-card{
background:#f7f5f1;
border:1px solid rgba(0,0,0,0.08);
border-radius:16px;
padding:22px;
text-align:left;
}

.contact-card a{color:inherit;}

@media(max-width:768px){
.contact{padding:40px 18px;}
.contact-grid{grid-template-columns:1fr;}
}



/* NAV MENU (SLIDE DOWN) */
#menu{
position:sticky;
top:70px; /* sits below header */
z-index:998;

display:flex;
flex-direction:column;
gap:6px;

background:#fff;
box-shadow:0 10px 25px rgba(0,0,0,.10);
border-radius:14px;

max-height:0;
opacity:0;
overflow:hidden;
transform:translateY(-8px);
transition:max-height .35s ease, opacity .25s ease, transform .25s ease;
margin:10px 10px 0 auto;
width:260px;
}

#menu a{
padding:12px 14px;
text-decoration:none;
color:#000;
border-radius:10px;
}

#menu a:hover{
background:#f7f5f1;
}

#menu.open{
max-height:420px;
opacity:1;
transform:translateY(0);
}

/* Mobile: full width slide-down */
@media(max-width:768px){
#menu{
width:calc(100% - 20px);
margin:10px auto 0;
}
}

/* PAGES */
.page-hero{
padding:55px 18px 10px;
text-align:center;
}
.page-hero h1{
font-family:'Playfair Display';
margin:0;
}
.page-sub{
opacity:.75;
margin-top:10px;
}
.page-content{
max-width:1050px;
margin:0 auto;
padding:20px 18px 40px;
}
.cards{
display:grid;
grid-template-columns:repeat(3, minmax(0, 1fr));
gap:18px;
}
.card{
background:#fff;
border:1px solid rgba(0,0,0,0.08);
border-radius:16px;
padding:20px;
box-shadow:0 8px 20px rgba(0,0,0,.05);
}
.muted{opacity:.75;}
@media(max-width:900px){
.cards{grid-template-columns:1fr;}
}


.big-img{
width:300px;
height:400px;
background-image:url('images/service-left.jpg');
background-size:cover;
background-position:center;
border-radius:12px;
transition:transform .4s ease;
}

.big-img:hover{
transform:scale(1.05);
}

.small-img{
width:300px;
height:190px;
background-size:cover;
background-position:center;
border-radius:12px;
margin-bottom:20px;
transition:transform .4s ease;
}

.small-img:hover{
transform:scale(1.05);
}

/* assign images */
.small-img:nth-child(1){
background-image:url('images/service-top.jpg');
}

.small-img:nth-child(2){
background-image:url('images/service-bottom.jpg');
}


/* MASSAGE SERVICES IMAGE */
.massage-services-section{
padding:40px 20px;
text-align:center;
background:#000;
}

.massage-services-section img{
max-width:900px;
width:100%;
border-radius:12px;
box-shadow:0 10px 30px rgba(0,0,0,.4);
}

/* Credentials Heading */
.credentials{
font-weight:800;
font-size:32px;
margin-top:40px;
text-align:center;
}



/* GALLERY IMAGES + MOTION */
.gallery-box{
height:240px;
border-radius:14px;
background-size:cover;
background-position:center;
overflow:hidden;
transition:transform .45s ease, filter .45s ease;
}

.gallery-box:hover{
transform:scale(1.04);
filter:brightness(1.05);
}

/* assign gallery images */
.gallery-grid .gallery-box:nth-child(1){background-image:url('images/gallery1.jpg');}
.gallery-grid .gallery-box:nth-child(2){background-image:url('images/gallery2.jpg');}
.gallery-grid .gallery-box:nth-child(3){background-image:url('images/gallery3.jpg');}
.gallery-grid .gallery-box:nth-child(4){background-image:url('images/gallery4.jpg');}

@media(max-width:768px){
.gallery-box{height:210px;}
}

/* CTA IMAGE */
.cta-img img{
width:300px;
max-width:100%;
border-radius:14px;
box-shadow:0 10px 30px rgba(0,0,0,.3);
}


/* CHAT ICONS */
.chat-icons{
display:flex;
gap:15px;
justify-content:center;
margin:15px 0;
}

.chat-icons img{
width:45px;
height:45px;
border-radius:12px;
transition:transform .3s ease;
cursor:pointer;
}

.chat-icons img:hover{
transform:scale(1.15);
}

/* GLOBAL CTA IMAGE */
.cta-global{
text-align:center;
padding:40px 20px;
background:#000;
}

.cta-global img{
max-width:900px;
width:100%;
border-radius:14px;
box-shadow:0 10px 30px rgba(0,0,0,.4);
}


/* IMAGE BEFORE CUSTOMIZED SPA */
.before-customized{
text-align:center;
padding:40px 20px;
background:#000;
}

.before-customized img{
max-width:900px;
width:100%;
border-radius:14px;
box-shadow:0 10px 30px rgba(0,0,0,.4);
}

.services-section{
padding:80px 20px;
background:#000;
color:white;
max-width:1000px;
margin:auto;
line-height:1.8;
}

/* SERVICES (Luxury layout) */
.services-hero{
text-align:center;
padding:30px 10px 10px;
}

.services-hero h1{
font-family:"Playfair Display", serif;
font-size:44px;
margin:0 0 10px;
}

.services-subtitle{
max-width:850px;
margin:0 auto;
opacity:.92;
}

.services-cta-row{
margin-top:22px;
display:flex;
gap:12px;
justify-content:center;
flex-wrap:wrap;
}

.btn-primary,
.btn-secondary{
display:inline-block;
padding:12px 18px;
border-radius:12px;
text-decoration:none;
font-family:Poppins;
font-weight:500;
letter-spacing:.2px;
transition:transform .2s ease, opacity .2s ease;
}

.btn-primary{
background:#d4af37;
color:#000;
}

.btn-secondary{
background:rgba(255,255,255,.08);
border:1px solid rgba(255,255,255,.18);
color:#fff;
backdrop-filter:blur(8px);
}

.btn-primary:hover,
.btn-secondary:hover{
transform:translateY(-1px);
opacity:.95;
}

.section-divider{
height:1px;
width:100%;
margin:34px 0;
background:linear-gradient(90deg, transparent, rgba(212,175,55,.55), transparent);
}

.services-block{
padding:0 6px;
}

.section-title{
font-size:30px;
margin:0 0 14px;
text-align:center;
}

.section-lead{
text-align:center;
max-width:860px;
margin:0 auto 18px;
opacity:.92;
}

.pricing-grid{
display:grid;
grid-template-columns:repeat(3, 1fr);
gap:14px;
}

.price-card{
background:rgba(255,255,255,.06);
border:1px solid rgba(255,255,255,.12);
border-radius:16px;
padding:16px;
backdrop-filter:blur(10px);
}

.price-top{
display:flex;
justify-content:space-between;
align-items:baseline;
gap:10px;
}

.price-duration{
font-weight:500;
}

.price-amount{
font-size:22px;
font-weight:600;
color:#d4af37;
}

.price-note{
margin-top:8px;
opacity:.88;
font-size:14px;
}

.pill-list{
display:flex;
flex-wrap:wrap;
gap:10px;
justify-content:center;
}

.pill{
padding:8px 12px;
border-radius:999px;
background:rgba(255,255,255,.07);
border:1px solid rgba(255,255,255,.14);
font-size:14px;
backdrop-filter:blur(8px);
}

.services-grid{
display:grid;
grid-template-columns:repeat(2, 1fr);
gap:16px;
margin-top:10px;
}

.service-card{
background:rgba(255,255,255,.05);
border:1px solid rgba(255,255,255,.12);
border-radius:18px;
padding:18px;
backdrop-filter:blur(10px);
}

.service-card h3{
margin:0 0 8px;
font-size:22px;
color:#d4af37;
}

.service-card p{
margin:0 0 10px;
opacity:.92;
}

.service-details{
margin-top:8px;
}

.service-details summary{
cursor:pointer;
list-style:none;
font-weight:500;
}

.service-details summary::-webkit-details-marker{
display:none;
}

.service-details summary::after{
content:"+";
float:right;
color:#d4af37;
}

.service-details[open] summary::after{
content:"−";
}

.service-details p{
margin:10px 0 0;
opacity:.9;
}

.two-col{
display:grid;
grid-template-columns:repeat(2, 1fr);
gap:16px;
}

.clean-list{
margin:0;
padding-left:18px;
}

.clean-list li{
margin:8px 0;
}

.vip-block{
background:rgba(212,175,55,.07);
border:1px solid rgba(212,175,55,.22);
border-radius:18px;
padding:22px 16px;
}

.services-final-cta{
text-align:center;
padding:26px 12px 10px;
}

.services-final-cta h2{
margin:0 0 8px;
}

.services-final-cta p{
margin:0 auto 16px;
max-width:760px;
opacity:.92;
}

@media (max-width: 820px){
  .pricing-grid{grid-template-columns:repeat(2, 1fr);}
  .services-grid{grid-template-columns:1fr;}
}

@media (max-width: 520px){
  .pricing-grid{grid-template-columns:1fr;}
  .services-hero h1{font-size:36px;}
}

.services-section h2{
font-size:36px;
margin-bottom:20px;
text-align:center;
}

.services-section h3{
margin-top:40px;
font-size:24px;
color:#d4af37;
}

.price-table{
margin-top:20px;
display:grid;
gap:10px;
font-size:18px;
text-align:center;
}

.contact-booking{
padding:80px 20px;
max-width:700px;
margin:auto;
text-align:left;
}

.contact-booking h2{
text-align:center;
margin-bottom:10px;
}

.booking-form{
display:flex;
flex-direction:column;
gap:15px;
margin-top:25px;
}

.booking-form input,
.booking-form select,
.booking-form textarea{
padding:12px;
border-radius:8px;
border:1px solid #ccc;
font-family:Poppins;
}

.booking-form textarea{
min-height:120px;
}

.respect-note{
margin-top:20px;
text-align:center;
font-style:italic;
}



/* GLASSMORPHISM BOOKING FORM */
.contact-booking{
display:flex;
justify-content:center;
align-items:center;
padding:80px 20px;
background:linear-gradient(135deg,#0a0a0a,#1a1a1a);
}

.booking-form{
backdrop-filter: blur(18px);
-webkit-backdrop-filter: blur(18px);
background:rgba(255,255,255,0.08);
border:1px solid rgba(255,255,255,0.18);
box-shadow:0 20px 45px rgba(0,0,0,.6);
border-radius:20px;
padding:40px;
max-width:650px;
width:100%;
display:flex;
flex-direction:column;
gap:18px;
}

.booking-form label{
font-weight:500;
color:#fff;
}

.booking-form input,
.booking-form select,
.booking-form textarea{
background:rgba(255,255,255,0.12);
border:none;
padding:14px;
border-radius:10px;
color:#fff;
outline:none;
font-size:15px;
}

.booking-form input::placeholder,
.booking-form textarea::placeholder{
color:rgba(255,255,255,.7);
}

.booking-form button{
margin-top:15px;
background:linear-gradient(135deg,#d4af37,#f5d67b);
border:none;
padding:15px;
border-radius:12px;
font-weight:600;
cursor:pointer;
transition:.35s;
}

.booking-form button:hover{
transform:translateY(-3px);
box-shadow:0 10px 25px rgba(212,175,55,.5);
}

.respect-note{
margin-top:15px;
text-align:center;
color:#ddd;
font-style:italic;
}


/* ===== FIXED HEADER + HAMBURGER ===== */

.header{
    position:sticky;
    top:0;
    z-index:9999;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:15px 20px;
    background:rgba(255,255,255,0.85);
    backdrop-filter:blur(12px);
}

.menu-btn{
    font-size:26px;
    background:none;
    border:none;
    cursor:pointer;
}

.menu{
    position:absolute;
    top:70px;
    right:20px;
    width:260px;
    background:white;
    border-radius:14px;
    box-shadow:0 15px 40px rgba(0,0,0,0.15);
    display:flex;
    flex-direction:column;
    overflow:hidden;
    max-height:0;
    opacity:0;
    transition:all .3s ease;
}

.menu a{
    padding:14px;
    text-decoration:none;
    color:#000;
}

.menu a:hover{
    background:#f4f4f4;
}

.menu.open{
    max-height:400px;
    opacity:1;
}


.verification{
    font-size:12px;
    text-align:center;
    flex:1;
    padding:0 10px;
    font-weight:500;
    letter-spacing:.5px;
}

/* ===== GLASS GALLERY ===== */

.glass-gallery {
    padding: 80px 8%;
    background: linear-gradient(135deg,#0e0e0e,#1a1a1a);
}

.gallery-title {
    text-align:center;
    color:white;
    font-size:40px;
    margin-bottom:50px;
}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:30px;
}

.glass-card{
    border-radius:20px;
    overflow:hidden;
    background:rgba(255,255,255,0.08);
    backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,0.15);
    transition:.5s ease;
    opacity:0;
    transform:translateY(40px);
    animation:fadeUp 1s forwards;
}

.glass-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:.6s;
}

.glass-card:hover{
    transform:translateY(-10px) scale(1.03);
    box-shadow:0 25px 50px rgba(0,0,0,0.6);
}

.glass-card:hover img{
    transform:scale(1.1);
}

@keyframes fadeUp{
    to{
        opacity:1;
        transform:translateY(0);
    }
}


/* ===== PREMIUM MODEL STYLE ===== */

.premium-gallery{
    background:#0b0b0b;
    padding:80px 5%;
    text-align:center;
}

.premium-title{
    color:white;
    font-size:42px;
    margin-bottom:40px;
}

/* SLIDER */
.slider{
    overflow:hidden;
    position:relative;
}

.slides{
    display:flex;
    animation:slide 25s infinite linear;
}

.slide{
    width:300px;
    margin:15px;
    border-radius:20px;
    filter:blur(6px);
    transition:.4s;
    cursor:pointer;
}

.slide:hover{
    filter:blur(0);
    transform:scale(1.05);
}

/* AUTO SLIDE */
@keyframes slide{
    0%{transform:translateX(0);}
    100%{transform:translateX(-50%);}
}

/* LIGHTBOX */
.lightbox{
    display:none;
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.95);
    justify-content:center;
    align-items:center;
}

.lightbox-img{
    max-width:90%;
    max-height:90%;
    border-radius:15px;
}

.close{
    position:absolute;
    top:30px;
    right:40px;
    color:white;
    font-size:40px;
    cursor:pointer;
}


/* ===== PREMIUM CTA BUTTONS ===== */

.cta-button{
    display:inline-block;
    padding:14px 28px;
    margin:10px;
    border-radius:40px;
    text-decoration:none;
    font-weight:bold;
    letter-spacing:1px;
    transition:.4s ease;
    backdrop-filter:blur(10px);
}

.cta-button.primary{
    background:linear-gradient(135deg,#ff007a,#ff4db2);
    color:white;
    box-shadow:0 10px 25px rgba(255,0,122,.5);
}

.cta-button.secondary{
    background:rgba(255,255,255,0.1);
    color:white;
    border:1px solid rgba(255,255,255,0.3);
}

.cta-button:hover{
    transform:translateY(-3px) scale(1.05);
    box-shadow:0 15px 35px rgba(0,0,0,.5);
}


/* ===== SCROLL STEP GALLERY ===== */

.scroll-gallery .glass-card{
    opacity:0;
    transform:translateY(80px);
    transition:all .8s ease;
}

.scroll-gallery .glass-card.show{
    opacity:1;
    transform:translateY(0);
}


/* ===== GALLERY PAGE ONLY LAYOUT FIX ===== */

.gallery-page header{
    padding:25px 40px;
}

.gallery-page .logo{
    font-size:28px;
}

.gallery-page .menu-btn{
    font-size:34px;
}

.gallery-page .scroll-gallery{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    min-height:80vh;
    padding-top:40px;
    padding-bottom:120px;
}

.gallery-page footer{
    position:fixed;
    bottom:0;
    left:0;
    width:100%;
    background:white;
    z-index:999;
    padding:15px 0;
    box-shadow:0 -2px 10px rgba(0,0,0,.1);
}

.gallery-page body{
    padding-bottom:120px;
}


/* ===== MATCH HEADER & FOOTER TO GLOBAL SIZE (GALLERY ONLY FIX) ===== */

.gallery-page header{
    padding:15px 40px !important; /* match default */
}

.gallery-page .logo{
    font-size:22px !important; /* match homepage */
}

.gallery-page .menu-btn{
    font-size:26px !important; /* match homepage */
}

/* Remove fixed footer behavior for gallery */
.gallery-page footer{
    position:relative !important;
    width:100% !important;
    bottom:auto !important;
    box-shadow:none !important;
}

/* Ensure normal flow spacing */
.gallery-page{
    padding-bottom:0 !important;
}

.page-layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.gallery-section {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 40px 20px;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    max-width: 1000px;
    width: 100%;
}

.gallery-grid img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    border-radius: 12px;
    cursor: pointer;
    transition: 0.3s ease;
}

.gallery-grid img:hover {
    transform: scale(1.03);
}

.modal {
    display: none;
    position: fixed;
    z-index: 999;
    padding-top: 60px;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.85);
}

.modal-content {
    margin: auto;
    display: block;
    width: 85%;
    max-width: 1000px;
}

.close, .prev, .next {
    position: absolute;
    color: white;
    font-size: 40px;
    cursor: pointer;
}

.close {
    top: 20px;
    right: 40px;
}

.prev {
    top: 50%;
    left: 40px;
    transform: translateY(-50%);
}

.next {
    top: 50%;
    right: 40px;
    transform: translateY(-50%);
}

.nav-menu.show {
    display: block;
}

/* --- HEADER FIX --- */
.header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.logo {
    height: 60px;
    width: auto;
}

.hamburger {
    font-size: 28px;
    cursor: pointer;
    display: block;
}

/* --- GALLERY LAYOUT FIX --- */
.page-layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.gallery-section {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 40px 20px;
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    max-width: 1000px;
    width: 100%;
}

.gallery-grid img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    border-radius: 12px;
    cursor: pointer;
}

.nav-menu.show {
    display: block;
}

/* Modal images corrected */
.modal-content {
    width: 90%;
    max-width: 1000px;
}

/* Hide nav by default */
.nav-menu {
    display: none;
    position: absolute;
    top: 80px;
    right: 20px;
    background: black;
    padding: 20px;
    border-radius: 10px;
}

.nav-menu a {
    display: block;
    color: white;
    text-decoration: none;
    margin: 10px 0;
}

.nav-menu.show {
    display: block;
}

/* Header text styling */
.header-text {
    font-size: 12px;
    font-weight: bold;
    text-align: center;
    max-width: 400px;
}


/* --- Gallery page layout (safe additions) --- */
.page-layout{
  display:flex;
  flex-direction:column;
  min-height:100vh;
}

.gallery-section{
  flex:1;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:40px 20px;
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:20px;
  max-width:1000px;
  width:100%;
}

.gallery-grid img{
  width:100%;
  height:320px;
  object-fit:cover;
  border-radius:12px;
  cursor:pointer;
}



/* --- DM Glass Booking Box --- */
.dm-booking-box{
  display:flex;
  justify-content:center;
  align-items:center;
  padding:60px 20px 20px;
}

.glass-card{
  backdrop-filter:blur(15px);
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.3);
  border-radius:20px;
  padding:40px;
  width:100%;
  max-width:600px;
  text-align:center;
  box-shadow:0 20px 40px rgba(0,0,0,0.2);
}

.glass-card h2{
  margin-bottom:25px;
  font-family:'Playfair Display', serif;
}

.dm-links{
  display:flex;
  flex-direction:column;
  gap:15px;
}

.dm-links a{
  text-decoration:none;
  padding:12px 15px;
  border-radius:12px;
  background:rgba(255,255,255,0.25);
  color:#000;
  font-weight:500;
  transition:all .3s ease;
}

.dm-links a:hover{
  background:rgba(255,255,255,0.45);
  transform:translateY(-2px);
}



/* --- Testimonials Background Redesign --- */
.testimonial-hero{
  position:relative;
  min-height:100vh;
  background-image:url("images/testimonial-bg.jpg");
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
  justify-content:center;
}

.testimonial-overlay{
  background:rgba(0,0,0,0.65);
  width:100%;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:60px 20px;
}

.testimonial-content{
  max-width:900px;
  text-align:center;
  color:white;
}

.testimonial-content h1{
  font-family:'Playfair Display', serif;
  font-size:42px;
  margin-bottom:40px;
}

.reviews-container{
  display:flex;
  flex-direction:column;
  gap:30px;
}

.review-card{
  background:rgba(255,255,255,0.1);
  backdrop-filter:blur(10px);
  padding:30px;
  border-radius:20px;
  color:white;
  text-align:left;
  box-shadow:0 20px 40px rgba(0,0,0,0.3);
}

.review-card h3{
  margin-bottom:10px;
  font-weight:600;
}

.review-card p{
  line-height:1.6;
  font-weight:300;
}



/* --- Star Ratings --- */
.stars{
  color:#d4af37;
  font-size:20px;
  margin-bottom:10px;
  letter-spacing:3px;
}

/* Gold Accent Line */
.review-card{
  border-left:4px solid #d4af37;
  opacity:0;
  transform:translateY(40px);
  transition:all .8s ease;
}

/* Fade-in Animation Active */
.review-card.show{
  opacity:1;
  transform:translateY(0);
}

/* Verified Badge */
.review-card h3::after{
  content:"  ✔ Verified Client";
  font-size:12px;
  color:#d4af37;
  margin-left:8px;
}



/* --- Updated 5-Star System --- */
.stars{
  margin-bottom:10px;
}

.star{
  font-size:20px;
  margin-right:4px;
}

.star.filled{
  color:#d4af37;
}

.star.empty{
  color:rgba(255,255,255,0.4);
}



/* --- Booking DM Glass Box --- */
.dm-booking-box{
  display:flex;
  justify-content:center;
  align-items:center;
  padding:80px 20px 40px;
}

.glass-card{
  backdrop-filter:blur(18px);
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.25);
  border-radius:22px;
  padding:45px;
  width:100%;
  max-width:650px;
  text-align:center;
  box-shadow:0 25px 60px rgba(0,0,0,0.35);
}

.glass-card h2{
  font-family:'Playfair Display', serif;
  margin-bottom:25px;
}

.dm-links{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.dm-links a{
  text-decoration:none;
  padding:14px;
  border-radius:14px;
  background:rgba(255,255,255,0.2);
  color:#000;
  font-weight:500;
  transition:all .3s ease;
}

.dm-links a:hover{
  background:rgba(255,255,255,0.35);
  transform:translateY(-3px);
}



/* --- Separate Booking Form Box --- */
.booking-form-box{
  display:flex;
  justify-content:center;
  align-items:center;
  padding:60px 20px 100px;
}

.booking-form-card{
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(15px);
  border:1px solid rgba(255,255,255,0.25);
  border-radius:24px;
  padding:50px 40px;
  width:100%;
  max-width:750px;
  box-shadow:0 30px 70px rgba(0,0,0,0.35);
}

.booking-form-card h2{
  text-align:center;
  font-family:'Playfair Display', serif;
  margin-bottom:10px;
}

.booking-subtext{
  text-align:center;
  margin-bottom:35px;
  opacity:0.8;
}

/* Make form fields spaced properly */
.booking-form-card form{
  display:flex;
  flex-direction:column;
  gap:18px;
}



/* --- Schedule Title Styling --- */
.schedule-title{
  margin-top:30px;
  text-align:center;
  font-size:18px;
  letter-spacing:1px;
}



/* --- Proper Schedule Title Placement --- */
.schedule-wrapper{
  display:flex;
  justify-content:center;
  margin-top:60px;
}

.schedule-title{
  font-size:22px;
  font-weight:700;
  text-align:center;
  letter-spacing:1.5px;
}



/* --- Styled Schedule Title (White with Red Stroke) --- */
.schedule-title strong{
  color: #ffffff;
  -webkit-text-stroke: 1px #b30000;
  text-stroke: 1px #b30000;
  text-shadow: 0 0 6px rgba(179, 0, 0, 0.4);
}



/* Hidden appointment terms section */
.appointment-terms{
  display:none;
  justify-content:center;
  align-items:center;
  padding:80px 20px;
  background:#111;
  color:white;
}

.terms-card{
  max-width:700px;
  background:rgba(255,255,255,0.05);
  backdrop-filter:blur(10px);
  border-radius:18px;
  padding:40px;
  text-align:center;
}

.terms-card h2{
  margin-bottom:20px;
  letter-spacing:2px;
}



/* Appointment Terms Background Image */
.appointment-terms{
  display:none;
  min-height:100vh;
  background-image:url("images/appointment_terms_bg.png");
  background-size:cover;
  background-position:center;
  align-items:center;
  justify-content:center;
}

.terms-overlay{
  width:100%;
  min-height:100vh;
  background:rgba(0,0,0,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
}

.terms-title{
  font-size:48px;
  color:#ffffff;
  text-align:center;
  letter-spacing:2px;
  font-weight:900;
}



/* Appointment Terms – Image Only Full Screen */
.appointment-terms{
  display:none;
  position:fixed;
  top:0;
  left:0;
  width:100vw;
  height:100vh;
  background:#000;
  z-index:9999;
  justify-content:center;
  align-items:center;
}

.terms-full-image{
  width:100%;
  height:100%;
  object-fit:cover;
}



/* Appointment terms image section */
#appointment-terms{
  display:none;
  width:100%;
  height:calc(100vh - 80px);
  background:#000;
  justify-content:center;
  align-items:center;
}

.terms-container{
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

#appointment-terms img{
  width:100%;
  height:90%;
  object-fit:contain;
}

.back-btn{
  margin-top:10px;
  padding:10px 18px;
  border:none;
  background:#111;
  color:white;
  border-radius:6px;
  cursor:pointer;
}

