/* ===== VARIABLES ===== */
:root {
  --bg:        #000000;
  --gold:      #c8a84b;
  --gold-hi:   #e2c46a;
  --gold-glow: rgba(200,168,75,0.22);
  --text:      #efefef;
  --muted:     #686868;
  --border:    rgba(200,168,75,0.16);
  --card:      #0f0f0f;
  --f-display: 'Bebas Neue', sans-serif;
  --f-body:    'DM Sans', sans-serif;
  --f-mega:    'Plus Jakarta Sans', sans-serif;
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:70px}
body{background:var(--bg);color:var(--text);font-family:var(--f-body);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* ===== LOADER ===== */
#loader{
  position:fixed;inset:0;background:var(--bg);
  z-index:9999;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1.25rem;
  transition:opacity .55s ease,visibility .55s ease;
}
#loader.hidden{opacity:0;visibility:hidden}
.loader-ring{
  width:48px;height:48px;border-radius:50%;
  border:2px solid rgba(200,168,75,.15);
  border-top-color:var(--gold);
  animation:spin .9s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-brand{
  font-family:var(--f-display);font-size:1.4rem;
  letter-spacing:.4em;color:var(--text);
}
.loader-brand span{color:var(--gold)}
.loader-bar-track{
  width:220px;height:1px;background:rgba(255,255,255,.08);
  position:relative;overflow:hidden;
}
#loading-bar{
  position:absolute;left:0;top:0;bottom:0;width:0%;
  background:var(--gold);transition:width .12s linear;
}
.loader-pct{
  font-size:.65rem;letter-spacing:.3em;color:var(--muted);
}

/* ===== NAVBAR ===== */
.navbar{
  position:fixed;
  top:1.2rem;left:50%;
  transform:translateX(-50%);
  z-index:1000;
  width:min(780px, calc(100% - 10rem));
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1rem .7rem 1.6rem;
  border-radius:100px;
  background:rgba(10,10,10,.55);
  backdrop-filter:blur(32px) saturate(180%);
  -webkit-backdrop-filter:blur(32px) saturate(180%);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 2px 40px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.06);
  transition:background .4s, border-color .4s, box-shadow .4s;
}
.navbar.scrolled{
  background:rgba(8,8,8,.75);
  border-color:rgba(255,255,255,.14);
  box-shadow:0 4px 48px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.08);
}
.nav-brand{
  display:flex;align-items:center;gap:.55rem;
  font-family:var(--f-mega);font-size:.85rem;font-weight:800;letter-spacing:.06em;
}
.nav-brand > span{display:flex;align-items:center;gap:.4rem;line-height:1}
.nav-brand em{
  color:var(--gold);font-style:normal;font-size:.58rem;font-weight:700;
  border:1px solid var(--gold);padding:.12rem .38rem;
  display:inline-flex;align-items:center;
}
.nav-links{display:flex;list-style:none;gap:.4rem}
.nav-links a{
  position:relative;
  font-family:var(--f-mega);font-size:.65rem;letter-spacing:.06em;font-weight:700;
  color:rgba(255,255,255,.5);
  padding:.45rem .9rem;border-radius:100px;
  transition:color .25s, background .25s;
}
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:.3rem;left:50%;
  transform:translateX(-50%) scaleX(0);
  width:60%;height:1px;
  background:var(--gold);
  transform-origin:center;
  transition:transform .3s cubic-bezier(.4,0,.2,1), opacity .3s;
  opacity:0;
}
.nav-links a:hover{
  color:#fff;
  background:rgba(255,255,255,.07);
}
.nav-links a:hover::after{
  transform:translateX(-50%) scaleX(1);
  opacity:1;
}
.nav-cta{
  font-family:var(--f-mega);font-size:.65rem;font-weight:700;letter-spacing:.06em;
  color:#000;background:#fff;
  padding:.52rem 1.4rem;border-radius:100px;
  transition:background .25s,color .25s,box-shadow .25s,transform .2s;
}
.nav-cta:hover{
  background:var(--gold);
  box-shadow:0 0 24px rgba(212,175,55,.4);
  transform:translateY(-1px);
}
.nav-right{display:flex;align-items:center;gap:.8rem}

