/* ============================================================
   TOP CERTIF FRANCE — LUXURY DESIGN LAYER
   Premium overlay : palette raffinée, animations dynamiques,
   typographie cinématographique, grain, aurora, tilt 3D.
   ============================================================ */

/* --- TYPOGRAPHIE ÉDITORIALE --- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&display=swap');

/* --- VARIABLES PREMIUM --- */
:root{
  --lux-gold: #D4B266;
  --lux-gold-deep: #B8924A;
  --lux-gold-light: #F2D98C;
  --lux-champagne: #F5E6BE;
  --lux-cream: #F7F2E8;
  --lux-onyx: #060606;
  --lux-obsidian: #0E0E10;
  --lux-graphite: #161618;
  --lux-ease: cubic-bezier(.19,1,.22,1);
  --lux-ease-smooth: cubic-bezier(.4,0,.2,1);
  --lux-shine: linear-gradient(115deg, transparent 0%, transparent 38%, rgba(255,255,255,.45) 50%, transparent 62%, transparent 100%);
  --lux-gold-grad: linear-gradient(135deg,#B8924A 0%,#D4B266 25%,#F2D98C 50%,#D4B266 75%,#B8924A 100%);
  --lux-border: linear-gradient(135deg,rgba(212,178,102,.35),rgba(212,178,102,.08) 50%,rgba(212,178,102,.35));
}

/* --- KEYFRAMES --- */
@keyframes luxShine{0%{background-position:-200% 50%}100%{background-position:200% 50%}}
@keyframes luxFloat{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-12px) rotate(1deg)}}
@keyframes luxAuroraPulse{0%,100%{opacity:.55;transform:scale(1) translate(0,0)}50%{opacity:.85;transform:scale(1.15) translate(2%,-3%)}}
@keyframes luxAuroraPulse2{0%,100%{opacity:.4;transform:scale(1) translate(0,0)}50%{opacity:.7;transform:scale(1.1) translate(-3%,2%)}}
@keyframes luxGrain{0%,100%{transform:translate(0,0)}10%{transform:translate(-5%,-8%)}20%{transform:translate(-12%,4%)}30%{transform:translate(6%,-20%)}40%{transform:translate(-4%,18%)}50%{transform:translate(-10%,8%)}60%{transform:translate(12%,0)}70%{transform:translate(0,12%)}80%{transform:translate(2%,24%)}90%{transform:translate(-8%,7%)}}
@keyframes luxRevealUp{from{opacity:0;transform:translateY(36px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes luxTextShine{0%{background-position:0% 50%}100%{background-position:300% 50%}}
@keyframes luxSparkle{0%,100%{opacity:0;transform:scale(0) rotate(0deg)}25%{opacity:1;transform:scale(1) rotate(90deg)}50%{opacity:.8;transform:scale(1.2) rotate(180deg)}75%{opacity:.4;transform:scale(.8) rotate(270deg)}}
@keyframes luxSpin{to{transform:rotate(360deg)}}
@keyframes luxMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes luxArrowSlide{0%,100%{transform:translateX(0)}50%{transform:translateX(4px)}}
@keyframes luxPulseRing{0%{transform:scale(.8);opacity:.9}100%{transform:scale(2.2);opacity:0}}
@keyframes luxLoadFade{0%{opacity:1;visibility:visible}99%{opacity:0;visibility:visible}100%{opacity:0;visibility:hidden}}

/* --- GRAIN GLOBAL (FILM LUXE) --- */
body::before{
  content:'';position:fixed;inset:-50%;z-index:9998;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.85  0 0 0 0 0.75  0 0 0 0 0.5  0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.55;mix-blend-mode:overlay;animation:luxGrain 7s steps(6) infinite;
}

/* --- VIGNETTE PREMIUM --- */
body::after{
  content:'';position:fixed;inset:0;z-index:9997;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 55%,rgba(0,0,0,.55) 100%);
}

/* --- CURSEUR CUSTOM: désactivé (souris native) --- */
.lux-cursor,.lux-cursor-ring{display:none!important;}

/* --- MENU MOBILE OPTIMISÉ --- */
@media (max-width:1100px){
  body.lux-menu-open{overflow:hidden!important;}
  nav{z-index:10003!important;}
  .hamburger{z-index:10005!important;position:relative;width:32px;height:32px;display:flex!important;flex-direction:column;justify-content:center;align-items:center;gap:6px;}
  .hamburger span{
    width:24px;height:1.5px;background:var(--lux-cream)!important;border-radius:2px;
    transition:transform .5s var(--lux-ease),opacity .3s ease,background .3s ease!important;
    transform-origin:center!important;
  }
  body.lux-menu-open .hamburger span{background:var(--lux-gold-light)!important;}
  body.lux-menu-open .hamburger span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
  body.lux-menu-open .hamburger span:nth-child(2){opacity:0;transform:scaleX(0);}
  body.lux-menu-open .hamburger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

  .nav-links.open{
    display:flex!important;
    position:fixed!important;inset:0!important;
    background:
      radial-gradient(ellipse at 20% 10%,rgba(212,178,102,.12) 0%,transparent 50%),
      radial-gradient(ellipse at 80% 90%,rgba(184,146,74,.08) 0%,transparent 50%),
      var(--lux-onyx)!important;
    backdrop-filter:none!important;
    flex-direction:column!important;align-items:center!important;justify-content:center!important;
    gap:0!important;z-index:10002!important;
    padding:100px 24px 40px!important;
    animation:luxMenuIn .5s var(--lux-ease) forwards;
  }
  .nav-links.open::before{
    content:'';position:absolute;top:84px;left:50%;transform:translateX(-50%);
    width:40px;height:1px;
    background:linear-gradient(90deg,transparent,var(--lux-gold-light),transparent);
    box-shadow:0 0 10px rgba(242,217,140,.6);
  }
  .nav-links.open li{
    list-style:none;width:100%;max-width:360px;text-align:center;
    border-bottom:1px solid rgba(212,178,102,.1);
    opacity:0;transform:translateY(14px);
    animation:luxMenuItem .55s var(--lux-ease) forwards;
  }
  .nav-links.open li:last-child{border-bottom:none;margin-top:24px;}
  .nav-links.open li:nth-child(1){animation-delay:.12s;}
  .nav-links.open li:nth-child(2){animation-delay:.18s;}
  .nav-links.open li:nth-child(3){animation-delay:.24s;}
  .nav-links.open li:nth-child(4){animation-delay:.30s;}
  .nav-links.open li:nth-child(5){animation-delay:.36s;}
  .nav-links.open li:nth-child(6){animation-delay:.42s;}
  .nav-links.open a{
    display:block!important;padding:20px 12px!important;
    font-family:'Fraunces',serif!important;
    font-size:22px!important;letter-spacing:1.5px!important;
    text-transform:none!important;
    color:rgba(247,242,232,.9)!important;
    font-weight:400!important;
    transition:color .4s ease,transform .4s ease!important;
  }
  .nav-links.open a::after{display:none!important;}
  .nav-links.open a:hover,.nav-links.open a:active{
    color:var(--lux-gold-light)!important;
    transform:translateY(-1px);
  }
  .nav-links.open .nav-cta{
    background:var(--lux-gold-grad)!important;background-size:200% 100%!important;
    color:var(--lux-onyx)!important;
    padding:16px 36px!important;border-radius:999px!important;
    font-family:'DM Sans',sans-serif!important;
    font-size:13px!important;letter-spacing:2.5px!important;
    text-transform:uppercase!important;font-weight:600!important;
    box-shadow:0 10px 32px rgba(212,178,102,.35)!important;
    display:inline-block!important;
  }
  .nav-links.open .nav-cta:hover{color:var(--lux-onyx)!important;transform:translateY(-2px);}
}

@keyframes luxMenuIn{from{opacity:0;}to{opacity:1;}}
@keyframes luxMenuItem{to{opacity:1;transform:translateY(0);}}

/* --- LOADER ÉLÉGANT --- */
.lux-loader{
  position:fixed;inset:0;z-index:10001;background:var(--lux-onyx);
  display:flex;align-items:center;justify-content:center;
  animation:luxLoadFade 1s ease 1.2s forwards;
}
.lux-loader-mark{
  width:60px;height:60px;border-radius:50%;position:relative;
  border:1px solid rgba(212,178,102,.15);
}
.lux-loader-mark::before{
  content:'';position:absolute;inset:-1px;border-radius:50%;
  border:1px solid transparent;border-top-color:var(--lux-gold-light);
  animation:luxSpin 1s linear infinite;
}
.lux-loader-mark::after{
  content:'TCF';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:12px;letter-spacing:2px;
  color:var(--lux-gold-light);font-weight:500;
}

/* --- SCROLL PROGRESS AMÉLIORÉ --- */
.scroll-progress{
  height:3px!important;
  background:linear-gradient(90deg,var(--lux-gold-deep),var(--lux-gold-light),var(--lux-champagne),var(--lux-gold-light),var(--lux-gold-deep))!important;
  background-size:200% 100%!important;
  animation:luxShine 3s linear infinite;
  box-shadow:0 0 12px rgba(242,217,140,.55),0 0 24px rgba(212,178,102,.3);
}

/* --- BODY / BASELINE --- */
body{
  background:radial-gradient(ellipse at 20% 0%,rgba(212,178,102,.05) 0%,transparent 50%),
             radial-gradient(ellipse at 80% 100%,rgba(184,146,74,.04) 0%,transparent 50%),
             var(--lux-onyx)!important;
  font-feature-settings:"ss01","liga","kern";
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

/* --- NAV PREMIUM --- */
nav{
  background:linear-gradient(180deg,rgba(6,6,6,.92) 0%,rgba(6,6,6,.75) 100%)!important;
  backdrop-filter:blur(28px) saturate(1.6)!important;
  border-bottom:1px solid transparent!important;
  border-image:linear-gradient(90deg,transparent,rgba(212,178,102,.35),transparent) 1!important;
  transition:padding .6s var(--lux-ease),background .6s ease,box-shadow .6s ease!important;
}
nav.scrolled{
  box-shadow:0 12px 48px rgba(0,0,0,.6),0 1px 0 rgba(212,178,102,.15) inset!important;
  background:linear-gradient(180deg,rgba(6,6,6,.97) 0%,rgba(6,6,6,.88) 100%)!important;
}
.nav-logo img{
  box-shadow:0 0 0 1px rgba(212,178,102,.2),0 6px 24px rgba(0,0,0,.4);
  transition:transform .6s var(--lux-ease), box-shadow .6s ease, filter .6s ease!important;
}
.nav-logo:hover img{
  transform:scale(1.1) rotate(-3deg)!important;
  box-shadow:0 0 0 1px var(--lux-gold-light),0 10px 32px rgba(212,178,102,.35)!important;
  filter:brightness(1.1) saturate(1.2);
}
.nav-logo-text{
  font-family:'Fraunces',serif!important;font-weight:500!important;letter-spacing:2.5px!important;
  color:var(--lux-cream)!important;
}
.nav-links a{
  font-weight:500!important;
  transition:color .4s var(--lux-ease),transform .4s var(--lux-ease),letter-spacing .4s ease!important;
}
.nav-links a:not(.nav-cta):hover{
  color:var(--lux-gold-light)!important;letter-spacing:2px!important;
}
.nav-links a::after{
  background:linear-gradient(90deg,transparent,var(--lux-gold-light),transparent)!important;
  height:1px!important;bottom:-6px!important;
  box-shadow:0 0 8px rgba(242,217,140,.8);
}
.nav-cta{
  background:var(--lux-gold-grad)!important;
  background-size:200% 100%!important;
  color:var(--lux-onyx)!important;
  font-weight:600!important;letter-spacing:1.5px!important;
  box-shadow:0 6px 20px rgba(212,178,102,.28),0 0 0 1px rgba(212,217,140,.35) inset;
  transition:all .5s var(--lux-ease)!important;
}
.nav-cta:hover{
  background-position:100% 0!important;
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(212,178,102,.5),0 0 0 1px rgba(242,217,140,.6) inset!important;
}

/* --- HERO CINÉMATOGRAPHIQUE --- */
#hero{overflow:hidden;position:relative;}
#hero::before{
  content:'';position:absolute;top:-20%;left:-20%;width:70%;height:70%;
  background:radial-gradient(circle,rgba(212,178,102,.22) 0%,rgba(212,178,102,.08) 40%,transparent 70%);
  filter:blur(60px);animation:luxAuroraPulse 12s ease-in-out infinite;pointer-events:none;z-index:0;
}
#hero::after{
  content:'';position:absolute;bottom:-30%;right:-20%;width:65%;height:65%;
  background:radial-gradient(circle,rgba(242,217,140,.18) 0%,rgba(184,146,74,.06) 40%,transparent 70%);
  filter:blur(80px);animation:luxAuroraPulse2 14s ease-in-out infinite;pointer-events:none;z-index:0;
}
.hero-content{position:relative;z-index:2;}
.hero-content h1,h1{
  font-family:'Fraunces',serif!important;
  font-weight:400!important;
  letter-spacing:-3px!important;
  line-height:.96!important;
}
.hero-content h1 em,h1 em{
  font-style:italic;font-weight:400;
  color:var(--lux-gold-light)!important;
  text-shadow:0 2px 20px rgba(212,178,102,.35),0 0 40px rgba(242,217,140,.15);
}
.eyebrow{
  color:var(--lux-gold-light)!important;
  font-weight:500!important;
  text-shadow:0 0 20px rgba(242,217,140,.4);
}
.eyebrow::before{
  background:linear-gradient(90deg,transparent,var(--lux-gold-light))!important;
  height:1px!important;box-shadow:0 0 6px rgba(242,217,140,.6);
}
.hero-sub{
  font-family:'Fraunces',serif!important;
  font-style:italic;font-weight:300!important;
  color:rgba(247,242,232,.72)!important;
  font-size:20px!important;letter-spacing:.2px;
}

/* --- SPARKLES SUR HERO --- */
.lux-sparkle{
  position:absolute;width:4px;height:4px;pointer-events:none;z-index:1;
  background:radial-gradient(circle,var(--lux-champagne) 0%,transparent 70%);
  border-radius:50%;
  animation:luxSparkle 4s ease-in-out infinite;
}

/* --- BOUTONS PREMIUM --- */
.btn-gold{
  background:var(--lux-gold-grad)!important;
  background-size:200% 100%!important;
  color:var(--lux-onyx)!important;
  font-weight:600!important;letter-spacing:2.2px!important;
  padding:16px 36px!important;
  box-shadow:0 8px 28px rgba(212,178,102,.3),0 0 0 1px rgba(242,217,140,.4) inset,0 -1px 0 rgba(255,255,255,.3) inset!important;
  transition:all .5s var(--lux-ease)!important;
  position:relative;overflow:hidden;
}
.btn-gold::before{
  background:var(--lux-shine)!important;
}
.btn-gold:hover{
  background-position:100% 0!important;
  transform:translateY(-3px) scale(1.02)!important;
  box-shadow:0 16px 48px rgba(212,178,102,.5),0 0 0 1px var(--lux-champagne) inset,0 -1px 0 rgba(255,255,255,.5) inset!important;
}
.btn-gold svg{transition:transform .4s var(--lux-ease);}
.btn-gold:hover svg{transform:translateX(6px);}

.btn-outline{
  padding:16px 36px!important;
  border:1px solid rgba(247,242,232,.25)!important;
  backdrop-filter:blur(10px);
  background:rgba(255,255,255,.02)!important;
  font-weight:500!important;letter-spacing:2.2px!important;
  transition:all .5s var(--lux-ease)!important;
  position:relative;overflow:hidden;
}
.btn-outline::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:var(--lux-gold-grad);background-size:200% 100%;
  opacity:0;transition:opacity .5s ease;z-index:-1;
}
.btn-outline:hover{
  border-color:transparent!important;color:var(--lux-onyx)!important;
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(212,178,102,.4);
}
.btn-outline:hover::before{opacity:1;}

