/* ============================================================
   ATLAS 888 GROUP — DESIGN SYSTEM v3.0
   Elegant · Premium · Fully Responsive
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&family=Poppins:wght@300;400;500;600&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400;1,600&display=swap');

/* ── LIGHT MODE (default) ── */
:root {
  --bg:          #FAFAF8;
  --bg-alt:      #F5F3EF;
  --bg-card:     #FFFFFF;
  --surface:     #FFFFFF;
  --black:       #0A0A0A;
  --text:        #1A1A1A;
  --text-muted:  #6B6B6B;
  --text-light:  #AAAAAA;
  --gold:        #B8912A;
  --gold-rich:   #C9A84C;
  --gold-light:  #D4AF57;
  --gold-pale:   #F0E6CC;
  --gold-dark:   #8A6A1C;
  --gold-bg:     rgba(185,145,42,0.07);
  --border:      rgba(0,0,0,0.09);
  --border-gold: rgba(185,145,42,0.28);
  --shadow:      0 4px 24px rgba(0,0,0,0.06);
  --shadow-lg:   0 20px 60px rgba(0,0,0,0.10);
  --shadow-gold: 0 8px 32px rgba(185,145,42,0.22);
  --navbar-bg:   rgba(255,255,255,0.97);
  --navbar-text: #1A1A1A;
  --hero-bg:     #0A0A0A;
  --transition:  0.32s cubic-bezier(0.25,0.46,0.45,0.94);
  --radius:      2px;
}

/* ── DARK MODE ── */
[data-theme="dark"] {
  --bg:          #0C0C0C;
  --bg-alt:      #141414;
  --bg-card:     #181818;
  --surface:     #1C1C1C;
  --text:        #E6E2D8;
  --text-muted:  #888888;
  --text-light:  #505050;
  --border:      rgba(255,255,255,0.07);
  --border-gold: rgba(185,145,42,0.22);
  --shadow:      0 4px 24px rgba(0,0,0,0.35);
  --shadow-lg:   0 20px 60px rgba(0,0,0,0.55);
  --navbar-bg:   rgba(10,10,10,0.98);
  --navbar-text: #E6E2D8;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:'Poppins',sans-serif;
  background:var(--bg);color:var(--text);
  line-height:1.7;overflow-x:hidden;
  transition:background .4s ease,color .4s ease;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5{font-family:'Montserrat',sans-serif;font-weight:700;line-height:1.2;color:var(--text)}
h1{font-size:clamp(2rem,4.5vw,3.6rem);letter-spacing:-0.02em}
h2{font-size:clamp(1.5rem,2.8vw,2.2rem);letter-spacing:-0.018em}
h3{font-size:clamp(1rem,1.6vw,1.2rem)}
h4{font-size:.95rem;font-weight:600}
p{font-size:.95rem;line-height:1.8}

/* ── LAYOUT ── */
.container{max-width:1220px;margin:0 auto;padding:0 24px}
.container--sm{max-width:820px;margin:0 auto;padding:0 24px}
.container--lg{max-width:1380px;margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section--sm{padding:52px 0}

/* ── LABELS ── */
.label{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:800;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  margin-bottom:12px;
}
.label::before,.label::after{content:'';display:block;width:20px;height:1px;background:var(--gold);flex-shrink:0}
.label--left::after{display:none}
.label--center{justify-content:center}
.section-header{margin-bottom:48px}
.section-header--center{text-align:center}
.section-header--center .label{justify-content:center}
.section-header p{margin-top:12px;color:var(--text-muted);max-width:560px;font-size:.97rem}
.section-header--center p{margin-left:auto;margin-right:auto}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:13px 26px;border-radius:var(--radius);
  transition:var(--transition);position:relative;overflow:hidden;
  white-space:nowrap;
}
.btn svg{width:13px;height:13px;flex-shrink:0;transition:transform .22s}
.btn:hover svg{transform:translateX(3px)}

.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:var(--shadow-gold)}

.btn-dark{background:var(--text);color:var(--bg)}
.btn-dark:hover{opacity:.85;transform:translateY(-2px)}

.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}

.btn-outline-gold{background:transparent;color:var(--gold);border:1.5px solid var(--border-gold)}
.btn-outline-gold:hover{background:var(--gold);color:#fff}

.btn-ghost{background:transparent;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.25);padding:12px 24px}
.btn-ghost:hover{border-color:var(--gold-rich);color:var(--gold-rich)}

/* ═══════════════════════════════════════════════
   NAVBAR — Slim, elegant, single-line guaranteed
   ═══════════════════════════════════════════════ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .4s ease,box-shadow .4s ease;
}
#navbar.scrolled{
  background:var(--navbar-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--border),var(--shadow);
}

.nav-inner{
  display:flex;align-items:center;
  height:62px;gap:0;
}

/* Logo — compact */
.nav-logo{
  display:flex;align-items:center;gap:9px;
  flex-shrink:0;margin-right:28px;
  text-decoration:none;
}
.nav-logo-emblem{
  width:33px;height:33px;
  border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:1rem;
  color:var(--gold);flex-shrink:0;
  position:relative;
}
.nav-logo-emblem::before{
  content:'';position:absolute;inset:3px;
  border:1px solid rgba(185,145,42,.18);
}
.nav-logo-text{display:flex;flex-direction:column;justify-content:center}
.nav-logo-name{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:.75rem;letter-spacing:.07em;text-transform:uppercase;
  color:#fff;line-height:1.2;
}
#navbar.scrolled .nav-logo-name{color:var(--navbar-text)}
.nav-logo-sub{
  font-size:.5rem;font-weight:500;letter-spacing:.16em;
  color:var(--gold);text-transform:uppercase;line-height:1;
  margin-top:2px;white-space:nowrap;
}

/* Desktop menu — ensure single line */
.nav-menu{
  display:flex;align-items:center;
  gap:2px;flex:1;
}
.nav-menu a{
  font-family:'Montserrat',sans-serif;font-size:.63rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.68);
  padding:6px 8px;white-space:nowrap;
  position:relative;transition:color .2s;
}
#navbar.scrolled .nav-menu a{color:var(--text-muted)}
.nav-menu a::after{
  content:'';position:absolute;bottom:2px;left:8px;right:8px;
  height:1px;background:var(--gold);transform:scaleX(0);
  transform-origin:center;transition:transform .22s;
}
.nav-menu a:hover,.nav-menu a.active{color:var(--gold)}
.nav-menu a:hover::after,.nav-menu a.active::after{transform:scaleX(1)}

/* Right side actions */
.nav-right{
  display:flex;align-items:center;
  gap:10px;flex-shrink:0;margin-left:auto;
}

/* Theme toggle */
.theme-toggle{
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.14);
  transition:var(--transition);flex-shrink:0;
}
#navbar.scrolled .theme-toggle{color:var(--text-muted);border-color:var(--border)}
.theme-toggle:hover{color:var(--gold);border-color:var(--gold)}
.theme-toggle svg{width:14px;height:14px}