/* LANGUAGE SWITCHER */
.lang-switcher{position:relative}
.lang-toggle{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:#fff;padding:.35rem .7rem;border-radius:6px;
  display:flex;align-items:center;gap:.35rem;cursor:pointer;
  font-family:var(--f-display);font-size:.72rem;letter-spacing:.12em;
  transition:background .2s,border-color .2s;
}
.lang-toggle:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35)}
.lang-dropdown{
  position:absolute;top:calc(100% + .5rem);right:0;
  background:#1a1a1a;border:1px solid rgba(255,255,255,.1);
  border-radius:8px;overflow:hidden;min-width:140px;
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:opacity .2s,transform .2s;z-index:200;
}
.lang-switcher.open .lang-dropdown{opacity:1;pointer-events:all;transform:translateY(0)}
.lang-opt{
  width:100%;background:none;border:none;color:rgba(255,255,255,.75);
  text-align:left;padding:.65rem 1rem;font-size:.82rem;cursor:pointer;
  transition:background .15s,color .15s;display:block;
}
.lang-opt:hover{background:rgba(255,255,255,.07);color:#fff}
.lang-opt.active{color:var(--gold)}
.cart-btn{
  position:relative;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);color:#fff;
  width:2.4rem;height:2.4rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s,border-color .2s;
}
.cart-btn:hover{background:rgba(200,168,75,.2);border-color:var(--gold);color:var(--gold)}
.cart-badge{
  position:absolute;top:-.3rem;right:-.3rem;
  background:var(--gold);color:#000;
  font-size:.55rem;font-weight:800;font-family:var(--f-body);
  width:1.1rem;height:1.1rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* CTA price row */
.cta-price-row{display:flex;flex-direction:column;gap:1.2rem;align-items:flex-start}
.cta-price{display:flex;align-items:baseline;gap:.9rem;flex-wrap:wrap}
.price-promo-tag{
  font-family:var(--f-display);font-size:.7rem;letter-spacing:.25em;
  background:var(--gold);color:#000;padding:.25rem .7rem;border-radius:100px;
}
.price-amount{font-family:var(--f-display);font-size:2.4rem;color:#fff;letter-spacing:.04em}
.price-original{font-size:.95rem;color:var(--muted);text-decoration:line-through}

/* CART DRAWER */
.cart-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);
  z-index:1998;opacity:0;pointer-events:none;
  transition:opacity .35s;
}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;
  width:min(420px,100vw);
  background:#111;border-left:1px solid rgba(255,255,255,.08);
  z-index:1999;
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.77,0,.175,1);
}
.cart-drawer.open{transform:translateX(0)}
.cart-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem 1.5rem 1.2rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.cart-title{font-family:var(--f-display);font-size:1rem;letter-spacing:.3em}
.cart-close{
  background:none;border:none;color:var(--muted);cursor:pointer;
  transition:color .2s;padding:.3rem;
}
.cart-close:hover{color:#fff}
.cart-body{flex:1;overflow-y:auto;padding:1.2rem 1.5rem}
.cart-empty{color:var(--muted);font-size:.88rem;padding:2rem 0;text-align:center}
.cart-item{
  display:flex;gap:1rem;align-items:center;
  padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.07);
}
.cart-item-img{
  width:70px;height:70px;border-radius:6px;
  background:#000;object-fit:contain;flex-shrink:0;
}
.cart-item-info{flex:1}
.cart-item-name{font-size:.88rem;font-weight:500;margin-bottom:.3rem}
.cart-item-price{color:var(--gold);font-size:.85rem;font-family:var(--f-display);letter-spacing:.05em}
.cart-item-qty{
  display:flex;align-items:center;gap:.5rem;margin-top:.5rem;
}
.qty-btn{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:#fff;width:1.6rem;height:1.6rem;border-radius:50%;
  cursor:pointer;font-size:1rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.qty-btn:hover{background:rgba(200,168,75,.2);border-color:var(--gold);color:var(--gold)}
.qty-value{font-size:.88rem;min-width:1.2rem;text-align:center}
.cart-footer{
  padding:1.2rem 1.5rem;border-top:1px solid rgba(255,255,255,.07);
  display:flex;flex-direction:column;gap:1rem;
}
.cart-total-row{
  display:flex;justify-content:space-between;align-items:baseline;
}
.cart-total-row span:first-child{font-size:.85rem;color:var(--muted)}
#cart-total{font-family:var(--f-display);font-size:1.4rem;color:var(--gold)}
.cart-checkout{width:100%;text-align:center;border-radius:100px}
.cart-shipping{font-size:.72rem;color:var(--muted);text-align:center}

.cta-bundle-offer{
  display:flex;align-items:center;gap:.6rem;
  background:rgba(200,168,75,.12);border:1px solid rgba(200,168,75,.3);
  border-radius:8px;padding:.65rem 1rem;
  font-size:.82rem;color:rgba(255,255,255,.8);
}
.cta-bundle-offer svg{color:var(--gold);flex-shrink:0}
.cta-bundle-offer strong{color:var(--gold)}

.cart-bundle-banner{
  background:rgba(200,168,75,.1);border:1px solid rgba(200,168,75,.25);
  border-radius:8px;padding:.7rem 1rem;margin-bottom:.8rem;
  font-size:.8rem;color:var(--gold);text-align:center;
}

/* ===== BUTTONS ===== */
.btn-gold{
  display:inline-block;
  background:var(--gold);color:#000;
  font-family:var(--f-display);font-size:.88rem;letter-spacing:.28em;
  padding:.9rem 2.8rem;border:1px solid var(--gold);cursor:pointer;
  border-radius:0;
  transition:background .22s,color .22s;
}
.btn-gold:hover{background:#000;color:var(--gold);}
.btn-gold.btn-lg{font-size:.95rem;padding:1.1rem 3.4rem}

.btn-ghost{
  display:inline-block;
  background:transparent;color:var(--text);
  font-family:var(--f-display);font-size:.88rem;letter-spacing:.28em;
  padding:.9rem 2.4rem;
  border:1px solid rgba(255,255,255,.3);
  cursor:pointer;border-radius:0;
  transition:border-color .22s,color .22s,background .22s;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ===== HERO ===== */
.hero{
  position:relative;height:100svh;min-height:600px;
  display:flex;align-items:center;overflow:hidden;
}
#hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(105deg, rgba(0,0,0,.88) 0%, rgba(0,0,0,.55) 50%, rgba(0,0,0,.15) 100%),
    linear-gradient(to bottom, transparent 55%, #000 100%);
}
.hero-content{
  position:relative;z-index:2;
  padding:0 6%;padding-top:4.5rem;max-width:52%;
}
.eyebrow{
  font-family:var(--f-body);font-size:.68rem;font-weight:500;
  letter-spacing:.22em;color:rgba(255,255,255,.45);margin-bottom:.9rem;
  display:block;
}
.eyebrow::before{content:'[ '}
.eyebrow::after{content:' ]'}
.hero-title{
  font-family:var(--f-display);
  font-size:clamp(5rem,12vw,9.5rem);
  line-height:.9;letter-spacing:.03em;margin-bottom:.9rem;
}
.hero-title span{color:var(--gold)}
.hero-sub{
  font-size:clamp(.95rem,1.8vw,1.3rem);
  font-weight:300;letter-spacing:.2em;color:rgba(255,255,255,.65);
  margin-bottom:2.2rem;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* mute toggle */
.unmute-btn{
  position:absolute;bottom:2.2rem;right:2.2rem;z-index:3;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:var(--text);width:2.6rem;height:2.6rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .2s,border-color .2s;
}
.unmute-btn:hover{background:rgba(200,168,75,.15);border-color:var(--gold)}

/* scroll hint */
.scroll-hint{
  position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;
  animation:bounce 2.5s ease-in-out infinite;
}
.scroll-hint span{
  font-family:var(--f-display);font-size:.6rem;
  letter-spacing:.35em;color:var(--muted);
}
.scroll-line{width:1px;height:38px;background:linear-gradient(to bottom,rgba(200,168,75,.7),transparent)}
@keyframes bounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(7px)}
}

/* ===== SCROLL ANIMATION ===== */
.scroll-section{position:relative;height:6000px}
.scroll-sticky{
  position:sticky;top:0;height:100svh;overflow:hidden;
}
.scroll-sticky::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:22%;pointer-events:none;z-index:3;
  background:linear-gradient(to bottom,transparent 0%,#000 100%);
}
#main-canvas{position:absolute;inset:0;width:100%;height:100%}

.scroll-text{
  position:absolute;left:6%;bottom:13%;
  opacity:0;transform:translateY(18px);
  transition:opacity .25s,transform .25s;
  pointer-events:none;max-width:500px;
}
.scroll-text .label{
  display:block;font-family:var(--f-body);font-size:.65rem;font-weight:500;
  letter-spacing:.22em;color:rgba(255,255,255,.45);margin-bottom:.9rem;
}
.scroll-text .label::before{content:'[ '}
.scroll-text .label::after{content:' ]'}
.scroll-text h2{
  font-family:var(--f-mega);font-weight:800;
  font-size:clamp(2rem,4vw,3.5rem);
  letter-spacing:-.02em;line-height:.95;margin-bottom:.9rem;
}
.scroll-text p{
  font-size:.88rem;color:var(--muted);line-height:1.7;max-width:320px;
}
.scroll-progress{
  position:absolute;right:2rem;top:50%;transform:translateY(-50%);
  width:2px;height:100px;background:rgba(255,255,255,.07);border-radius:2px;overflow:hidden;
}
#scroll-progress-fill{
  width:100%;height:0%;background:var(--gold);border-radius:2px;
  transition:height .08s linear;
}

/* ===== GALLERY ===== */
.gallery-section{ padding-top:0; }
.section-title{
  font-family:var(--f-mega);font-weight:800;
  font-size:clamp(2.2rem,4.5vw,4rem);
  letter-spacing:-.03em;line-height:.93;
  margin:.5rem 0 1.2rem;
}
.gallery-header{
  padding:5rem 6% 3rem;
}
.gallery-header .section-title{
  font-size:clamp(3.2rem,7vw,6rem);
  letter-spacing:-.03em;line-height:.92;margin:.6rem 0 1rem;
}
.gallery-header .section-sub{font-size:.88rem;color:var(--muted);max-width:480px}

.gallery-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3px;
  background:#000;
}
.gallery-item{
  overflow:hidden;background:#000;
  aspect-ratio:16/9;
  opacity:0;transform:scale(.98);
  transition:opacity .55s ease,transform .55s ease;
  position:relative;
}
/* masque le bas de l'image (reflets, artefacts) */
.gallery-item::before{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:32%;z-index:1;pointer-events:none;
  background:linear-gradient(to top,#000 30%,transparent 100%);
}
.gallery-item.visible{opacity:1;transform:scale(1)}
.gallery-item img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .6s ease;
}
.gallery-item:hover img{transform:scale(1.05)}