/* --- HERO BADGES --- */
.hero-badge{
  background:linear-gradient(135deg,rgba(22,22,24,.85),rgba(14,14,16,.7))!important;
  border:1px solid transparent!important;
  background-clip:padding-box!important;
  backdrop-filter:blur(18px) saturate(1.3)!important;
  box-shadow:0 8px 24px rgba(0,0,0,.4),0 0 0 1px rgba(212,178,102,.15) inset;
  transition:all .6s var(--lux-ease)!important;
  position:relative;overflow:hidden;
}
.hero-badge::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:var(--lux-border);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.8;
}
.hero-badge:hover{
  transform:translateY(-6px) scale(1.04)!important;
  box-shadow:0 16px 36px rgba(212,178,102,.22),0 0 0 1px rgba(212,178,102,.4) inset!important;
}
.hero-badge strong{
  font-family:'Fraunces',serif!important;
  color:var(--lux-gold-light)!important;
  font-weight:500!important;
}

/* --- SECTION LABELS / CLIENTS MARQUEE --- */
#labels-clients{position:relative;}
.lux-marquee{
  display:flex;gap:70px;animation:luxMarquee 30s linear infinite;width:max-content;
}
.lux-marquee img{height:50px!important;opacity:.4;transition:opacity .5s ease,filter .5s ease;filter:grayscale(1) brightness(1.2);}
.lux-marquee img:hover{opacity:1;filter:grayscale(0) brightness(1.1) drop-shadow(0 4px 20px rgba(212,178,102,.35));}
.lux-marquee-wrap{
  overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
}

