/*
Theme Name: House Of She
Theme URI: https://houseofshe.ma
Author: House Of She
Author URI: https://houseofshe.ma
Description: Theme WordPress premium pour le spa de luxe House Of She — Maarif, Casablanca. Massage, hammam et soins bien-etre. Design editorial contemporain, SEO local avance, 100% responsive.
Version: 1.0.0
Requires at least: 6.0
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: house-of-she
Tags: spa, wellness, beauty, business, full-site-editing, responsive
*/

:root{
  --hos-sand:#EDE4D8;
  --hos-nude:#D9C7B4;
  --hos-champagne:#C8A24B;
  --hos-champagne-dark:#A9842F;
  --hos-sage:#8C9B7E;
  --hos-terracotta:#C57B57;
  --hos-ink:#2B2622;
  --hos-soft:#6B6258;
  --hos-white:#FBF8F4;
  --hos-line:rgba(43,38,34,.12);
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;
  --radius:18px;
  --shadow:0 18px 50px rgba(43,38,34,.10);
  --maxw:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--hos-ink);background:var(--hos-white);font-size:17px;line-height:1.75;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--hos-champagne-dark);text-decoration:none;transition:color .25s}
a:hover{color:var(--hos-terracotta)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--hos-ink);margin:0 0 .5em}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
p{margin:0 0 1.1em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.32em;font-size:.72rem;color:var(--hos-champagne-dark);font-weight:500;margin-bottom:1rem;display:inline-block}
.section{padding:clamp(60px,9vw,120px) 0}
.section--sand{background:var(--hos-sand)}
.section--nude{background:linear-gradient(180deg,var(--hos-sand),var(--hos-nude))}
.center{text-align:center}
.lead{font-size:1.2rem;color:var(--hos-soft);max-width:640px}
.center .lead{margin-left:auto;margin-right:auto}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:14px 30px;border-radius:50px;font-family:var(--sans);font-weight:500;letter-spacing:.05em;font-size:.9rem;text-transform:uppercase;transition:all .3s;cursor:pointer;border:1px solid transparent}
.btn--primary{background:var(--hos-champagne);color:#fff}
.btn--primary:hover{background:var(--hos-champagne-dark);color:#fff;transform:translateY(-2px);box-shadow:0 12px 28px rgba(168,132,47,.35)}
.btn--ghost{background:transparent;color:var(--hos-ink);border-color:var(--hos-ink)}
.btn--ghost:hover{background:var(--hos-ink);color:#fff}
.btn--light{background:#fff;color:var(--hos-ink)}
.btn--light:hover{background:var(--hos-champagne);color:#fff}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,248,244,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--hos-line);transition:background .3s}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{font-family:var(--serif);font-size:1.7rem;font-weight:600;letter-spacing:.02em;color:var(--hos-ink)}
.brand span{color:var(--hos-champagne-dark)}
.main-nav ul{display:flex;gap:34px;list-style:none;margin:0;padding:0}
.main-nav a{color:var(--hos-ink);font-family:var(--sans);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;position:relative}
.main-nav a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--hos-champagne);transition:width .3s}
.main-nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--hos-ink)}

/* Hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:linear-gradient(120deg,#3a322b,#6b5a48);background-size:cover;background-position:center}
.hero__bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,16,12,.65),rgba(20,16,12,.15))}
.hero__inner{position:relative;z-index:2;max-width:680px}
.hero h1{color:#fff}
.hero .eyebrow{color:var(--hos-champagne)}
.hero p{font-size:1.25rem;color:rgba(255,255,255,.9)}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:2rem}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.is-visible{opacity:1;transform:none}

/* Grid cards */
.grid{display:grid;gap:30px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .35s,box-shadow .35s}
.card:hover{transform:translateY(-8px);box-shadow:0 28px 60px rgba(43,38,34,.16)}
.card__img{aspect-ratio:4/3;background:var(--hos-nude) center/cover}
.card__body{padding:26px}
.card__body h3{margin-bottom:.4rem}
.card__body p{color:var(--hos-soft);font-size:.97rem;margin-bottom:0}

/* Split image/text */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(30px,6vw,80px)}
.split--rev .split__media{order:2}
.split__media img,.split__media .ph{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover}