/* pleine largeur — ouverture et fermeture */
.gi-full{
  grid-column:1 / -1;
  aspect-ratio:16/9;
}
.gi-full img{
  object-fit:contain;
}

/* ===== VIDEO CAROUSEL ===== */
.video-section{
  padding:0 0 4rem;
  overflow:hidden;
}
.video-header{
  padding:5rem 6% 3rem;
}
.video-header .section-title{
  font-size:clamp(3.2rem,7vw,6rem);
  letter-spacing:-.03em;line-height:.92;margin:.6rem 0 1rem;
}
.video-header .section-sub{font-size:.88rem;color:var(--muted);max-width:480px}

.carousel-track-wrap{
  width:100%;overflow:hidden;
}
.carousel-track{
  display:flex;
  transition:transform .55s cubic-bezier(.77,0,.175,1);
  will-change:transform;
}
.carousel-slide{
  flex:0 0 100%;
  position:relative;
  aspect-ratio:16/9;
  background:#000;
  cursor:pointer;
}
.carousel-slide video{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.carousel-play{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);
  transition:background .25s;
}
.carousel-play svg{
  color:#fff;
  filter:drop-shadow(0 0 16px rgba(200,168,75,.6));
  transition:transform .2s,filter .2s;
  width:64px;height:64px;
  background:rgba(200,168,75,.15);
  border:1px solid rgba(200,168,75,.5);
  border-radius:50%;padding:18px;
}
.carousel-slide:hover .carousel-play{background:rgba(0,0,0,.15)}
.carousel-slide:hover .carousel-play svg{
  transform:scale(1.08);
  filter:drop-shadow(0 0 24px rgba(200,168,75,.9));
}
.carousel-play.hidden{display:none}

