/* ── ViZualCréa Theme CSS v1.0.0 ── */
/* ══════════════════════════════════════════════
   ViZualCréa — style-index.css  v1.0.0
   Page d'accueil
   ══════════════════════════════════════════════ */

/* ── ViZualCréa CSS v1.0.0 ── */
/* ── Police de substitution Syne — réduit le CLS ── */
@font-face {
  font-family: 'Syne Fallback';
  src: local('Arial Black'), local('Impact');
  ascent-override: 94%;
  descent-override: 22%;
  line-gap-override: 0%;
  size-adjust: 108%;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07070e;--bg2:#0e0e1c;--bg3:#141426;--surf:#1a1a2e;
  --b:rgba(255,255,255,.07);--b2:rgba(255,255,255,.13);
  --v:#7c3aed;--vl:#a78bfa;--c:#06b6d4;--cl:#67e8f9;
  --l:#84cc16;--ll:#bef264;--o:#f97316;--ol:#fdba74;
  --r:#f43f5e;--rl:#fda4af;
  --txt:#eeeef6;--txt2:#9898b8;--txt3:#6e6e96;
  --ff:'Outfit',sans-serif;--fd:'Syne','Syne Fallback',sans-serif;
}
html{overflow-x:hidden}
body{font-family:var(--ff);background:var(--bg);color:var(--txt);overflow-x:hidden;line-height:1.6}

/* Grain */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9990;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.023}

/* Gradient text */
.gvc{background:linear-gradient(135deg,var(--v),var(--c));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gv {background:linear-gradient(135deg,var(--v),var(--vl));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gc {background:linear-gradient(135deg,var(--c),var(--cl));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gl {background:linear-gradient(135deg,var(--l),var(--ll));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gor{background:linear-gradient(135deg,var(--o),var(--r));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.eyebrow{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--vl);margin-bottom:14px}

/* Layout */
.container{max-width:1280px;margin:0 auto;padding:0 48px}
.section{padding:100px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.grid-2x2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ─── SCROLL PROGRESS ─── */
.scroll-line{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--v),var(--c),var(--l));z-index:500;width:0%;pointer-events:none}

/* ─── CURSOR ─── */
.cursor{width:10px;height:10px;background:var(--vl);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;mix-blend-mode:screen}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(167,139,250,.4);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9997}

/* ─── PAGE TRANSITION OVERLAY ─── */
.page-veil{position:fixed;inset:0;z-index:9000;pointer-events:none;display:flex;align-items:stretch}
.veil-panel{flex:1;background:var(--bg3);transform:scaleY(0);transform-origin:bottom;pointer-events:none}

/* ─── NAV ─── */
.nav{position:fixed;top:0;left:0;right:0;z-index:400;height:64px;
  display:flex;align-items:center;justify-content:space-between;padding:0 48px;
  background:rgba(7,7,14,.78);backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--b);transform:translateY(-100%)}
.nav .custom-logo {height:53px;display:block;width:auto;top:5px;position:absolute;}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-size:14px;color:var(--txt2);text-decoration:none;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--vl);transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.nav-links a:hover{color:var(--txt)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
/* Dropdown Boutique */
.nav-item-drop{position:relative}
.nav-dropdown{position:absolute;top:100%;left:50%;
  background:var(--bg2);border:1px solid var(--b2);border-radius:14px;padding:20px 12px 12px;
  min-width:220px;display:flex;flex-direction:column;gap:4px;
  opacity:0;pointer-events:none;transform:translateX(-50%) translateY(-4px);
  transition:opacity .22s,transform .22s cubic-bezier(.4,0,.2,1);
  box-shadow:0 20px 60px rgba(0,0,0,.5)}
.nav-item-drop:hover .nav-dropdown{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dropdown::after{content:'';position:absolute;top:-16px;left:0;right:0;height:16px;background:transparent}
.nav-dropdown::before{content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:10px;height:10px;background:var(--bg2);border-left:1px solid var(--b2);border-top:1px solid var(--b2);rotate:45deg;z-index:1}
.nav-dd-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  text-decoration:none;transition:background .2s;cursor:pointer}
.nav-dd-item:hover{background:rgba(255,255,255,.05)}
.nav-dd-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.nav-dd-text{font-size:13px;font-weight:500;color:var(--txt2);transition:color .2s;line-height:1.2}
.nav-dd-sub{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.nav-dd-item:hover .nav-dd-text{color:var(--txt)}

/* Burger */
.burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px;z-index:600;position:relative;background:transparent;border:0;}
.burger span{display:block;height:1.5px;background:var(--txt);border-radius:2px;transition:all .4s cubic-bezier(.4,0,.2,1)}
.burger span:nth-child(1){width:28px}
.burger span:nth-child(2){width:20px}
.burger span:nth-child(3){width:24px}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);width:26px}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);width:26px}

