/*
Theme Name: Écuries de la Vallée des Rois
Theme URI: https://www.ecuries-de-la-vallee-des-rois.fr
Author: Écuries de la Vallée des Rois
Author URI: https://www.ecuries-de-la-vallee-des-rois.fr
Description: Thème personnalisé pour le centre équestre Écuries de la Vallée des Rois — Azay-sur-Cher, Val de Loire.
Version: 2.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vallee-des-rois
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#C4A265;
  --gold-light:#D4B87A;
  --dark:#1A1714;
  --dark-warm:#2A2520;
  --cream:#F5F0E8;
  --cream-dark:#E8E0D2;
  --olive:#5C6B4F;
  --text:#3A3530;
  --text-light:#6B6560;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Cormorant Garamond',serif;color:var(--text);background:var(--cream);overflow-x:hidden}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}

.loader{position:fixed;inset:0;background:var(--dark);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .8s,visibility .8s;flex-direction:column;gap:20px}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-horse{width:70px;height:auto;animation:gallop 1.2s ease-in-out infinite}
@keyframes gallop{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.loader-text{font-family:'Playfair Display',serif;color:var(--gold);font-size:1.2rem;letter-spacing:6px;text-transform:uppercase;animation:fadeInOut 1.5s ease infinite}
@keyframes fadeInOut{0%,100%{opacity:.4}50%{opacity:1}}

/* NAV */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 60px;display:flex;justify-content:space-between;align-items:center;transition:all .5s}
.site-nav.scrolled{background:rgba(26,23,20,.95);backdrop-filter:blur(20px);padding:14px 60px;box-shadow:0 4px 30px rgba(0,0,0,.3)}
.nav-logo{display:flex;align-items:center;text-decoration:none}
.nav-logo img{height:30px!important;width:auto!important;max-width:180px!important;transition:opacity .3s}
.nav-logo:hover img{opacity:.85}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{text-decoration:none;color:var(--cream);font-family:'Montserrat',sans-serif;font-size:.7rem;letter-spacing:3px;text-transform:uppercase;position:relative;padding-bottom:4px;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width .4s}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-phone{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--gold);font-family:'Montserrat',sans-serif;font-size:.7rem;letter-spacing:2px;transition:opacity .3s}
.nav-phone:hover{opacity:.7}
.nav-phone svg{width:16px;height:16px}
.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:101}
.menu-toggle span{width:28px;height:2px;background:var(--gold);transition:all .3s}

/* HERO */
.hero{height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.35) contrast(1.1) saturate(.8)}
.hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(26,23,20,.3) 0%,rgba(26,23,20,.1) 40%,rgba(26,23,20,.6) 100%)}
.hero-vignette{position:absolute;inset:0;z-index:3;background:radial-gradient(ellipse at 50% 50%,transparent 50%,rgba(26,23,20,.5) 100%)}
.hero-content{position:relative;z-index:10;text-align:center;max-width:900px;padding:0 40px}
.hero-badge{font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:8px;text-transform:uppercase;color:var(--gold);margin-bottom:30px;opacity:0;animation:slideUp .8s .5s forwards}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,5vw,4.5rem);color:var(--cream);font-weight:400;line-height:1.15;margin-bottom:24px;opacity:0;animation:slideUp .8s .7s forwards}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-family:'Cormorant Garamond',serif;font-size:clamp(1rem,2vw,1.4rem);color:rgba(245,240,232,.7);font-weight:300;max-width:600px;margin:0 auto 50px;line-height:1.7;opacity:0;animation:slideUp .8s .9s forwards}
.hero-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;opacity:0;animation:slideUp .8s 1.1s forwards}
.btn{font-family:'Montserrat',sans-serif;font-size:.65rem;letter-spacing:3px;text-transform:uppercase;padding:16px 40px;text-decoration:none;transition:all .4s;display:inline-block}
.btn-primary{background:var(--gold);color:var(--dark);border:1px solid var(--gold)}
.btn-primary:hover{background:transparent;color:var(--gold)}
.btn-outline{border:1px solid rgba(196,162,101,.5);color:var(--cream)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:rgba(196,162,101,.08)}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(245,240,232,.4);font-family:'Montserrat',sans-serif;font-size:.55rem;letter-spacing:4px;text-transform:uppercase;animation:bounce 2s infinite}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* SECTIONS */
section{padding:120px 60px;position:relative}
.section-badge{font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:6px;text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:16px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);text-align:center;font-weight:400;line-height:1.2;margin-bottom:20px}
.section-subtitle{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--text-light);text-align:center;max-width:650px;margin:0 auto 70px;line-height:1.7;font-weight:300}
.divider{width:60px;height:1px;background:var(--gold);margin:0 auto 50px}