.carousel-controls{
  display:flex;align-items:center;justify-content:center;
  gap:2rem;padding-top:2rem;
}
.carousel-btn{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);
  color:#fff;width:3.2rem;height:3.2rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s,border-color .2s,transform .2s;
  flex-shrink:0;
}
.carousel-btn svg{width:24px;height:24px;stroke-width:2.5}
.carousel-btn:hover{background:var(--gold);border-color:var(--gold);color:#000;transform:scale(1.08)}
.carousel-dots{display:flex;gap:1rem;align-items:center}
.carousel-dot{
  width:36px;height:4px;border-radius:2px;
  background:rgba(255,255,255,.2);border:none;cursor:pointer;
  transition:background .25s,transform .25s;padding:0;
}
.carousel-dot.active{background:var(--gold);transform:scaleX(1.15)}

/* ===== SPECS ===== */
.specs-left .eyebrow{font-size:.68rem}
.specs-left .section-title{
  font-size:clamp(2rem,4vw,3.2rem);
  letter-spacing:-.02em;line-height:.95;
}
.specs-section{
  display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;
  padding:5rem 6% 0;
}
.specs-left{display:flex;flex-direction:column;gap:1rem}
.specs-right{align-self:start}

.specs-table{width:100%;border-collapse:collapse}
.specs-table tr{border-bottom:1px solid var(--border)}
.specs-table td{padding:.95rem 0;font-size:.87rem;vertical-align:middle}
.specs-table td:first-child{color:var(--muted);width:38%;font-weight:400}
.specs-table td:last-child{color:var(--text);font-weight:500}

/* FAQ inside specs-left */
.faq-list{margin-top:1.5rem}
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{
  width:100%;background:none;border:none;color:var(--text);
  text-align:left;padding:1.1rem 0;
  font-family:var(--f-body);font-size:.88rem;font-weight:500;
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq-plus{
  color:var(--gold);font-size:1.3rem;font-weight:300;flex-shrink:0;
  transition:transform .32s ease;
}
.faq-item.open .faq-plus{transform:rotate(45deg)}
.faq-answer{
  color:var(--muted);font-size:.83rem;line-height:1.75;
  max-height:0;overflow:hidden;transition:max-height .38s ease,padding-bottom .28s;
}
.faq-item.open .faq-answer{max-height:180px;padding-bottom:1.2rem}

/* ===== REVIEWS ===== */
.reviews-section{padding:5rem 6% 6rem}
.reviews-header{text-align:center;margin-bottom:3.5rem}
.reviews-global{
  display:flex;align-items:center;justify-content:center;gap:1.2rem;
  margin-top:1.8rem;
}
.reviews-score-num{
  font-family:var(--f-display);font-size:3.8rem;line-height:1;
  color:var(--gold);letter-spacing:-.02em;
}
.reviews-stars-global{color:var(--gold);font-size:1.3rem;letter-spacing:.1em}
.reviews-stars-global .star-half{opacity:.35}
.reviews-total{font-size:.78rem;letter-spacing:.08em;color:rgba(255,255,255,.38)}
.reviews-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;
  max-width:1100px;margin:0 auto;
}
.review-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:1.8rem 1.6rem;
  transition:border-color .3s,background .3s,transform .3s;
  cursor:default;
}
.review-card:hover{
  border-color:rgba(212,175,55,.28);
  background:rgba(255,255,255,.055);
  transform:translateY(-3px);
}
.review-top{display:flex;align-items:center;gap:.9rem;margin-bottom:1.2rem}
.review-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:var(--gold);color:#000;
  font-family:var(--f-display);font-size:1rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.review-meta{flex:1;min-width:0}