/* ─── FULLSCREEN MENU ─── */
.fullmenu{position:fixed;inset:0;z-index:300;display:flex;pointer-events:none;overflow:hidden}
.fullmenu-bg{position:absolute;inset:0;background:var(--bg2);transform:scaleX(0);transform-origin:right}
.fullmenu-content{position:relative;z-index:1;display:flex;width:100%;align-items:center;justify-content:space-between;padding:100px 80px;opacity:0}
.fullmenu-links{display:flex;flex-direction:column;gap:4px}
.fullmenu-link{font-family:var(--fd);font-size:clamp(44px,6vw,80px);font-weight:800;letter-spacing:-2px;line-height:1.05;color:var(--txt);text-decoration:none;cursor:pointer;transition:color .2s;display:block;overflow:hidden;position:relative}
.fullmenu-link span{display:block}
.fullmenu-link:hover{color:transparent}
.fullmenu-link:hover .line-fill{opacity:1}
.line-fill{position:absolute;inset:0;background:linear-gradient(135deg,var(--v),var(--c));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;transition:opacity .15s}
.fullmenu-img{width:380px;height:460px;border-radius:20px;overflow:hidden;opacity:0;transform:scale(.9);transition:opacity .4s,transform .4s;flex-shrink:0}
.fullmenu-img img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.1)}
.fullmenu-footer{position:absolute;bottom:48px;left:80px;right:80px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--b);padding-top:24px}
.fullmenu-contact a{font-size:13px;color:var(--txt2);text-decoration:none;margin-right:24px;transition:color .2s}
.fullmenu-contact a:hover{color:var(--vl)}
.fullmenu-catalogues{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-left:4px;border-top:1px solid var(--b);padding-top:20px}
.cat-link{display:inline-flex;align-items:center;gap:12px;text-decoration:none;transition:all .25s;width:fit-content}
.cat-badge{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:999px;transition:all .25s;white-space:nowrap}
.cat-objets .cat-badge{background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.4);color:var(--ol)}
.cat-textiles .cat-badge{background:rgba(244,63,94,.15);border:1px solid rgba(244,63,94,.4);color:var(--rl)}
.cat-name{font-family:var(--fd);font-size:clamp(20px,2.4vw,32px);font-weight:700;letter-spacing:-.5px;color:var(--txt2);transition:color .25s}
.cat-arrow{font-size:16px;color:var(--txt3);transition:transform .3s cubic-bezier(.34,1.56,.64,1),color .25s}
.cat-link:hover .cat-name{color:var(--txt)}
.cat-objets:hover .cat-badge{background:rgba(249,115,22,.28);box-shadow:0 0 18px rgba(249,115,22,.25)}
.cat-textiles:hover .cat-badge{background:rgba(244,63,94,.28);box-shadow:0 0 18px rgba(244,63,94,.25)}
.cat-link:hover .cat-arrow{transform:translateX(6px);color:var(--txt2)}
.fullmenu-num{font-family:var(--fd);font-size:11px;color:var(--txt3);letter-spacing:.1em;text-transform:uppercase}

/* ─── HERO ─── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:100px 24px 60px;position:relative;overflow:hidden}
.orb{position:absolute;border-radius:50%;pointer-events:none}
.hero-title{font-family:var(--fd);font-weight:800;line-height:1.0;letter-spacing:-2.5px;
  font-size:clamp(48px,8vw,96px);position:relative;z-index:1;margin-bottom:24px}
.hero-sub{font-size:18px;color:var(--txt2);max-width:520px;line-height:1.75;
  margin-bottom:40px;font-weight:300;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(124,58,237,.1);
  border:1px solid rgba(124,58,237,.25);border-radius:999px;padding:6px 18px;
  font-size:11px;color:var(--vl);margin-bottom:28px;letter-spacing:.07em;
  font-weight:600;text-transform:uppercase;position:relative;z-index:1}
.blink{width:6px;height:6px;border-radius:50%;background:var(--vl);
  box-shadow:0 0 8px var(--v);animation:blink 2s ease-in-out infinite;display:inline-block}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.15}}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;margin-bottom:64px}
.hero-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;width:100%;max-width:1000px;position:relative;z-index:1}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff);font-weight:600;font-size:15px;
  padding:13px 30px;border-radius:999px;border:none;cursor:pointer;text-decoration:none;
  transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(255,255,255,.18),transparent 70%);opacity:0;transition:opacity .3s}
.btn:hover::after{opacity:1}
.btn-p{background:linear-gradient(135deg,var(--v),var(--c));color:#fff;box-shadow:0 0 24px rgba(124,58,237,.25)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 0 48px rgba(124,58,237,.5)}
.btn-g{background:transparent;color:var(--txt2);border:1px solid var(--b2)}
.btn-g:hover{border-color:rgba(124,58,237,.5);color:var(--vl)}
.mag{display:inline-block}

/* ─── TICKER ─── */
.ticker-wrap{overflow:hidden;padding:16px 0;border-top:1px solid var(--b);border-bottom:1px solid var(--b);background:var(--bg2)}
.ticker-track{display:flex;gap:56px;animation:ticker 22s linear infinite;width:max-content}
.ticker-item{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--txt3);white-space:nowrap;display:flex;align-items:center;gap:14px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── PHOTO CARDS ─── */
.photo-card{position:relative;overflow:hidden;border-radius:16px}
.photo-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.photo-card:hover img{transform:scale(1.07)}
.photo-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,14,.9) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:18px;pointer-events:none}
.photo-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}