/* Placeholder */
.ph{background:repeating-linear-gradient(45deg,var(--hos-nude),var(--hos-nude) 14px,var(--hos-sand) 14px,var(--hos-sand) 28px);display:flex;align-items:center;justify-content:center;color:var(--hos-soft);font-family:var(--sans);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:20px;min-height:240px;border-radius:var(--radius)}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery .ph,.gallery img{aspect-ratio:1/1;object-fit:cover;border-radius:14px;transition:transform .4s}
.gallery a:hover img{transform:scale(1.04)}

/* Services / price menu */
.tabs{display:flex;gap:12px;justify-content:center;margin-bottom:48px;flex-wrap:wrap}
.tab-btn{padding:14px 36px;border-radius:50px;border:1px solid var(--hos-ink);background:transparent;font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;cursor:pointer;transition:all .3s}
.tab-btn.is-active{background:var(--hos-ink);color:#fff}
.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:fade .5s ease}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.price-group{margin-bottom:48px}
.price-group h3{border-bottom:1px solid var(--hos-line);padding-bottom:.5rem;color:var(--hos-champagne-dark)}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:14px 0;border-bottom:1px dashed var(--hos-line)}
.price-row .name{font-family:var(--serif);font-size:1.25rem}
.price-row .dur{color:var(--hos-soft);font-size:.85rem;display:block}
.price-row .price{font-family:var(--serif);font-size:1.3rem;color:var(--hos-champagne-dark);white-space:nowrap;font-weight:600}
.price-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(28px,4vw,48px)}

/* Testimonials */
.quote{background:#fff;border-radius:var(--radius);padding:36px;box-shadow:var(--shadow)}
.quote p{font-family:var(--serif);font-size:1.3rem;font-style:italic;color:var(--hos-ink)}
.quote .who{font-family:var(--sans);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--hos-champagne-dark);font-style:normal}
.stars{color:var(--hos-champagne);letter-spacing:.15em;margin-bottom:.6rem}

/* Forms */
.form-field{margin-bottom:20px}
.form-field label{display:block;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--hos-soft);margin-bottom:8px}
.form-field input,.form-field select,.form-field textarea{width:100%;padding:14px 16px;border:1px solid var(--hos-line);border-radius:12px;font-family:var(--sans);font-size:1rem;background:#fff;color:var(--hos-ink)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--hos-champagne)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* Contact info */
.info-list{list-style:none;padding:0;margin:0}
.info-list li{padding:14px 0;border-bottom:1px solid var(--hos-line);display:flex;gap:14px}
.info-list strong{font-family:var(--serif);font-size:1.05rem}
.map-embed iframe{width:100%;border:0;border-radius:var(--radius);min-height:340px;box-shadow:var(--shadow)}

/* Floating WhatsApp */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:200;width:60px;height:60px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(37,211,102,.45);animation:pulse 2.4s infinite}
.wa-float svg{width:32px;height:32px;fill:#fff}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* Footer */
.site-footer{background:var(--hos-ink);color:rgba(255,255,255,.78);padding:70px 0 30px}
.site-footer h4{color:#fff;font-family:var(--serif);margin-bottom:1rem}
.site-footer a{color:rgba(255,255,255,.78)}
.site-footer a:hover{color:var(--hos-champagne)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* Page hero (interior) */
.page-hero{background:linear-gradient(120deg,#3a322b,#6b5a48);color:#fff;padding:clamp(90px,12vw,150px) 0 clamp(50px,7vw,80px);text-align:center}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.85);max-width:620px;margin:0 auto}

/* Responsive */
@media(max-width:980px){
  .grid--3{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .main-nav{position:fixed;inset:84px 0 auto 0;background:var(--hos-white);border-bottom:1px solid var(--hos-line);transform:translateY(-130%);transition:transform .4s;padding:24px}
  .main-nav.is-open{transform:translateY(0)}
  .main-nav ul{flex-direction:column;gap:20px}
  .nav-toggle{display:block}
  .header-cta .btn{display:none}
  .grid--3,.grid--2,.form-grid,.gallery{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
}