.review-name{font-family:var(--f-display);font-size:.78rem;letter-spacing:.1em;color:#fff;margin-bottom:.2rem}
.review-stars{color:var(--gold);font-size:.85rem;letter-spacing:.05em}
.review-badge{
  margin-left:auto;flex-shrink:0;
  font-size:.62rem;letter-spacing:.07em;color:rgba(255,255,255,.35);
  border:1px solid rgba(255,255,255,.1);
  padding:.18rem .55rem;border-radius:100px;white-space:nowrap;
}
.review-text{
  font-size:.87rem;line-height:1.75;
  color:rgba(255,255,255,.6);margin-bottom:1.1rem;
}
.review-game{
  font-size:.7rem;letter-spacing:.1em;
  color:rgba(255,255,255,.25);
}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr}}

/* ===== CTA ===== */
.cta-section{
  position:relative;min-height:70vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;margin-top:0;
}
.cta-bg{
  position:absolute;inset:0;
}
.cta-bg img{
  width:100%;height:100%;object-fit:contain;object-position:right center;
  opacity:.25;filter:brightness(.7);
}
.cta-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,rgba(0,0,0,.98) 35%,rgba(0,0,0,.5) 75%,transparent 100%);
}
.cta-content{
  position:relative;z-index:2;
  padding:4rem 6%;max-width:640px;align-self:center;
  display:flex;flex-direction:column;gap:1.1rem;align-items:flex-start;
}
.cta-content h2{
  font-family:var(--f-mega);font-weight:800;
  font-size:clamp(3rem,6vw,5rem);
  line-height:.92;color:var(--gold);letter-spacing:-.02em;
}
.cta-content p{font-size:.9rem;color:var(--muted)}