/* ─── SERVICES ─── */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b);border-radius:20px;overflow:hidden;margin-top:56px}
.svc-card{background:var(--bg2);padding:32px 28px;display:flex;flex-direction:column;gap:14px;
  transition:background .25s;cursor:pointer;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.svc-card::before{content:'';position:absolute;inset:0;z-index:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),var(--gc,rgba(124,58,237,.12)),transparent 55%);
  opacity:0;transition:opacity .4s;pointer-events:none}
.svc-card:hover{background:var(--bg3)}
.svc-card:hover::before{opacity:1}
.svc-card>*{position:relative;z-index:1}
.icon-box{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s}
.svc-card:hover .icon-box{transform:scale(1.15) rotate(-6deg)}
.svc-name{font-family:var(--fd);font-size:17px;font-weight:700}
.svc-desc{font-size:13px;color:var(--txt2);line-height:1.65;font-weight:300;flex:1}
.svc-tag{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}

/* ─── MASONRY GALLERY ─── */
.gallery-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.gf-btn{padding:8px 20px;border-radius:999px;border:1px solid var(--b2);background:transparent;
  font-size:13px;color:var(--txt2);cursor:pointer;font-family:var(--ff);transition:all .25s}
.gf-btn:hover{border-color:rgba(124,58,237,.45);color:var(--vl)}
.gf-btn.active{background:linear-gradient(135deg,var(--v),var(--c));color:#fff;border-color:transparent;box-shadow:0 0 20px rgba(124,58,237,.3)}

.masonry{columns:3;gap:14px;column-gap:14px}
.masonry-item{break-inside:avoid;margin-bottom:14px;border-radius:14px;overflow:hidden;
  cursor:pointer;position:relative;border:1px solid var(--b);transition:border-color .25s}
.masonry-item:hover{border-color:rgba(124,58,237,.3)}
.masonry-item img{width:100%;display:block;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.masonry-item:hover img{transform:scale(1.05)}
.masonry-item .mi-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,14,.9),transparent 45%);
  opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:16px}
.masonry-item:hover .mi-overlay{opacity:1}
.mi-cat{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.mi-title{font-size:13px;color:var(--txt);font-weight:500}
/* hidden items */
.masonry-item.hidden{display:none}

/* ─── SWIPER ─── */
.swiper-pagination-bullet{background:rgba(255,255,255,.25)!important;width:6px!important;height:6px!important}
.swiper-pagination-bullet-active{background:var(--v)!important;width:22px!important;border-radius:99px!important}
.swiper-button-next,.swiper-button-prev{width:44px!important;height:44px!important;background:rgba(255,255,255,.06);
  border:1px solid var(--b2);border-radius:50%!important;backdrop-filter:blur(8px);transition:all .2s}
.swiper-button-next::after,.swiper-button-prev::after{font-size:14px!important;color:var(--vl)}
.swiper-button-next:hover,.swiper-button-prev:hover{background:rgba(124,58,237,.22);border-color:rgba(124,58,237,.5)}

/* ─── STATS ─── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--b);border-radius:18px;overflow:hidden;border:1px solid var(--b)}
.stat-box{background:var(--surf);padding:32px}
.stat-num{font-family:var(--fd);font-size:44px;font-weight:800;letter-spacing:-1.5px;line-height:1;margin-bottom:6px}
.stat-lbl{font-size:13px;color:var(--txt3);font-weight:300}

/* ─── TEAM ─── */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}
.team-card{background:var(--bg2);border:1px solid var(--b);border-radius:18px;padding:28px;
  display:flex;flex-direction:column;gap:12px;transition:border-color .25s,transform .3s cubic-bezier(.4,0,.2,1)}
.team-card:hover{border-color:rgba(124,58,237,.3)}
.avatar-wrap{position:relative}
.avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-weight:800;font-size:17px;color:var(--bg);position:relative;z-index:1}
.avatar-ring{position:absolute;inset:-3px;border-radius:50%;z-index:0}
.t-name{font-family:var(--fd);font-size:16px;font-weight:700}
.t-role{font-size:12px;font-weight:500;margin-top:2px}
.t-contact{display:flex;flex-direction:column;gap:6px;padding-top:14px;border-top:1px solid var(--b)}
.t-contact a{font-size:13px;color:var(--txt2);text-decoration:none;transition:color .2s}

/* ─── FORM ─── */
.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form{display:flex;flex-direction:column;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;color:var(--txt2);font-weight:500}
.field input,.field textarea,.field select{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:12px 16px;font-size:14px;font-family:var(--ff);color:var(--txt);
  outline:none;transition:border-color .2s,box-shadow .2s;width:100%}