/* ABOUT */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1200px;margin:0 auto}
.about-visual{position:relative;height:600px;overflow:hidden}
.about-visual img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
.about-visual:hover img{transform:scale(1.05)}
.about-visual-overlay{position:absolute;inset:0;border:1px solid rgba(196,162,101,.15);margin:20px;pointer-events:none;z-index:2}
.about-visual-label{position:absolute;bottom:40px;left:40px;font-family:'Montserrat',sans-serif;font-size:.55rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);z-index:3;background:rgba(26,23,20,.7);padding:8px 16px;backdrop-filter:blur(8px)}
.about-text h3{font-family:'Playfair Display',serif;font-size:clamp(1.4rem,3.5vw,2.4rem);font-weight:400;margin-bottom:30px;line-height:1.3}
.about-text h3 em{color:var(--gold);font-style:italic}
.about-text p{font-size:1.1rem;line-height:1.9;color:var(--text-light);margin-bottom:20px;font-weight:300}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px;padding-top:40px;border-top:1px solid var(--cream-dark)}
.stat-num{font-family:'Playfair Display',serif;font-size:2.5rem;color:var(--gold);display:block}
.stat-label{font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:var(--text-light);margin-top:4px}

/* PHOTO BAND */
.photo-band{display:grid;grid-template-columns:repeat(4,1fr);height:350px;overflow:hidden}
.photo-band img{width:100%;height:100%;object-fit:cover;transition:all .6s;filter:saturate(.85)}
.photo-band img:hover{filter:saturate(1);transform:scale(1.03)}

/* ACTIVITIES */
.activities{background:var(--dark);color:var(--cream)}
.activities .section-title{color:var(--cream)}
.activities .section-subtitle{color:rgba(245,240,232,.5)}
.activity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto}
.activity-card{position:relative;overflow:hidden;height:420px;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end}
.activity-card img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;filter:brightness(.5) saturate(.7);z-index:0}
.activity-card-content{position:relative;z-index:3;padding:30px;background:linear-gradient(to top,rgba(26,23,20,.9) 0%,rgba(26,23,20,.6) 60%,transparent 100%);padding-top:80px}
.activity-card-content h4{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:400;color:#F5F0E8;margin:0 0 8px 0}
.activity-card-content p{font-size:.95rem;color:rgba(245,240,232,.6);line-height:1.7;font-weight:300;margin:0}
.activity-card-tag{position:absolute;top:24px;left:24px;font-family:'Montserrat',sans-serif;font-size:.55rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);background:rgba(26,23,20,.7);padding:6px 14px;z-index:3}
@media(hover:hover){
  .activity-card-content p{opacity:0;max-height:0;overflow:hidden;transition:all .5s}
  .activity-card:hover .activity-card-content p{opacity:1;max-height:200px}
  .activity-card:hover img{transform:scale(1.08);filter:brightness(.35) saturate(.9);transition:transform .8s,filter .8s}
}

/* PARALLAX QUOTE */
.parallax-quote{height:450px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.parallax-quote img{position:absolute;inset:0;width:100%;height:120%;object-fit:cover;filter:brightness(.3) saturate(.6);transform:translateY(-10%)}
.parallax-quote-content{position:relative;z-index:2;text-align:center;max-width:700px;padding:0 40px}
.parallax-quote blockquote{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2.2rem);color:var(--cream);font-weight:400;line-height:1.5;font-style:italic}
.parallax-quote cite{font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);display:block;margin-top:24px;font-style:normal}

