/* ============================================
   We4u Salon — Premium Static Site Styles
   ============================================ */
:root{
  --bg:#0e0e10;
  --bg-dark:#0a0a0c;
  --cream:#f7f3ec;
  --cream-2:#efe8d8;
  --text:#1a1a1a;
  --muted:#6b6b6b;
  --gold:#c9a35c;
  --gold-soft:#e6c98a;
  --gold-deep:#a8843f;
  --line:rgba(255,255,255,.12);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
  --radius:16px;
  --shadow-sm:0 4px 20px rgba(0,0,0,.06);
  --shadow:0 20px 60px -20px rgba(0,0,0,.45);
  --shadow-gold:0 20px 50px -20px rgba(201,163,92,.45);
  --grad-gold:linear-gradient(135deg, #e6c98a 0%, #c9a35c 50%, #a8843f 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--sans);color:var(--text);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s}
button{font-family:inherit}
.container{max-width:1240px;margin:0 auto;padding:0 24px}

/* ===== Selection ===== */
::selection{background:var(--gold);color:#111}

/* ===== Loader ===== */
.loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;transition:opacity .6s .2s, visibility .6s .2s}
.loader.hide{opacity:0;visibility:hidden}
.loader-logo{font-family:var(--serif);font-size:48px;font-weight:700;color:#fff;letter-spacing:3px}
.loader-logo span{color:var(--gold);font-style:italic;animation:pulse 1.4s ease-in-out infinite}
.loader-bar{width:200px;height:2px;background:rgba(255,255,255,.1);overflow:hidden;border-radius:2px}
.loader-bar span{display:block;width:30%;height:100%;background:var(--grad-gold);animation:loaderSlide 1.2s ease-in-out infinite}
@keyframes loaderSlide{0%{transform:translateX(-100%)}100%{transform:translateX(400%)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 0;transition:all .35s cubic-bezier(.4,0,.2,1);background:transparent}
.site-header.scrolled{background:rgba(14,14,16,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:10px 0;border-bottom:1px solid var(--line);box-shadow:0 4px 30px rgba(0,0,0,.3)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{font-family:var(--serif);font-size:30px;font-weight:700;color:#fff;letter-spacing:2px;transition:transform .3s}
.logo:hover{transform:scale(1.05)}
.logo span{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.nav-links{display:flex;gap:36px}
.nav-links a{color:#fff;font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase}
.nav-right{display:flex;align-items:center;gap:18px}
.phone-link{color:#fff;font-size:14px;display:flex;align-items:center;gap:6px;transition:color .25s}
.phone-link:hover{color:var(--gold)}
.hamburger{display:none;background:none;border:0;cursor:pointer;width:32px;height:24px;position:relative;padding:0}
.hamburger span{display:block;position:absolute;left:0;width:100%;height:2px;background:#fff;border-radius:2px;transition:.3s cubic-bezier(.4,0,.2,1)}
.hamburger span:nth-child(1){top:2px}
.hamburger span:nth-child(2){top:11px}
.hamburger span:nth-child(3){top:20px}
.hamburger.open span:nth-child(1){top:11px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:11px;transform:rotate(-45deg)}

/* ===== Story Link (animated underline) ===== */
.story-link{position:relative;display:inline-block}
.story-link::after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.4,0,.2,1)}
.story-link:hover::after{transform:scaleX(1);transform-origin:left}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;border:1px solid transparent;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);border-radius:2px;position:relative;overflow:hidden}
.btn-gold{background:var(--grad-gold);color:#111;box-shadow:0 8px 24px -8px rgba(201,163,92,.6)}
.btn-gold::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#fff,#e6c98a);opacity:0;transition:opacity .3s}
.btn-gold:hover::before{opacity:1}
.btn-gold span,.btn-gold{position:relative;z-index:1}
.btn-gold:hover{box-shadow:0 14px 30px -8px rgba(201,163,92,.8)}
.btn-outline{border-color:rgba(255,255,255,.5);color:#fff;background:transparent;backdrop-filter:blur(4px)}
.btn-outline:hover{background:#fff;color:#111;border-color:#fff}
.btn-gold-sm{background:transparent;color:var(--gold-deep);border:1px solid var(--gold);padding:11px 22px;font-size:11px}
.btn-gold-sm:hover{background:var(--gold);color:#fff;letter-spacing:3px}
.btn.full{width:100%;justify-content:center}
.hover-lift{transition:transform .3s ease, box-shadow .3s ease}
.hover-lift:hover{transform:translateY(-3px)}

/* ===== Reveal Animations ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.4,0,.2,1), transform .8s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}
@keyframes bounceArrow{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@keyframes glow{0%,100%{box-shadow:0 0 20px rgba(201,163,92,.3)}50%{box-shadow:0 0 40px rgba(201,163,92,.6)}}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0;animation:heroZoom 20s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.65) 50%,rgba(0,0,0,.85) 100%);z-index:1}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center;padding:160px 24px 100px;width:100%;position:relative;z-index:2}
.eyebrow{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:28px;font-weight:500}
.hero-text h1{font-family:var(--serif);font-size:clamp(52px,8vw,108px);font-weight:600;line-height:.95;margin-bottom:32px;letter-spacing:-1px}
.hero-text h1 em{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;display:inline-block;animation:shimmer 4s ease-in-out infinite;background-size:200% 100%}
.hero-text .lead{font-size:17px;color:rgba(255,255,255,.82);max-width:540px;margin-bottom:44px;font-weight:300}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px}

.concierge-card{background:rgba(10,10,12,.65);border:1px solid var(--line);padding:36px;border-radius:var(--radius);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}

.concierge-card {
    position: absolute;
    right: 1px;
    top: 180px;
    width: 100;
}

.card-eyebrow{color:var(--gold);font-size:11px;letter-spacing:3px;text-transform:uppercase;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line);font-weight:500}

.card-row{display:flex;gap:4px;margin-bottom:20px;align-items:flex-start}

.card-row .ico{font-size:18px;margin-top:2px;flex-shrink:0}

.card-row .label{font-size:10px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:4px;font-weight:600}

.card-row a,.card-row p{color:rgba(255,255,255,.92);font-size:14px;line-height:1.5}

.card-row a:hover{color:var(--gold)}

.quote{font-family:var(--serif);font-style:italic;color:rgba(255,255,255,.65);text-align:center;border-top:1px solid var(--line);padding-top:18px;margin-top:8px;font-size:15px}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:2}
.scroll-cue span{font-size:10px;letter-spacing:4px;color:rgba(255,255,255,.6);font-weight:500}
.scroll-line{width:1px;height:50px;background:rgba(255,255,255,.3);position:relative;overflow:hidden}
.scroll-line::after{content:"";position:absolute;inset:0;background:var(--gold);animation:scrollLine 2s ease-in-out infinite}

/* ===== Stats Bar ===== */
.stats-bar{background:var(--bg);color:#fff;padding:50px 0;border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat{display:flex;flex-direction:column;align-items:center;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:50%;transform:translateY(-50%);width:1px;height:50px;background:var(--line)}
.stat .num{font-family:var(--serif);font-size:48px;font-weight:600;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat .plus{display:inline;font-family:var(--serif);font-size:32px;color:var(--gold);margin-left:2px}
.stat p{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:10px;font-weight:500}

/* ===== Sections ===== */
.section{padding:110px 0;position:relative}
.section-dark{background:var(--bg);color:#fff;overflow:hidden}
.section-cream{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%)}
.bg-pattern{position:absolute;inset:0;opacity:.04;background-image:radial-gradient(circle at 1px 1px, var(--gold) 1px, transparent 0);background-size:30px 30px;pointer-events:none}
.section-eyebrow{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:18px;font-weight:600}
.section-eyebrow.left{text-align:left}
.section-title{font-family:var(--serif);font-size:clamp(40px,5.5vw,68px);font-weight:600;text-align:center;margin-bottom:18px;letter-spacing:-.5px;line-height:1.05}
.section-title.light{color:#fff}
.section-title.left{text-align:left}
.section-sub{text-align:center;color:var(--muted);margin-bottom:60px;font-size:16px;font-weight:300}
.section-dark .section-sub{color:rgba(255,255,255,.6)}

/* ===== Services ===== */
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px;margin-top:50px}
.service-card{background:#fff;border:1px solid #f0eadb;border-radius:var(--radius);overflow:hidden;transition:all .5s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}
.service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow);border-color:var(--gold)}
.card-img{height:220px;overflow:hidden;position:relative}
.card-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4) 100%)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.service-card:hover .card-img img{transform:scale(1.1)}
.card-body{padding:32px 28px}
.service-card h3{font-family:var(--serif);font-size:28px;color:var(--text);margin-bottom:24px;padding-bottom:14px;position:relative}
.service-card h3::after{content:"";position:absolute;bottom:0;left:0;width:50px;height:2px;background:var(--grad-gold);transition:width .4s}
.service-card:hover h3::after{width:100%}
.service-card ul{list-style:none}
.service-card li{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px dashed #eee;font-size:14.5px;transition:padding .25s}
.service-card li:hover{padding-left:8px;border-color:var(--gold-soft)}
.service-card li:last-child{border:0}
.service-card li strong{color:var(--gold-deep);font-weight:600;font-family:var(--serif);font-size:18px}

/* ===== Combos ===== */
.combo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px;margin-top:50px;position:relative;z-index:1}
.combo-card{background:rgba(255,255,255,.04);border:1px solid var(--line);padding:28px;border-radius:var(--radius);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.combo-card::before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:var(--grad-gold);border-radius:var(--radius);opacity:0;transition:opacity .4s;z-index:-1}
.combo-card:hover{transform:translateY(-8px);background:rgba(201,163,92,.08);border-color:var(--gold)}
.combo-card.featured{background:rgba(201,163,92,.1);border-color:var(--gold);animation:glow 3s ease-in-out infinite}
.ribbon{position:absolute;top:14px;right:14px;background:var(--grad-gold);color:#111;font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:5px 12px;border-radius:99px;font-weight:700}
.combo-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.combo-head h4{font-family:var(--serif);font-size:24px;font-weight:600;color:#fff}
.combo-head .price{font-family:var(--serif);color:var(--gold);font-size:26px;font-weight:600}
.combo-card ul{list-style:none}
.combo-card li{padding:7px 0;color:rgba(255,255,255,.82);font-size:14px;position:relative;padding-left:20px}
.combo-card li::before{content:"◆";position:absolute;left:0;color:var(--gold);font-size:9px;top:11px}

/* ===== Gallery ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:50px}
.gal{position:relative;display:block;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:#000}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.4,0,.2,1), opacity .4s}
.gal::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7) 100%);opacity:0;transition:opacity .4s}
.gal-caption{position:absolute;bottom:20px;left:20px;color:#fff;font-family:var(--serif);font-size:20px;font-weight:600;opacity:0;transform:translateY(10px);transition:all .4s ease;z-index:2}
.gal:hover img{transform:scale(1.08)}
.gal:hover::after{opacity:1}
.gal:hover .gal-caption{opacity:1;transform:translateY(0)}

/* ===== Lightbox ===== */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9998;display:none;align-items:center;justify-content:center;animation:fadeInUp .3s ease;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox-close{position:absolute;top:20px;right:30px;color:#fff;font-size:48px;cursor:pointer;line-height:1;font-weight:300;transition:transform .25s}
.lightbox-close:hover{transform:rotate(90deg)}

/* ===== Offers ===== */
.offer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:30px}
.offer-card{background:#fff;padding:36px 28px;border-radius:var(--radius);border:1px solid #ece5d5;text-align:center;transition:all .45s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;position:relative;overflow:hidden}
.offer-card::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(120deg,transparent,rgba(201,163,92,.1),transparent);transition:left .8s ease}
.offer-card:hover::before{left:100%}
.offer-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-gold);border-color:var(--gold)}
.offer-card .tag{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-deep);background:rgba(201,163,92,.15);padding:6px 14px;border-radius:99px;display:inline-block;margin-bottom:20px;align-self:center;font-weight:600}
.offer-card .big{font-family:var(--serif);font-size:48px;font-weight:700;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:14px;line-height:1}
.offer-card .big small{font-size:16px;color:var(--muted);font-weight:400;margin-left:6px;-webkit-text-fill-color:var(--muted)}
.offer-card h4{font-family:var(--serif);font-size:24px;margin-bottom:14px;color:var(--text)}
.offer-card p{color:var(--muted);font-size:14px;margin-bottom:24px;flex:1;line-height:1.6}
.offer-card .btn-gold-sm{align-self:center}
.fineprint{text-align:center;color:var(--muted);font-size:12px;margin-top:36px;font-style:italic}

/* ===== Reviews ===== */
.rating-row{text-align:center;margin-bottom:50px;color:var(--muted);display:flex;flex-direction:column;gap:8px;align-items:center}
.big-rating{font-family:var(--serif);font-size:42px;color:var(--gold);font-weight:600;letter-spacing:1px}
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:26px}
.review-card{background:#fff;padding:36px 30px;border-radius:var(--radius);border:1px solid #eee;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}
.review-card:hover{box-shadow:var(--shadow);transform:translateY(-6px);border-color:var(--gold-soft)}
.g-badge{position:absolute;top:-16px;left:28px;width:36px;height:36px;border-radius:50%;background:#fff;border:2px solid #4285F4;color:#4285F4;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(66,133,244,.3)}
.stars{color:#f4b400;font-size:16px;letter-spacing:2px;margin:6px 0 14px}
.review-card p{font-style:italic;color:#444;margin-bottom:24px;font-family:var(--serif);font-size:17px;line-height:1.6}
.reviewer{border-top:1px solid #eee;padding-top:18px;display:flex;align-items:center;gap:14px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--grad-gold);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--serif);font-size:18px;flex-shrink:0}
.reviewer strong{color:var(--text);display:block;font-size:14px}
.reviewer span{font-size:12px;color:var(--muted)}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;position:relative;z-index:1}
.contact-sub{font-family:var(--serif);font-size:32px;margin:24px 0 14px;color:var(--gold);font-weight:600}
.muted{color:rgba(255,255,255,.65)}
.section-cream .muted,body .muted{color:var(--muted)}
.section-dark .muted{color:rgba(255,255,255,.65)}
.info-block{margin-top:24px}
.info-block .label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:6px;font-weight:600}
.info-block p,.info-block a{color:rgba(255,255,255,.88);font-size:15px}
.info-block a:hover{color:var(--gold)}
.contact-form{background:rgba(255,255,255,.04);padding:42px;border-radius:var(--radius);border:1px solid var(--line);backdrop-filter:blur(8px)}
.contact-form h3{font-family:var(--serif);font-size:30px;color:#fff;margin-bottom:28px;font-weight:600}
.contact-form label{display:block;margin-bottom:18px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600}
.contact-form input,.contact-form textarea{width:100%;margin-top:8px;padding:14px 16px;background:rgba(0,0,0,.3);border:1px solid var(--line);color:#fff;border-radius:8px;font-family:inherit;font-size:14px;outline:none;transition:all .3s;letter-spacing:normal;text-transform:none;font-weight:400}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--gold);background:rgba(0,0,0,.5);box-shadow:0 0 0 3px rgba(201,163,92,.15)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,.3)}
.hint{text-align:center;color:rgba(255,255,255,.45);font-size:12px;margin-top:14px;letter-spacing:.5px}

/* ===== Map ===== */
.map-section{position:relative;background:var(--bg);line-height:0}
.map-section iframe{filter:grayscale(20%) contrast(1.05)}

/* ===== Footer ===== */
.footer{background:#06060a;color:#fff;padding:70px 0 24px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;margin-bottom:40px}
.footer .logo{font-size:32px;margin-bottom:14px;display:inline-block}
.footer .label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:600}
.footer a{display:block;color:rgba(255,255,255,.7);padding:5px 0;font-size:14px}
.footer a:hover{color:var(--gold)}
.socials{display:flex;gap:14px}
.socials a{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--line);font-size:18px;padding:0;transition:all .3s}
.socials a:hover{background:var(--grad-gold);border-color:var(--gold);transform:translateY(-3px) rotate(8deg)}
.copyright{text-align:center;color:rgba(255,255,255,.4);font-size:12px;border-top:1px solid var(--line);padding-top:24px;letter-spacing:.5px}

/* ===== Floating Buttons ===== */
.wa-float{position:fixed;bottom:24px;right:24px;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 8px 24px rgba(37,211,102,.45);z-index:90;transition:all .3s;animation:float 3s ease-in-out infinite}
.wa-float:hover{transform:scale(1.15) rotate(8deg);box-shadow:0 12px 30px rgba(37,211,102,.6)}
.wa-float::before{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid #25D366;opacity:.5;animation:pulse 2s ease-in-out infinite}
.to-top{position:fixed;bottom:96px;right:24px;width:46px;height:46px;border-radius:50%;background:var(--bg);color:var(--gold);border:1px solid var(--gold);font-size:20px;cursor:pointer;z-index:90;opacity:0;visibility:hidden;transition:all .3s}
.to-top.show{opacity:1;visibility:visible}
.to-top:hover{background:var(--gold);color:#fff;transform:translateY(-3px)}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px;padding-top:130px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2)::after{display:none}
}
@media(max-width:880px){
  .nav-links{position:fixed;top:0;right:0;background:rgba(10,10,12,.98);backdrop-filter:blur(20px);flex-direction:column;width:75%;height:100vh;padding:100px 40px 40px;gap:28px;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);align-items:flex-start;border-left:1px solid var(--line)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:14px}
  .hamburger{display:block;z-index:101}
  .phone-link{display:none}
  .section{padding:80px 0}
}
@media(max-width:600px){
  .hero-text h1{font-size:52px}
  .hero-cta .btn{padding:12px 22px;font-size:11px}
  .nav-right .btn{padding:10px 16px;font-size:11px}
  .container{padding:0 10px}
  .concierge-card{padding:28px 22px}
  .stats-grid{gap:20px}
  .stat .num{font-size:36px}
  .contact-form{padding:28px 22px}
  .review-card,.offer-card{padding:28px 22px}
}
/* ===== Logo image ===== */
.logo-link{display:inline-flex;align-items:center;transition:transform .3s}
.logo-link:hover{transform:scale(1.05)}
.logo-img{height:54px;width:auto;display:block;filter:drop-shadow(0 4px 12px rgba(201,163,92,.35))}
.site-header.scrolled .logo-img{height:44px;transition:height .3s}
.loader-img{width:140px;height:auto;animation:pulse 1.6s ease-in-out infinite;filter:drop-shadow(0 0 30px rgba(201,163,92,.5))}
.footer-logo{height:70px;width:auto;margin-bottom:14px;display:block}

/* ===== Hero brand text colors ===== */
.brand-we{color:#fff;font-style:normal}
.brand-4{background:linear-gradient(135deg,#ffd86b,#f5c542,#c9a35c);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;display:inline-block;animation:shimmer 4s ease-in-out infinite;background-size:200% 100%;padding:0 .04em}
.hero-text h1 em{background:linear-gradient(135deg,#fff,#f5e9c8,#fff);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;display:inline-block;font-size:.6em;font-weight:500;letter-spacing:1px;animation:shimmer 5s ease-in-out infinite;background-size:200% 100%}

/* ===== Marquee (auto-scrolling services) ===== */
.marquee{margin-top:50px;overflow:hidden;position:relative;padding:20px 0;mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee-track{display:flex;gap:24px;width:max-content;animation:marqueeScroll 60s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .service-card{width:340px;flex-shrink:0;background:#fff;border:1px solid #f0eadb;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .4s,box-shadow .4s}
.marquee .service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--gold)}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Ladies Services ===== */
.ladies-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:50px}
.ladies-card{background:#fff;border:1px solid #ece5d5;border-radius:var(--radius);padding:32px 26px;text-align:center;transition:all .45s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.ladies-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-gold);transform:scaleX(0);transform-origin:left;transition:transform .5s}
.ladies-card:hover::before{transform:scaleX(1)}
.ladies-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-gold);border-color:var(--gold)}
.ladies-card.highlight{background:linear-gradient(160deg,#fff8e8,#fff);border-color:var(--gold);animation:glow 3s ease-in-out infinite}
.ladies-card h4{font-family:var(--serif);font-size:22px;color:var(--text);margin-bottom:14px;font-weight:600}
.ladies-card .price-tag{font-family:var(--serif);font-size:34px;font-weight:700;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:14px;line-height:1}
.ladies-card .ladies-note{color:var(--muted);font-size:13.5px;line-height:1.55}
.ladies-card .ladies-note strong{color:var(--gold-deep);font-weight:600}
.ribbon-sm{position:absolute;top:14px;right:-32px;background:var(--grad-gold);color:#111;font-size:10px;letter-spacing:1.5px;font-weight:700;padding:5px 38px;transform:rotate(35deg);text-transform:uppercase;box-shadow:0 4px 10px rgba(0,0,0,.15)}

/* ===== Combo with images ===== */
.combo-card{padding:0;display:flex;flex-direction:column}
.combo-img{height:160px;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;position:relative}
.combo-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,10,12,.8) 100%)}
.combo-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.combo-card:hover .combo-img img{transform:scale(1.1)}
.combo-body{padding:24px 26px 28px;flex:1;display:flex;flex-direction:column}
.combo-card.featured .ribbon{z-index:3}

/* ===== Testimonials ===== */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px;margin-top:30px}
.testi-card{background:#fff;border:1px solid #ece5d5;border-radius:var(--radius);padding:32px 26px 26px;text-align:center;transition:all .4s;box-shadow:var(--shadow-sm);position:relative}
.testi-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.testi-photo{width:80px;height:80px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:32px;font-weight:700;box-shadow:0 8px 20px rgba(201,163,92,.35);border:3px solid #fff}
.testi-card .stars{justify-content:center;display:block;margin:4px 0 14px}
.testi-card p{font-style:italic;color:#444;font-family:var(--serif);font-size:16px;line-height:1.6;margin-bottom:18px}
.testi-card strong{display:block;color:var(--text);font-size:15px;margin-bottom:2px}
.testi-card span{font-size:12px;color:var(--muted)}
.video-card .video-wrap{margin-bottom:18px;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#1a1a1a,#0e0e10);aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;position:relative}
.video-placeholder{text-align:center;color:#fff;padding:20px}
.play-btn{display:inline-flex;width:60px;height:60px;border-radius:50%;background:var(--grad-gold);align-items:center;justify-content:center;color:#111;font-size:22px;margin-bottom:12px;animation:pulse 2s infinite;box-shadow:0 8px 24px rgba(201,163,92,.5)}
.video-placeholder p{color:#fff;font-family:var(--serif);font-size:16px;margin:0 0 4px;font-style:normal}
.video-placeholder small{color:rgba(255,255,255,.5);font-size:11px;letter-spacing:1px;text-transform:uppercase}

/* ===== QR Codes ===== */
.qr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px;margin-top:50px;max-width:900px;margin-left:auto;margin-right:auto}
.qr-card{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:var(--radius);padding:30px 24px;text-align:center;transition:all .4s;display:block;color:#fff}
.qr-card:hover{transform:translateY(-8px);background:rgba(201,163,92,.1);border-color:var(--gold);box-shadow:var(--shadow-gold)}
.qr-img-wrap{background:#fff;border-radius:12px;padding:14px;margin:0 auto 18px;width:180px;height:180px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.qr-img-wrap img{width:100%;height:100%;object-fit:contain}
.qr-img-wrap.wa-icon{background:#25D366}
.qr-img-wrap.wa-icon span{font-size:96px}
.qr-label{font-family:var(--serif);font-size:22px;color:var(--gold);font-weight:600;margin-bottom:4px}
.qr-card small{color:rgba(255,255,255,.6);font-size:12.5px;letter-spacing:1px}

@media(max-width:600px){
  .logo-img{height:44px}
  .marquee .service-card{width:280px}
  .qr-img-wrap{width:150px;height:150px}
}