.field input:focus,.field textarea:focus{border-color:rgba(124,58,237,.6);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.field input::placeholder,.field textarea::placeholder{color:var(--txt3)}
.field textarea{resize:vertical;min-height:110px}
.field select{cursor:pointer;color:var(--txt2)}

/* ─── MISC ─── */
.pill{padding:6px 16px;border-radius:999px;border:1px solid var(--b2);background:rgba(255,255,255,.03);font-size:13px;color:var(--txt2);display:inline-block}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--b2),transparent);margin:0 48px}
.address-box{background:rgba(255,255,255,.025);border:1px solid var(--b);border-radius:14px;padding:24px;
  display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--txt2);line-height:1.8}
.address-box a{color:var(--vl);text-decoration:none;transition:color .2s}
.address-box a:hover{color:var(--txt)}
.bg2{background:var(--bg2)}
.bt{border-top:1px solid var(--b)}
.bb{border-bottom:1px solid var(--b)}


/* ── H2 BULGE + RGB SHIFT ── */
.h2-wrap{position:relative;display:inline-block;width:100%;cursor:default}
.h2-wrap h2{position:relative;z-index:1}
.h2-canvas{
  position:absolute;
  top:0;left:0;
  pointer-events:none;
  z-index:2;
  opacity:0;
  will-change:transform;
}

/* ── H2 BULGE + RGB SHIFT : CSS clone layers ── */
.h2-wrap { position:relative; display:block; width:100%; cursor:default; }
.h2-wrap > h2 { position:relative; z-index:2; }