/* Devis CTA — slim */
.nav-devis{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;
  padding:8px 16px;
  background:var(--gold);color:#fff;
  transition:var(--transition);white-space:nowrap;
  border-radius:var(--radius);
}
.nav-devis:hover{background:var(--gold-dark);box-shadow:var(--shadow-gold)}
.nav-devis svg{width:11px;height:11px;flex-shrink:0}

/* Hamburger */
.nav-toggle{
  display:none;flex-direction:column;gap:4.5px;
  padding:6px;margin-left:8px;flex-shrink:0;
}
.nav-toggle span{
  display:block;width:20px;height:1.5px;
  background:#fff;transition:var(--transition);
}
#navbar.scrolled .nav-toggle span{background:var(--text)}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Mobile nav panel */
.mobile-nav{
  position:fixed;top:0;right:0;bottom:0;width:280px;
  background:var(--bg-card);z-index:1001;
  padding:72px 28px 36px;
  transform:translateX(100%);
  transition:transform .38s cubic-bezier(.25,.46,.45,.94);
  border-left:1px solid var(--border);
  overflow-y:auto;
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav-close{
  position:absolute;top:18px;right:18px;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);border:1px solid var(--border);
  transition:var(--transition);
}
.mobile-nav-close:hover{border-color:var(--gold);color:var(--gold)}
.mobile-nav ul{display:flex;flex-direction:column}
.mobile-nav ul li a{
  display:block;
  font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-muted);
  padding:13px 0;border-bottom:1px solid var(--border);
  transition:color .2s;
}
.mobile-nav ul li a:hover{color:var(--gold)}
.mobile-nav-devis{
  margin-top:24px;display:block;text-align:center;
  padding:12px 20px;background:var(--gold);color:#fff;
  font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;
}
.mobile-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);
  z-index:1000;opacity:0;visibility:hidden;transition:var(--transition);
}
.mobile-overlay.open{opacity:1;visibility:visible}

/* ── PAGE LOADER ── */
.page-loader{
  position:fixed;inset:0;background:#0A0A0A;z-index:9999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;
  transition:opacity .6s ease,visibility .6s ease;
}
.page-loader.loaded{opacity:0;visibility:hidden}
.loader-logo{font-family:'Cormorant Garamond',serif;font-size:2.4rem;color:var(--gold);letter-spacing:.1em}
.loader-bar{width:100px;height:1px;background:rgba(255,255,255,.08);overflow:hidden;position:relative}
.loader-bar::after{content:'';position:absolute;inset:0;background:var(--gold);animation:loaderFill 1.4s ease forwards}
@keyframes loaderFill{from{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1);transform-origin:left}}
.loader-text{font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.28)}

/* ── BREADCRUMB ── */
.breadcrumb{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.38);margin-bottom:18px;
}
.breadcrumb a{color:rgba(255,255,255,.42);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb-sep{color:rgba(255,255,255,.18)}
.breadcrumb span:last-child{color:var(--gold)}

/* ═══════════════════════════════════
   HERO — Stunning, light-balanced
   ═══════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:#0A0A0A;overflow:hidden;
}
.hero-bg-img{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1615529162924-f8605388461d?w=1920&q=90') center/cover no-repeat;
  animation:heroZoom 24s 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(135deg,rgba(10,10,10,.92) 0%,rgba(10,10,10,.6) 50%,rgba(10,10,10,.82) 100%);
}
/* Gold accent bar */
.hero::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(to bottom,transparent,var(--gold),transparent);
  z-index:3;
}

.hero-content{
  position:relative;z-index:2;text-align:center;
  max-width:800px;padding:100px 24px 80px;
  width:100%;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  margin-bottom:20px;
  opacity:0;animation:fadeUp .8s .3s ease forwards;
}
.hero-eyebrow-line{width:36px;height:1px;background:var(--gold)}
.hero-eyebrow span{
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.26em;text-transform:uppercase;color:var(--gold);
}
.hero h1{
  color:#fff;font-size:clamp(2.2rem,5.5vw,4.2rem);
  font-weight:900;letter-spacing:-.025em;
  opacity:0;animation:fadeUp .9s .5s ease forwards;
}
.hero h1 em{
  font-style:normal;color:var(--gold-rich);
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:1.12em;
}
.hero-sub{
  color:rgba(255,255,255,.65);font-size:1rem;
  max-width:500px;margin:20px auto 0;
  opacity:0;animation:fadeUp .9s .7s ease forwards;
}
.hero-actions{
  margin-top:38px;display:flex;align-items:center;
  justify-content:center;gap:12px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .9s .9s ease forwards;
}
.hero-scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:fadeIn 1s 1.6s forwards;
}
.hero-scroll-line{
  width:1px;height:40px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{opacity:.35}50%{opacity:1}}
.hero-scroll-text{font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.32)}

/* Stats strip — right side desktop only */
.hero-stats{
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  z-index:2;display:flex;flex-direction:column;
  opacity:0;animation:fadeIn 1s 1.2s forwards;
}
.hero-stat{
  padding:22px 28px;text-align:center;
  border:1px solid rgba(185,145,42,.18);
  border-right:none;border-top:none;
  background:rgba(10,10,10,.65);backdrop-filter:blur(10px);
  transition:background .3s;min-width:120px;
}
.hero-stat:first-child{border-top:1px solid rgba(185,145,42,.18)}
.hero-stat:hover{background:rgba(185,145,42,.08)}
.hero-stat-num{font-family:'Montserrat',sans-serif;font-size:1.8rem;font-weight:900;color:var(--gold);line-height:1}
.hero-stat-lbl{font-size:.55rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-top:4px;font-family:'Montserrat',sans-serif}

/* Inner page hero */
.page-hero{
  background:#0A0A0A;padding:130px 0 56px;
  position:relative;overflow:hidden;text-align:center;
}
.page-hero::before{
  content:'';position:absolute;inset:0;opacity:.14;
  background:url('https://images.unsplash.com/photo-1600607687644-aac4c3eac7f4?w=1400&q=80') center/cover;
}
.page-hero>.container{position:relative;z-index:1}
.page-hero h1{color:#fff;margin-top:10px}
.page-hero p{color:rgba(255,255,255,.52);margin-top:12px;font-size:.98rem;max-width:500px;margin-left:auto;margin-right:auto}

/* ── TICKER ── */
.ticker{background:var(--gold);padding:10px 0;overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-flex;gap:52px;animation:tickerMove 30s linear infinite}
.ticker-track span{font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#fff}
.ticker-dot{color:rgba(255,255,255,.45)!important}
@keyframes tickerMove{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── ADVANTAGES ── */
.advantages-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);
}
.adv-item{
  background:var(--bg-card);padding:36px 28px;
  transition:var(--transition);position:relative;overflow:hidden;
}
.adv-item::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.adv-item:hover{background:var(--bg-alt)}
.adv-item:hover::after{transform:scaleX(1)}
.adv-icon{
  width:40px;height:40px;margin-bottom:18px;
  color:var(--gold);flex-shrink:0;
}
.adv-item h3{font-size:.92rem;margin-bottom:8px;color:var(--text)}
.adv-item p{font-size:.82rem;color:var(--text-muted);line-height:1.7}

/* ═══════════════════════════════════
   PRODUCT CARDS — Equal height grid
   ═══════════════════════════════════ */
.products-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  grid-auto-rows:260px;  /* enforced equal height */
}
.products-grid--3{grid-template-columns:repeat(3,1fr)}