/* PENSION */
.pension{background:var(--cream-dark)}
.pension-layout{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1200px;margin:0 auto}
.pension-card{padding:60px;background:var(--cream);border:1px solid rgba(196,162,101,.12);position:relative}
.pension-card:first-child{border-right:none}
.pension-card h4{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:400;margin-bottom:10px}
.pension-card .price{font-family:'Montserrat',sans-serif;font-size:.65rem;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:24px}
.pension-card p{font-size:1.05rem;line-height:1.9;color:var(--text-light);font-weight:300;margin-bottom:16px}
.pension-card ul{list-style:none;margin-top:24px}
.pension-card li{padding:10px 0;border-bottom:1px solid var(--cream-dark);font-size:1rem;color:var(--text-light);padding-left:20px;position:relative;font-weight:300}
.pension-card li::before{content:'—';position:absolute;left:0;color:var(--gold)}
.pension-img{height:350px;overflow:hidden;max-width:1200px;margin:50px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:0}
.pension-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.85);transition:all .6s}
.pension-img img:hover{filter:saturate(1)}

/* GITE */
.gite{background:var(--dark);color:var(--cream);overflow:hidden}
.gite-wrapper{display:grid;grid-template-columns:1fr 1fr;max-width:1200px;margin:0 auto;gap:60px;align-items:center}
.gite-images{display:grid;grid-template-rows:1fr 1fr;gap:16px;height:560px}
.gite-images img{width:100%;height:100%;object-fit:cover;transition:transform 4s;border:1px solid rgba(196,162,101,.1)}
.gite-images img:hover{transform:scale(1.03)}
.gite-content{text-align:left}
.gite-features{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:40px 0}
.gite-feat{text-align:left}
.gite-feat-num{font-family:'Playfair Display',serif;font-size:2.6rem;color:var(--gold)}
.gite-feat-label{font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:rgba(245,240,232,.5);margin-top:4px}
.gite-content p{font-size:1.1rem;line-height:1.8;color:rgba(245,240,232,.6);font-weight:300;margin-bottom:30px}

/* CONTACT */
.contact{background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1100px;margin:0 auto}
.contact-info{padding:60px}
.contact-info h3{font-family:'Playfair Display',serif;font-size:2rem;font-weight:400;margin-bottom:30px}
.contact-item{display:flex;gap:16px;margin-bottom:28px;align-items:flex-start}
.contact-item-icon{width:20px;height:20px;color:var(--gold);flex-shrink:0;margin-top:4px}
.contact-item-text{font-size:1.05rem;line-height:1.7;color:var(--text-light);font-weight:300}
.contact-item-text strong{font-weight:500;color:var(--text);display:block;margin-bottom:2px;font-family:'Montserrat',sans-serif;font-size:.7rem;letter-spacing:2px;text-transform:uppercase}
.contact-map{min-height:450px;position:relative;overflow:hidden}
.contact-map iframe{width:100%;height:100%;min-height:450px;border:0;filter:grayscale(.7) contrast(1.1) brightness(.85)}