/* The 3 RGB ghost layers sit behind, invisible by default */
.h2-r, .h2-g, .h2-b {
  position:absolute;
  top:0; left:0; right:0;
  z-index:1;
  pointer-events:none;
  font-family:var(--fd);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-1.5px;
  opacity:0;
  will-change:transform, opacity;
  /* Isolate channel via CSS filter */
}
.h2-r { color:#ff0055; mix-blend-mode:screen; filter:blur(0.3px); }
.h2-g { color:#00ffcc; mix-blend-mode:screen; filter:blur(0.3px); }
.h2-b { color:#4488ff; mix-blend-mode:screen; filter:blur(0.3px); }

/* ─── RESPONSIVE ─── */

/* ── H2 BULGE + RGB SHIFT : CSS clone layers ── */
.h2-wrap { position:relative; display:block; width:100%; cursor:default; }
.h2-wrap > h2 { position:relative; z-index:2; }

/* The 3 RGB ghost layers sit behind, invisible by default */

/* ─── RESPONSIVE ─── */


/* ─── CHECKBOX RGPD ─── */
.field-check{display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.field-check input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;min-width:18px;border-radius:5px;
  border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);
  cursor:pointer;transition:all .2s;margin-top:1px;position:relative;
}
.field-check input[type=checkbox]:checked{
  background:linear-gradient(135deg,var(--v),var(--c));border-color:transparent;
  box-shadow:0 0 12px rgba(124,58,237,.35);
}
.field-check input[type=checkbox]:checked::after{
  content:'';position:absolute;left:5px;top:2px;
  width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;
  transform:rotate(45deg);
}
.field-check input[type=checkbox]:focus{box-shadow:0 0 0 3px rgba(124,58,237,.2)}
.field-check-label{font-size:12px;color:var(--txt2);line-height:1.6}
.field-check-label a{color:var(--vl);text-decoration:none}
.field-check-label a:hover{text-decoration:underline}

/* ─── RÉGLEMENTATION ─── */
.rgl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rgl-card{background:var(--bg2);border:1px solid var(--b);border-radius:18px;padding:28px 24px;
  display:flex;flex-direction:column;gap:10px;text-decoration:none;
  transition:border-color .25s,transform .3s cubic-bezier(.4,0,.2,1),background .25s}
.rgl-card:hover{border-color:rgba(124,58,237,.3);background:var(--bg3);transform:translateY(-4px)}
.rgl-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.rgl-tag{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.rgl-title{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--txt);line-height:1.2}
.rgl-desc{font-size:13px;color:var(--txt2);line-height:1.6;font-weight:300;flex:1}
.rgl-dl{font-size:12px;font-weight:600;color:var(--txt3);letter-spacing:.05em;margin-top:4px;transition:color .2s}
.rgl-card:hover .rgl-dl{color:var(--vl)}


/* Tablet large — 1280px */
@media(max-width:1280px){
  .container{padding:0 36px}
  .fullmenu-content{padding:90px 60px}
  .fullmenu-footer{left:60px;right:60px}
}

/* Tablet — 1100px */
@media(max-width:1100px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .hero-strip{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr;gap:48px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
  .fullmenu-link{font-size:clamp(36px,5vw,60px)}
  .fullmenu-img{width:300px;height:380px}
  .rgl-grid{grid-template-columns:repeat(2,1fr)}
}

/* Mobile large — 768px */
@media(max-width:768px){
  /* Layout */
  .container{padding:0 20px}
  .section{padding:64px 0}
  .grid-2{grid-template-columns:1fr;gap:36px}
  .grid-2x2{grid-template-columns:1fr 1fr}
  .divider{margin:0 20px}
  .form-grid2{grid-template-columns:1fr}

  /* Nav */
  .nav{padding:0 20px;height:56px}
  .nav-links{display:none}
  .nav-dropdown{display:none}

  /* Hero */
  .hero{padding:80px 20px 48px}
  .hero-strip{grid-template-columns:1fr 1fr;gap:8px}
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px}
  .hero-cta .btn{justify-content:center}

  /* Services */
  .svc-grid{grid-template-columns:1fr 1fr;gap:1px}

  /* Masonry */
  .masonry{columns:2;gap:10px;column-gap:10px}
  .masonry-item{margin-bottom:10px}

  /* Gallery filters */
  .gallery-filters{gap:6px}
  .gf-btn{padding:6px 14px;font-size:12px}

  /* Stats */
  .stat-grid{grid-template-columns:1fr 1fr}
  .stat-num{font-size:36px}

  /* Team */
  .team-grid{grid-template-columns:1fr}

  /* Fullmenu */
  .fullmenu-content{flex-direction:column;padding:80px 24px 140px;gap:32px;overflow-y:auto}
  .fullmenu-links{gap:2px}
  .fullmenu-link{font-size:clamp(32px,8vw,52px);letter-spacing:-1px}
  .fullmenu-img{display:none}
  .fullmenu-footer{left:20px;right:20px;bottom:28px;flex-direction:column;align-items:flex-start;gap:10px}
  .fullmenu-catalogues{margin-top:12px;padding-top:14px;gap:8px}
  .cat-name{font-size:clamp(16px,4vw,22px)}
  .cat-badge{font-size:9px;padding:4px 10px}

  /* Boutique */
  .grid-2x2{gap:8px}
}

/* Mobile small — 480px */
@media(max-width:480px){
  .svc-grid{grid-template-columns:1fr}
  .hero-strip{grid-template-columns:1fr 1fr}
  .masonry{columns:1}
  .team-grid{grid-template-columns:1fr}
  .hero-title{letter-spacing:-1.5px}
  .stat-box{padding:20px}
  .stat-num{font-size:32px}
  .fullmenu-link{font-size:clamp(28px,9vw,44px)}
  .cat-name{font-size:18px}
  .rgl-grid{grid-template-columns:1fr}
  .fullmenu-content{padding:76px 20px 130px}
}

/* Très petit — 360px */
@media(max-width:360px){
  .container{padding:0 16px}
  .nav{padding:0 16px}
  .fullmenu-content{padding:72px 16px 120px}
  .fullmenu-link{font-size:28px}
  .hero-strip{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
}

/* Cursor masqué sur touch */
@media(pointer:coarse){
  .cursor,.cursor-ring{display:none!important}
  .mag-inner{transform:none!important}
}/* ══════════════════════════════════════════════
   ViZualCréa — style-services.css  v1.0.0
   Pages service, services, portfolio
   ══════════════════════════════════════════════ */

/* ── ViZualCréa CSS v1.0.0 ── */
/* ── Police de substitution Syne — réduit le CLS ── */
@font-face {
  font-family: 'Syne Fallback';
  src: local('Arial Black'), local('Impact');
  ascent-override: 94%;
  descent-override: 22%;
  line-gap-override: 0%;
  size-adjust: 108%;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07070e;--bg2:#0e0e1c;--bg3:#141426;--surf:#1a1a2e;
  --b:rgba(255,255,255,.07);--b2:rgba(255,255,255,.13);
  --v:#7c3aed;--vl:#a78bfa;--c:#06b6d4;--cl:#67e8f9;
  --l:#84cc16;--ll:#bef264;--o:#f97316;--ol:#fdba74;
  --r:#f43f5e;--rl:#fda4af;
  --txt:#eeeef6;--txt2:#9898b8;--txt3:#6e6e96;
  --ff:'Outfit',sans-serif;--fd:'Syne','Syne Fallback',sans-serif;
}
html{overflow-x:hidden}
body{font-family:var(--ff);background:var(--bg);color:var(--txt);overflow-x:hidden;line-height:1.6}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9990;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.023}
.gvc{background:linear-gradient(135deg,var(--v),var(--c));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gv{background:linear-gradient(135deg,var(--v),var(--vl));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gc{background:linear-gradient(135deg,var(--c),var(--cl));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gl{background:linear-gradient(135deg,var(--l),var(--ll));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gor{background:linear-gradient(135deg,var(--o),var(--r));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.eyebrow{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--vl);margin-bottom:14px}
.container{max-width:1280px;margin:0 auto;padding:0 48px}
.section{padding:100px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.scroll-line{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--v),var(--c),var(--l));z-index:500;width:0%;pointer-events:none}
.cursor{width:10px;height:10px;background:var(--vl);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;mix-blend-mode:screen}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(167,139,250,.4);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9997}
.page-veil{position:fixed;inset:0;z-index:9000;pointer-events:none;display:flex;align-items:stretch;will-change:transform}
.veil-panel{flex:1;background:var(--bg3);transform:scaleY(1);transform-origin:bottom;will-change:transform;pointer-events:none}

/* ─── NAV ─── */
.nav{position:fixed;top:0;left:0;right:0;z-index:400;height:64px;
  display:flex;align-items:center;justify-content:space-between;padding:0 48px;
  background:rgba(7,7,14,.78);backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--b);transform:translateY(-100%)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-size:14px;color:var(--txt2);text-decoration:none;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--vl);transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.nav-links a:hover,.nav-links a.active{color:var(--txt)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-item-drop{position:relative}
.nav-dropdown{position:absolute;top:100%;left:50%;
  background:var(--bg2);border:1px solid var(--b2);border-radius:14px;
  padding:20px 12px 12px;
  min-width:220px;display:flex;flex-direction:column;gap:4px;
  opacity:0;pointer-events:none;transform:translateX(-50%) translateY(-4px);
  transition:opacity .22s,transform .22s cubic-bezier(.4,0,.2,1);
  box-shadow:0 20px 60px rgba(0,0,0,.5)}
/* Pont invisible — comble le gap entre le lien et le dropdown */
.nav-dropdown::after{content:'';position:absolute;top:-16px;left:0;right:0;height:16px;background:transparent}
.nav-item-drop:hover .nav-dropdown{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
/* Petite flèche décorative */
.nav-dropdown::before{content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:10px;height:10px;background:var(--bg2);border-left:1px solid var(--b2);border-top:1px solid var(--b2);rotate:45deg;z-index:1}
.nav-dd-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;text-decoration:none;transition:background .2s}
.nav-dd-item:hover{background:rgba(255,255,255,.05)}
.nav-dd-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.nav-dd-text{font-size:13px;font-weight:500;color:var(--txt2);transition:color .2s;line-height:1.2}
.nav-dd-sub{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.nav-dd-item:hover .nav-dd-text{color:var(--txt)}
.burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px;z-index:600;position:relative}
.burger span{display:block;height:1.5px;background:var(--txt);border-radius:2px;transition:all .4s cubic-bezier(.4,0,.2,1)}
.burger span:nth-child(1){width:28px}
.burger span:nth-child(2){width:20px}
.burger span:nth-child(3){width:24px}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);width:26px}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);width:26px}