/* ===== CONTACT STRIP ===== */
.contact-strip{
  padding:5rem 6%;
  border-top:1px solid rgba(255,255,255,.07);
  display:flex;flex-direction:column;gap:2rem;
}
.contact-label{
  font-family:var(--f-mega);font-weight:800;
  font-size:clamp(2rem,4vw,3.5rem);
  letter-spacing:-.02em;line-height:.95;
  color:#fff;
}
.contact-mail{
  display:inline-flex;align-items:center;gap:1rem;
  border:1px solid rgba(255,255,255,.25);
  padding:.95rem 1.8rem;
  font-family:var(--f-body);font-size:.8rem;font-weight:500;
  letter-spacing:.18em;color:rgba(255,255,255,.8);
  transition:border-color .25s,color .25s,background .25s;
  width:fit-content;
}
.contact-mail svg{flex-shrink:0;transition:transform .25s}
.contact-mail:hover{
  border-color:var(--gold);color:var(--gold);
  background:rgba(200,168,75,.05);
}
.contact-mail:hover svg{transform:translateX(4px)}

/* ===== FOOTER ===== */
.footer{
  padding:1.8rem 6%;
  display:flex;align-items:center;justify-content:space-between;
}
.footer-brand{
  font-family:var(--f-display);font-size:.95rem;letter-spacing:.22em;
}
.footer-brand em{color:var(--gold);font-style:normal}
.footer-copy{font-size:.72rem;color:var(--muted)}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .specs-section{grid-template-columns:1fr;gap:3rem}
}
@media(max-width:768px){
  .navbar{padding:.9rem 1.4rem}
  .nav-links{display:none}
  .hero-content{max-width:90%;padding:0 5%;padding-top:4rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gi-large{grid-column:span 2}
  .cta-content{padding:3rem 5%}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .gi-large{grid-column:span 1;aspect-ratio:4/3}
  .hero-btns{flex-direction:column}
}
