:root{
  --fond-1:#dddad0;
  --fond-2:#474953;
  --ink:#171717;
  --muted:#646464;
  --light:#f7f4ea;
  --white:#fff;
  --accent:#ff9f1c;
  --accent-2:#d97800;
  --line:rgba(23,23,23,.12);
  --shadow:0 24px 80px rgba(0,0,0,.18);
  --radius:28px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:var(--fond-1);color:var(--ink);font-family:Inter,Arial,Helvetica,sans-serif} a{color:inherit;text-decoration:none} p{line-height:1.7}.site-header{position:sticky;top:0;z-index:1000;height:76px;padding:0 5vw;display:flex;align-items:center;justify-content:space-between;background:rgba(221,218,208,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}.brand,.footer-brand{font-weight:950;font-size:1.45rem;letter-spacing:.12em}.brand span,.footer-brand span{color:var(--accent)}.main-nav{display:flex;align-items:center;gap:22px;font-weight:800}.main-nav>a,.nav-group>button{font:inherit;border:0;background:none;color:var(--ink);cursor:pointer;padding:12px 0}.main-nav a:hover,.nav-group button:hover{color:var(--accent-2)}.nav-cta{background:var(--fond-2)!important;color:var(--light)!important;padding:13px 18px!important;border-radius:999px}.nav-cta:hover{background:var(--accent)!important;color:var(--ink)!important}.nav-group{position:relative}.dropdown{position:absolute;top:44px;left:0;width:230px;padding:12px;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);display:none}.dropdown a{display:block;padding:12px;border-radius:12px}.dropdown a:hover{background:var(--fond-1)}.nav-group:hover .dropdown{display:block}.nav-toggle{display:none;background:none;border:0}.nav-toggle span{display:block;width:28px;height:3px;background:var(--ink);margin:5px;border-radius:3px}.hero-v3{min-height:calc(100vh - 76px);padding:8vw 5vw;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;overflow:hidden}.hero-v3:before{content:"";position:absolute;inset:-20%;background:radial-gradient(circle at 18% 20%,rgba(255,159,28,.22),transparent 28%),radial-gradient(circle at 82% 45%,rgba(71,73,83,.26),transparent 32%);z-index:-1}.eyebrow{font-size:.78rem;font-weight:950;letter-spacing:.17em;text-transform:uppercase;color:var(--accent-2)}h1,h2,h3{letter-spacing:-.04em}h1{font-size:clamp(3.4rem,7.8vw,8.5rem);line-height:.88;margin:18px 0}h1 span{color:var(--fond-2)}.hero-copy p:not(.eyebrow),.page-hero p{font-size:clamp(1.08rem,1.5vw,1.35rem);max-width:760px;color:#333}.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:16px 24px;font-weight:950;transition:.25s}.btn.primary{background:var(--accent);color:#151515}.btn.primary:hover{background:var(--accent-2);color:white;transform:translateY(-3px)}.btn.ghost{border:2px solid var(--fond-2)}.btn.ghost:hover{background:var(--fond-2);color:var(--light);transform:translateY(-3px)}.hero-visual{min-height:520px}.machine-card{height:520px;border-radius:52px;background:linear-gradient(145deg,rgba(255,255,255,.58),rgba(71,73,83,.22));box-shadow:var(--shadow);position:relative;overflow:hidden}.piece-core{position:absolute;inset:0;margin:auto;width:205px;height:205px;border-radius:44px;background:linear-gradient(145deg,var(--fond-2),#22242a);transform:rotate(-12deg);box-shadow:0 34px 95px rgba(0,0,0,.34)}.piece-core:after{content:"";position:absolute;width:76px;height:76px;border-radius:20px;top:35px;left:35px;background:var(--fond-1)}.scan-beam{position:absolute;left:0;right:0;height:4px;background:var(--accent);box-shadow:0 0 42px var(--accent);animation:scan 2.7s ease-in-out infinite;z-index:4}@keyframes scan{0%,100%{top:15%}50%{top:84%}}.tag{position:absolute;padding:12px 18px;border-radius:999px;background:rgba(255,255,255,.82);font-weight:950;box-shadow:0 12px 40px rgba(0,0,0,.12);animation:float 4s ease-in-out infinite}.tag-a{top:12%;left:10%}.tag-b{top:18%;right:12%;animation-delay:.4s}.tag-c{bottom:14%;left:12%;animation-delay:.8s}.tag-d{bottom:20%;right:10%;animation-delay:1.2s}@keyframes float{50%{transform:translateY(-14px)}}.trust-bar{margin:-36px 5vw 60px;padding:28px;border-radius:var(--radius);background:white;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.trust-bar div{text-align:center}.trust-bar strong{display:block;font-size:clamp(1.4rem,2.6vw,2.5rem);color:var(--fond-2)}.trust-bar span{font-weight:800;color:var(--muted)}.section{padding:90px 5vw}.section-heading{max-width:820px;margin-bottom:42px}.section-heading h2,.page-hero h1{font-size:clamp(2.5rem,5vw,5.8rem);line-height:.94;margin:12px 0}.intro-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}.mini-cards,.solution-row,.timeline,.sector-grid,.gallery-grid,.contact-grid{display:grid;gap:22px}.mini-cards{grid-template-columns:repeat(3,1fr)}.mini-card,.solution-card,.sector-card,.gallery-card,.contact-card,.detail-block,.wide-steps article{background:white;border-radius:var(--radius);padding:30px;box-shadow:0 12px 36px rgba(0,0,0,.08);transition:.25s}.mini-card:hover,.solution-card:hover,.sector-card:hover,.gallery-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}.dark-section{background:var(--fond-2);color:var(--light)}.dark-section .eyebrow{color:var(--accent)}.solution-row{grid-template-columns:repeat(4,1fr)}.solution-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:var(--light)}.solution-card span,.detail-block span{color:var(--accent);font-weight:950;font-size:1.4rem}.timeline{grid-template-columns:repeat(4,1fr)}.timeline-item{border-left:3px solid var(--accent);padding-left:24px}.timeline-item strong,.wide-steps strong{font-size:2.2rem;color:var(--accent-2)}.final-cta{margin:80px 5vw;padding:76px 5vw;border-radius:44px;background:var(--fond-2);color:var(--light);text-align:center;box-shadow:var(--shadow)}.final-cta h2{font-size:clamp(2.5rem,5.3vw,6rem);line-height:.95;margin:10px auto 30px;max-width:980px}.page{padding-bottom:80px}.page-hero{padding:95px 5vw 50px}.service-detail{padding:20px 5vw;display:grid;gap:22px}.detail-block{display:grid;grid-template-columns:90px 280px 1fr;align-items:center}.sector-grid,.gallery-grid{padding:20px 5vw;grid-template-columns:repeat(2,1fr)}.gallery-card div{height:240px;border-radius:22px;background:linear-gradient(135deg,var(--fond-2),#202126);margin-bottom:20px}.wide-steps{padding:20px 5vw;display:grid;gap:22px}.form-shell{padding:20px 5vw}.quote-form{max-width:950px;background:white;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.quote-form label{font-weight:900}.quote-form input,.quote-form select,.quote-form textarea{width:100%;margin-top:8px;padding:15px;border-radius:14px;border:1px solid var(--line);font:inherit;background:#f8f7f2}.quote-form .full{grid-column:1/-1}.contact-grid{padding:20px 5vw;grid-template-columns:repeat(3,1fr)}.site-footer{padding:52px 5vw;background:#202127;color:var(--light);display:grid;grid-template-columns:1.4fr .8fr .8fr;gap:30px}.site-footer a{display:block;margin:8px 0;color:var(--light)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:1180px){.main-nav{gap:13px;font-size:.9rem}.hero-v3,.intro-grid{grid-template-columns:1fr}.solution-row,.timeline,.trust-bar{grid-template-columns:repeat(2,1fr)}.mini-cards{grid-template-columns:1fr}.detail-block{grid-template-columns:1fr}}
@media(max-width:820px){.nav-toggle{display:block}.main-nav{position:fixed;top:76px;right:-100%;width:min(86vw,420px);height:calc(100vh - 76px);background:var(--fond-2);color:var(--light);display:flex;align-items:stretch;flex-direction:column;padding:28px;transition:.3s;overflow:auto}.main-nav.open{right:0}.main-nav>a,.nav-group>button{color:var(--light);text-align:left}.nav-cta{background:var(--accent)!important;color:var(--ink)!important}.dropdown{position:static;display:block;width:auto;background:rgba(255,255,255,.08);box-shadow:none;border-color:rgba(255,255,255,.12);margin:6px 0 12px}.hero-v3{padding-top:60px}.hero-visual,.machine-card{min-height:390px;height:390px}.trust-bar,.solution-row,.timeline,.sector-grid,.gallery-grid,.contact-grid,.quote-form{grid-template-columns:1fr}.site-footer{grid-template-columns:1fr}h1{font-size:clamp(3rem,15vw,5.4rem)}}

/* Phase 2 - crédibilité, devis, filtres et pages secondaires */
.quote-layout{padding:20px 5vw;display:grid;grid-template-columns:.82fr 1.18fr;gap:28px;align-items:start}.quote-helper{background:var(--fond-2);color:var(--light);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);position:sticky;top:96px}.quote-helper .eyebrow{color:var(--accent)}.quote-helper h2{font-size:clamp(2rem,3vw,3.4rem);line-height:.95;margin:14px 0}.quote-helper ul{padding-left:20px;line-height:1.9}.helper-card{margin-top:24px;padding:22px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14)}.form-note{margin:0;color:var(--muted);font-size:.92rem}.filter-row{padding:0 5vw 20px;display:flex;flex-wrap:wrap;gap:12px}.filter-btn{border:1px solid var(--line);background:white;border-radius:999px;padding:12px 18px;font-weight:950;cursor:pointer}.filter-btn.active,.filter-btn:hover{background:var(--fond-2);color:var(--light)}.gallery-card.is-hidden{display:none}.gallery-card span{display:inline-flex;margin-bottom:6px;color:var(--accent-2);font-weight:950;text-transform:uppercase;letter-spacing:.08em;font-size:.76rem}.mock-img{height:240px;border-radius:22px;margin-bottom:20px;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--fond-2),#202126)}.mock-img:before{content:"";position:absolute;inset:42px;border-radius:28px;background:rgba(221,218,208,.82);transform:rotate(-9deg)}.mock-img:after{content:"";position:absolute;width:70px;height:70px;border-radius:16px;background:var(--accent);right:54px;bottom:54px}.mock-img.scan:after{left:0;right:0;top:50%;width:100%;height:4px;border-radius:0;box-shadow:0 0 30px var(--accent)}.mock-img.serie:before{box-shadow:56px 26px 0 rgba(221,218,208,.45),112px 52px 0 rgba(221,218,208,.28)}.faq-list{padding:20px 5vw;display:grid;gap:16px;max-width:1100px}.faq-list details{background:white;border-radius:22px;padding:22px 26px;box-shadow:0 12px 36px rgba(0,0,0,.08)}.faq-list summary{font-weight:950;font-size:1.15rem;cursor:pointer}.legal-box{margin:20px 5vw;background:white;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);max-width:1100px}.quote-form input[type=file]{background:white}.page-hero{position:relative;overflow:hidden}.page-hero:after{content:"";position:absolute;right:5vw;top:48px;width:180px;height:180px;border-radius:38px;background:rgba(255,159,28,.16);transform:rotate(16deg);z-index:-1}
@media(max-width:980px){.quote-layout{grid-template-columns:1fr}.quote-helper{position:static}.page-hero:after{display:none}}
@media(max-width:820px){.dropdown a{color:var(--light)}.quote-form{padding:24px}.filter-row{padding-top:10px}.quote-helper{padding:26px}}