/* --- SECTION LABELS / TITLES --- */
.sl{
  color:var(--lux-gold-light)!important;
  font-weight:500!important;letter-spacing:5px!important;
  text-shadow:0 0 20px rgba(242,217,140,.35);
}
.sl::after{background:linear-gradient(90deg,var(--lux-gold),transparent)!important;}
.st{
  font-family:'Fraunces',serif!important;
  font-weight:400!important;letter-spacing:-1.5px!important;
  line-height:1.05!important;
}
.st em{
  color:var(--lux-gold-light)!important;
  font-style:italic;
  text-shadow:0 2px 16px rgba(212,178,102,.3);
}
.ss{
  font-family:'Fraunces',serif!important;font-style:italic;
  color:rgba(247,242,232,.62)!important;
  font-weight:300!important;
}

/* --- CARTES PRODUITS LUXE --- */
.pc{
  border-radius:12px!important;
  overflow:hidden!important;
  box-shadow:0 10px 40px rgba(0,0,0,.5);
  transform-style:preserve-3d;
  transition:transform .6s var(--lux-ease), box-shadow .6s ease!important;
}
.pc::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;z-index:3;pointer-events:none;
  background:linear-gradient(135deg,rgba(212,178,102,0) 0%,rgba(212,178,102,.6) 50%,rgba(212,178,102,0) 100%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .6s ease;
}
.pc:hover{
  box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 0 1px rgba(212,178,102,.3);
}
.pc:hover::before{opacity:1;}
.pc-bg{transition:transform 1.2s var(--lux-ease),filter .6s ease!important;}
.pc:hover .pc-bg{transform:scale(1.12)!important;filter:brightness(1.08) saturate(1.15)!important;}
.pc-ov{
  background:linear-gradient(0deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.4) 45%,rgba(0,0,0,.05) 75%,rgba(0,0,0,0) 100%)!important;
}
.pc:hover .pc-ov{
  background:linear-gradient(0deg,rgba(0,0,0,.95) 0%,rgba(14,14,16,.5) 55%,rgba(0,0,0,.1) 85%,transparent 100%)!important;
}
.pc-title{
  font-family:'Fraunces',serif!important;
  font-size:34px!important;font-weight:400!important;letter-spacing:-.5px;
}
.pc-type{
  color:var(--lux-gold-light)!important;letter-spacing:3.5px!important;
  font-weight:500!important;
}
.pc-cta{
  color:var(--lux-gold-light)!important;
  font-weight:600!important;letter-spacing:2.5px!important;
}