/* ─── FULLSCREEN MENU ─── */
.fullmenu{position:fixed;inset:0;z-index:300;display:flex;pointer-events:none;overflow:hidden}
.fullmenu-bg{position:absolute;inset:0;background:var(--bg2);transform:scaleX(0);transform-origin:right}
.fullmenu-content{position:relative;z-index:1;display:flex;width:100%;align-items:center;justify-content:space-between;padding:100px 80px;opacity:0}
.fullmenu-links{display:flex;flex-direction:column;gap:4px}
.fullmenu-link{font-family:var(--fd);font-size:clamp(44px,6vw,80px);font-weight:800;letter-spacing:-2px;line-height:1.05;color:var(--txt);text-decoration:none;cursor:pointer;transition:color .2s;display:block;overflow:hidden;position:relative}
.fullmenu-link span{display:block}
.fullmenu-link:hover{color:transparent}
.fullmenu-link:hover .line-fill{opacity:1}
.line-fill{position:absolute;inset:0;background:linear-gradient(135deg,var(--v),var(--c));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;transition:opacity .15s}
.fullmenu-img{width:380px;height:460px;border-radius:20px;overflow:hidden;opacity:0;transform:scale(.9);transition:opacity .4s,transform .4s;flex-shrink:0}
.fullmenu-img img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.1)}
.fullmenu-footer{position:absolute;bottom:48px;left:80px;right:80px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--b);padding-top:24px}
.fullmenu-contact a{font-size:13px;color:var(--txt2);text-decoration:none;margin-right:24px;transition:color .2s}
.fullmenu-contact a:hover{color:var(--vl)}
.fullmenu-catalogues{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-left:4px;border-top:1px solid var(--b);padding-top:20px}
.cat-link{display:inline-flex;align-items:center;gap:12px;text-decoration:none;transition:all .25s;width:fit-content}
.cat-badge{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:999px;transition:all .25s;white-space:nowrap}
.cat-objets .cat-badge{background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.4);color:var(--ol)}
.cat-textiles .cat-badge{background:rgba(244,63,94,.15);border:1px solid rgba(244,63,94,.4);color:var(--rl)}
.cat-name{font-family:var(--fd);font-size:clamp(20px,2.4vw,32px);font-weight:700;letter-spacing:-.5px;color:var(--txt2);transition:color .25s}
.cat-arrow{font-size:16px;color:var(--txt3);transition:transform .3s cubic-bezier(.34,1.56,.64,1),color .25s}
.cat-link:hover .cat-name{color:var(--txt)}
.cat-objets:hover .cat-badge{background:rgba(249,115,22,.28);box-shadow:0 0 18px rgba(249,115,22,.25)}
.cat-textiles:hover .cat-badge{background:rgba(244,63,94,.28);box-shadow:0 0 18px rgba(244,63,94,.25)}
.cat-link:hover .cat-arrow{transform:translateX(6px);color:var(--txt2)}
.fullmenu-num{font-family:var(--fd);font-size:11px;color:var(--txt3);letter-spacing:.1em;text-transform:uppercase}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff);font-weight:600;font-size:15px;
  padding:13px 30px;border-radius:999px;border:none;cursor:pointer;text-decoration:none;
  transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(255,255,255,.18),transparent 70%);opacity:0;transition:opacity .3s}