/* Phase 3 - crédibilité locale, guide demande, finitions production */
.local-proof{background:rgba(255,255,255,.28)}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.proof-card,.guide-card{background:white;border-radius:var(--radius);padding:30px;box-shadow:0 12px 36px rgba(0,0,0,.08);transition:.25s}
.proof-card:hover,.guide-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.proof-card strong{display:block;font-size:1.35rem;letter-spacing:-.03em;margin-bottom:10px;color:var(--fond-2)}
.guide-grid{padding:20px 5vw;display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.guide-card span{display:inline-flex;color:var(--accent-2);font-size:1.4rem;font-weight:950;margin-bottom:8px}
.guide-card h2{font-size:clamp(1.6rem,2.8vw,3rem);line-height:.98;margin:8px 0}
.inline-link{color:var(--accent);font-weight:950;text-decoration:underline;text-underline-offset:4px}
:focus-visible{outline:3px solid var(--accent);outline-offset:4px;border-radius:10px}
@media(max-width:900px){.proof-grid,.guide-grid{grid-template-columns:1fr}.proof-card,.guide-card{padding:24px}}


/* Phase 4 - fond image premium sous animation hero */
.machine-card.cinematic-bg{
  background:#101116 url('../img/hero-d3dia-tech.png') center center / cover no-repeat;
  isolation:isolate;
}
.machine-card.cinematic-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(16,17,22,.14), rgba(16,17,22,.06)),
    radial-gradient(circle at 50% 50%, rgba(255,159,28,.12), transparent 34%);
  z-index:0;
  pointer-events:none;
}
.machine-card.cinematic-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.38));
  z-index:0;
  pointer-events:none;
}
.machine-card.cinematic-bg .scan-beam,
.machine-card.cinematic-bg .piece-core,
.machine-card.cinematic-bg .tag{
  z-index:2;
}
.machine-card.cinematic-bg .piece-core{
  width:150px;
  height:150px;
  opacity:.88;
  background:linear-gradient(145deg,rgba(221,218,208,.92),rgba(71,73,83,.78));
  mix-blend-mode:screen;
}
.machine-card.cinematic-bg .piece-core::after{
  width:54px;
  height:54px;
  top:27px;
  left:27px;
  background:rgba(20,21,26,.76);
}
.machine-card.cinematic-bg .tag{
  background:rgba(255,255,255,.9);
}
@media(max-width:700px){
  .machine-card.cinematic-bg{background-position:center}
  .machine-card.cinematic-bg .piece-core{width:120px;height:120px}
}