/* --- GALERIE --- */
.gallery-grid{gap:6px!important;}
.gi{border-radius:8px!important;position:relative;overflow:hidden;}
.gi::before{
  content:'';position:absolute;inset:0;border-radius:inherit;z-index:2;pointer-events:none;
  background:linear-gradient(135deg,rgba(212,178,102,0) 50%,rgba(212,178,102,.25) 100%);
  opacity:0;transition:opacity .5s ease;
}
.gi::after{border-radius:8px!important;}
.gi:hover::before{opacity:1;}
.gi img{transition:transform 1s var(--lux-ease),filter .6s ease!important;}
.gi:hover img{transform:scale(1.08)!important;filter:brightness(1.05) contrast(1.05)!important;}

/* --- TIER BADGES --- */
.tier-badge{
  padding:12px 20px!important;
  border-radius:999px!important;
  font-weight:500!important;letter-spacing:.5px!important;
  transition:all .5s var(--lux-ease)!important;
  position:relative;overflow:hidden;
}
.tier-badge::before{
  content:'';position:absolute;inset:0;background:var(--lux-shine);
  background-size:200% 100%;transform:translateX(-100%);transition:transform .6s ease;
}
.tier-badge:hover::before{transform:translateX(100%);}
.tier-badge.active{
  box-shadow:0 0 0 2px currentColor inset,0 8px 24px rgba(212,178,102,.18);
}