/* FOOTER */
.site-footer{background:var(--dark);padding:80px 60px 40px;color:rgba(245,240,232,.4)}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;max-width:1200px;margin:0 auto 60px;flex-wrap:wrap;gap:40px}
.footer-brand{max-width:350px}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--gold);margin-bottom:12px}
.footer-brand p{font-size:.95rem;line-height:1.7;font-weight:300}
.footer-links h5{font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.footer-links a{display:block;color:rgba(245,240,232,.4);text-decoration:none;font-size:.95rem;margin-bottom:10px;transition:color .3s;font-weight:300}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(196,162,101,.1);padding-top:30px;text-align:center;max-width:1200px;margin:0 auto;font-family:'Montserrat',sans-serif;font-size:.6rem;letter-spacing:2px;text-transform:uppercase}
.footer-social{display:flex;gap:20px;margin-top:20px;justify-content:center}
.footer-social a{width:40px;height:40px;border:1px solid rgba(196,162,101,.2);display:flex;align-items:center;justify-content:center;color:var(--gold);text-decoration:none;transition:all .3s;font-size:.8rem}
.footer-social a:hover{background:var(--gold);color:var(--dark)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:all .8s cubic-bezier(.16,1,.3,1);animation:revealFallback 0s 1.5s forwards}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
.reveal.visible{animation:none;opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════
   RESPONSIVE — TABLET (max 1024px)
   ═══════════════════════════════════════════ */
@media(max-width:1024px){
  section{padding:80px 30px}
  .about-grid,.pension-layout,.contact-grid,.gite-wrapper{grid-template-columns:1fr;gap:40px}
  .activity-grid{grid-template-columns:1fr 1fr}
  .about-visual{height:400px}
  .photo-band{grid-template-columns:1fr 1fr;height:auto}
  .photo-band img{height:250px}
  .pension-img{grid-template-columns:1fr}
  .pension-card:first-child{border-right:1px solid rgba(196,162,101,.12)}
  .gite-images{height:400px}
  .hero-content{padding:0 30px}
}

/* ═══════════════════════════════════════════
   RESPONSIVE — MOBILE (max 768px)
   ═══════════════════════════════════════════ */
@media(max-width:768px){
  /* NAV */
  .site-nav{padding:12px 16px}
  .site-nav.scrolled{padding:10px 16px}
  .nav-links{display:none}
  .nav-phone .phone-text{display:none}
  .nav-phone svg{width:20px;height:20px}
  .nav-logo img{height:22px}
  .menu-toggle{display:flex}

  /* HERO */
  .hero{height:100svh;min-height:560px}
  .hero-content{padding:0 20px;margin-top:20px}
  .hero h1{font-size:1.75rem;line-height:1.2;margin-bottom:14px}
  .hero h1 em{display:block}
  .hero-badge{font-size:.45rem;letter-spacing:4px;margin-bottom:16px}
  .hero-sub{font-size:.9rem;line-height:1.55;margin-bottom:28px;max-width:340px}
  .hero-buttons{flex-direction:column;align-items:center;gap:10px}
  .hero-buttons .btn{width:100%;max-width:260px;text-align:center;padding:13px 20px;font-size:.6rem}
  .hero-scroll{display:none}

  /* SECTIONS */
  section{padding:60px 20px}
  .section-badge{font-size:.5rem;letter-spacing:4px;margin-bottom:12px}
  .section-title{font-size:clamp(1.6rem,6vw,2.2rem);margin-bottom:14px}
  .section-subtitle{font-size:1rem;margin-bottom:40px;line-height:1.6}
  .divider{margin-bottom:30px}

  /* ABOUT */
  .about-grid{gap:30px}
  .about-visual{height:280px}
  .about-visual-overlay{margin:12px}
  .about-visual-label{bottom:24px;left:24px;font-size:.5rem;letter-spacing:3px}
  .about-text h3{font-size:1.6rem;margin-bottom:20px}
  .about-text p{font-size:1rem;line-height:1.7;margin-bottom:14px}
  .about-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:30px;padding-top:24px}
  .stat-num{font-size:1.8rem}
  .stat-label{font-size:.5rem;letter-spacing:2px}

  /* PHOTO BAND */
  .photo-band{grid-template-columns:1fr 1fr;height:auto}
  .photo-band img{height:180px}

  /* ACTIVITIES */
  .activities{padding:60px 20px}
  .activity-grid{grid-template-columns:1fr;gap:16px}
  .activity-card{height:auto;min-height:280px}
  .activity-card-tag{top:16px;left:16px;font-size:.5rem;padding:5px 10px}
  .activity-card-content{padding:60px 20px 24px 20px}
  .activity-card-content h4{font-size:1.2rem}
  .activity-card-content p{font-size:.85rem;line-height:1.6;opacity:1!important;max-height:none!important;overflow:visible!important}

  /* PARALLAX QUOTE */
  .parallax-quote{height:300px}
  .parallax-quote-content{padding:0 24px}
  .parallax-quote blockquote{font-size:1.1rem;line-height:1.5}
  .parallax-quote cite{font-size:.5rem;letter-spacing:3px;margin-top:16px}

  /* PENSION */
  .pension-layout{grid-template-columns:1fr;gap:0}
  .pension-card{padding:36px 24px}
  .pension-card:first-child{border-right:1px solid rgba(196,162,101,.12);border-bottom:none}
  .pension-card h4{font-size:1.3rem}
  .pension-card .price{font-size:.6rem}
  .pension-card p{font-size:.95rem;line-height:1.7}
  .pension-card li{font-size:.9rem;padding:8px 0 8px 18px}
  .pension-img{grid-template-columns:1fr;height:auto;margin-top:30px}
  .pension-img img{height:220px}

  /* GITE */
  .gite{padding:60px 20px}
  .gite-wrapper{gap:30px}
  .gite-images{height:auto;grid-template-rows:auto auto;gap:12px}
  .gite-images img{height:200px}
  .gite-content h2{font-size:1.8rem!important}
  .gite-content p{font-size:1rem;line-height:1.7}
  .gite-features{grid-template-columns:1fr 1fr;gap:20px;margin:30px 0}
  .gite-feat-num{font-size:2rem}
  .gite-feat-label{font-size:.5rem}
  .gite-content .btn{width:100%;text-align:center;max-width:280px}

  /* CONTACT */
  .contact-grid{grid-template-columns:1fr}
  .contact-info{padding:30px 20px}
  .contact-info h3{font-size:1.5rem;margin-bottom:24px}
  .contact-item{margin-bottom:20px}
  .contact-item-text{font-size:.95rem}
  .contact-item-text strong{font-size:.6rem}
  .contact-map{min-height:300px}
  .contact-map iframe{min-height:300px}

  /* FOOTER */
  .site-footer{padding:50px 20px 30px}
  .footer-top{flex-direction:column;gap:30px;margin-bottom:40px}
  .footer-brand{max-width:100%}
  .footer-brand-name{font-size:1.1rem}
  .footer-brand p{font-size:.85rem}
  .footer-links h5{font-size:.55rem;margin-bottom:14px}
  .footer-links a{font-size:.85rem;margin-bottom:8px}
  .footer-bottom{font-size:.5rem}
  .footer-social a{width:36px;height:36px;font-size:.7rem}
}

