/*
Theme Name: Luxea Spa
Theme URI: https://luxeaspa.com/
Author: Luxea Spa
Author URI: https://luxeaspa.com/
Description: Luxea Spa — Premium luxury spa, hammam and massage WordPress theme for Casablanca, Morocco. Bilingual (FR/EN), SEO-optimized, fully responsive, with Schema.org local business data. Built for "Meilleur Spa Casablanca", "Hammam Massage Casablanca", "Spa Massage Casablanca".
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: luxea-spa
Tags: custom-logo, custom-menu, featured-images, translation-ready, threaded-comments, block-styles, wide-blocks, responsive-layout
*/

/* =============================================================
   LUXEA SPA — Luxury Gold Theme
   Colors: Gold #C9A96A, Deep Black #0B0B0C, Ivory #F6F1E7,
           Champagne #E7D5B2, Soft Beige #EFE7D7
============================================================= */

:root{
  --gold:#C9A96A;
  --gold-dark:#A8884C;
  --gold-soft:#E7D5B2;
  --black:#0B0B0C;
  --ink:#1a1a1b;
  --ivory:#F6F1E7;
  --cream:#FBF7EF;
  --beige:#EFE7D7;
  --text:#222;
  --muted:#6b6357;
  --radius:14px;
  --shadow:0 10px 40px rgba(0,0,0,.08);
  --shadow-lg:0 30px 60px rgba(0,0,0,.18);
  --ff-serif:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --ff-sans:'Inter','Poppins', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--ff-sans);
  color:var(--text);
  background:var(--cream);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold-dark);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--ff-serif);color:var(--black);font-weight:600;letter-spacing:.3px;line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.75rem)}
h3{font-size:1.4rem}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
section{padding:80px 0}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(11,11,12,.92);
  backdrop-filter:blur(10px);
  color:#fff;
  border-bottom:1px solid rgba(201,169,106,.25);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:15px 20px}