/* --- FORMULAIRE / ORDER-FORM PREMIUM --- */
.order-form,.contact-form{
  background:linear-gradient(145deg,rgba(22,22,24,.85),rgba(14,14,16,.6))!important;
  border:1px solid transparent!important;
  backdrop-filter:blur(20px) saturate(1.2)!important;
  border-radius:14px!important;
  padding:44px!important;
  box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 0 1px rgba(212,178,102,.12) inset;
  position:relative;
  transition:transform .6s var(--lux-ease),box-shadow .6s ease,border-color .6s ease!important;
}
.order-form::before,.contact-form::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:var(--lux-border);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
}
.order-form:hover,.contact-form:hover{
  box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 0 1px rgba(212,178,102,.25) inset!important;
}
.form-title{
  font-family:'Fraunces',serif!important;
  font-size:24px!important;font-weight:500!important;
  color:var(--lux-cream)!important;
}
label{
  color:rgba(247,242,232,.5)!important;
  font-weight:500!important;letter-spacing:2px!important;
}
input,select,textarea{
  background:rgba(255,255,255,.03)!important;
  border:1px solid rgba(212,178,102,.12)!important;
  border-radius:8px!important;
  padding:15px 18px!important;
  transition:all .4s var(--lux-ease)!important;
  font-family:'DM Sans',sans-serif;
}
input:hover,select:hover,textarea:hover{border-color:rgba(212,178,102,.25)!important;}
input:focus,select:focus,textarea:focus{
  border-color:var(--lux-gold-light)!important;
  background:rgba(212,178,102,.05)!important;
  box-shadow:0 0 0 4px rgba(212,178,102,.12),0 0 24px rgba(212,178,102,.15)!important;
}
.ps{
  background:linear-gradient(135deg,rgba(212,178,102,.08),rgba(212,178,102,.02))!important;
  border:1px solid rgba(212,178,102,.2)!important;
  border-radius:10px!important;
  padding:22px!important;
}
.pt span:last-child{
  font-family:'Fraunces',serif;font-weight:500;
  color:var(--lux-gold-light)!important;
}
.pp-btn{
  background:linear-gradient(135deg,#003087 0%,#0070BA 50%,#009CDE 100%)!important;
  background-size:200% 100%!important;
  border-radius:10px!important;padding:18px 24px!important;
  font-weight:600!important;letter-spacing:1px!important;
  box-shadow:0 10px 28px rgba(0,112,186,.4),0 0 0 1px rgba(0,156,222,.3) inset!important;
  transition:all .5s var(--lux-ease)!important;
  position:relative;overflow:hidden;
}
.pp-btn::before{
  content:'';position:absolute;inset:0;background:var(--lux-shine);
  background-size:200% 100%;transform:translateX(-100%);transition:transform .7s ease;
}
.pp-btn:hover:not(:disabled){
  background-position:100% 0!important;
  transform:translateY(-3px)!important;
  box-shadow:0 18px 44px rgba(0,112,186,.55),0 0 0 1px rgba(0,156,222,.5) inset!important;
}
.pp-btn:hover:not(:disabled)::before{transform:translateX(100%);}

/* --- CGV CHECKBOX --- */
.cgv-box{
  border:2px solid var(--lux-gold-light)!important;
  border-radius:5px!important;
  transition:all .3s ease;
  box-shadow:0 0 0 0 rgba(212,178,102,.3);
}
.cgv input[type=checkbox]:checked + .cgv-box{
  background:var(--lux-gold-grad)!important;background-size:200% 100%;
  box-shadow:0 0 16px rgba(212,178,102,.45);
}

/* --- STAT BOXES --- */
.stat-box{
  background:linear-gradient(145deg,rgba(22,22,24,.6),rgba(14,14,16,.4))!important;
  border:1px solid rgba(212,178,102,.15)!important;
  border-radius:10px!important;
  padding:26px!important;position:relative;overflow:hidden;
  transition:all .6s var(--lux-ease)!important;
}
.stat-box::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--lux-gold-light),transparent);
  opacity:0;transition:opacity .5s ease;
}
.stat-box:hover{
  border-color:rgba(212,178,102,.4)!important;
  transform:translateY(-4px) scale(1.02)!important;
  box-shadow:0 20px 44px rgba(212,178,102,.14),0 0 0 1px rgba(212,178,102,.3) inset!important;
}
.stat-box:hover::before{opacity:1;}
.stat-num{
  font-family:'Fraunces',serif!important;
  font-size:34px!important;
  color:var(--lux-gold-light)!important;
  text-shadow:0 2px 16px rgba(212,178,102,.25);
}