/* Phase 5 - correction hero : image propre sans double animation par-dessus */
.machine-card.cinematic-bg{
  background:#101116 url('../img/hero-d3dia-tech.png') center center / cover no-repeat;
}
.machine-card.cinematic-bg .scan-beam,
.machine-card.cinematic-bg .piece-core,
.machine-card.cinematic-bg .tag{
  display:none !important;
}
.machine-card.cinematic-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.10), rgba(0,0,0,.06));
  z-index:1;
  pointer-events:none;
}
.machine-card.cinematic-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 52%, rgba(255,159,28,.10), transparent 42%);
  z-index:1;
  pointer-events:none;
}
@media(max-width:700px){
  .machine-card.cinematic-bg{
    background-size:cover;
    background-position:center center;
  }
}

/* Phase 6 - vraie animation canvas, sans photo de fond ni CNC */
.hero-scanner .hero-visual{min-height:560px}
.scanner-stage{
  height:560px;
  border-radius:52px;
  position:relative;
  overflow:hidden;
  background:#101116;
  box-shadow:0 30px 100px rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.12);
}
.scanner-stage::before,
.scanner-stage::after{display:none!important}
.scanner-stage canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}
.stage-labels{
  position:absolute;
  left:22px;
  right:22px;
  bottom:20px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  z-index:3;
  pointer-events:none;
}
.stage-labels span{
  padding:10px 14px;
  border-radius:999px;
  color:var(--light);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(10px);
  font-size:.78rem;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.three-services{grid-template-columns:repeat(3,1fr)}
.scan-context{background:rgba(255,255,255,.22)}
@media(max-width:900px){.three-services{grid-template-columns:1fr}.hero-scanner .hero-visual,.scanner-stage{min-height:430px;height:430px}}
@media(max-width:560px){.hero-scanner .hero-visual,.scanner-stage{min-height:360px;height:360px}.stage-labels span{font-size:.7rem;padding:8px 10px}}

/* V3.1 - D3DIA maison mère + LAB showroom */
.lab-hero{
  background:
    radial-gradient(circle at 78% 20%, rgba(255,159,28,.18), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,.36), rgba(255,255,255,.12));
  border-bottom:1px solid rgba(23,23,23,.08);
}
.lab-intro{padding-top:70px}
.lab-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
}
.lab-card{
  min-height:390px;
  padding:30px;
  border-radius:var(--radius);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:var(--light);
  transition:.25s ease;
  display:flex;
  flex-direction:column;
}
.lab-card:hover{
  transform:translateY(-8px);
  background:rgba(255,255,255,.12);
  box-shadow:0 28px 80px rgba(0,0,0,.26);
}
.lab-card .lab-icon{
  width:58px;
  height:58px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:rgba(255,159,28,.16);
  font-size:1.6rem;
  margin-bottom:22px;
}
.lab-card span{
  color:var(--accent);
  font-weight:950;
  letter-spacing:.09em;
  text-transform:uppercase;
  font-size:.74rem;
}
.lab-card h3{
  font-size:clamp(1.8rem,2.3vw,2.8rem);
  line-height:.95;
  margin:14px 0;
}
.lab-card p{color:rgba(247,244,234,.84)}
.lab-link{
  margin-top:auto;
  color:var(--accent);
  font-weight:950;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.lab-link::after{content:"→";transition:.2s}
.lab-card:hover .lab-link::after{transform:translateX(5px)}
.lab-offer{background:rgba(255,255,255,.26)}
.lab-preview{background:rgba(255,255,255,.26)}
.lab-mini-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.lab-mini-card{
  min-height:160px;
  padding:26px;
  border-radius:24px;
  background:var(--fond-2);
  color:var(--light);
  box-shadow:0 16px 45px rgba(0,0,0,.12);
  transition:.25s ease;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  position:relative;
  overflow:hidden;
}
.lab-mini-card::before{
  content:"";
  position:absolute;
  width:130px;
  height:130px;
  border-radius:34px;
  right:-34px;
  top:-38px;
  background:rgba(255,159,28,.14);
  transform:rotate(18deg);
}
.lab-mini-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.lab-mini-card strong{
  font-size:1.45rem;
  letter-spacing:-.04em;
  position:relative;
  z-index:1;
}
.lab-mini-card span{
  color:rgba(247,244,234,.74);
  font-weight:800;
  position:relative;
  z-index:1;
}
.site-header .main-nav{gap:20px}
@media(max-width:1180px){
  .lab-grid,.lab-mini-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .lab-grid,.lab-mini-grid{grid-template-columns:1fr}
  .lab-card{min-height:auto}
}

/* V3.1 - D3DIA LAB : ShopLab */
.featured-shoplab .lab-icon{
  background:rgba(70,155,255,.16);
}
.featured-shoplab{
  background:linear-gradient(145deg,rgba(255,255,255,.10),rgba(70,155,255,.08));
}

/* ==============================
   V3.2 — corrections LAB lisibilité
   ============================== */
.lab-offer {
  background:
    radial-gradient(circle at 15% 10%, rgba(255,159,28,.10), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.42), rgba(255,255,255,.16));
}
.lab-offer .section-heading p:not(.eyebrow) {
  color: #30323a;
}
.lab-offer .three-services {
  align-items: stretch;
}
.lab-offer .solution-card {
  position: relative;
  overflow: hidden;
  background: #ffffff;
  color: var(--fond-2);
  border: 1px solid rgba(71,73,83,.10);
  box-shadow: 0 18px 52px rgba(0,0,0,.10);
  min-height: 280px;
}
.lab-offer .solution-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: var(--accent);
  transform: scaleY(.28);
  transform-origin: top;
  transition: transform .25s ease;
}
.lab-offer .solution-card::after {
  content: "";
  position: absolute;
  width: 150px;
  height: 150px;
  right: -55px;
  top: -60px;
  border-radius: 38px;
  background: rgba(255,159,28,.12);
  transform: rotate(18deg);
  pointer-events: none;
}
.lab-offer .solution-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 80px rgba(0,0,0,.16);
  border-color: rgba(255,159,28,.42);
}
.lab-offer .solution-card:hover::before {
  transform: scaleY(1);
}
.lab-offer .solution-card span {
  display: inline-grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 18px;
  margin-bottom: 18px;
  background: rgba(255,159,28,.14);
  color: var(--accent-2);
  font-size: 1.45rem;
  letter-spacing: 0;
}
.lab-offer .solution-card h3 {
  color: var(--fond-2);
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1.05;
  margin: 0 0 16px;
}
.lab-offer .solution-card p {
  color: #565962;
  font-size: 1.02rem;
  line-height: 1.72;
}
.lab-offer .solution-card:nth-child(1) span::before { content: "◫"; }
.lab-offer .solution-card:nth-child(2) span::before { content: "▣"; }
.lab-offer .solution-card:nth-child(3) span::before { content: "⚙"; }
.lab-offer .solution-card span {
  font-size: 0;
}
.lab-offer .solution-card span::before {
  font-size: 1.55rem;
  line-height: 1;
}