.btn:hover::after{opacity:1}
.btn-p{background:linear-gradient(135deg,var(--v),var(--c));color:#fff;box-shadow:0 0 24px rgba(124,58,237,.25)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 0 48px rgba(124,58,237,.5)}
.btn-g{background:transparent;color:var(--txt2);border:1px solid var(--b2)}
.btn-g:hover{border-color:rgba(124,58,237,.5);color:var(--vl)}
.mag{display:inline-block}

/* ─── MISC ─── */
.pill{padding:6px 16px;border-radius:999px;border:1px solid var(--b2);background:rgba(255,255,255,.03);font-size:13px;color:var(--txt2);display:inline-block}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--b2),transparent);margin:0 48px}
.bg2{background:var(--bg2)}
.bt{border-top:1px solid var(--b)}
.bb{border-bottom:1px solid var(--b)}

/* ─── PAGE HERO (pages secondaires) ─── */
.page-hero{padding:140px 0 80px;position:relative;overflow:hidden;border-bottom:1px solid var(--b)}
.page-hero-bg{position:absolute;inset:0;pointer-events:none}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt3);margin-bottom:20px}
.breadcrumb a{color:var(--txt3);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--vl)}
.breadcrumb span{color:var(--txt3)}
.page-title{font-family:var(--fd);font-weight:800;font-size:clamp(48px,7vw,88px);letter-spacing:-2.5px;line-height:1.0;margin-bottom:20px}
.page-sub{font-size:18px;color:var(--txt2);max-width:580px;line-height:1.75;font-weight:300}

/* ─── INNER MASONRY ─── */
.masonry{columns:3;gap:14px;column-gap:14px}
.masonry-item{break-inside:avoid;margin-bottom:14px;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;border:1px solid var(--b);transition:border-color .25s}
.masonry-item:hover{border-color:rgba(124,58,237,.3)}
.masonry-item img{width:100%;display:block;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.masonry-item:hover img{transform:scale(1.05)}
.masonry-item .mi-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,14,.9),transparent 45%);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:16px}
.masonry-item:hover .mi-overlay{opacity:1}
.mi-cat{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.mi-title{font-size:13px;color:var(--txt);font-weight:500}
.masonry-item.hidden{display:none}
.gallery-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.gf-btn{padding:8px 20px;border-radius:999px;border:1px solid var(--b2);background:transparent;font-size:13px;color:var(--txt2);cursor:pointer;font-family:var(--ff);transition:all .25s}
.gf-btn:hover{border-color:rgba(124,58,237,.45);color:var(--vl)}
.gf-btn.active{background:linear-gradient(135deg,var(--v),var(--c));color:#fff;border-color:transparent;box-shadow:0 0 20px rgba(124,58,237,.3)}

/* ─── SERVICE PAGE ─── */
.svc-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.svc-feature-list{display:flex;flex-direction:column;gap:16px;margin-top:32px}
.svc-feature{display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--bg2);border:1px solid var(--b);border-radius:14px;transition:border-color .25s}
.svc-feature:hover{border-color:rgba(124,58,237,.3)}
.svc-feature-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-feature-text h4{font-family:var(--fd);font-size:15px;font-weight:700;margin-bottom:4px}
.svc-feature-text p{font-size:13px;color:var(--txt2);line-height:1.65;font-weight:300}
.svc-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:32px}
.svc-gallery-item{border-radius:14px;overflow:hidden;position:relative;border:1px solid var(--b)}
.svc-gallery-item img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.svc-gallery-item:hover img{transform:scale(1.06)}
.other-services{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b);border-radius:20px;overflow:hidden;margin-top:48px}
.other-svc-card{background:var(--bg2);padding:28px 24px;display:flex;flex-direction:column;gap:12px;text-decoration:none;transition:background .25s;position:relative;overflow:hidden}
.other-svc-card::before{content:'';position:absolute;inset:0;z-index:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),var(--gc,rgba(124,58,237,.12)),transparent 55%);opacity:0;transition:opacity .4s;pointer-events:none}
.other-svc-card:hover{background:var(--bg3)}
.other-svc-card:hover::before{opacity:1}
.other-svc-card>*{position:relative;z-index:1}
.other-svc-card .icon-box{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.other-svc-card:hover .icon-box{transform:scale(1.15) rotate(-6deg)}
.other-svc-card .svc-name{font-family:var(--fd);font-size:15px;font-weight:700;color:var(--txt)}
.other-svc-card .svc-tag{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}

/* ─── FORM ─── */
.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form{display:flex;flex-direction:column;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;color:var(--txt2);font-weight:500}
.field input,.field textarea,.field select{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px 16px;font-size:14px;font-family:var(--ff);color:var(--txt);outline:none;transition:border-color .2s,box-shadow .2s;width:100%}
.field input:focus,.field textarea:focus{border-color:rgba(124,58,237,.6);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.field input::placeholder,.field textarea::placeholder{color:var(--txt3)}
.field textarea{resize:vertical;min-height:110px}
.field select{cursor:pointer;color:var(--txt2)}
.address-box{background:rgba(255,255,255,.025);border:1px solid var(--b);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--txt2);line-height:1.8}
.address-box a{color:var(--vl);text-decoration:none;transition:color .2s}
.address-box a:hover{color:var(--txt)}

/* ─── REVEAL ─── */
.reveal-up{opacity:0;transform:translateY(40px)}
.reveal-left{opacity:0;transform:translateX(-50px)}
.reveal-right{opacity:0;transform:translateX(50px)}
.reveal-card{opacity:0;transform:translateY(50px) scale(.95)}


/* ─── CHECKBOX RGPD ─── */
.field-check{display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.field-check input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;min-width:18px;border-radius:5px;
  border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);
  cursor:pointer;transition:all .2s;margin-top:1px;position:relative;
}
.field-check input[type=checkbox]:checked{
  background:linear-gradient(135deg,var(--v),var(--c));border-color:transparent;
  box-shadow:0 0 12px rgba(124,58,237,.35);
}
.field-check input[type=checkbox]:checked::after{
  content:'';position:absolute;left:5px;top:2px;
  width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;
  transform:rotate(45deg);
}
.field-check input[type=checkbox]:focus{box-shadow:0 0 0 3px rgba(124,58,237,.2)}
.field-check-label{font-size:12px;color:var(--txt2);line-height:1.6}
.field-check-label a{color:var(--vl);text-decoration:none}
.field-check-label a:hover{text-decoration:underline}