.site-brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--ff-serif);font-size:1.7rem;letter-spacing:2px}
.site-brand span{color:var(--gold)}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:28px}
.main-nav a{color:#f6f1e7;font-weight:500;font-size:.95rem;letter-spacing:.5px;position:relative;padding:6px 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.main-nav a:hover,.main-nav .current-menu-item > a{color:var(--gold)}
.main-nav a:hover::after,.main-nav .current-menu-item > a::after{width:100%}
.main-nav .sub-menu{position:absolute;top:100%;left:0;background:#0b0b0c;padding:14px 0;min-width:220px;display:none;box-shadow:var(--shadow-lg);border-top:2px solid var(--gold)}
.main-nav li{position:relative}
.main-nav li:hover > .sub-menu{display:block}
.main-nav .sub-menu a{display:block;padding:8px 22px}
.header-actions{display:flex;align-items:center;gap:14px}
.lang-switch{display:flex;gap:6px;font-size:.8rem;font-weight:600}
.lang-switch a{color:#cdbf9d;padding:4px 8px;border:1px solid transparent;border-radius:4px}
.lang-switch a.active,.lang-switch a:hover{color:var(--black);background:var(--gold);border-color:var(--gold)}
.btn-header{background:var(--gold);color:var(--black);padding:10px 22px;border-radius:50px;font-weight:600;font-size:.85rem;letter-spacing:1px;text-transform:uppercase;transition:.25s}
.btn-header:hover{background:#fff;color:var(--black)}
.menu-toggle{display:none;background:transparent;border:0;color:#fff;font-size:1.5rem;cursor:pointer}

/* ===== Buttons ===== */
.btn{display:inline-block;padding:14px 34px;background:var(--gold);color:var(--black);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;font-size:.82rem;border-radius:50px;border:2px solid var(--gold);transition:.3s;cursor:pointer}
.btn:hover{background:transparent;color:var(--gold)}
.btn-outline{background:transparent;color:#fff;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--black)}
.btn-dark{background:var(--black);color:var(--gold);border-color:var(--black)}
.btn-dark:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}

/* ===== Hero ===== */
.hero{
  min-height:92vh;display:flex;align-items:center;justify-content:center;
  text-align:center;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.6)), var(--hero-img,url('assets/images/hero-luxury-tray.jpg')) center/cover no-repeat;
}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,.6))}
.hero .inner{position:relative;z-index:2;max-width:900px;padding:0 20px;animation:fadeUp 1s ease both}
.hero .eyebrow{color:var(--gold);letter-spacing:4px;text-transform:uppercase;font-size:.8rem;margin-bottom:14px;display:inline-block;font-weight:600}
.hero h1{color:#fff;margin-bottom:18px}
.hero p{font-size:1.15rem;color:#eae2d1;max-width:680px;margin:0 auto 32px}
.hero .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* ===== Section headings ===== */
.section-title{text-align:center;margin-bottom:60px}
.section-title .eyebrow{color:var(--gold);letter-spacing:4px;text-transform:uppercase;font-size:.75rem;font-weight:700}
.section-title h2{margin-top:10px}
.section-title .sep{width:60px;height:2px;background:var(--gold);margin:14px auto 0}

/* ===== About ===== */
.about{background:var(--ivory)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.about-img img{width:100%;height:520px;object-fit:cover}
.about-text p{color:var(--muted);margin-bottom:18px}
.about-text .btn{margin-top:16px}

/* ===== Services Cards ===== */
.services{background:linear-gradient(180deg,var(--cream),var(--beige))}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.service-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.35s;position:relative}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.service-card .img{height:260px;overflow:hidden;position:relative}
.service-card .img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.service-card:hover .img img{transform:scale(1.08)}
.service-card .body{padding:28px}
.service-card h3{color:var(--black);margin-bottom:10px}
.service-card p{color:var(--muted);font-size:.95rem;margin-bottom:16px}
.service-card .price{color:var(--gold-dark);font-weight:700;font-size:1.1rem;margin-bottom:14px;display:block}
.service-card .more{color:var(--black);font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.78rem;border-bottom:1px solid var(--gold);padding-bottom:2px}

/* ===== Why choose ===== */
.why{background:var(--black);color:#eae2d1}
.why h2,.why h3{color:#fff}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.why-item{text-align:center;padding:30px 20px;border:1px solid rgba(201,169,106,.2);border-radius:var(--radius);transition:.3s}
.why-item:hover{border-color:var(--gold);background:rgba(201,169,106,.05)}
.why-item .icon{font-size:2.4rem;color:var(--gold);margin-bottom:14px}
.why-item p{color:#cdbf9d;font-size:.95rem}

/* ===== Price preview / Packs ===== */
.prices{background:var(--ivory)}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.price-card{background:#fff;padding:36px 26px;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);border-top:3px solid var(--gold);transition:.3s}
.price-card:hover{transform:translateY(-6px)}
.price-card h3{color:var(--black)}
.price-card .amt{font-family:var(--ff-serif);font-size:2.2rem;color:var(--gold-dark);margin:10px 0;display:block}
.price-card .dur{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.price-card ul{list-style:none;padding:0;margin:0 0 18px;text-align:left}
.price-card ul li{padding:6px 0;color:#555;font-size:.9rem;border-bottom:1px dashed #eee;display:flex;gap:8px}
.price-card ul li::before{content:"✦";color:var(--gold)}

/* ===== Gallery ===== */
.gallery{background:var(--cream)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery-grid a{display:block;overflow:hidden;border-radius:8px;height:220px}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery-grid a:hover img{transform:scale(1.08)}

/* ===== Testimonials ===== */
.testimonials{background:var(--beige)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.t-card{background:#fff;padding:36px 28px;border-radius:var(--radius);box-shadow:var(--shadow);position:relative}
.t-card::before{content:"“";position:absolute;top:-20px;left:20px;font-family:var(--ff-serif);font-size:6rem;color:var(--gold);line-height:1}
.t-card p{color:#444;font-style:italic;margin-bottom:18px;font-size:.95rem}
.t-card .who{font-weight:700;color:var(--black)}
.t-card .stars{color:var(--gold);margin-bottom:10px;letter-spacing:2px}

/* ===== FAQ ===== */
.faq{background:var(--ivory)}
.faq-list{max-width:820px;margin:0 auto}
.faq-item{background:#fff;margin-bottom:14px;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.05);overflow:hidden}
.faq-item summary{padding:22px 26px;font-weight:600;color:var(--black);cursor:pointer;font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--gold);font-size:1.6rem;transition:.3s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 26px 22px;color:var(--muted);margin:0}

/* ===== CTA banner ===== */
.cta-banner{background:linear-gradient(rgba(11,11,12,.78),rgba(11,11,12,.8)),url('assets/images/hammam-tajine-candles.jpg') center/cover no-repeat fixed;color:#fff;text-align:center;padding:100px 20px}
.cta-banner h2{color:#fff}
.cta-banner p{color:#cdbf9d;max-width:620px;margin:0 auto 24px}

/* ===== Forms ===== */
.form-wrap{max-width:720px;margin:0 auto;background:#fff;padding:50px;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px}
.form-wrap label{display:block;font-size:.8rem;font-weight:600;color:var(--black);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px}
.form-wrap input,.form-wrap select,.form-wrap textarea{
  width:100%;padding:14px 16px;border:1px solid #e0d6c2;border-radius:8px;font:inherit;background:var(--cream);transition:.2s
}
.form-wrap input:focus,.form-wrap select:focus,.form-wrap textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,169,106,.2)}
.form-wrap textarea{min-height:130px;resize:vertical}
.form-msg{padding:14px;border-radius:8px;margin-bottom:18px;text-align:center;font-weight:600}
.form-msg.ok{background:#e9f7ec;color:#2c6e3b;border:1px solid #b9e0c2}
.form-msg.err{background:#fdeaea;color:#9b2c2c;border:1px solid #f3b8b8}

/* ===== Footer ===== */
.site-footer{background:var(--black);color:#b9ae92;padding:70px 0 25px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.site-footer h4{color:#fff;margin-bottom:18px;font-size:1.1rem;letter-spacing:2px;text-transform:uppercase}
.site-footer a{color:#b9ae92}
.site-footer a:hover{color:var(--gold)}
.site-footer .brand{font-family:var(--ff-serif);font-size:1.8rem;color:#fff;letter-spacing:3px;margin-bottom:14px;display:block}
.site-footer .brand span{color:var(--gold)}
.footer-links ul{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:10px}
.footer-contact p{margin:0 0 8px;font-size:.93rem}
.footer-bottom{border-top:1px solid rgba(201,169,106,.2);padding-top:22px;display:flex;justify-content:space-between;font-size:.85rem;flex-wrap:wrap;gap:10px}

/* ===== Page banner ===== */
.page-banner{background:linear-gradient(rgba(11,11,12,.7),rgba(11,11,12,.7)),url('assets/images/spa-room-robe.jpg') center/cover no-repeat;color:#fff;text-align:center;padding:130px 20px 90px}
.page-banner h1{color:#fff}
.breadcrumb{color:var(--gold);font-size:.85rem;letter-spacing:2px;text-transform:uppercase;margin-top:8px}

/* ===== Blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.post-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.3s}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.post-card .img{height:230px;overflow:hidden}
.post-card .img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.post-card:hover .img img{transform:scale(1.06)}
.post-card .body{padding:24px}
.post-card .meta{color:var(--gold-dark);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.post-card h3{font-size:1.25rem}
.post-card p{color:var(--muted);font-size:.93rem}

/* ===== Responsive ===== */
@media (max-width:980px){
  .service-grid,.why-grid,.t-grid,.blog-grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
  .about-img img{height:380px}
  .gallery-grid{grid-template-columns:1fr 1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .form-wrap{padding:30px}
}
@media (max-width:680px){
  section{padding:60px 0}
  .main-nav{position:fixed;top:0;right:-100%;width:85%;height:100vh;background:#0b0b0c;padding:80px 30px;transition:.35s;box-shadow:-10px 0 40px rgba(0,0,0,.5)}
  .main-nav.open{right:0}
  .main-nav ul{flex-direction:column;gap:20px}
  .menu-toggle{display:block}
  .header-actions .btn-header{display:none}
  .service-grid,.why-grid,.t-grid,.blog-grid,.price-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .hero{min-height:85vh}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .cta-banner{background-attachment:scroll}
}

/* ===== Floating call button (mobile) ===== */
.float-call{position:fixed;right:18px;bottom:18px;z-index:99;background:var(--gold);color:var(--black);padding:14px 18px;border-radius:50px;font-weight:700;box-shadow:var(--shadow-lg);display:none}
.float-call:hover{background:#fff;color:var(--black)}
@media (max-width:680px){.float-call{display:inline-flex;gap:8px;align-items:center}}


/* ============================================================
   LUXEA — PATCH 2026-04-29 : Mobile submenu fix + WhatsApp FAB
   ============================================================ */
.float-call{display:none !important}

@media (max-width:680px){
  .main-nav .sub-menu{position:static !important;display:none;background:transparent !important;box-shadow:none !important;border-top:0 !important;padding:6px 0 6px 18px !important;min-width:0 !important;margin-top:6px}
  .main-nav li.menu-item-has-children.is-open > .sub-menu{display:block}
  .main-nav li{position:static}
  .main-nav li:hover > .sub-menu{display:none}
  .main-nav li.menu-item-has-children > a{display:flex;justify-content:space-between;align-items:center}
  .main-nav li.menu-item-has-children > a::after{content:"+";color:var(--gold);font-size:1.4rem;line-height:1;margin-left:12px;transition:transform .25s}
  .main-nav li.menu-item-has-children.is-open > a::after{content:"−"}
  .main-nav .sub-menu a{display:block;padding:10px 0;color:var(--gold);font-family:var(--ff-serif);font-size:1.05rem;letter-spacing:.5px}
}

.luxea-wa-fab{position:fixed;right:22px;bottom:22px;z-index:9999;width:62px;height:62px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(37,211,102,.45);transition:transform .25s, box-shadow .25s}
.luxea-wa-fab:hover{transform:scale(1.08);box-shadow:0 14px 36px rgba(37,211,102,.55)}
.luxea-wa-fab svg{width:32px;height:32px;fill:#fff}
.luxea-wa-fab .pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,211,102,.55);animation:luxeaPulse 2s infinite}
@keyframes luxeaPulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.4);opacity:0}}
@media (max-width:680px){.luxea-wa-fab{width:58px;height:58px;right:16px;bottom:16px}.luxea-wa-fab svg{width:28px;height:28px}}

/* === LUXEA WhatsApp FAB hardening (specificity + size) === */
body a.luxea-wa-fab,
footer a.luxea-wa-fab,
.site-footer a.luxea-wa-fab,
a.luxea-wa-fab{
  position:fixed !important;
  right:22px !important;
  bottom:22px !important;
  left:auto !important;
  top:auto !important;
  width:62px !important;
  height:62px !important;
  max-width:62px !important;
  max-height:62px !important;
  border-radius:50% !important;
  background:#25D366 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:0 !important;
  margin:0 !important;
  overflow:visible !important;
  z-index:99999 !important;
  box-shadow:0 10px 28px rgba(37,211,102,.45) !important;
}
a.luxea-wa-fab svg{
  width:32px !important;
  height:32px !important;
  max-width:32px !important;
  max-height:32px !important;
  fill:#fff !important;
  display:block !important;
}
a.luxea-wa-fab .pulse{
  position:absolute !important;
  inset:-4px !important;
  border-radius:50% !important;
  border:2px solid rgba(37,211,102,.55) !important;
  pointer-events:none !important;
}
@media (max-width:680px){
  a.luxea-wa-fab{width:58px !important;height:58px !important;right:16px !important;bottom:16px !important;max-width:58px !important;max-height:58px !important}
  a.luxea-wa-fab svg{width:28px !important;height:28px !important;max-width:28px !important;max-height:28px !important}
}

/* Mobile menu accordion hardening */
@media (max-width:680px){
  .main-nav ul.sub-menu,
  .main-nav .sub-menu{
    position:static !important;
    top:auto !important;
    left:auto !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    padding:6px 0 6px 18px !important;
    min-width:0 !important;
    width:100% !important;
    display:none !important;
  }
  .main-nav li.menu-item-has-children.is-open > ul.sub-menu,
  .main-nav li.menu-item-has-children.is-open > .sub-menu{
    display:block !important;
  }
}