.product-card{
  position:relative;overflow:hidden;background:var(--black);
  cursor:pointer;
  /* height is set by grid-auto-rows */
}
.product-card img{
  width:100%;height:100%;object-fit:cover;
  opacity:.82;transition:transform .65s ease,opacity .4s;
}
.product-card:hover img{transform:scale(1.07);opacity:.55}
.product-card-body{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px 20px 18px;
  background:linear-gradient(to top,rgba(10,10,10,.96) 0%,transparent 100%);
}
.product-card-badge{
  display:inline-block;background:var(--gold);color:#fff;
  font-family:'Montserrat',sans-serif;font-size:.52rem;font-weight:800;
  letter-spacing:.16em;text-transform:uppercase;padding:3px 9px;margin-bottom:6px;
}
.product-card h3{color:#fff;font-size:.98rem;margin-bottom:4px}
.product-card p{
  color:rgba(255,255,255,.52);font-size:.78rem;line-height:1.55;
  opacity:0;transform:translateY(8px);transition:all .32s .04s;
}
.product-card:hover p{opacity:1;transform:translateY(0)}
.product-card-link{
  display:inline-flex;align-items:center;gap:5px;
  color:var(--gold);font-family:'Montserrat',sans-serif;font-size:.62rem;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-top:10px;opacity:0;transform:translateY(5px);transition:all .32s .08s;
}
.product-card:hover .product-card-link{opacity:1;transform:translateY(0)}

/* Wide card spans 2 columns */
.product-card--wide{
  grid-column:span 2;
}

/* Full product cards (produits.php page) */
.product-full-card{
  background:var(--bg-card);border:1px solid var(--border);
  overflow:hidden;transition:var(--transition);
}
.product-full-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-gold);transform:translateY(-3px)}
.product-full-card-img{position:relative;overflow:hidden;aspect-ratio:4/3}
.product-full-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.product-full-card:hover .product-full-card-img img{transform:scale(1.06)}
.product-full-card-body{padding:22px}
.product-full-card-body h3{margin-bottom:7px;color:var(--text)}
.product-full-card-body p{font-size:.83rem;color:var(--text-muted);margin-bottom:16px}

/* ── REALISATIONS ── */
.real-layout{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.real-main{position:relative;overflow:hidden;aspect-ratio:4/3}
.real-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:9px}
.real-item{position:relative;overflow:hidden}
.real-item img,.real-main img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.real-item:hover img,.real-main:hover img{transform:scale(1.06)}
.real-overlay{
  position:absolute;inset:0;background:rgba(10,10,10,.65);
  display:flex;align-items:flex-end;padding:14px;
  opacity:0;transition:opacity .32s;
}
.real-item:hover .real-overlay,.real-main:hover .real-overlay{opacity:1}
.real-overlay span{font-family:'Montserrat',sans-serif;font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}

/* Masonry */
.masonry{columns:3;column-gap:16px}
.masonry-item{break-inside:avoid;margin-bottom:16px;position:relative;overflow:hidden;cursor:pointer}
.masonry-item img{width:100%;display:block;transition:transform .6s}
.masonry-item:hover img{transform:scale(1.05)}
.masonry-info{
  position:absolute;inset:0;background:rgba(10,10,10,.72);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  opacity:0;transition:opacity .32s;
}
.masonry-item:hover .masonry-info{opacity:1}
.masonry-info h4{color:#fff;font-size:.94rem}
.masonry-info span{color:var(--gold);font-size:.62rem;font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:.1em;text-transform:uppercase}

/* ── TESTIMONIALS ── */
.testi-wrap{overflow:hidden}
.testi-track{display:flex;gap:18px;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.testi-card{
  flex:0 0 calc(33.333% - 12px);
  background:var(--bg-card);border:1px solid var(--border-gold);
  padding:32px;position:relative;
}
.testi-card::before{
  content:'\201C';position:absolute;top:14px;right:20px;
  font-family:'Cormorant Garamond',serif;font-size:5rem;
  color:rgba(185,145,42,.1);line-height:1;
}
.testi-stars{display:flex;gap:3px;color:var(--gold);margin-bottom:14px}
.testi-stars svg{width:12px;height:12px}
.testi-text{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:var(--text-muted);line-height:1.8;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:40px;height:40px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.85rem;color:#fff;flex-shrink:0}
.testi-name{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.82rem;color:var(--text)}
.testi-role{font-size:.7rem;color:var(--gold);margin-top:2px}
.slider-controls{display:flex;gap:9px;margin-top:28px}
.slider-btn{
  width:42px;height:42px;border:1px solid var(--border-gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:var(--transition);
}
.slider-btn:hover{border-color:var(--gold);background:var(--gold);color:#fff}
.slider-btn svg{width:15px;height:15px}

/* ── CTA BAND ── */
.cta-band{background:var(--gold);padding:68px 0;position:relative;overflow:hidden}
.cta-band::before{
  content:'888';position:absolute;right:-10px;top:50%;transform:translateY(-50%);
  font-family:'Montserrat',sans-serif;font-size:14rem;font-weight:900;
  color:rgba(0,0,0,.05);line-height:1;user-select:none;
}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:36px;position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(1.4rem,2.5vw,2rem)}
.cta-band p{color:rgba(255,255,255,.7);margin-top:8px}
.cta-band-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;flex-shrink:0}

/* ── FILTER BAR ── */
.filter-bar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:36px}
.filter-btn{
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:7px 16px;border:1.5px solid var(--border);
  background:transparent;color:var(--text-muted);transition:var(--transition);
  border-radius:var(--radius);
}
.filter-btn.active,.filter-btn:hover{background:var(--text);border-color:var(--text);color:var(--bg)}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{
  background:var(--bg-card);border:1px solid var(--border);overflow:hidden;
  transition:var(--transition);display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-gold)}
.blog-card-img{position:relative;overflow:hidden;aspect-ratio:16/9}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-cat{
  position:absolute;top:12px;left:12px;
  background:var(--gold);color:#fff;
  font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:800;
  letter-spacing:.15em;text-transform:uppercase;padding:3px 9px;
}
.blog-card-body{padding:22px;display:flex;flex-direction:column;flex:1}
.blog-card-meta{display:flex;gap:10px;font-size:.7rem;color:var(--text-light);margin-bottom:10px;font-family:'Montserrat',sans-serif}
.blog-card h3{font-size:.97rem;line-height:1.42;margin-bottom:9px;color:var(--text)}
.blog-card p{font-size:.82rem;color:var(--text-muted);margin-bottom:16px;flex:1}
.blog-card-link{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gold);
  margin-top:auto;transition:gap .2s;
}
.blog-card-link svg{width:12px;height:12px}
.blog-card:hover .blog-card-link{gap:9px}