/* --- ABOUT FRAME --- */
.about-frame{
  background:linear-gradient(145deg,rgba(22,22,24,.8),rgba(14,14,16,.5))!important;
  border:1px solid rgba(212,178,102,.18)!important;
  border-radius:16px!important;
  padding:40px!important;position:relative;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.about-frame::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:conic-gradient(from 180deg at 50% 50%,transparent 0deg,rgba(212,178,102,.1) 90deg,transparent 180deg,rgba(212,178,102,.08) 270deg,transparent 360deg);
  animation:luxSpin 24s linear infinite;pointer-events:none;opacity:.5;
}
.about-frame > *{position:relative;z-index:1;}
.about-logo-wrap{
  border:2px solid transparent!important;
  background:linear-gradient(var(--lux-graphite),var(--lux-graphite)) padding-box,var(--lux-gold-grad) border-box!important;
  box-shadow:0 12px 36px rgba(212,178,102,.2),0 0 0 1px rgba(212,178,102,.1) inset;
}
.about-badge{
  background:linear-gradient(135deg,rgba(212,178,102,.12),rgba(212,178,102,.04))!important;
  border:1px solid rgba(212,178,102,.3)!important;
  border-radius:999px!important;
  padding:10px 20px!important;
  color:var(--lux-gold-light)!important;
  font-weight:500!important;
}