@media(max-width:900px){
  .lab-offer .solution-card { min-height: auto; }
}

/* ==============================
   V3.3 — pages démonstrateurs LAB
   ============================== */
.demo-page .demo-hero{
  background:
    radial-gradient(circle at 12% 12%, rgba(255,159,28,.12), transparent 28%),
    radial-gradient(circle at 85% 35%, rgba(71,73,83,.16), transparent 34%);
}
.demo-hero .hero-actions{margin-top:26px}
.demo-showcase,
.viewer-demo-section,
.dashboard-demo{
  padding-top:40px;
}
.shop-window,
.viewer-shell,
.dashboard-shell{
  border-radius:42px;
  box-shadow:0 30px 100px rgba(0,0,0,.18);
  overflow:hidden;
  border:1px solid rgba(71,73,83,.12);
}
.shop-window{
  background:#fff;
  max-width:1180px;
  margin:auto;
}
.shop-topbar{
  height:66px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 22px;
  background:#202127;
  color:var(--light);
}
.shop-topbar span{
  width:13px;height:13px;border-radius:50%;background:rgba(255,255,255,.25)
}
.shop-topbar strong{margin-left:10px;letter-spacing:.1em;text-transform:uppercase}
.shop-layout{
  display:grid;
  grid-template-columns:220px 1fr 280px;
  min-height:460px;
}
.shop-layout aside{
  padding:30px;
  border-right:1px solid var(--line);
  background:#f7f5ed;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.shop-layout aside b{font-size:1.25rem;color:var(--fond-2)}
.shop-layout aside a{font-weight:850;color:#666}
.shop-products{
  padding:30px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  align-content:center;
}
.shop-products article{
  padding:18px;
  border-radius:24px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 12px 34px rgba(0,0,0,.07);
}
.shop-products article div{
  height:160px;
  border-radius:20px;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,159,28,.20), transparent 38%),
    linear-gradient(145deg,#474953,#202127);
  margin-bottom:16px;
  position:relative;
}
.shop-products article div::after{
  content:"";
  position:absolute;
  width:72px;height:72px;
  border-radius:20px;
  background:#dddad0;
  inset:0;margin:auto;
  transform:rotate(-12deg);
}
.shop-products strong{display:block;color:var(--fond-2)}
.shop-products span{color:var(--accent-2);font-weight:850}
.shop-panel{
  padding:30px;
  background:var(--fond-2);
  color:var(--light);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.shop-panel .eyebrow{color:var(--accent)}
.shop-panel h3{font-size:2rem;margin:8px 0}
.shop-panel button{
  border:0;
  margin-top:16px;
  border-radius:999px;
  padding:14px 18px;
  font-weight:950;
  background:var(--accent);
  cursor:pointer;
}
.viewer-shell{
  position:relative;
  height:620px;
  max-width:1180px;
  margin:auto;
  background:#11141a;
}
.viewer-toolbar{
  position:absolute;
  z-index:4;
  top:22px;left:22px;right:22px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.viewer-toolbar span{
  padding:10px 14px;
  border-radius:999px;
  color:var(--light);
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.12);
  font-weight:850;
}
#miniViewerCanvas{
  width:100%;height:100%;display:block;
}
.viewer-info{
  position:absolute;
  left:24px;bottom:24px;
  padding:20px 22px;
  max-width:360px;
  border-radius:22px;
  color:var(--light);
  background:rgba(0,0,0,.34);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.12);
}
.viewer-info strong{font-size:1.4rem}
.viewer-info p{margin:.3rem 0 0;color:rgba(247,244,234,.75)}
.dashboard-shell{
  max-width:1180px;
  min-height:560px;
  margin:auto;
  display:grid;
  grid-template-columns:260px 1fr;
  background:#10141a;
  color:var(--light);
}
.dashboard-shell aside{
  padding:30px;
  border-right:1px solid rgba(255,255,255,.10);
  display:flex;
  flex-direction:column;
  gap:16px;
  background:#1b2028;
}
.dashboard-shell aside strong{
  color:var(--accent);
  font-size:1.45rem;
  margin-bottom:16px;
}
.dashboard-shell aside a{
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  font-weight:850;
}
.dash-main{
  padding:32px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  align-content:start;
}
.dash-card,
.dash-chart{
  border-radius:26px;
  padding:24px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.dash-card span{display:block;color:rgba(247,244,234,.72);font-weight:850}
.dash-card strong{display:block;font-size:2.6rem;margin:12px 0;color:#fff}
.dash-card em{color:var(--accent);font-style:normal;font-weight:850}
.dash-chart{
  grid-column:1/-1;
  height:250px;
  display:flex;
  align-items:end;
  gap:18px;
}
.dash-chart i{
  flex:1;
  border-radius:12px 12px 0 0;
  background:linear-gradient(180deg,var(--accent),rgba(255,159,28,.22));
  min-height:35%;
  animation:dashBars 3.2s ease-in-out infinite;
}
.dash-chart i:nth-child(2){height:68%;animation-delay:.2s}
.dash-chart i:nth-child(3){height:42%;animation-delay:.4s}
.dash-chart i:nth-child(4){height:82%;animation-delay:.6s}
.dash-chart i:nth-child(5){height:56%;animation-delay:.8s}
.dash-chart i:nth-child(6){height:74%;animation-delay:1s}
@keyframes dashBars{50%{filter:brightness(1.25);transform:scaleY(1.06)}}
@media(max-width:980px){
  .shop-layout{grid-template-columns:1fr}
  .shop-layout aside{border-right:0;border-bottom:1px solid var(--line)}
  .shop-products{grid-template-columns:1fr}
  .dashboard-shell{grid-template-columns:1fr}
  .dash-main{grid-template-columns:1fr}
  .viewer-shell{height:480px}
}

/* ──────────────────────────────────────────────
   D3DIA Viewer 3D intégré - V3.4
────────────────────────────────────────────── */
.viewer-full-section{
  width:min(1440px, 92vw);
  margin: 0 auto 110px;
}
.d3-viewer-app{
  position:relative;
  min-height:760px;
  border-radius:32px;
  overflow:hidden;
  background: radial-gradient(circle at 70% 25%, rgba(30,155,255,.18), transparent 32%), linear-gradient(145deg,#080a0d,#121720 55%,#07080b);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 35px 120px rgba(0,0,0,.35);
  display:grid;
  grid-template-columns:300px 1fr;
}
.d3-viewer-panel{
  position:relative;
  z-index:2;
  background:rgba(10,12,16,.96);
  color:#d8d8d8;
  border-right:1px solid rgba(255,255,255,.1);
  overflow-y:auto;
  max-height:760px;
}
.d3-viewer-panel::-webkit-scrollbar{width:6px}.d3-viewer-panel::-webkit-scrollbar-thumb{background:#2d3440;border-radius:999px}
.viewer-panel-head{
  display:flex;
  align-items:center;
  gap:12px;
  padding:18px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.viewer-logo-mini{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:var(--accent,#ff9f1c);
  color:#121212;font-weight:950;
}
.viewer-panel-head strong{display:block;color:#fff;letter-spacing:.05em}.viewer-panel-head span{display:block;font-size:.76rem;color:#8f98a6;margin-top:2px}
.viewer-control-section{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.07)}
.viewer-control-section p{margin:0 0 10px;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:#7d8795;font-weight:900}
.viewer-file-label,.viewer-btn{
  width:100%;display:block;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.055);color:#e9edf2;border-radius:10px;
  padding:10px 12px;margin-bottom:8px;text-align:left;font-weight:800;font-size:.78rem;cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.viewer-file-label{border-style:dashed;text-align:center;color:#ffb347;background:rgba(255,159,28,.1)}
.viewer-file-label:hover,.viewer-btn:hover{transform:translateY(-1px);border-color:rgba(255,159,28,.7);background:rgba(255,159,28,.12);color:#fff}
#viewerFileInput{display:none}.viewer-btn.active{background:rgba(255,159,28,.18);border-color:#ff9f1c;color:#ffb347}.viewer-btn.accent{background:#ff9f1c;color:#161616;border-color:#ff9f1c;text-align:center}
.viewer-btn-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}.viewer-btn-row .viewer-btn{margin:0;text-align:center;padding:9px 8px}.viewer-btn-row:has(.viewer-btn:nth-child(4)){grid-template-columns:repeat(4,1fr)}
.viewer-slider-row{margin:9px 0}.viewer-slider-row label{display:flex;justify-content:space-between;font-size:.74rem;color:#9ea6b2;margin-bottom:5px}.viewer-slider-row span,.viewer-info-box span{color:#ffb347;font-variant-numeric:tabular-nums}
.viewer-slider-row input[type=range]{width:100%;height:4px;appearance:none;background:#252c36;border-radius:999px;outline:none;cursor:pointer}.viewer-slider-row input[type=range]::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:#ff9f1c;box-shadow:0 0 0 4px rgba(255,159,28,.18)}
.viewer-color-row{display:flex;align-items:center;gap:12px;margin:10px 0}.viewer-color-row label{flex:1;color:#9ea6b2;font-size:.78rem}.viewer-color-row input{width:38px;height:26px;padding:0;border:0;background:transparent;cursor:pointer}
.viewer-info-box{font-size:.78rem;color:#9ba4b2;line-height:1.75;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:11px}
.d3-viewer-stage{position:relative;min-height:760px}.d3-viewer-stage canvas{display:block;width:100%;height:100%}.viewer-stage-overlay{position:absolute;right:22px;top:22px;z-index:3;padding:12px 14px;border-radius:16px;background:rgba(7,8,11,.52);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(14px);color:#fff;text-align:right;pointer-events:none}.viewer-stage-overlay span{display:block;color:#8fa7bf;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;font-weight:900}.viewer-stage-overlay strong{display:block;margin-top:4px;font-size:.98rem}.viewer-toast{position:absolute;left:50%;bottom:22px;z-index:9;transform:translateX(-50%);padding:10px 18px;border-radius:999px;background:#ff9f1c;color:#111;font-weight:900;opacity:0;pointer-events:none;transition:opacity .25s ease}.viewer-toast.show{opacity:1}
@media (max-width: 960px){.d3-viewer-app{grid-template-columns:1fr;min-height:auto}.d3-viewer-panel{max-height:none;border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}.d3-viewer-stage{min-height:520px}.viewer-full-section{width:94vw}.viewer-stage-overlay{left:16px;right:16px;text-align:left}}
@media (max-width: 620px){.d3-viewer-stage{min-height:420px}.viewer-btn-row,.viewer-btn-row:has(.viewer-btn:nth-child(4)){grid-template-columns:repeat(2,1fr)}.d3-viewer-app{border-radius:22px}.viewer-full-section{margin-bottom:70px}}


/* ──────────────────────────────────────────────
   D3DIA Viewer 3D - V3.5 responsive / drawer mobile
────────────────────────────────────────────── */
.viewer-mobile-toggle,
.viewer-panel-close,
.viewer-panel-backdrop,
.viewer-drop-hint{
  display:none;
}
.d3-viewer-stage.drag-over{
  outline:2px dashed rgba(30,155,255,.85);
  outline-offset:-14px;
}
.viewer-drop-hint{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  z-index:8;
  padding:18px 24px;
  border-radius:20px;
  background:rgba(30,155,255,.16);
  border:1px solid rgba(30,155,255,.55);
  color:#dff4ff;
  font-weight:950;
  letter-spacing:.05em;
  text-transform:uppercase;
  backdrop-filter:blur(14px);
  pointer-events:none;
}
.d3-viewer-stage.drag-over .viewer-drop-hint{display:block;}
.viewer-btn.accent + .viewer-btn{margin-top:8px;}
@media (max-width: 960px){
  body.viewer-tools-open{overflow:hidden;}
  .viewer-mobile-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    position:absolute;
    left:16px;
    top:16px;
    z-index:15;
    height:44px;
    padding:0 18px;
    border:1px solid rgba(255,255,255,.16);
    border-radius:999px;
    background:rgba(255,159,28,.96);
    color:#141414;
    font-weight:950;
    box-shadow:0 14px 34px rgba(0,0,0,.28);
    cursor:pointer;
  }
  .viewer-panel-close{
    display:grid;
    place-items:center;
    position:absolute;
    right:12px;
    top:12px;
    z-index:4;
    width:38px;
    height:38px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:999px;
    background:rgba(255,255,255,.07);
    color:#fff;
    font-size:1.6rem;
    cursor:pointer;
  }
  .viewer-panel-backdrop{
    position:absolute;
    inset:0;
    z-index:18;
    background:rgba(0,0,0,.56);
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease;
  }
  .d3-viewer-app.panel-open .viewer-panel-backdrop{
    display:block;
    opacity:1;
    pointer-events:auto;
  }
  .d3-viewer-app{
    display:block;
    min-height:calc(100dvh - 110px);
  }
  .d3-viewer-panel{
    position:absolute;
    inset:0 auto 0 0;
    width:min(88vw,360px);
    max-height:none;
    height:100%;
    z-index:20;
    transform:translateX(-105%);
    transition:transform .28s cubic-bezier(.2,.8,.2,1);
    border-right:1px solid rgba(255,255,255,.12);
    border-bottom:0;
    box-shadow:30px 0 70px rgba(0,0,0,.48);
  }
  .d3-viewer-app.panel-open .d3-viewer-panel{transform:translateX(0);}
  .viewer-panel-head{padding-right:58px;}
  .d3-viewer-stage{
    min-height:calc(100dvh - 110px);
    height:calc(100dvh - 110px);
  }
  .viewer-stage-overlay{
    top:auto;
    bottom:16px;
    left:16px;
    right:16px;
    text-align:left;
  }
}
@media (max-width: 620px){
  .viewer-full-section{width:100%;margin-bottom:60px;padding:0 12px;}
  .d3-viewer-app{border-radius:18px;min-height:calc(100dvh - 92px);}
  .d3-viewer-stage{height:calc(100dvh - 92px);min-height:430px;}
  .viewer-stage-overlay{font-size:.86rem;}
  .viewer-mobile-toggle{left:14px;top:14px;height:42px;}
  .viewer-control-section{padding:13px 14px;}
  .viewer-btn,.viewer-file-label{min-height:42px;}
}

.viewer-summary-box{
  padding:18px;
  margin:0 0 18px;
  border-radius:18px;
  background:#10141a;
  color:#f7f4ea;
  border:1px solid rgba(255,159,28,.35);
}
.viewer-summary-box strong{display:block;color:#ff9f1c;margin-bottom:10px;}
.viewer-summary-box pre{white-space:pre-wrap;margin:0;font-family:ui-monospace,Consolas,monospace;font-size:.86rem;line-height:1.55;color:#d8dde5;}

/* D3DIA SQL form states */
.form-alert{max-width:1180px;margin:0 auto 24px;padding:16px 20px;border-radius:16px;font-weight:800;box-shadow:0 14px 35px rgba(0,0,0,.08)}
.form-alert.success{background:#e6f7ec;color:#176b36;border:1px solid rgba(23,107,54,.22)}
.form-alert.error{background:#ffecec;color:#9b1c1c;border:1px solid rgba(155,28,28,.22)}

/* Anti-spam honeypot */
.d3dia-hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;}


/* V3.8.1 FINAL - corrections mobiles accueil + admin */
@media(max-width:820px){
  .hero-v3{
    padding-top:44px;
    padding-bottom:34px;
    gap:28px;
  }
  .hero-scanner .hero-visual{
    margin-bottom:10px;
  }
  .trust-bar{
    margin:24px 5vw 58px;
  }
}
@media(max-width:560px){
  .hero-v3{
    padding-top:34px;
    padding-bottom:42px;
  }
  .hero-scanner .hero-visual,
  .scanner-stage{
    min-height:330px;
    height:330px;
  }
  .trust-bar{
    margin:30px 5vw 54px;
    padding:22px;
  }
}

/* PATCH URGENT - Réalisations : cartes compactes + images cadrées */
.real-gallery{
  padding:20px 5vw 60px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:26px;
  align-items:stretch;
}
.real-gallery .gallery-card{
  padding:0;
  overflow:hidden;
  border-radius:26px;
  background:#fff;
  display:flex;
  flex-direction:column;
  min-height:0;
}
.real-gallery .real-img{
  display:block;
  width:100%;
  aspect-ratio:16/10;
  height:auto;
  max-height:260px;
  overflow:hidden;
  background:#1f2025;
  border-radius:0;
  margin:0;
  cursor:zoom-in;
}
.real-gallery .real-img img{
  display:block;
  width:100%;
  height:100%;
  max-width:100%;
  object-fit:cover;
  object-position:center;
  transition:transform .45s ease, filter .45s ease;
}
.real-gallery .gallery-card:hover .real-img img{
  transform:scale(1.055);
  filter:contrast(1.04) saturate(1.03);
}
.real-gallery .gallery-card span{
  margin:18px 22px 0;
}
.real-gallery .gallery-card h2{
  margin:8px 22px 8px;
  font-size:clamp(1.25rem,2vw,1.75rem);
  line-height:1.05;
  color:var(--fond-2);
}
.real-gallery .gallery-card p{
  margin:0 22px 24px;
  color:var(--muted);
  font-size:.95rem;
}
.d3dia-lightbox{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(12,13,16,.88);
  backdrop-filter:blur(10px);
}
.d3dia-lightbox.open{display:flex;}
.d3dia-lightbox img{
  max-width:min(1200px,94vw);
  max-height:86vh;
  object-fit:contain;
  border-radius:22px;
  box-shadow:0 30px 120px rgba(0,0,0,.55);
  background:#111;
}
.d3dia-lightbox button{
  position:absolute;
  top:18px;
  right:18px;
  width:46px;
  height:46px;
  border:0;
  border-radius:999px;
  background:#ff9f1c;
  color:#171717;
  font-size:26px;
  font-weight:900;
  cursor:pointer;
}
@media(max-width:700px){
  .real-gallery{grid-template-columns:1fr;gap:20px;padding:10px 5vw 45px;}
  .real-gallery .real-img{max-height:220px;}
  .real-gallery .gallery-card h2{font-size:1.25rem;}
  .d3dia-lightbox{padding:12px;}
  .d3dia-lightbox img{max-width:96vw;max-height:80vh;border-radius:16px;}
}


/* =========================================================
   PATCH GLOBAL MOBILE - anti fenêtre vide à droite
   Corrige le scroll horizontal sur l'accueil et les pages D3DIA
   ========================================================= */
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

body{
  position:relative;
}

img,
svg,
canvas,
video{
  max-width:100%;
}

.site-header,
main,
section,
.site-footer{
  max-width:100%;
}

/* Le menu mobile ne doit plus agrandir la page hors écran */
@media(max-width:820px){
  .main-nav{
    right:0 !important;
    transform:translateX(110%);
    width:min(86vw,420px);
    max-width:86vw;
    overflow-x:hidden;
  }

  .main-nav.open{
    right:0 !important;
    transform:translateX(0);
  }

  .site-header{
    width:100%;
    max-width:100%;
  }

  .hero-v3,
  .section,
  .page-hero,
  .lab-hero,
  .demo-page .demo-hero{
    overflow:hidden;
  }

  .hero-actions,
  .cards,
  .solution-row,
  .trust-bar,
  .lab-grid,
  .lab-mini-grid,
  .proof-grid,
  .guide-grid{
    max-width:100%;
  }
}

/* Sécurité mobile supplémentaire pour très petits écrans */
@media(max-width:560px){
  .hero-v3,
  .page-hero,
  .section{
    width:100%;
    max-width:100%;
  }

  .btn{
    max-width:100%;
    white-space:normal;
    text-align:center;
  }
}


/* =========================================================
   D3DIA V4 - Confiance, FAQ, tarifs et LAB industriel
   ========================================================= */
.price-signal{
  padding-top:40px;
}
.price-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-top:28px;
}
.price-grid article{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(71,73,83,.12);
  border-radius:24px;
  padding:26px;
  box-shadow:0 14px 38px rgba(0,0,0,.08);
}
.price-grid span{
  display:block;
  color:#7a766d;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-size:.76rem;
}
.price-grid strong{
  display:block;
  margin:10px 0;
  color:#474953;
  font-size:clamp(1.8rem,3vw,3rem);
  line-height:1;
}
.price-grid p{
  margin:0;
  color:#4e4e4e;
  line-height:1.55;
}
.faq-rich details{
  border-left:5px solid transparent;
}
.faq-rich details[open]{
  border-left-color:#ff9f1c;
}
.founder-block{
  padding-top:40px;
}
.founder-card{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:34px;
  align-items:start;
  background:#fff;
  border-radius:34px;
  padding:38px;
  box-shadow:0 24px 70px rgba(0,0,0,.12);
  border:1px solid rgba(71,73,83,.10);
}
.founder-avatar{
  width:150px;
  height:150px;
  border-radius:34px;
  display:grid;
  place-items:center;
  background:linear-gradient(145deg,#474953,#25262c);
  color:#ffb21a;
  font-size:3rem;
  font-weight:950;
  letter-spacing:-.08em;
  box-shadow:0 18px 50px rgba(0,0,0,.22);
}
.founder-card h2{
  margin:0 0 14px;
  font-size:clamp(2rem,4vw,4rem);
  color:#474953;
}
.founder-card p{
  color:#444;
  line-height:1.75;
  font-size:1.05rem;
}
.trust-section{
  padding-top:40px;
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  margin-top:28px;
}
.trust-card{
  background:rgba(71,73,83,.96);
  color:#f7f4ea;
  border-radius:24px;
  padding:26px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 18px 50px rgba(0,0,0,.14);
}
.trust-card strong{
  display:block;
  color:#ffb21a;
  font-size:1.25rem;
  margin-bottom:10px;
}
.trust-card p{
  color:rgba(247,244,234,.82);
  line-height:1.6;
  margin:0;
}
.industrial-lab-section{
  background:linear-gradient(145deg,#f4f1e8,#dddad0);
}
.industrial-case-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  margin-top:28px;
}
.industrial-case{
  background:#fff;
  border:1px solid rgba(71,73,83,.12);
  border-radius:26px;
  padding:26px;
  box-shadow:0 18px 45px rgba(0,0,0,.08);
  transition:.25s ease;
}
.industrial-case:hover{
  transform:translateY(-6px);
  box-shadow:0 26px 70px rgba(0,0,0,.12);
}
.industrial-case span{
  display:inline-grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:#474953;
  color:#ffb21a;
  font-weight:950;
  margin-bottom:14px;
}
.industrial-case h3{
  color:#474953;
  font-size:1.25rem;
  margin:0 0 14px;
}
.industrial-case p{
  color:#4d4d4d;
  line-height:1.55;
  margin:10px 0;
}
.industrial-case b{
  color:#1f2025;
}

@media(max-width:1100px){
  .price-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .trust-grid,.industrial-case-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:700px){
  .price-grid,.trust-grid,.industrial-case-grid{grid-template-columns:1fr;}
  .founder-card{grid-template-columns:1fr;padding:26px;border-radius:26px;}
  .founder-avatar{width:112px;height:112px;border-radius:26px;font-size:2.2rem;}
  .price-grid article,.industrial-case,.trust-card{padding:22px;}
}


/* =========================================================
   PAGES LÉGALES / RGPD
   ========================================================= */
.legal-page .page-hero{
  padding-bottom:32px;
}
.legal-box{
  line-height:1.72;
}
.legal-box h2{
  margin-top:34px;
  margin-bottom:12px;
  color:var(--fond-2);
}
.legal-box h2:first-child{
  margin-top:0;
}
.legal-box ul{
  padding-left:22px;
}
.legal-box li{
  margin:8px 0;
}
.legal-box a{
  color:var(--accent-2);
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:3px;
}
.legal-table-wrap{
  overflow-x:auto;
  margin:18px 0;
  border-radius:18px;
  border:1px solid var(--line);
}
.legal-table{
  width:100%;
  min-width:620px;
  border-collapse:collapse;
  background:#fff;
}
.legal-table th,
.legal-table td{
  padding:15px 16px;
  text-align:left;
  border-bottom:1px solid var(--line);
}
.legal-table th{
  background:var(--fond-2);
  color:var(--light);
}
.legal-table tr:last-child td{
  border-bottom:0;
}
.legal-update{
  margin-top:34px;
  padding:16px 18px;
  border-radius:18px;
  background:#f8f7f2;
  border:1px solid var(--line);
}
.form-note a{
  color:var(--accent-2);
  font-weight:900;
  text-decoration:underline;
}
@media(max-width:680px){
  .legal-box{
    padding:22px;
    margin:12px 5vw;
  }
  .legal-table{
    min-width:560px;
  }
}

/* =========================================================
   PATCH LAB - Ordre cartes + badges compacts proprement
   ========================================================= */
.lab-grid.lab-grid-showroom{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}
.lab-grid-showroom .lab-card{
  min-height:360px;
}
.lab-grid-showroom .lab-card:nth-child(1),
.lab-grid-showroom .lab-card:nth-child(2){
  grid-column:span 3;
}
.lab-grid-showroom .lab-card:nth-child(3),
.lab-grid-showroom .lab-card:nth-child(4),
.lab-grid-showroom .lab-card:nth-child(5){
  grid-column:span 2;
}
.lab-card-top{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:18px;
  width:100%;
}
.lab-top-inline{
  justify-content:space-between;
}
.lab-top-centered{
  flex-direction:column;
  justify-content:center;
  text-align:center;
  gap:10px;
}
.lab-card .lab-card-top .lab-icon{
  margin:0;
  flex:0 0 58px;
}
.lab-badge{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  gap:6px;
  width:auto;
  max-width:104px;
  min-width:74px;
  height:26px;
  padding:0 10px;
  border-radius:999px;
  font-size:10px !important;
  font-weight:950 !important;
  letter-spacing:.06em !important;
  line-height:1;
  text-transform:uppercase;
  white-space:nowrap;
  flex-shrink:0;
  margin:0 !important;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.07);
  color:var(--light) !important;
}
.lab-badge i{
  display:block;
  width:6px;
  height:6px;
  border-radius:50%;
  flex:0 0 6px;
}
.badge-service{
  color:#58ff95 !important;
  background:rgba(88,255,149,.10);
  border-color:rgba(88,255,149,.20);
}
.badge-service i{background:#58ff95;box-shadow:0 0 10px rgba(88,255,149,.65)}
.badge-demo{
  color:#6bbcff !important;
  background:rgba(107,188,255,.10);
  border-color:rgba(107,188,255,.20);
}
.badge-demo i{background:#6bbcff;box-shadow:0 0 10px rgba(107,188,255,.65)}
.lab-kicker{
  display:block;
  color:var(--accent) !important;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.72rem !important;
  margin-top:2px;
}
.lab-top-centered + .lab-kicker{
  text-align:center;
}
@media(max-width:1050px){
  .lab-grid.lab-grid-showroom{grid-template-columns:repeat(2,minmax(0,1fr));}
  .lab-grid-showroom .lab-card:nth-child(n){grid-column:span 1;}
  .lab-top-centered{align-items:flex-start;text-align:left;flex-direction:row;justify-content:space-between;}
  .lab-top-centered + .lab-kicker{text-align:left;}
}
@media(max-width:680px){
  .lab-grid.lab-grid-showroom{grid-template-columns:1fr;}
  .lab-grid-showroom .lab-card{min-height:auto;padding:24px;}
  .lab-card-top,
  .lab-top-centered{flex-direction:row;justify-content:space-between;text-align:left;align-items:center;}
  .lab-card .lab-card-top .lab-icon{width:52px;height:52px;flex-basis:52px;font-size:1.45rem;}
  .lab-badge{height:24px;font-size:9px !important;min-width:66px;max-width:96px;padding:0 8px;}
}

/* =========================================================
   Carré hero LAB animé - version propre
   ========================================================= */
.lab-hero{
  position:relative;
  isolation:isolate;
}

.lab-hero > *{
  position:relative;
  z-index:2;
}

.lab-hero::after{
  content:"";
  position:absolute;
  top:100px;
  right:auto;
  left:clamp(1000px, 40vw, 500px);
  width:168px;
  height:168px;
  border-radius:38px;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(circle at 26% 32%, rgba(255,255,255,.46) 0 9px, transparent 28px),
    radial-gradient(circle at 68% 62%, rgba(255,159,28,.44) 0 26px, transparent 72px),
    radial-gradient(circle at 42% 78%, rgba(255,215,130,.32) 0 18px, transparent 64px),
    linear-gradient(135deg, rgba(255,159,28,.34), rgba(255,205,120,.12));
  background-size:160% 160%, 180% 180%, 170% 170%, 100% 100%;
  background-position:22% 18%, 78% 62%, 34% 82%, center;
  border:1px solid rgba(255,159,28,.28);
  box-shadow:
    0 22px 70px rgba(255,159,28,.20),
    inset 0 0 28px rgba(255,255,255,.18),
    inset 0 0 55px rgba(255,159,28,.16);
  animation:labLivingSquare 9s ease-in-out infinite;
  will-change:transform, background-position;
}

@keyframes labLivingSquare{
  0%,100%{
    transform:translate3d(0,0,0) rotate(14deg) scale(1);
    background-position:22% 18%,78% 62%,34% 82%,center;
  }
  20%{
    transform:translate3d(-5px,4px,0) rotate(12deg) scale(1.02);
    background-position:68% 24%,40% 68%,60% 42%,center;
  }
  40%{
    transform:translate3d(5px,-6px,0) rotate(17deg) scale(.99);
    background-position:54% 74%,60% 30%,28% 54%,center;
  }
  60%{
    transform:translate3d(8px,3px,0) rotate(13deg) scale(1.03);
    background-position:30% 44%,82% 76%,72% 70%,center;
  }
  80%{
    transform:translate3d(-3px,-5px,0) rotate(15deg) scale(.98);
    background-position:60% 36%,36% 64%,50% 72%,center;
  }
}

@media(max-width:980px){
  .lab-hero::after{
    display:none;
  }
}