/* ── ARTICLE ── */
.article-hero{background:#0A0A0A;padding:130px 0 60px;position:relative;overflow:hidden}
.article-hero::before{content:'';position:absolute;inset:0;opacity:.2;background-size:cover;background-position:center}
.article-hero>.container{position:relative;z-index:2;max-width:820px}
.article-hero .hero-overlay{position:absolute;inset:0;background:rgba(10,10,10,.78);z-index:1}
.article-hero h1{color:#fff;font-size:clamp(1.5rem,3.2vw,2.5rem)}
.article-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:14px;font-size:.72rem;font-family:'Montserrat',sans-serif;color:rgba(255,255,255,.42)}
.article-meta strong{color:var(--gold)}
.article-body{padding:68px 0}
.article-content{max-width:720px;margin:0 auto}
.article-content h2{color:var(--text);font-size:1.45rem;margin:36px 0 14px}
.article-content h3{color:var(--text);font-size:1.1rem;margin:28px 0 10px}
.article-content p{color:var(--text-muted);line-height:1.9;margin-bottom:18px}
.article-content img{width:100%;margin:24px 0;border:1px solid var(--border)}
.article-content ul{margin:14px 0 18px 0;padding-left:18px}
.article-content ul li{color:var(--text-muted);line-height:1.8;margin-bottom:7px;list-style:disc}
.article-content blockquote{
  border-left:3px solid var(--gold);padding:14px 22px;margin:24px 0;
  background:var(--bg-alt);font-family:'Cormorant Garamond',serif;font-size:1.08rem;
  font-style:italic;color:var(--text-muted);
}

/* ── FAQ ── */
.faq-list{max-width:740px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:22px 0;cursor:pointer;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.94rem;
  color:var(--text);transition:color .2s;
}
.faq-q:hover{color:var(--gold)}
.faq-icon{
  width:28px;height:28px;border:1.5px solid var(--border-gold);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);transition:var(--transition);
}
.faq-icon svg{width:12px;height:12px}
.faq-item.open .faq-icon{background:var(--gold);color:#fff;border-color:var(--gold);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.25,.46,.45,.94)}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding:0 44px 22px 0;font-size:.9rem;color:var(--text-muted);line-height:1.85}

/* ── CONTACT ── */
.contact-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:48px}
.contact-info{background:var(--bg-alt);padding:44px;border:1px solid var(--border)}
[data-theme="dark"] .contact-info{background:#111}
.contact-info-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px}
.contact-info-icon{
  width:38px;height:38px;border:1px solid var(--border-gold);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold);
}
.contact-info-icon svg{width:16px;height:16px}
.contact-info-item h4{font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.contact-info-item p{font-size:.86rem;color:var(--text-muted)}
.map-box{margin-top:24px;height:180px;overflow:hidden;border:1px solid var(--border)}
.map-box iframe{width:100%;height:100%;border:none;filter:grayscale(.3)}

/* ── FORMS ── */
.form-group{margin-bottom:18px}
.form-group label{
  display:block;font-family:'Montserrat',sans-serif;font-size:.6rem;
  font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:7px;
}
.form-group .req{color:var(--gold)}
.form-control{
  width:100%;padding:12px 15px;
  border:1.5px solid var(--border);background:var(--surface);
  font-family:'Poppins',sans-serif;font-size:.88rem;color:var(--text);
  transition:border-color .2s,box-shadow .2s;outline:none;border-radius:0;
  -webkit-appearance:none;
}
.form-control:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(185,145,42,.1)}
.form-control::placeholder{color:var(--text-light)}
select.form-control{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B8912A' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:38px;cursor:pointer;
}
textarea.form-control{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-success{
  display:none;padding:14px 18px;background:#f0faf0;border:1px solid #4caf50;
  color:#2e7d32;font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:600;
  text-align:center;margin-bottom:14px;
}
[data-theme="dark"] .form-success{background:#0d2010;border-color:#2e7d32;color:#81c784}

/* ── DEVIS PAGE ── */
.devis-wrapper{max-width:820px;margin:0 auto;background:var(--bg-card);border:1px solid var(--border-gold)}
.devis-top{
  background:#0A0A0A;padding:32px 44px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:2px solid var(--gold);
}
.devis-top h2{color:#fff;font-size:1.15rem}
.devis-top p{color:rgba(255,255,255,.42);font-size:.78rem;margin-top:4px}
.devis-badge{background:var(--gold);padding:10px 16px;text-align:center;flex-shrink:0}
.devis-badge .d-n{font-family:'Montserrat',sans-serif;font-size:1.6rem;font-weight:900;color:#fff;line-height:1}
.devis-badge .d-t{font-family:'Montserrat',sans-serif;font-size:.54rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:2px}
.devis-body{padding:44px}
.devis-section-title{
  font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
  padding-bottom:9px;border-bottom:1px solid var(--border-gold);margin-bottom:20px;margin-top:28px;
}
.devis-section-title:first-child{margin-top:0}

/* ── ABOUT ── */
.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.about-img-wrap{position:relative}
.about-img-wrap img{width:100%;aspect-ratio:4/5;object-fit:cover}
.about-img-wrap::before{
  content:'';position:absolute;top:-14px;left:-14px;right:14px;bottom:14px;
  border:1.5px solid var(--gold);z-index:-1;
}
.about-img-badge{
  position:absolute;bottom:-14px;right:-14px;
  background:var(--gold);padding:20px 24px;text-align:center;
}
.about-img-badge .num{font-family:'Montserrat',sans-serif;font-size:2rem;font-weight:900;color:#fff;line-height:1}
.about-img-badge .lbl{font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:3px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value-card{padding:32px;border:1px solid var(--border);position:relative;transition:var(--transition)}
.value-card::after{content:'';position:absolute;bottom:0;left:0;width:32px;height:2px;background:var(--gold);transition:width .4s}
.value-card:hover::after{width:100%}
.value-card:hover{border-color:var(--border-gold)}
.value-num{font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--border-gold);line-height:1;margin-bottom:12px}
.value-card h3{margin-bottom:9px;font-size:.97rem;color:var(--text)}
.value-card p{font-size:.82rem;color:var(--text-muted)}
.timeline{max-width:720px;margin:0 auto;position:relative}
.timeline::before{
  content:'';position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom,transparent,var(--gold),transparent);
  transform:translateX(-50%);
}
.timeline-item{display:grid;grid-template-columns:1fr 72px 1fr;gap:20px;align-items:center;margin-bottom:32px}
.timeline-content{padding:20px 22px;background:var(--bg-alt);border:1px solid var(--border)}
.timeline-content h4{font-size:.88rem;margin-bottom:5px;color:var(--text)}
.timeline-content p{font-size:.8rem;color:var(--text-muted)}
.timeline-center{display:flex;flex-direction:column;align-items:center;gap:4px}
.timeline-dot{width:11px;height:11px;border-radius:50%;background:var(--gold);border:2.5px solid var(--bg);box-shadow:0 0 0 2px var(--gold)}
.timeline-year{font-family:'Montserrat',sans-serif;font-size:.6rem;font-weight:700;color:var(--gold);letter-spacing:.04em}

/* ── STATS BAND ── */
.stats-band{background:#0A0A0A;padding:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(185,145,42,.1)}
.stat-item{background:#0A0A0A;padding:48px 36px;text-align:center;transition:background .3s}
.stat-item:hover{background:rgba(185,145,42,.06)}
.stat-num{font-family:'Montserrat',sans-serif;font-size:clamp(1.8rem,3.5vw,3rem);font-weight:900;color:var(--gold);line-height:1}
.stat-lbl{font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-top:7px}

/* ═══════════════════════════════════
   FOOTER — Professional & clean
   ═══════════════════════════════════ */
footer{background:#080808;color:rgba(255,255,255,.45);padding:68px 0 0}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap:48px;padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer-brand p{
  font-size:.82rem;line-height:1.8;color:rgba(255,255,255,.36);
  margin-top:16px;max-width:280px;
}
.footer-social{display:flex;gap:7px;margin-top:22px}
.footer-social a{
  width:34px;height:34px;border:1px solid rgba(255,255,255,.09);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.36);transition:var(--transition);
}
.footer-social a:hover{border-color:var(--gold);color:var(--gold)}
.footer-social a svg{width:14px;height:14px}
.footer-col h4{
  font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;
}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{
  font-size:.82rem;color:rgba(255,255,255,.36);
  transition:color .2s;display:flex;align-items:center;gap:5px;
}
.footer-col ul li a:hover{color:var(--gold)}
.footer-col ul li a svg{width:10px;height:10px;opacity:0;transition:opacity .2s}
.footer-col ul li a:hover svg{opacity:1}
.newsletter-form{display:flex}
.newsletter-form input{
  flex:1;padding:11px 14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);border-right:none;
  color:#fff;font-family:'Poppins',sans-serif;font-size:.82rem;outline:none;
}
.newsletter-form input::placeholder{color:rgba(255,255,255,.22)}
.newsletter-form button{
  padding:11px 14px;background:var(--gold);border:none;cursor:pointer;
  color:#fff;transition:background .2s;display:flex;align-items:center;
}
.newsletter-form button:hover{background:var(--gold-light)}
.newsletter-form button svg{width:14px;height:14px}
.footer-contact{margin-top:22px}
.footer-contact-item{
  display:flex;align-items:center;gap:9px;margin-bottom:9px;
  font-size:.82rem;color:rgba(255,255,255,.36);
}
.footer-contact-item svg{width:13px;height:13px;color:var(--gold);flex-shrink:0}
.footer-bottom{
  padding:18px 0;display:flex;align-items:center;
  justify-content:space-between;gap:18px;
  font-size:.72rem;color:rgba(255,255,255,.22);flex-wrap:wrap;
}
.footer-bottom a{color:rgba(255,255,255,.22);transition:color .2s}
.footer-bottom a:hover{color:var(--gold)}
.footer-bottom-links{display:flex;gap:18px;flex-wrap:wrap}

/* ── WHATSAPP ── */
.wa-float{
  position:fixed;bottom:26px;right:26px;z-index:999;
  display:flex;flex-direction:column;align-items:flex-end;gap:7px;
}
.wa-tooltip{
  background:var(--bg-card);color:var(--text);border:1px solid var(--border);
  font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:600;
  padding:6px 13px;white-space:nowrap;
  opacity:0;transform:translateX(7px);transition:var(--transition);pointer-events:none;
}
.wa-float:hover .wa-tooltip{opacity:1;transform:translateX(0)}
.wa-btn{
  width:52px;height:52px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.32);
  transition:var(--transition);position:relative;
}
.wa-btn:hover{transform:scale(1.09);box-shadow:0 10px 26px rgba(37,211,102,.48)}
.wa-btn svg{width:25px;height:25px;color:#fff}
.wa-pulse{position:absolute;inset:0;border-radius:50%;background:#25D366;animation:waPulse 2.2s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.9);opacity:0}}

/* ── 404 ── */
.page-404{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;background:var(--bg)}
.page-404-num{font-family:'Cormorant Garamond',serif;font-size:clamp(7rem,20vw,14rem);color:var(--border);line-height:1;margin-bottom:-20px;font-weight:400}

/* ── AOS ── */
[data-aos]{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
[data-aos="fade-left"]{transform:translateX(-24px)}
[data-aos="fade-right"]{transform:translateX(24px)}
[data-aos="zoom-in"]{transform:scale(.93)}
[data-aos].aos-animate{opacity:1;transform:none}

@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── UTILITIES ── */
.text-gold{color:var(--gold)}
.text-center{text-align:center}
.mt-4{margin-top:16px}.mt-8{margin-top:32px}.mt-12{margin-top:48px}
.trust-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:44px}
.trust-badge{background:var(--bg-alt);border:1px solid var(--border-gold);padding:22px;text-align:center}
.trust-badge-icon{margin-bottom:7px;color:var(--gold);display:flex;align-items:center;justify-content:center}
.trust-badge-icon svg{width:24px;height:24px}
.trust-badge h4{font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:700;margin-bottom:4px;color:var(--text)}
.trust-badge p{font-size:.73rem;color:var(--text-muted)}

/* ══════════════════════════════════════════
   RESPONSIVE — Mobile-first, smooth & solid
   ══════════════════════════════════════════ */

/* ── Tablet 1100px ── */
@media(max-width:1100px){
  .advantages-grid{grid-template-columns:repeat(2,1fr)}
  .products-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:240px}
  .product-card--wide{grid-column:span 2}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero-stats{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  /* Hide phone in nav at medium size */
  .nav-phone{display:none}
}

/* ── 960px — hide desktop nav, show hamburger ── */
@media(max-width:960px){
  .section{padding:64px 0}
  /* Nav: hide links, show hamburger */
  .nav-menu{display:none}
  .nav-toggle{display:flex}
  /* Keep logo + theme toggle + hamburger */
  .nav-right{gap:8px}
  .nav-devis{display:none} /* shown in mobile menu */

  .about-intro{grid-template-columns:1fr;gap:36px}
  .contact-layout{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .real-layout{grid-template-columns:1fr}
  .masonry{columns:2}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .cta-band-inner{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .devis-top{flex-direction:column;gap:14px;text-align:center}
  .devis-body{padding:28px 22px}
  .trust-badges{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

/* ── 640px mobile ── */
@media(max-width:640px){
  .section{padding:48px 0}
  .container{padding:0 16px}
  .products-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .product-card--wide{grid-column:span 2}
  .blog-grid{grid-template-columns:1fr}
  .advantages-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .values-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:center}
  .testi-card{flex:0 0 86vw}
  .page-hero{padding:108px 0 44px}
  .timeline::before{display:none}
  .timeline-item{grid-template-columns:1fr;gap:7px}
  .timeline-center{flex-direction:row;justify-content:flex-start}
  .timeline-empty{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .devis-top{padding:22px 18px}
  .footer-grid{gap:24px}
  .about-img-wrap::before{display:none}
  .about-img-badge{right:0;bottom:0}
  .cta-band{padding:52px 0}
  .cta-band-actions{justify-content:center;width:100%}
  .hero-stat{min-width:100px;padding:18px 22px}
  h1{font-size:clamp(1.8rem,7vw,2.8rem)}
  h2{font-size:clamp(1.3rem,5vw,1.8rem)}
}

/* ── 380px extra small ── */
@media(max-width:380px){
  h1{font-size:1.7rem}
  .products-grid{grid-template-columns:1fr}
  .product-card--wide{grid-column:span 1}
  .nav-devis{display:none}
}

/* ── DARK MODE OVERRIDES ── */
[data-theme="dark"] .form-control{background:var(--surface);color:var(--text);border-color:var(--border)}
[data-theme="dark"] .form-control:focus{border-color:var(--gold)}
[data-theme="dark"] select.form-control option{background:var(--surface);color:var(--text)}
[data-theme="dark"] .blog-card{background:var(--bg-card);border-color:var(--border)}
[data-theme="dark"] .blog-card h3{color:var(--text)}
[data-theme="dark"] .product-full-card{background:var(--bg-card);border-color:var(--border)}
[data-theme="dark"] .product-full-card h3{color:var(--text)}
[data-theme="dark"] .devis-wrapper{background:var(--bg-card);border-color:var(--border-gold)}
[data-theme="dark"] .devis-body{background:var(--bg-card)}
[data-theme="dark"] .contact-info{background:var(--bg-alt);border-color:var(--border)}
[data-theme="dark"] .adv-item{background:var(--bg-card)}
[data-theme="dark"] .adv-item:hover{background:var(--bg-alt)}
[data-theme="dark"] .value-card{background:var(--bg-card);border-color:var(--border)}
[data-theme="dark"] .timeline-content{background:var(--bg-alt);border-color:var(--border)}
[data-theme="dark"] .filter-btn{border-color:var(--border);color:var(--text-muted)}
[data-theme="dark"] .filter-btn.active,[data-theme="dark"] .filter-btn:hover{background:var(--gold);border-color:var(--gold);color:#fff}
[data-theme="dark"] footer{background:#050505}
[data-theme="dark"] .trust-badge{background:var(--bg-alt)}
[data-theme="dark"] .testi-card{background:var(--bg-card)}

/* ── PAGE TRANSITIONS ── */
.page-content{animation:pageFadeIn .4s ease}
@keyframes pageFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── PRINT ── */
@media print{
  #navbar,.wa-float,.page-loader,.mobile-nav,.mobile-overlay{display:none!important}
  body{color:#000;background:#fff}
  .section{padding:20px 0}
}

/* ── Products full page - equal card sizes ── */
.products-grid--3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.products-grid--3 .product-full-card{
  display:flex;flex-direction:column;
}
.products-grid--3 .product-full-card-img{
  aspect-ratio:4/3;flex-shrink:0;
}
.products-grid--3 .product-full-card-body{
  flex:1;display:flex;flex-direction:column;
}
.products-grid--3 .product-full-card-body .btn{
  margin-top:auto;
}
@media(max-width:900px){
  .products-grid--3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:580px){
  .products-grid--3{grid-template-columns:1fr}
}

/* ══════════════════════════════════════
   ABOUT HERO — was missing
   ══════════════════════════════════════ */
.about-hero{
  background:#0A0A0A;padding:130px 0 56px;
  position:relative;overflow:hidden;
}
.about-hero::before{
  content:'';position:absolute;inset:0;opacity:.12;
  background:url('https://images.unsplash.com/photo-1600585154526-990dced4db0d?w=1400&q=80') center/cover;
}
.about-hero>.container{position:relative;z-index:1}
.about-hero h1{color:#fff}

/* ── About intro image wrapper (missing classes) ── */
.about-intro-image{position:relative}
.about-intro-image img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block}
.about-intro-image::before{
  content:'';position:absolute;top:-14px;left:-14px;right:14px;bottom:14px;
  border:1.5px solid var(--gold);z-index:-1;
}
.about-intro-badge{
  position:absolute;bottom:-14px;right:-14px;
  background:var(--gold);padding:20px 24px;text-align:center;
}
.about-intro-badge .num{font-family:'Montserrat',sans-serif;font-size:2rem;font-weight:900;color:#fff;line-height:1}
.about-intro-badge .lbl{font-family:'Montserrat',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-top:3px}
@media(max-width:640px){
  .about-intro-image::before{display:none}
  .about-intro-badge{right:0;bottom:0}
}

/* ══════════════════════════════════════
   NAVBAR — push body down to avoid overlap
   ══════════════════════════════════════ */
body{padding-top:62px}
.hero,.page-hero,.about-hero,.article-hero{margin-top:-62px;padding-top:0}
.hero{padding-top:0}
.hero-content{padding-top:124px}
.page-hero{padding-top:130px}
.about-hero{padding-top:130px}
.article-hero{padding-top:130px}

/* ══════════════════════════════════════
   CONTACT INFO — dark/light mode colors
   ══════════════════════════════════════ */
.contact-info{
  background:var(--bg-alt);padding:44px;border:1px solid var(--border);
}
.contact-info h3{color:var(--text)}          /* adapts to mode */
.contact-info h4{color:var(--gold)}
.contact-info p{color:var(--text-muted)}
.contact-info-item p[style*="rgba(255,255,255"]{color:var(--text-light)!important}
/* Dark mode: light card with dark bg */
[data-theme="dark"] .contact-info{background:var(--bg-card);border-color:var(--border)}

/* Map container fix */
.map-container{margin-top:28px;height:200px;overflow:hidden;border:1px solid var(--border)}
.map-container iframe{width:100%;height:100%;border:none;filter:grayscale(.3)}

/* ══════════════════════════════════════
   FOOTER BOTTOM — white text
   ══════════════════════════════════════ */
.footer-bottom{
  color:rgba(255,255,255,.5)!important;
}
.footer-bottom span{color:rgba(255,255,255,.5)}
.footer-bottom a{color:rgba(255,255,255,.5)}
.footer-bottom a:hover{color:var(--gold)}

/* ══════════════════════════════════════
   REALISATIONS — organized masonry grid
   ══════════════════════════════════════ */
.masonry-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.masonry-item{
  position:relative;overflow:hidden;cursor:pointer;
  aspect-ratio:4/3;
  break-inside:unset;margin-bottom:0;
}
.masonry-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;display:block;
}
.masonry-item:hover img{transform:scale(1.06)}
.masonry-item-info{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.88) 0%,transparent 55%);
  display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;
  padding:18px;
  opacity:0;transition:opacity .32s;
}
.masonry-item:hover .masonry-item-info{opacity:1}
.masonry-item-info h4{color:#fff;font-size:.95rem;margin-bottom:4px}
.masonry-item-info span{color:var(--gold);font-size:.62rem;font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
/* Always show label on mobile */
@media(max-width:768px){
  .masonry-item-info{opacity:1;background:linear-gradient(to top,rgba(10,10,10,.75) 0%,transparent 50%)}
}
@media(max-width:900px){.masonry-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.masonry-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════
   LIGHTBOX — click to zoom gallery
   ══════════════════════════════════════ */
.lightbox-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.94);
  z-index:9000;display:none;align-items:center;justify-content:center;
}
.lightbox-overlay.open{display:flex}
.lightbox-inner{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center}
.lightbox-img{
  max-width:85vw;max-height:85vh;object-fit:contain;
  border:1px solid rgba(185,145,42,.2);
  display:block;
}
.lightbox-close{
  position:fixed;top:22px;right:26px;
  width:42px;height:42px;background:rgba(255,255,255,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;cursor:pointer;border:1px solid rgba(255,255,255,.2);
  transition:.25s;z-index:9001;
}
.lightbox-close:hover{background:var(--gold);border-color:var(--gold)}
.lightbox-close svg{width:18px;height:18px}
.lightbox-prev,.lightbox-next{
  position:fixed;top:50%;transform:translateY(-50%);
  width:48px;height:48px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;cursor:pointer;transition:.25s;z-index:9001;
}
.lightbox-prev{left:18px}
.lightbox-next{right:18px}
.lightbox-prev:hover,.lightbox-next:hover{background:var(--gold);border-color:var(--gold)}
.lightbox-prev svg,.lightbox-next svg{width:20px;height:20px}
.lightbox-caption{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.7);padding:8px 20px;
  font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gold);
  white-space:nowrap;z-index:9001;
}

/* ══════════════════════════════════════
   TESTIMONIALS PAGE
   ══════════════════════════════════════ */
.testi-page-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media(max-width:900px){.testi-page-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.testi-page-grid{grid-template-columns:1fr}}

/* ════════════════════════════════════════════════════════════
   COMPLETE RESPONSIVE OVERHAUL — All pages, all breakpoints
   ════════════════════════════════════════════════════════════ */

/* ── Inline-style grid fixes → responsive classes ── */

/* mission/vision 2-col on about */
.about-mv-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;
}
@media(max-width:700px){
  .about-mv-grid{grid-template-columns:1fr}
}

/* mini-stats inside about intro */
.about-mini-stats{
  display:flex;gap:36px;margin-top:36px;flex-wrap:wrap;
}
.about-mini-stat-num{
  font-family:'Montserrat',sans-serif;font-size:2.2rem;font-weight:900;
  color:var(--gold);line-height:1;
}
.about-mini-stat-lbl{
  font-size:.68rem;font-family:'Montserrat',sans-serif;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-top:5px;
}

/* value-card-n (was value-num) */
.value-card-n{
  font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--border-gold);
  line-height:1;margin-bottom:12px;
}

/* devis trust badges responsive */
.devis-trust-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:48px;
}
@media(max-width:640px){
  .devis-trust-grid{grid-template-columns:1fr;gap:12px}
}

/* devis reassurance 2-col */
.devis-reassure-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:40px;
}
@media(max-width:640px){
  .devis-reassure-grid{grid-template-columns:1fr}
}

/* contact quick-band 3-col */
.contact-quick-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(185,145,42,.1);
}
@media(max-width:700px){
  .contact-quick-grid{grid-template-columns:1fr}
}
.contact-quick-item{
  background:var(--black);padding:36px;text-align:center;
  transition:background .3s;
}
.contact-quick-item:hover{background:rgba(185,145,42,.06)}
.contact-quick-icon{color:var(--gold);margin-bottom:10px;display:flex;justify-content:center}
.contact-quick-label{font-family:'Montserrat',sans-serif;font-size:.64rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.contact-quick-link{color:#fff;font-size:1rem;font-family:'Montserrat',sans-serif;font-weight:600;transition:color .2s}
.contact-quick-link:hover{color:var(--gold-light)}

/* ── Temoignages stats strip responsive ── */
.testi-stats-strip{
  display:flex;align-items:center;justify-content:center;
  gap:52px;flex-wrap:wrap;padding:36px 24px;text-align:center;
}
.testi-stats-sep{width:1px;height:70px;background:var(--border);flex-shrink:0}
@media(max-width:640px){
  .testi-stats-sep{display:none}
  .testi-stats-strip{gap:28px}
}

/* ════════════════════════════
   GLOBAL MOBILE — ≤960px
   ════════════════════════════ */
@media(max-width:960px){

  /* Nav guaranteed single row */
  .nav-inner{height:58px}
  .nav-logo-sub{display:none}   /* hide subtitle on tablet */

  /* Section spacing tighter */
  .section{padding:60px 0}
  .section--sm{padding:36px 0}

  /* About page */
  .about-intro{grid-template-columns:1fr;gap:32px}
  .about-mv-grid{grid-template-columns:1fr;gap:20px}
  .values-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .timeline::before{display:none}
  .timeline-item{grid-template-columns:1fr;gap:0}
  .timeline-empty{display:none}
  .timeline-center{
    flex-direction:row;gap:10px;padding:8px 0;
    border-bottom:1px solid var(--border);margin-bottom:14px;
  }

  /* Contact */
  .contact-layout{grid-template-columns:1fr;gap:32px}
  .contact-info{padding:28px}
  .contact-quick-grid{grid-template-columns:1fr 1fr}

  /* Devis */
  .devis-top{flex-direction:column;gap:14px;align-items:flex-start}
  .devis-body{padding:28px 24px}
  .form-row{grid-template-columns:1fr}
  .devis-trust-grid{grid-template-columns:repeat(3,1fr)}
  .devis-reassure-grid{grid-template-columns:1fr 1fr}

  /* Blog */
  .blog-grid{grid-template-columns:repeat(2,1fr)}

  /* Products */
  .products-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:220px}
  .products-grid--3{grid-template-columns:repeat(2,1fr)}

  /* CTA band */
  .cta-band-inner{flex-direction:column;text-align:center}
  .cta-band-actions{justify-content:center;width:100%}

  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}

  /* Masonry */
  .masonry-grid{grid-template-columns:repeat(2,1fr)}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .advantages-grid{grid-template-columns:repeat(2,1fr)}
}

/* ════════════════════════════
   MOBILE — ≤640px
   ════════════════════════════ */
@media(max-width:640px){

  body{padding-top:58px}
  .hero-content{padding-top:120px;padding-bottom:70px}
  .container,.container--sm,.container--lg{padding:0 16px}

  /* Typography scale */
  h1{font-size:clamp(1.65rem,7vw,2.4rem)!important}
  h2{font-size:clamp(1.2rem,5.5vw,1.7rem)!important}
  h3{font-size:1rem!important}
  .stat-num{font-size:2.2rem!important}
  .hero-stat-num{font-size:1.5rem}

  /* Hero */
  .hero-stats{display:none!important}
  .hero-actions{flex-direction:column;align-items:stretch;width:100%;max-width:280px;margin-left:auto;margin-right:auto}
  .hero-actions .btn{justify-content:center;text-align:center}
  .hero-sub{font-size:.88rem}

  /* Page hero */
  .page-hero,.about-hero{padding-top:100px;padding-bottom:36px}

  /* Section */
  .section{padding:44px 0}
  .section-header{margin-bottom:32px}
  .section-header p{font-size:.88rem}

  /* Navbar */
  .nav-inner{height:56px}
  .nav-logo-name{font-size:.68rem}
  .nav-logo-sub{display:none}

  /* About */
  .about-intro{grid-template-columns:1fr;gap:28px}
  .about-intro-image img{aspect-ratio:16/10}
  .about-intro-image::before{display:none}
  .about-intro-badge{position:static;margin-top:12px;display:inline-flex;gap:16px;align-items:center}
  .about-intro-badge .num{font-size:1.6rem}
  .about-mv-grid{grid-template-columns:1fr;gap:16px}
  .about-mini-stats{gap:22px}
  .about-mini-stat-num{font-size:1.8rem}
  .values-grid{grid-template-columns:1fr;gap:12px}
  .value-card{padding:22px}

  /* Stats band */
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-item{padding:32px 16px}

  /* Advantages */
  .advantages-grid{grid-template-columns:1fr}
  .adv-item{padding:24px 20px}

  /* Products home */
  .products-grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px;gap:10px}
  .product-card--wide{grid-column:span 2}
  .products-grid--3{grid-template-columns:1fr}

  /* Testimonials */
  .testi-card{flex:0 0 calc(100vw - 48px)}
  .testi-wrap{overflow:hidden}
  .testi-page-grid{grid-template-columns:1fr}

  /* Blog */
  .blog-grid{grid-template-columns:1fr}
  .blog-card-meta{font-size:.65rem}

  /* Realisations */
  .masonry-grid{grid-template-columns:1fr 1fr;gap:10px}
  .filter-bar{gap:5px}
  .filter-btn{font-size:.58rem;padding:6px 12px}

  /* FAQ */
  .faq-list{max-width:100%}
  .faq-q{font-size:.86rem;padding:18px 0}
  .faq-a p{font-size:.84rem}

  /* Contact */
  .contact-layout{grid-template-columns:1fr;gap:24px}
  .contact-info{padding:22px}
  .contact-quick-grid{grid-template-columns:1fr}
  .contact-quick-item{padding:24px}
  .map-container{height:170px}

  /* Devis */
  .devis-wrapper{margin:0 0}
  .devis-top{padding:22px 20px}
  .devis-body{padding:22px 18px}
  .devis-trust-grid{grid-template-columns:1fr;gap:10px}
  .devis-reassure-grid{grid-template-columns:1fr;gap:12px}
  .form-row{grid-template-columns:1fr}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:28px}
  footer{padding:44px 0 0}
  .newsletter-form input{font-size:.78rem}
  .footer-bottom{flex-direction:column;text-align:center;gap:10px}
  .footer-bottom-links{justify-content:center}
  .footer-brand p{max-width:100%}

  /* CTA band */
  .cta-band{padding:44px 0}
  .cta-band h2{font-size:1.3rem}
  .cta-band-actions .btn{padding:12px 20px;font-size:.65rem}
  .cta-band-inner{gap:22px}

  /* Timeline mobile */
  .timeline-item{grid-template-columns:1fr}
  .timeline::before{display:none}
  .timeline-center{flex-direction:row;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border)}
  .timeline-empty{display:none}
  .timeline-content{margin-bottom:16px}

  /* Article */
  .article-content h2{font-size:1.2rem}
  .article-content h3{font-size:1rem}

  /* Temoignages stat strip */
  .testi-stats-strip{gap:20px;padding:24px 16px}
  .testi-stats-sep{display:none}

  /* Lightbox prev/next */
  .lightbox-prev{left:6px}
  .lightbox-next{right:6px}
  .lightbox-prev,.lightbox-next{width:38px;height:38px}
  .lightbox-img{max-width:96vw}

  /* WhatsApp float */
  .wa-float{bottom:18px;right:16px}
  .wa-btn{width:46px;height:46px}
  .wa-btn svg{width:22px;height:22px}
}

/* ════════════════════════════
   XS — ≤380px
   ════════════════════════════ */
@media(max-width:380px){
  .products-grid{grid-template-columns:1fr}
  .product-card--wide{grid-column:span 1}
  .masonry-grid{grid-template-columns:1fr}
  .nav-logo-name{font-size:.62rem}
  h1{font-size:1.5rem!important}
  .hero h1{font-size:1.55rem!important}
  .btn{font-size:.62rem;padding:11px 18px}
  .nav-devis{display:none}
  .stats-grid{grid-template-columns:1fr 1fr}
  .adv-item{padding:20px 16px}
}

/* ══════════════════════════════
   SAFE INLINE-STYLE OVERRIDES
   (Convert common inline patterns)
   ══════════════════════════════ */

/* Mission/vision cards must stack on mobile */
@media(max-width:700px){
  /* These target the inline style="display:grid;grid-template-columns:1fr 1fr" in a-propos */
  .about-mv-grid>div:first-child,
  .about-mv-grid>div:last-child{
    width:100%!important;
  }
}

/* devis page: inline grid badges */
@media(max-width:640px){
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns: repeat(3, 1fr)"]{
    grid-template-columns:1fr!important;
  }
  [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr!important;
  }
  [style*="display:flex"][style*="gap:48px"],
  [style*="display:flex"][style*="gap: 48px"]{
    flex-direction:column!important;
    gap:16px!important;
  }
}

/* contact quick band inline grid */
@media(max-width:700px){
  [style*="grid-template-columns:repeat(3,1fr)"].contact-band-inner{
    grid-template-columns:1fr!important;
  }
}

/* devis-trust-grid reuses trust-badge style */
.devis-trust-grid .trust-badge{
  background:var(--bg-alt);border:1px solid var(--border-gold);
  padding:24px;text-align:center;
}
[data-theme="dark"] .devis-trust-grid .trust-badge{background:var(--bg-card)}

/* ── About hero h1 — centered, full width, responsive ── */
.about-hero h1{
  color:#fff;
  text-align:center;
  max-width:100%;
  font-size:clamp(1.8rem,4.5vw,3.2rem);
  line-height:1.22;
}
@media(max-width:640px){
  .about-hero h1{
    font-size:clamp(1.55rem,7vw,2.2rem)!important;
    text-align:center;
  }
}

/* ── Temoignages stats strip numbers & labels ── */
.testi-stat-big{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(2.2rem,6vw,4rem);
  font-weight:900;color:var(--gold);line-height:1;
}
.testi-stat-lbl{
  font-family:'Montserrat',sans-serif;
  font-size:.65rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-muted);margin-top:10px;
}
/* Strip itself — already defined, just enforce centering */
.testi-stats-strip{
  display:flex;align-items:center;justify-content:center;
  gap:52px;flex-wrap:wrap;padding:40px 24px;text-align:center;
}
@media(max-width:640px){
  .testi-stats-strip{
    gap:0;
    padding:28px 16px;
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    text-align:center;
  }
  .testi-stats-sep{display:none!important}
  .testi-stat-big{font-size:1.75rem}
  .testi-stat-lbl{font-size:.55rem;margin-top:6px}
  /* stars row smaller on mobile */
  .testi-stats-strip svg{width:13px!important;height:13px!important}
}