/* --- LEGAL CARDS --- */
.legal-card{
  background:linear-gradient(145deg,rgba(22,22,24,.75),rgba(14,14,16,.5))!important;
  border:1px solid transparent!important;
  border-radius:14px!important;
  padding:36px!important;position:relative;overflow:hidden;
  transition:all .6s var(--lux-ease)!important;
  box-shadow:0 12px 32px rgba(0,0,0,.3);
}
.legal-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:var(--lux-border);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;transition:opacity .5s ease;
}
.legal-card:hover{
  transform:translateY(-8px) scale(1.02)!important;
  box-shadow:0 24px 64px rgba(212,178,102,.15),0 0 0 1px rgba(212,178,102,.3) inset!important;
}
.legal-card:hover::before{opacity:1;}
.legal-icon{
  background:linear-gradient(135deg,rgba(212,178,102,.18),rgba(212,178,102,.06))!important;
  width:52px!important;height:52px!important;
  box-shadow:0 8px 20px rgba(212,178,102,.15);
  transition:all .5s var(--lux-ease)!important;
}
.legal-card:hover .legal-icon{
  transform:rotate(-8deg) scale(1.08);
  box-shadow:0 12px 28px rgba(212,178,102,.3)!important;
}
.legal-card-title{
  font-family:'Fraunces',serif!important;
  font-size:20px!important;font-weight:500!important;
}

/* --- FAQ DETAILS --- */
details{
  border-radius:10px!important;
  background:linear-gradient(145deg,rgba(22,22,24,.7),rgba(14,14,16,.4))!important;
  border:1px solid rgba(212,178,102,.15)!important;
  transition:all .5s var(--lux-ease);
  overflow:hidden;
}
details:hover{border-color:rgba(212,178,102,.3)!important;transform:translateY(-2px);}
details[open]{
  border-color:rgba(212,178,102,.35)!important;
  box-shadow:0 12px 32px rgba(0,0,0,.3),0 0 0 1px rgba(212,178,102,.2) inset;
}
details summary{font-family:'Fraunces',serif!important;}

/* --- CONTACT ITEMS --- */
.ci-icon{
  background:linear-gradient(135deg,rgba(212,178,102,.15),rgba(212,178,102,.04))!important;
  border:1px solid rgba(212,178,102,.2);
  width:48px!important;height:48px!important;
  box-shadow:0 8px 20px rgba(0,0,0,.3);
}
.ci-item:hover .ci-icon{
  background:linear-gradient(135deg,rgba(212,178,102,.28),rgba(212,178,102,.1))!important;
  box-shadow:0 12px 28px rgba(212,178,102,.25)!important;
}