/* ═══════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE (max 420px)
   ═══════════════════════════════════════════ */
@media(max-width:420px){
  .site-nav{padding:10px 12px}
  .nav-logo img{height:18px}

  section{padding:44px 14px}
  .hero-content{padding:0 16px}
  .hero h1{font-size:1.45rem}
  .hero-sub{font-size:.82rem;max-width:300px}
  .hero-buttons .btn{padding:11px 16px;font-size:.55rem;max-width:240px}

  .about-visual{height:200px}
  .about-text h3{font-size:1.3rem}
  .about-stats{gap:6px}
  .stat-num{font-size:1.4rem}
  .stat-label{font-size:.45rem}

  .photo-band{grid-template-columns:1fr}
  .photo-band img{height:180px}

  .activity-card{min-height:240px}
  .activity-card-content{padding:50px 16px 20px 16px}
  .activity-card-content h4{font-size:1rem}
  .activity-card-content p{font-size:.8rem}

  .parallax-quote{height:240px}
  .parallax-quote blockquote{font-size:.95rem}

  .pension-card{padding:24px 16px}
  .pension-card h4{font-size:1.1rem}
  .pension-card p{font-size:.88rem}
  .pension-card li{font-size:.82rem}

  .gite-images img{height:160px}
  .gite-content h2{font-size:1.4rem!important}
  .gite-feat-num{font-size:1.6rem}
  .gite-features{gap:12px;margin:20px 0}

  .contact-info{padding:20px 14px}
  .contact-info h3{font-size:1.2rem}
  .contact-item-text{font-size:.88rem}

  .section-title{font-size:1.4rem}
  .section-subtitle{font-size:.9rem}
  .section-badge{font-size:.45rem;letter-spacing:3px}
}

/* ═══════════════════════════════════════════
   MOBILE MENU
   ═══════════════════════════════════════════ */
.mobile-menu{position:fixed;inset:0;background:rgba(26,23,20,.98);z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:0;visibility:hidden;transition:all .4s;padding:20px}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--cream);text-decoration:none;transition:color .3s}
.mobile-menu a:hover{color:var(--gold)}

/* Close button for mobile menu */
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* WordPress admin bar fix */
body.admin-bar .site-nav{top:32px}
@media(max-width:782px){body.admin-bar .site-nav{top:46px}}

/* Tap targets — minimum 44px for mobile */
@media(max-width:768px){
  .nav-phone{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
  .menu-toggle{min-width:44px;min-height:44px;justify-content:center;align-items:center}
  .footer-social a{min-width:44px;min-height:44px}
  .btn{min-height:48px;display:flex;align-items:center;justify-content:center}
  .mobile-menu a{padding:8px 16px;min-height:44px;display:flex;align-items:center}
}

/* Smooth height for 100vh on mobile browsers */
@supports(height:100svh){
  .hero{height:100svh}
}

/* Prevent horizontal overflow */
img{max-width:100%}
iframe{max-width:100%}