/* ─── RÉGLEMENTATION ─── */
.rgl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rgl-card{background:var(--bg2);border:1px solid var(--b);border-radius:18px;padding:28px 24px;
  display:flex;flex-direction:column;gap:10px;text-decoration:none;
  transition:border-color .25s,transform .3s cubic-bezier(.4,0,.2,1),background .25s}
.rgl-card:hover{border-color:rgba(124,58,237,.3);background:var(--bg3);transform:translateY(-4px)}
.rgl-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.rgl-tag{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.rgl-title{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--txt);line-height:1.2}
.rgl-desc{font-size:13px;color:var(--txt2);line-height:1.6;font-weight:300;flex:1}
.rgl-dl{font-size:12px;font-weight:600;color:var(--txt3);letter-spacing:.05em;margin-top:4px;transition:color .2s}
.rgl-card:hover .rgl-dl{color:var(--vl)}

/* ─── RESPONSIVE ─── */
@media(max-width:1280px){.container{padding:0 36px}}
@media(max-width:1100px){
  .svc-detail-grid{grid-template-columns:1fr;gap:40px}
  .grid-2{grid-template-columns:1fr;gap:48px}
  .other-services{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
  .svc-gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .container{padding:0 20px}
  .section{padding:64px 0}
  .nav{padding:0 20px;height:56px}
  .nav-links{display:none}
  .fullmenu-content{flex-direction:column;padding:80px 24px 140px;gap:32px;overflow-y:auto}
  .fullmenu-link{font-size:clamp(32px,8vw,52px);letter-spacing:-1px}
  .fullmenu-img{display:none}
  .fullmenu-footer{left:20px;right:20px;bottom:28px;flex-direction:column;align-items:flex-start;gap:10px}
  .fullmenu-catalogues{margin-top:12px;padding-top:14px;gap:8px}
  .cat-name{font-size:clamp(16px,4vw,22px)}
  .cat-badge{font-size:9px;padding:4px 10px}
  .other-services{grid-template-columns:1fr 1fr}
  .svc-gallery{grid-template-columns:1fr}
  .masonry{columns:1}
  .form-grid2{grid-template-columns:1fr}
  .page-title{font-size:clamp(36px,8vw,56px)}
  .page-sub{font-size:15px}
  .divider{margin:0 20px}
}
@media(max-width:480px){
  .other-services{grid-template-columns:1fr}
}
@media(pointer:coarse){.cursor,.cursor-ring{display:none!important}}

/* ── Lecteur YouTube lazy ── */
.yt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:40px}
@media(max-width:640px){.yt-grid{grid-template-columns:1fr}}
.yt-card{position:relative;border-radius:14px;overflow:hidden;background:var(--bg2);border:1px solid var(--b);cursor:pointer;aspect-ratio:16/9}
.yt-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.4,0,.2,1)}
.yt-card:hover .yt-thumb{transform:scale(1.04)}
.yt-overlay{position:absolute;inset:0;background:rgba(7,7,14,.45);display:flex;align-items:center;justify-content:center;transition:background .25s}
.yt-card:hover .yt-overlay{background:rgba(7,7,14,.2)}
.yt-play{width:56px;height:56px;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;flex-shrink:0}
.yt-card:hover .yt-play{transform:scale(1.12);box-shadow:0 0 32px rgba(132,204,22,.4)}
.yt-title{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(to top,rgba(7,7,14,.85),transparent);font-size:13px;font-weight:500;color:#fff;line-height:1.3}
.yt-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