/* --- FOOTER --- */
footer{
  background:linear-gradient(180deg,var(--lux-onyx),#030303)!important;
  border-top:1px solid transparent!important;
  border-image:linear-gradient(90deg,transparent,var(--lux-gold),transparent) 1!important;
  position:relative;
}
footer::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:200px;height:1px;
  background:linear-gradient(90deg,transparent,var(--lux-gold-light),transparent);
  box-shadow:0 0 12px rgba(242,217,140,.4);
}
.fct{
  color:var(--lux-gold-light)!important;
  font-weight:600!important;letter-spacing:3.5px!important;
}
.fl2 a{transition:color .4s var(--lux-ease),padding-left .4s var(--lux-ease)!important;}
.fl2 a:hover{color:var(--lux-gold-light)!important;padding-left:8px;}

/* --- MODAL --- */
.modal{
  background:linear-gradient(145deg,rgba(22,22,24,.98),rgba(14,14,16,.92))!important;
  border:1px solid transparent!important;
  border-radius:16px!important;
  box-shadow:0 40px 100px rgba(0,0,0,.7),0 0 0 1px rgba(212,178,102,.15) inset!important;
  position:relative;overflow:hidden;
}
.modal::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:var(--lux-border);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
}
.modal-title{font-family:'Fraunces',serif!important;font-weight:500!important;}
.modal-icon{
  background:linear-gradient(135deg,rgba(212,178,102,.25),rgba(212,178,102,.08))!important;
  box-shadow:0 10px 28px rgba(212,178,102,.25);
}

/* --- PAGES PRODUITS (disque-or/platine/diamant/tiktok) --- */
header{
  background:linear-gradient(180deg,rgba(6,6,6,.94),rgba(6,6,6,.82))!important;
  backdrop-filter:blur(24px) saturate(1.5)!important;
  border-bottom:1px solid rgba(212,178,102,.18)!important;
}
.hero,#hero-product,.hero-section{position:relative;overflow:hidden;}
.product-hero,.product-detail{position:relative;}

/* --- DIVIDER ORNEMENTAL (injecté par JS) --- */
.lux-divider{
  display:flex;align-items:center;justify-content:center;gap:16px;
  margin:48px auto;max-width:240px;opacity:.5;
}
.lux-divider::before,.lux-divider::after{
  content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--lux-gold));
}
.lux-divider::after{background:linear-gradient(90deg,var(--lux-gold),transparent);}
.lux-divider svg{color:var(--lux-gold-light);filter:drop-shadow(0 0 6px rgba(242,217,140,.5));}

/* --- SCROLLBAR PREMIUM --- */
::-webkit-scrollbar{width:8px!important;}
::-webkit-scrollbar-track{background:var(--lux-onyx)!important;}
::-webkit-scrollbar-thumb{
  background:var(--lux-gold-grad)!important;
  background-size:100% 200%!important;
  border-radius:10px!important;
  border:2px solid var(--lux-onyx);
}
::-webkit-scrollbar-thumb:hover{background-position:0 100%!important;}

/* --- SELECTION --- */
::selection{background:rgba(212,178,102,.35)!important;color:var(--lux-cream)!important;text-shadow:0 0 12px rgba(242,217,140,.5);}

/* --- REVEAL ANIMATIONS --- */
.lux-reveal{opacity:0;transform:translateY(40px);transition:opacity 1.2s var(--lux-ease),transform 1.2s var(--lux-ease);}
.lux-reveal.in{opacity:1;transform:translateY(0);}
.animate.visible{animation:luxRevealUp 1s var(--lux-ease) forwards;}

/* --- LIEN INTERNE CATALOGUE --- */
a[href$=".html"][href^="disque-"], a[href$="trophee-tiktok.html"]{
  transition:all .5s var(--lux-ease)!important;
}

/* --- RESPONSIVE LUX --- */
@media (max-width:900px){
  .lux-cursor,.lux-cursor-ring{display:none!important;}
  body.lux-ready,body.lux-ready *{cursor:auto!important;}
  .order-form,.contact-form{padding:24px!important;}
  .about-frame{padding:28px!important;}
  body::before{opacity:.35;}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;}
  body::before{animation:none;}
}
