
:root{
  --blue:#006da8;
  --blue-dark:#003b62;
  --blue-soft:#eaf7fd;
  --sky:#00a6d6;
  --orange:#f26522;
  --orange-light:#ff8b3c;
  --ink:#061626;
  --muted:#65778b;
  --line:rgba(0,109,168,.16);
  --white:#fff;
  --shadow:0 30px 95px rgba(0,61,100,.16);
  --shadow-strong:0 38px 120px rgba(0,45,78,.22);
  --orange-shadow:0 20px 60px rgba(242,101,34,.28);
  --radius:30px;
  --ease:cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 8% 12%, rgba(0,166,214,.10), transparent 30%),
    radial-gradient(circle at 92% 5%, rgba(242,101,34,.12), transparent 28%),
    linear-gradient(180deg,#ffffff 0%,#edf9ff 44%,#ffffff 100%);
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img,video{display:block;max-width:100%}
.container{width:min(1240px, calc(100% - 44px));margin-inline:auto}
.bg-aurora{position:fixed;inset:0;z-index:-5;overflow:hidden;pointer-events:none}
.bg-aurora span{position:absolute;border-radius:999px;filter:blur(68px);opacity:.22;animation:float 15s var(--ease) infinite alternate}
.bg-aurora span:nth-child(1){width:430px;height:430px;background:var(--sky);left:-160px;top:120px}
.bg-aurora span:nth-child(2){width:380px;height:380px;background:var(--orange);right:-140px;top:20px;animation-delay:1s}
.bg-aurora span:nth-child(3){width:560px;height:560px;background:var(--blue);left:36%;bottom:-360px;animation-delay:.4s}
@keyframes float{to{transform:translate3d(30px,-26px,0) scale(1.08)}}
.scroll-progress{position:fixed;top:0;left:0;width:0;height:3px;z-index:1000;background:linear-gradient(90deg,var(--blue),var(--orange));box-shadow:0 0 24px rgba(0,109,168,.35)}

.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:blur(22px);border-bottom:1px solid var(--line)}
.header-inner{height:88px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand img{height:62px;width:auto;object-fit:contain;filter:drop-shadow(0 12px 25px rgba(0,50,85,.12))}
.desktop-nav{display:flex;align-items:center;gap:6px}
.desktop-nav a,.mobile-nav a{font-weight:850;color:#17374e;padding:12px 14px;border-radius:15px;transition:.22s var(--ease)}
.desktop-nav a:hover,.desktop-nav a.active,.mobile-nav a:hover,.mobile-nav a.active{background:rgba(0,109,168,.08);color:var(--blue)}
.header-actions{display:flex;align-items:center;gap:12px}
.header-phone{display:inline-flex;border:1px solid var(--line);background:#fff;color:var(--blue-dark);border-radius:999px;padding:12px 16px;font-weight:900;box-shadow:0 14px 34px rgba(0,61,100,.08)}
.menu-button{display:none;border:0;background:var(--blue-dark);border-radius:16px;padding:12px;box-shadow:var(--shadow);cursor:pointer}
.menu-button span{display:block;width:24px;height:2px;background:#fff;border-radius:99px;margin:5px}
.mobile-nav{display:none}

.eyebrow{display:inline-flex;align-items:center;gap:9px;border-radius:999px;padding:10px 14px;background:rgba(255,255,255,.88);color:var(--orange);border:1px solid rgba(255,255,255,.55);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.13em;box-shadow:0 16px 36px rgba(0,0,0,.08)}

.hero{position:relative;min-height:calc(100vh - 88px);display:grid;place-items:center;overflow:hidden;background:#052b46}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62;filter:saturate(1.1) contrast(1.04)}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 82% 18%,rgba(242,101,34,.36),transparent 26%),linear-gradient(90deg,rgba(2,27,47,.96),rgba(0,72,118,.72),rgba(0,0,0,.28))}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .74fr;gap:54px;align-items:center;padding:78px 0}
.hero h1{font-size:clamp(48px,7.2vw,96px);line-height:.95;letter-spacing:-.075em;color:#fff;margin:24px 0 20px;text-shadow:0 24px 90px rgba(0,0,0,.34)}
.hero h1 span{color:#ffe4d3}
.hero p{font-size:20px;line-height:1.68;color:rgba(255,255,255,.88);max-width:680px;margin:0}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0 36px}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:18px;padding:15px 23px;font-weight:950;transition:.25s var(--ease);cursor:pointer}
.btn:hover{transform:translateY(-4px)}
.btn.primary{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:#fff;box-shadow:var(--orange-shadow)}
.btn.ghost{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);color:#fff;backdrop-filter:blur(12px)}
.btn.light{background:#fff;color:var(--blue-dark);box-shadow:0 20px 54px rgba(255,255,255,.18)}
.hero-signature{width:min(620px,92%);filter:drop-shadow(0 16px 34px rgba(0,0,0,.24))}
.hero-badge{margin:0;border-radius:42px;padding:24px;background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.22);box-shadow:0 38px 110px rgba(0,0,0,.28);animation:levitate 5s var(--ease) infinite alternate}
.hero-badge img{border-radius:28px;width:100%}
@keyframes levitate{to{transform:translateY(-14px) rotate(1deg)}}

.section{padding:86px 0}
.service-preview{padding-top:0;margin-top:-56px;position:relative;z-index:5}
.service-strip,.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.service-grid{grid-template-columns:repeat(3,1fr)}
.service-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);transition:.32s var(--ease)}
.service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-strong)}
.service-card-media{height:220px;display:block;overflow:hidden;background:linear-gradient(135deg,var(--blue-dark),var(--blue))}
.service-card-media img{width:100%;height:100%;object-fit:cover;transition:.48s var(--ease)}
.service-card:hover .service-card-media img{transform:scale(1.065)}
.service-card-content{padding:25px}
.card-index{font-weight:950;color:var(--orange);font-size:13px;letter-spacing:.18em}
.service-card h3{font-size:22px;line-height:1.18;color:var(--blue-dark);margin:14px 0 10px}
.service-card p{color:var(--muted);line-height:1.62;margin:0 0 15px}
.text-link{font-weight:950;color:var(--orange)}

.split,.page-hero-grid,.service-hero-grid,.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.text-block h2,.section-title h2,.page-copy h1,.service-hero h1{font-size:clamp(40px,5.4vw,72px);line-height:1.02;letter-spacing:-.06em;color:var(--blue-dark);margin:20px 0}
.text-block p,.section-title p,.page-copy p{font-size:17px;line-height:1.76;color:var(--muted)}
.image-stack{position:relative;margin:0}
.image-stack>img:first-child{width:100%;height:470px;object-fit:cover;border-radius:38px;box-shadow:var(--shadow)}
.floating-signature{position:absolute;left:-30px;bottom:30px;width:76%;padding:12px;background:rgba(255,255,255,.92);border-radius:20px;box-shadow:0 22px 60px rgba(0,0,0,.16)}
.section-title{text-align:center;max-width:860px;margin:0 auto 46px}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.gallery-card{position:relative;min-height:340px;border-radius:30px;overflow:hidden;box-shadow:var(--shadow);isolation:isolate;background:var(--blue-dark)}
.gallery-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:.55s var(--ease)}
.gallery-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,32,55,.88))}
.gallery-card:hover img{transform:scale(1.06)}
.gallery-card div{position:absolute;left:25px;right:25px;bottom:25px;color:#fff}
.gallery-card h3{font-size:25px;margin:0 0 10px}
.gallery-card p{color:rgba(255,255,255,.84);line-height:1.55;margin:0 0 12px}
.gallery-card span{color:#ffe1d0;font-weight:950}

.cta{position:relative;overflow:hidden;padding:78px 0;background:linear-gradient(135deg,var(--blue-dark),var(--blue));color:#fff}
.cta::before{content:"";position:absolute;right:-140px;top:-130px;width:470px;height:470px;border-radius:50%;background:rgba(242,101,34,.36);filter:blur(52px)}
.cta-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:30px}
.cta h2{font-size:clamp(34px,4.7vw,62px);line-height:1.03;letter-spacing:-.055em;margin:0}
.cta p{font-size:18px;line-height:1.65;color:rgba(255,255,255,.83)}
.brand-cta img{max-height:210px;border-radius:28px}

.page-hero{padding:100px 0 74px;background:linear-gradient(135deg,rgba(0,109,168,.10),rgba(242,101,34,.08))}
.page-media{margin:0;border-radius:38px;overflow:hidden;background:linear-gradient(135deg,var(--blue-dark),var(--blue));box-shadow:var(--shadow);min-height:330px}
.page-media img{width:100%;height:390px;object-fit:cover}

.dual,.pillar-grid,.feature-grid,.process-grid{display:grid;gap:24px}
.dual{grid-template-columns:1fr 1fr}
.panel{background:#fff;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);padding:31px}
.panel h1,.panel h2{font-size:clamp(30px,4vw,48px);line-height:1.08;letter-spacing:-.045em;color:var(--blue-dark);margin:0 0 16px}
.panel p{font-size:17px;line-height:1.75;color:var(--muted)}
.pillar-grid{grid-template-columns:repeat(4,1fr)}
.pillar-card{background:#fff;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);overflow:hidden;transition:.3s var(--ease)}
.pillar-card:hover{transform:translateY(-8px)}
.pillar-card img{width:100%;height:220px;object-fit:cover}
.pillar-card div{padding:25px}
.pillar-card h2{color:var(--blue-dark);margin:0 0 12px}
.pillar-card p{color:var(--muted);line-height:1.65;margin:0}

.service-hero{padding:92px 0;background:linear-gradient(135deg,#052b46,#006da8);color:#fff;position:relative;overflow:hidden}
.service-hero::after{content:"";position:absolute;right:-190px;top:-170px;width:540px;height:540px;border-radius:50%;background:rgba(242,101,34,.34);filter:blur(54px)}
.service-hero-grid{position:relative;z-index:1}
.service-hero h1{color:#fff}
.service-hero p{font-size:19px;line-height:1.68;color:rgba(255,255,255,.86);max-width:760px}
.back-link{display:inline-flex;margin-bottom:22px;color:#ffe3d4;font-weight:950}
.service-hero-media{margin:0;position:relative;border-radius:40px;overflow:hidden;box-shadow:0 38px 110px rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.18)}
.service-hero-media>img:first-child{width:100%;height:430px;object-fit:cover}
.service-signature{position:absolute;left:24px;right:24px;bottom:22px;width:calc(100% - 48px);padding:11px;background:rgba(255,255,255,.92);border-radius:18px;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.service-content{display:grid;gap:30px}
.feature-grid{grid-template-columns:repeat(3,1fr)}
.feature-card,.process-card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:26px}
.feature-card h3,.process-card h3{font-size:22px;color:var(--blue-dark);margin:0 0 10px}
.feature-card p,.process-card p{color:var(--muted);line-height:1.65}
.process-grid{grid-template-columns:repeat(4,1fr)}
.process-card strong{width:48px;height:48px;border-radius:16px;background:var(--orange);color:#fff;display:grid;place-items:center;font-size:22px;margin-bottom:18px}
.mini-cta{padding-top:42px}

.contact-card,.contact-form{background:#fff;border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);padding:31px}
.contact-card h3,.contact-form h3{font-size:38px;color:var(--blue-dark);letter-spacing:-.04em;line-height:1.05;margin:0 0 14px}
.contact-row{display:grid;grid-template-columns:.75fr 1.25fr;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.contact-row b{color:var(--orange)}
.contact-row span,.contact-card p{color:var(--muted);line-height:1.6}
.contact-form{display:grid;gap:16px}
.contact-form label{display:grid;gap:8px;font-weight:850;color:#17364e}
.contact-form input,.contact-form select,.contact-form textarea{border:1px solid var(--line);border-radius:16px;padding:14px;background:#f8fcff;font:inherit;outline:none}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,109,168,.10)}

.footer{background:#031d31;color:#fff;padding:62px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.4fr .8fr 1fr;gap:38px}
.footer-logo,.footer-brand>img:first-child{height:72px;width:auto;margin-bottom:16px}
.footer p{color:rgba(255,255,255,.76);line-height:1.72}
.footer a{display:block;color:rgba(255,255,255,.83);margin:9px 0}
.footer h3{margin-top:0}
.footer-signature{width:280px;margin-top:16px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.24))}
.footer-bottom{border-top:1px solid rgba(255,255,255,.10);padding-top:20px;margin-top:34px;color:rgba(255,255,255,.65)}
.whatsapp{position:fixed;right:24px;bottom:22px;z-index:90;background:#25D366;color:#07130c;border-radius:999px;padding:14px 18px;font-weight:950;box-shadow:0 22px 56px rgba(37,211,102,.35);transition:.25s}
.whatsapp:hover{transform:translateY(-4px)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s var(--ease), transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:none}

@media(max-width:1100px){
  .desktop-nav,.header-phone{display:none}
  .menu-button{display:block}
  .mobile-nav{display:none;position:absolute;left:18px;right:18px;top:88px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:14px;box-shadow:var(--shadow)}
  .mobile-nav.open{display:flex;flex-direction:column}
  .hero-grid,.split,.page-hero-grid,.service-hero-grid,.contact-grid{grid-template-columns:1fr}
  .service-strip,.service-grid,.gallery-grid,.pillar-grid,.feature-grid,.process-grid,.dual{grid-template-columns:1fr 1fr}
  .hero-badge{max-width:430px}
}
@media(max-width:700px){
  .container{width:calc(100% - 28px)}
  .header-inner{height:80px}
  .brand img{height:52px}
  .mobile-nav{top:80px}
  .hero{min-height:auto}
  .hero-grid{padding:76px 0 60px}
  .hero h1{font-size:44px}
  .hero p{font-size:17px}
  .service-strip,.service-grid,.gallery-grid,.pillar-grid,.feature-grid,.process-grid,.dual{grid-template-columns:1fr}
  .service-card-media{height:250px}
  .image-stack>img:first-child,.page-media img{height:320px}
  .cta-inner{align-items:flex-start;flex-direction:column}
  .footer-grid{grid-template-columns:1fr}
  .contact-row{grid-template-columns:1fr}
  .whatsapp{width:56px;height:56px;overflow:hidden;color:transparent;padding:0}
  .page-copy h1,.service-hero h1{font-size:42px}
  .service-hero-media>img:first-child{height:320px}
}


/* V2 navigation + video clarity refinement */
.site-header{
  transition: background .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease);
}
.site-header.is-scrolled{
  background:rgba(255,255,255,.94);
  box-shadow:0 18px 55px rgba(0,61,100,.13);
  border-color:rgba(0,109,168,.12);
}
.desktop-nav{
  padding:6px;
  border:1px solid rgba(0,109,168,.10);
  border-radius:22px;
  background:rgba(255,255,255,.62);
  box-shadow:0 12px 34px rgba(0,61,100,.06);
}
.desktop-nav a,
.mobile-nav a{
  position:relative;
  white-space:nowrap;
}
.desktop-nav a.active,
.desktop-nav a[aria-current="page"]{
  color:#fff;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  box-shadow:0 14px 32px rgba(0,109,168,.26);
}
.desktop-nav a.active::after,
.desktop-nav a[aria-current="page"]::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-9px;
  width:7px;
  height:7px;
  border-radius:999px;
  background:var(--orange);
  box-shadow:0 0 0 6px rgba(242,101,34,.14);
  transform:translateX(-50%);
}
.header-phone{
  transition:.24s var(--ease);
}
.header-phone:hover{
  transform:translateY(-2px);
  color:#fff;
  background:linear-gradient(135deg,var(--orange),var(--orange-light));
  border-color:transparent;
}

/* Better hero video visibility: lighter filter, text readability preserved locally around content */
.hero-video{
  opacity:.86;
  filter:saturate(1.18) contrast(1.08) brightness(1.02);
}
.hero-overlay{
  background:
    radial-gradient(circle at 82% 18%,rgba(242,101,34,.22),transparent 25%),
    linear-gradient(90deg,rgba(2,27,47,.82) 0%, rgba(0,72,118,.38) 48%, rgba(0,0,0,.12) 100%);
}
.hero-copy{
  position:relative;
}
.hero-copy::before{
  content:"";
  position:absolute;
  z-index:-1;
  inset:-34px -40px -34px -34px;
  border-radius:34px;
  background:linear-gradient(135deg,rgba(0,28,48,.72),rgba(0,75,120,.24));
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 30px 90px rgba(0,0,0,.18);
  backdrop-filter:blur(6px);
}
.hero h1{
  text-shadow:0 18px 62px rgba(0,0,0,.46);
}
.hero p{
  color:rgba(255,255,255,.94);
}

/* More responsive grids */
@media (max-width:1280px){
  .desktop-nav a{padding:11px 10px;font-size:14px}
  .header-phone{font-size:14px;padding:11px 13px}
}
@media (max-width:1180px){
  .desktop-nav,.header-phone{display:none}
  .menu-button{display:block}
  .mobile-nav{
    display:flex;
    position:fixed;
    top:96px;
    right:18px;
    left:auto;
    width:min(390px,calc(100vw - 36px));
    max-height:calc(100vh - 118px);
    overflow:auto;
    flex-direction:column;
    gap:8px;
    padding:16px;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(239,249,255,.96));
    border:1px solid rgba(0,109,168,.16);
    border-radius:28px;
    box-shadow:0 34px 95px rgba(0,45,78,.24);
    transform:translateY(-12px) scale(.96);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:.28s var(--ease);
    z-index:120;
  }
  .mobile-nav.open{
    transform:translateY(0) scale(1);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }
  .mobile-nav a{
    width:100%;
    padding:15px 16px;
    border:1px solid rgba(0,109,168,.10);
    background:rgba(255,255,255,.76);
  }
  .mobile-nav a.active,
  .mobile-nav a[aria-current="page"]{
    color:#fff;
    background:linear-gradient(135deg,var(--blue),var(--blue-dark));
    box-shadow:0 14px 32px rgba(0,109,168,.22);
  }
  .menu-backdrop{
    position:fixed;
    inset:0;
    background:rgba(3,29,49,.28);
    backdrop-filter:blur(3px);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:.25s var(--ease);
    z-index:110;
  }
  .menu-backdrop.open{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }
  body.menu-open{
    overflow:hidden;
  }
  .menu-button.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-button.open span:nth-child(2){opacity:0}
  .menu-button.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .menu-button span{transition:.22s var(--ease)}
}
@media (max-width:900px){
  .hero-grid{
    gap:34px;
  }
  .hero-copy::before{
    inset:-24px;
  }
  .hero-video{
    opacity:.72;
  }
  .hero-overlay{
    background:
      radial-gradient(circle at 80% 18%,rgba(242,101,34,.20),transparent 26%),
      linear-gradient(180deg,rgba(2,27,47,.78),rgba(0,72,118,.50),rgba(0,0,0,.18));
  }
  .service-strip,
  .service-grid,
  .gallery-grid,
  .pillar-grid,
  .feature-grid,
  .process-grid,
  .dual{
    grid-template-columns:1fr;
  }
  .service-card-media{
    height:260px;
  }
}
@media (max-width:520px){
  .container{width:calc(100% - 24px)}
  .hero h1{font-size:40px}
  .hero-copy::before{inset:-18px;border-radius:26px}
  .hero-signature{width:100%}
  .mobile-nav{top:84px;right:12px;width:calc(100vw - 24px)}
  .site-header .header-inner{height:78px}
}


/* V3 travel luxury refinement: clearer video, branded blue veil, header signature, multilingual */
:root{
  --font-vatis:"Poppins","Montserrat","Inter","Avenir Next","Segoe UI",system-ui,-apple-system,Arial,sans-serif;
}
body{
  font-family:var(--font-vatis);
}

/* Header brand signature */
.header-inner{
  gap:18px;
}
.brand{
  flex:0 0 auto;
}
.header-signature{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:7px 10px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(0,109,168,.10);
  box-shadow:0 14px 36px rgba(0,61,100,.08);
}
.header-signature img{
  height:34px;
  width:auto;
  max-width:265px;
  object-fit:contain;
  filter:drop-shadow(0 6px 12px rgba(0,61,100,.08));
}

/* Header navigation more high-end and aware */
.desktop-nav{
  margin-left:auto;
}
.desktop-nav a.active,
.desktop-nav a[aria-current="page"]{
  background:linear-gradient(135deg,#006da8,#003b62) !important;
  color:#fff !important;
}
.mobile-nav a.active,
.mobile-nav a[aria-current="page"]{
  background:linear-gradient(135deg,#006da8,#003b62) !important;
  color:#fff !important;
}

/* Language switcher */
.language-switcher{
  position:relative;
  flex:0 0 auto;
  z-index:140;
}
.language-toggle{
  display:flex;
  align-items:center;
  gap:7px;
  border:1px solid rgba(0,109,168,.14);
  background:rgba(255,255,255,.88);
  color:var(--blue-dark);
  border-radius:999px;
  padding:10px 13px;
  font-weight:950;
  cursor:pointer;
  box-shadow:0 14px 34px rgba(0,61,100,.08);
  transition:.22s var(--ease);
}
.language-toggle:hover{
  transform:translateY(-2px);
  background:#fff;
  box-shadow:0 18px 44px rgba(0,61,100,.14);
}
.language-flag{
  font-size:17px;
  line-height:1;
}
.language-code{
  font-size:12px;
  letter-spacing:.08em;
}
.language-menu{
  position:absolute;
  right:0;
  top:calc(100% + 12px);
  min-width:190px;
  padding:10px;
  border-radius:22px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(0,109,168,.14);
  box-shadow:0 28px 80px rgba(0,45,78,.20);
  display:grid;
  gap:6px;
  opacity:0;
  visibility:hidden;
  transform:translateY(-8px) scale(.96);
  pointer-events:none;
  transition:.24s var(--ease);
}
.language-switcher.open .language-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.language-menu button{
  border:0;
  display:flex;
  align-items:center;
  gap:9px;
  width:100%;
  padding:11px 12px;
  border-radius:15px;
  background:transparent;
  color:#16364e;
  font-weight:850;
  cursor:pointer;
  text-align:left;
}
.language-menu button:hover,
.language-menu button.active{
  background:linear-gradient(135deg,rgba(0,109,168,.10),rgba(242,101,34,.09));
  color:var(--blue-dark);
}
#google_translate_element{
  position:absolute!important;
  left:-9999px!important;
  top:-9999px!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
  opacity:.01!important;
}
.goog-te-banner-frame,
body > .skiptranslate{
  display:none!important;
}
body{
  top:0!important;
}

/* Hero: full first viewport, buttons visible, video clearer */
.hero{
  min-height:calc(100svh - 88px);
  max-height:calc(100svh - 88px);
}
.hero-grid{
  min-height:calc(100svh - 88px);
  padding:clamp(22px,3.8vh,42px) 0;
  grid-template-columns:minmax(0,1.03fr) minmax(280px,.58fr);
  gap:clamp(26px,4vw,48px);
}
.hero-video{
  opacity:.98 !important;
  filter:saturate(1.24) contrast(1.08) brightness(1.08) !important;
}
.hero-overlay{
  background:
    radial-gradient(circle at 85% 16%,rgba(242,101,34,.16),transparent 24%),
    radial-gradient(circle at 18% 85%,rgba(0,166,214,.14),transparent 31%),
    linear-gradient(90deg,rgba(0,59,98,.54) 0%, rgba(0,109,168,.24) 46%, rgba(0,109,168,.08) 100%) !important;
}
.hero-copy::before{
  background:linear-gradient(135deg,rgba(0,38,65,.58),rgba(0,109,168,.18)) !important;
  backdrop-filter:blur(5px);
}
.hero h1{
  font-size:clamp(42px,6.2vw,82px);
  margin:clamp(14px,2vh,22px) 0 clamp(12px,1.8vh,18px);
}
.hero p{
  font-size:clamp(16px,1.65vw,19px);
  max-width:620px;
}
.hero-actions{
  margin:clamp(18px,2.4vh,26px) 0 0;
}
.hero-signature{
  display:none!important;
}
.hero-badge{
  max-width:min(355px,100%);
  justify-self:end;
}
.hero-badge img{
  max-height:clamp(230px,43vh,350px);
  object-fit:contain;
}

/* Luxury travel details */
.hero::after{
  content:"";
  position:absolute;
  z-index:1;
  left:0;
  right:0;
  bottom:0;
  height:110px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.10));
  pointer-events:none;
}
.hero-copy .eyebrow{
  background:rgba(255,255,255,.92);
}
.btn.primary{
  box-shadow:0 20px 58px rgba(242,101,34,.34), inset 0 1px 0 rgba(255,255,255,.22);
}
.btn.ghost{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.32);
}
.service-card,
.gallery-card,
.pillar-card,
.panel,
.contact-card,
.contact-form{
  transform-style:preserve-3d;
}
.service-card::before,
.gallery-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.20),transparent 30%,rgba(255,255,255,.06));
  opacity:.55;
}
.service-card-content,
.gallery-card div{
  position:relative;
  z-index:3;
}

/* Low-height desktop: keep entire first screen visible */
@media (max-height:760px) and (min-width:901px){
  .hero h1{font-size:clamp(38px,5.4vw,70px);margin:12px 0}
  .hero p{font-size:16px;line-height:1.55}
  .hero-actions{margin-top:16px}
  .hero-badge{max-width:300px}
  .hero-badge img{max-height:285px}
  .hero-copy::before{inset:-22px -24px}
}
@media (max-width:1320px){
  .header-signature img{max-width:220px;height:31px}
  .desktop-nav a{font-size:13.5px;padding:10px 9px}
  .language-toggle{padding:10px 12px}
}
@media (max-width:1180px){
  .header-signature{
    margin-right:auto;
  }
}
@media (max-width:900px){
  .hero{
    min-height:calc(100svh - 80px);
    max-height:none;
  }
  .hero-grid{
    min-height:calc(100svh - 80px);
    grid-template-columns:1fr;
    align-content:center;
    padding:26px 0;
  }
  .hero-badge{
    display:none;
  }
  .hero-video{
    opacity:.90!important;
  }
  .hero-overlay{
    background:
      linear-gradient(180deg,rgba(0,59,98,.66),rgba(0,109,168,.32),rgba(0,0,0,.12)) !important;
  }
}
@media (max-width:620px){
  .header-signature img{max-width:138px;height:25px}
  .header-signature{padding:5px 7px;border-radius:14px}
  .language-toggle{padding:9px 10px}
  .language-code{display:none}
  .language-menu{right:-48px}
  .hero h1{font-size:38px}
  .hero-copy::before{inset:-16px;border-radius:24px}
}
@media (max-width:390px){
  .header-signature{display:none}
}


/* V4 Ultimate Premium Luxury Prestige Plus */
.prestige-preloader{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%,rgba(0,166,214,.26),transparent 30%),
    radial-gradient(circle at 82% 22%,rgba(242,101,34,.22),transparent 26%),
    linear-gradient(135deg,#031d31 0%,#003b62 54%,#006da8 100%);
  transition:opacity .58s var(--ease), visibility .58s var(--ease), transform .58s var(--ease);
}
.prestige-preloader::before{
  content:"";
  position:absolute;
  inset:-30%;
  background:
    linear-gradient(115deg,transparent 0%,rgba(255,255,255,.12) 45%,transparent 62%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 1px,transparent 1px 110px);
  animation:preloaderSweep 2.6s linear infinite;
}
.prestige-preloader::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at center,transparent 0 32%,rgba(0,0,0,.14) 100%);
  pointer-events:none;
}
@keyframes preloaderSweep{
  to{transform:translateX(18%) translateY(-6%) rotate(2deg)}
}
.prestige-preloader.is-hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:scale(1.015);
}
.preloader-card{
  position:relative;
  z-index:2;
  width:min(420px,calc(100vw - 44px));
  padding:34px 30px 30px;
  border-radius:34px;
  display:grid;
  justify-items:center;
  gap:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.07));
  border:1px solid rgba(255,255,255,.20);
  box-shadow:0 40px 130px rgba(0,0,0,.32);
  backdrop-filter:blur(18px);
}
.preloader-logo{
  max-width:230px;
  filter:drop-shadow(0 18px 38px rgba(0,0,0,.22));
}
.preloader-signature{
  width:min(300px,86%);
  filter:drop-shadow(0 14px 28px rgba(0,0,0,.25));
}
.preloader-line{
  width:82%;
  height:4px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.18);
}
.preloader-line span{
  display:block;
  width:48%;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),#fff,var(--sky));
  animation:preloaderLine 1.05s var(--ease) infinite alternate;
}
@keyframes preloaderLine{
  from{transform:translateX(-20%)}
  to{transform:translateX(132%)}
}
.preloader-orbit{
  position:absolute;
  width:min(560px,88vw);
  aspect-ratio:1;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:inset 0 0 80px rgba(255,255,255,.08),0 0 90px rgba(0,166,214,.22);
  animation:preloaderOrbit 5s linear infinite;
}
.preloader-orbit::before,
.preloader-orbit::after{
  content:"";
  position:absolute;
  width:14px;
  height:14px;
  border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 28px rgba(242,101,34,.9);
}
.preloader-orbit::before{top:8%;left:50%}
.preloader-orbit::after{bottom:10%;right:18%;background:var(--sky);box-shadow:0 0 28px rgba(0,166,214,.9)}
@keyframes preloaderOrbit{
  to{transform:rotate(360deg)}
}
body.preloading{
  overflow:hidden;
}

/* White transparent footer signature: no frame, no background */
.footer-signature-white,
.footer .footer-signature{
  background:transparent!important;
  padding:0!important;
  border:0!important;
  box-shadow:none!important;
  filter:drop-shadow(0 16px 26px rgba(0,0,0,.28));
  max-width:320px;
  width:min(320px,90%);
}

/* WhatsApp prestige floating button */
.whatsapp{
  width:64px;
  height:64px;
  padding:0!important;
  display:grid!important;
  place-items:center;
  border:1px solid rgba(255,255,255,.38);
  background:
    radial-gradient(circle at 28% 20%,rgba(255,255,255,.35),transparent 30%),
    linear-gradient(135deg,#25D366,#128C7E)!important;
  color:#fff!important;
  box-shadow:0 24px 62px rgba(37,211,102,.38),0 0 0 10px rgba(37,211,102,.10);
  animation:whatsappPulse 2.6s var(--ease) infinite;
}
.whatsapp svg{
  width:34px;
  height:34px;
  fill:#fff;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.20));
}
.whatsapp span{
  position:absolute;
  right:74px;
  top:50%;
  transform:translateY(-50%) translateX(8px);
  opacity:0;
  visibility:hidden;
  white-space:nowrap;
  padding:10px 13px;
  border-radius:999px;
  color:#fff;
  background:rgba(3,29,49,.88);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 18px 45px rgba(0,0,0,.18);
  transition:.24s var(--ease);
}
.whatsapp:hover span{
  opacity:1;
  visibility:visible;
  transform:translateY(-50%) translateX(0);
}
@keyframes whatsappPulse{
  0%,100%{box-shadow:0 24px 62px rgba(37,211,102,.38),0 0 0 8px rgba(37,211,102,.10)}
  50%{box-shadow:0 30px 72px rgba(37,211,102,.50),0 0 0 15px rgba(37,211,102,.04)}
}

/* Extra prestige layer */
.site-header{
  box-shadow:0 1px 0 rgba(255,255,255,.7),0 16px 54px rgba(0,61,100,.08);
}
.header-signature{
  background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,255,255,.64));
}
.hero-copy::before{
  box-shadow:0 34px 110px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.16);
}
.hero-badge{
  box-shadow:0 44px 132px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.18);
}
.service-card,
.gallery-card,
.pillar-card,
.panel,
.contact-card,
.contact-form{
  border-color:rgba(0,109,168,.12);
}
.service-card:hover,
.gallery-card:hover,
.pillar-card:hover{
  box-shadow:0 42px 130px rgba(0,61,100,.24);
}
.cta{
  background:
    radial-gradient(circle at 88% 18%,rgba(242,101,34,.32),transparent 26%),
    radial-gradient(circle at 12% 92%,rgba(0,166,214,.24),transparent 28%),
    linear-gradient(135deg,#031d31,#003b62 45%,#006da8);
}

@media(max-width:700px){
  .prestige-preloader .preloader-card{
    padding:28px 22px 24px;
  }
  .preloader-logo{
    max-width:190px;
  }
  .whatsapp{
    width:58px;
    height:58px;
  }
  .whatsapp svg{
    width:31px;
    height:31px;
  }
  .whatsapp span{
    display:none;
  }
}


/* V5 Grand Luxe Prestige refinement */

/* Refined preloader: lighter, closer to a luxury travel house */
.refined-preloader{
  background:
    radial-gradient(circle at 50% 42%,rgba(0,166,214,.20),transparent 28%),
    linear-gradient(135deg,#031d31 0%,#052b46 46%,#003b62 100%);
}
.refined-preloader::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg,transparent 0%,rgba(255,255,255,.07) 42%,transparent 57%),
    radial-gradient(circle at 20% 80%,rgba(242,101,34,.16),transparent 24%);
  animation:preloaderSoftSweep 2.4s ease-in-out infinite alternate;
}
.refined-preloader::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:42%;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.18));
}
@keyframes preloaderSoftSweep{
  from{transform:translateX(-4%)}
  to{transform:translateX(5%)}
}
.preloader-card.refined{
  width:min(330px,calc(100vw - 48px));
  padding:30px 26px 26px;
  gap:16px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.13),rgba(255,255,255,.055));
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 34px 110px rgba(0,0,0,.28);
  backdrop-filter:blur(16px);
}
.preloader-card.refined::before{
  content:"";
  position:absolute;
  inset:13px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
}
.preloader-glow{
  position:absolute;
  width:min(430px,82vw);
  aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle,rgba(0,166,214,.20),transparent 62%);
  animation:preloaderBreath 1.9s ease-in-out infinite alternate;
}
@keyframes preloaderBreath{
  to{transform:scale(1.08);opacity:.72}
}
.preloader-card.refined .preloader-logo{
  max-width:205px;
}
.preloader-card.refined .preloader-signature{
  width:min(245px,84%);
  filter:brightness(0) invert(1) drop-shadow(0 12px 24px rgba(0,0,0,.30));
  opacity:.94;
}
.preloader-status{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:7px;
  margin:2px 0;
}
.preloader-status span{
  width:7px;
  height:7px;
  border-radius:50%;
  background:#fff;
  opacity:.35;
  animation:preloaderDots 1.05s ease-in-out infinite;
}
.preloader-status span:nth-child(2){animation-delay:.16s;background:var(--sky)}
.preloader-status span:nth-child(3){animation-delay:.32s;background:var(--orange)}
@keyframes preloaderDots{
  0%,100%{transform:translateY(0);opacity:.35}
  50%{transform:translateY(-5px);opacity:1}
}
.prestige-preloader .preloader-orbit,
.prestige-preloader .preloader-line{
  display:none!important;
}

/* Footer signature must be white, transparent, no frame */
.footer-signature-white{
  filter:brightness(0) invert(1) drop-shadow(0 16px 28px rgba(0,0,0,.34))!important;
  opacity:.96;
  background:transparent!important;
  box-shadow:none!important;
  border:0!important;
  padding:0!important;
}

/* Page transition between pages */
.page-transition{
  position:fixed;
  inset:0;
  z-index:9998;
  pointer-events:none;
  visibility:hidden;
  opacity:0;
  background:
    radial-gradient(circle at 50% 48%,rgba(0,166,214,.20),transparent 30%),
    linear-gradient(135deg,#031d31,#003b62 58%,#006da8);
  transition:opacity .38s var(--ease), visibility .38s var(--ease);
}
.page-transition span{
  position:absolute;
  left:50%;
  top:50%;
  width:110px;
  height:2px;
  border-radius:999px;
  transform:translate(-50%,-50%);
  background:linear-gradient(90deg,transparent,#fff,var(--orange),transparent);
  box-shadow:0 0 34px rgba(255,255,255,.35);
}
.page-transition.active{
  opacity:1;
  visibility:visible;
}

/* Non-home pages: make them feel designed, not plain */
.page-hero{
  position:relative;
  overflow:hidden;
  min-height:430px;
  display:grid;
  align-items:center;
  background:
    radial-gradient(circle at 86% 20%,rgba(242,101,34,.18),transparent 25%),
    radial-gradient(circle at 12% 85%,rgba(0,166,214,.16),transparent 28%),
    linear-gradient(135deg,rgba(0,109,168,.10),rgba(255,255,255,.72) 50%,rgba(242,101,34,.08));
}
.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg,rgba(0,109,168,.055) 1px,transparent 1px),
    linear-gradient(30deg,rgba(0,109,168,.04) 1px,transparent 1px);
  background-size:78px 78px;
  mask-image:linear-gradient(90deg,#000,transparent 82%);
  animation:pageHeroGrid 22s linear infinite;
}
.page-hero::after{
  content:"";
  position:absolute;
  right:-110px;
  bottom:-130px;
  width:440px;
  height:440px;
  border-radius:50%;
  border:1px solid rgba(0,109,168,.14);
  box-shadow:inset 0 0 70px rgba(0,166,214,.10),0 0 80px rgba(0,109,168,.10);
}
@keyframes pageHeroGrid{
  to{background-position:78px 78px}
}
.page-hero-grid{
  position:relative;
  z-index:2;
}
.page-copy .eyebrow{
  background:rgba(255,255,255,.92);
}
.page-copy h1{
  text-shadow:0 20px 60px rgba(0,61,100,.12);
}
.page-media{
  position:relative;
  transform:perspective(1200px) rotateY(-4deg) rotateX(2deg);
  transition:.45s var(--ease);
}
.page-media:hover{
  transform:perspective(1200px) rotateY(0deg) rotateX(0deg) translateY(-8px);
}
.page-media::before{
  content:"";
  position:absolute;
  inset:18px -18px -18px 18px;
  border-radius:38px;
  background:linear-gradient(135deg,rgba(0,109,168,.18),rgba(242,101,34,.18));
  z-index:-1;
  filter:blur(.2px);
}
.page-media::after{
  content:"VATIS™";
  position:absolute;
  right:18px;
  top:18px;
  padding:9px 12px;
  border-radius:999px;
  color:#fff;
  font-size:12px;
  letter-spacing:.16em;
  font-weight:950;
  background:rgba(3,29,49,.58);
  border:1px solid rgba(255,255,255,.20);
  backdrop-filter:blur(10px);
}

/* Ribbon after page hero */
.prestige-page-ribbon{
  position:relative;
  z-index:4;
  margin-top:-42px;
}
.prestige-ribbon-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.prestige-ribbon-grid article{
  min-height:112px;
  padding:20px 22px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,253,255,.86));
  border:1px solid rgba(0,109,168,.13);
  box-shadow:0 24px 70px rgba(0,61,100,.12);
  display:grid;
  gap:5px;
  position:relative;
  overflow:hidden;
}
.prestige-ribbon-grid article::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg,var(--orange),var(--blue));
}
.prestige-ribbon-grid span{
  font-size:12px;
  letter-spacing:.16em;
  font-weight:950;
  color:var(--orange);
}
.prestige-ribbon-grid strong{
  font-size:19px;
  color:var(--blue-dark);
}
.prestige-ribbon-grid em{
  font-style:normal;
  color:var(--muted);
}

/* Intra-page reveal variants */
.service-card,
.gallery-card,
.pillar-card,
.feature-card,
.process-card,
.panel,
.contact-card,
.contact-form{
  will-change:transform, opacity;
}
.reveal.visible:nth-child(2n){
  transition-delay:.04s;
}
.reveal.visible:nth-child(3n){
  transition-delay:.08s;
}
.service-card:hover .service-card-content h3,
.pillar-card:hover h2,
.feature-card:hover h3,
.process-card:hover h3{
  color:var(--blue);
}

/* Service detail pages: stronger prestige composition */
.service-hero{
  min-height:520px;
}
.service-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg,rgba(255,255,255,.055) 1px,transparent 1px),
    radial-gradient(circle at 15% 84%,rgba(0,166,214,.16),transparent 28%);
  background-size:72px 72px,auto;
}
.service-hero-media{
  transform:perspective(1200px) rotateY(-5deg) rotateX(2deg);
  transition:.45s var(--ease);
}
.service-hero-media:hover{
  transform:perspective(1200px) rotateY(0deg) rotateX(0deg) translateY(-8px);
}
.service-hero-media::after{
  content:"Service Premium";
  position:absolute;
  right:20px;
  top:20px;
  padding:10px 13px;
  border-radius:999px;
  color:#fff;
  font-size:12px;
  letter-spacing:.12em;
  font-weight:950;
  background:rgba(3,29,49,.58);
  border:1px solid rgba(255,255,255,.20);
  backdrop-filter:blur(10px);
}

/* Page content: luxury spacing and card depth */
.dual,
.pillar-grid,
.feature-grid,
.process-grid,
.contact-grid{
  perspective:1200px;
}
.panel,
.feature-card,
.process-card,
.contact-card,
.contact-form{
  background:linear-gradient(180deg,#fff,rgba(248,253,255,.94));
}
.panel::before,
.contact-card::before,
.contact-form::before{
  content:"";
  display:block;
  width:52px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  margin-bottom:18px;
}

/* More premium CTA and footer */
.cta::after{
  content:"";
  position:absolute;
  inset:auto 10% 0 10%;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.36),transparent);
}
.footer{
  background:
    radial-gradient(circle at 85% 12%,rgba(0,166,214,.14),transparent 26%),
    linear-gradient(135deg,#021522,#031d31 58%,#042a45);
}
.footer-grid{
  position:relative;
}
.footer-grid::before{
  content:"";
  position:absolute;
  top:-22px;
  left:0;
  width:120px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--sky));
}

@media(max-width:900px){
  .prestige-ribbon-grid{
    grid-template-columns:1fr;
  }
  .prestige-page-ribbon{
    margin-top:-22px;
  }
  .page-media,
  .service-hero-media{
    transform:none;
  }
  .service-hero{
    min-height:auto;
  }
}
@media(max-width:600px){
  .preloader-card.refined{
    width:min(292px,calc(100vw - 40px));
  }
  .preloader-card.refined .preloader-logo{
    max-width:180px;
  }
  .preloader-card.refined .preloader-signature{
    max-width:210px;
  }
}


/* V6 Light Prestige Preloader + Gallery readability correction */
.refined-preloader,
.prestige-preloader{
  background:
    radial-gradient(circle at 18% 16%,rgba(0,166,214,.20),transparent 28%),
    radial-gradient(circle at 82% 18%,rgba(242,101,34,.16),transparent 26%),
    linear-gradient(135deg,#ffffff 0%,#f3fbff 46%,#ffffff 100%) !important;
}
.refined-preloader::before,
.prestige-preloader::before{
  background:
    linear-gradient(115deg,transparent 0%,rgba(0,109,168,.09) 44%,transparent 62%),
    repeating-linear-gradient(90deg,rgba(0,109,168,.045) 0 1px,transparent 1px 118px) !important;
  opacity:.9;
}
.refined-preloader::after,
.prestige-preloader::after{
  background:
    radial-gradient(circle at 50% 60%,rgba(0,109,168,.08),transparent 36%),
    linear-gradient(180deg,transparent,rgba(0,109,168,.06)) !important;
}
.preloader-card.refined,
.preloader-card{
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,255,255,.74)) !important;
  border:1px solid rgba(0,109,168,.16) !important;
  box-shadow:0 34px 110px rgba(0,61,100,.18), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
.preloader-card.refined::before{
  border-color:rgba(0,109,168,.10) !important;
}
.preloader-glow{
  background:
    radial-gradient(circle,rgba(0,166,214,.16),transparent 58%),
    radial-gradient(circle at 60% 40%,rgba(242,101,34,.10),transparent 48%) !important;
}
.preloader-card.refined .preloader-logo,
.preloader-logo{
  filter:drop-shadow(0 16px 30px rgba(0,61,100,.18)) !important;
}
.preloader-card.refined .preloader-signature,
.preloader-signature{
  filter:drop-shadow(0 12px 24px rgba(0,61,100,.18)) !important;
  opacity:1 !important;
}
.preloader-status span{
  background:var(--blue) !important;
  box-shadow:0 0 18px rgba(0,109,168,.22);
}
.preloader-status span:nth-child(2){
  background:var(--orange) !important;
}
.preloader-status span:nth-child(3){
  background:var(--sky) !important;
}

/* Galerie Photos: text must remain readable on all images */
.gallery-card{
  isolation:isolate;
}
.gallery-card::after{
  background:
    linear-gradient(180deg,rgba(0,25,43,.14) 0%,rgba(0,32,55,.50) 48%,rgba(0,18,32,.92) 100%) !important;
}
.gallery-card div{
  z-index:5 !important;
  left:20px !important;
  right:20px !important;
  bottom:20px !important;
  padding:18px 18px 16px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(3,29,49,.72),rgba(3,29,49,.58));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 20px 56px rgba(0,0,0,.28);
  backdrop-filter:blur(12px);
}
.gallery-card h3{
  color:#ffffff !important;
  text-shadow:0 3px 18px rgba(0,0,0,.75),0 1px 0 rgba(0,0,0,.45);
  line-height:1.08;
  margin-bottom:8px !important;
}
.gallery-card p{
  color:rgba(255,255,255,.92) !important;
  text-shadow:0 2px 12px rgba(0,0,0,.72);
}
.gallery-card span{
  display:inline-flex;
  margin-top:4px;
  color:#ffe1d0 !important;
  text-shadow:0 2px 12px rgba(0,0,0,.55);
}
.gallery-card::before{
  z-index:1 !important;
  opacity:.28 !important;
}
@media(max-width:700px){
  .gallery-card div{
    left:16px !important;
    right:16px !important;
    bottom:16px !important;
    padding:16px;
  }
}


/* V7 — Effet écriture sur "Jusqu'au bout du voyage" dans le préloader */
.preloader-writing{
  position:relative;
  width:min(265px,86%);
  display:grid;
  place-items:center;
  overflow:visible;
  margin-top:2px;
}
.preloader-writing .preloader-signature{
  width:100% !important;
  max-width:none !important;
  opacity:1 !important;
  transform-origin:left center;
  clip-path:inset(0 100% 0 0);
  animation:signatureWrite 1.55s cubic-bezier(.22,.86,.28,1) .36s forwards;
  filter:drop-shadow(0 12px 24px rgba(0,61,100,.16)) !important;
}
.preloader-writing .writing-cursor{
  position:absolute;
  left:0;
  top:50%;
  width:2px;
  height:58%;
  border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,var(--blue),var(--orange),transparent);
  box-shadow:0 0 16px rgba(0,109,168,.55);
  animation:signatureCursor 1.55s cubic-bezier(.22,.86,.28,1) .36s forwards,
            cursorBlink .42s ease-in-out 2.05s 3 alternate;
}
@keyframes signatureWrite{
  from{clip-path:inset(0 100% 0 0);filter:drop-shadow(0 12px 24px rgba(0,61,100,.08))}
  72%{clip-path:inset(0 12% 0 0)}
  to{clip-path:inset(0 0 0 0);filter:drop-shadow(0 12px 24px rgba(0,61,100,.20))}
}
@keyframes signatureCursor{
  from{left:0;opacity:.95}
  72%{left:88%;opacity:1}
  to{left:100%;opacity:0}
}
@keyframes cursorBlink{
  from{opacity:0}
  to{opacity:1}
}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce){
  .preloader-writing .preloader-signature{
    animation:none!important;
    clip-path:none!important;
  }
  .preloader-writing .writing-cursor{
    display:none!important;
  }
}


/* V8 — Écriture plus humaine + CTAs/header fixes */
.human-writing{
  width:min(282px,88%);
  display:grid;
  place-items:center;
  margin-top:2px;
  overflow:visible;
}
.signature-handwrite{
  width:100%;
  height:auto;
  overflow:visible;
  filter:drop-shadow(0 12px 24px rgba(0,61,100,.16));
}
.human-mask-stroke{
  fill:none;
  stroke:#fff;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke-width:54;
  stroke-dasharray:930;
  stroke-dashoffset:930;
}
.stroke-main{
  animation:humanWriteMain 1.92s cubic-bezier(.22,.78,.24,1) .22s forwards;
}
.stroke-rise{
  stroke-width:46;
  stroke-dasharray:380;
  stroke-dashoffset:380;
  animation:humanWriteDetail 1.45s cubic-bezier(.22,.78,.24,1) .62s forwards;
}
.stroke-fall{
  stroke-width:44;
  stroke-dasharray:360;
  stroke-dashoffset:360;
  animation:humanWriteFall 1.32s cubic-bezier(.22,.78,.24,1) .86s forwards;
}
.human-guide-path{fill:none;stroke:transparent;}
.human-pen-dot{
  fill:var(--orange);
  stroke:#fff;
  stroke-width:2;
  filter:drop-shadow(0 0 12px rgba(242,101,34,.65));
  opacity:0;
  animation:penDotVisibility 2.55s ease .18s forwards;
}
@keyframes humanWriteMain{
  0%{stroke-dashoffset:930}
  12%{stroke-dashoffset:820}
  24%{stroke-dashoffset:735}
  38%{stroke-dashoffset:555}
  49%{stroke-dashoffset:510}
  63%{stroke-dashoffset:335}
  77%{stroke-dashoffset:210}
  100%{stroke-dashoffset:0}
}
@keyframes humanWriteDetail{
  from{stroke-dashoffset:380}
  38%{stroke-dashoffset:270}
  62%{stroke-dashoffset:135}
  to{stroke-dashoffset:0}
}
@keyframes humanWriteFall{
  from{stroke-dashoffset:360}
  45%{stroke-dashoffset:205}
  70%{stroke-dashoffset:118}
  to{stroke-dashoffset:0}
}
@keyframes penDotVisibility{
  0%{opacity:0}
  8%{opacity:1}
  84%{opacity:1}
  100%{opacity:0}
}
.btn{white-space:nowrap;}
.btn.primary,.btn.light,.btn.ghost{letter-spacing:.045em;}
a.btn[href*="contact"],.cta .btn,.page-hero .btn{text-transform:uppercase;}
.header-phone{
  white-space:nowrap!important;
  min-width:max-content;
  flex-shrink:0;
  word-break:keep-all;
  overflow-wrap:normal;
}
@media (max-width:1320px){
  .header-phone{font-size:13px!important;padding:10px 12px!important;}
  .desktop-nav a{font-size:13px!important;padding:10px 8px!important;}
}
@media (max-width:1180px){.header-phone{display:none!important;}}
@media (prefers-reduced-motion: reduce){
  .human-mask-stroke{animation:none!important;stroke-dashoffset:0!important;}
  .human-pen-dot{display:none!important;}
}


/* V9 — corrected handwriting, brighter gallery, blue text header signature */

/* Header signature: no box/background, VATIS blue text */
.header-signature.header-signature-blue{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
}
.header-signature-blue span{
  color:var(--blue)!important;
  font-weight:950;
  font-style:italic;
  font-size:clamp(15px,1.25vw,20px);
  letter-spacing:-.02em;
  white-space:nowrap;
  text-shadow:0 8px 18px rgba(0,109,168,.12);
}
.header-signature-blue:hover span{
  color:var(--blue-dark)!important;
}

/* Replace failed wipe/mask with a real letter-by-letter SVG stroke animation */
.true-letter-writing{
  width:min(342px,90%);
  display:grid;
  place-items:center;
  margin-top:2px;
  overflow:visible;
}
.letter-signature-svg{
  width:100%;
  height:auto;
  overflow:visible;
}
.signature-letters .pre-letter{
  font-family:"Segoe Script","Brush Script MT","Snell Roundhand","Lucida Handwriting",cursive;
  font-size:42px;
  font-weight:700;
  fill:transparent;
  stroke:var(--blue);
  stroke-width:1.55;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke-dasharray:150;
  stroke-dashoffset:150;
  paint-order:stroke fill;
  filter:drop-shadow(0 7px 14px rgba(0,109,168,.16));
  animation:
    drawGlyph .72s cubic-bezier(.22,.78,.24,1) var(--d) forwards,
    fillGlyph .34s ease calc(var(--d) + .54s) forwards;
}
.signature-underline{
  fill:none;
  stroke:var(--orange);
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-dasharray:620;
  stroke-dashoffset:620;
  opacity:.9;
  animation:drawUnderline 1.05s cubic-bezier(.22,.78,.24,1) 2.12s forwards;
  filter:drop-shadow(0 8px 13px rgba(242,101,34,.22));
}
.signature-pen{
  fill:var(--orange);
  stroke:#fff;
  stroke-width:1.8;
  filter:drop-shadow(0 0 13px rgba(242,101,34,.75));
  opacity:0;
  animation:penHuman 2.55s ease .12s forwards;
}
@keyframes drawGlyph{
  0%{stroke-dashoffset:150; opacity:.45; transform:translateY(2px)}
  55%{opacity:1}
  100%{stroke-dashoffset:0; opacity:1; transform:translateY(0)}
}
@keyframes fillGlyph{
  from{fill:transparent}
  to{fill:var(--blue)}
}
@keyframes drawUnderline{
  to{stroke-dashoffset:0}
}
@keyframes penHuman{
  0%{opacity:0}
  8%{opacity:1}
  86%{opacity:1}
  100%{opacity:0}
}

/* Gallery photos: brighten images and make captions readable without darkening the whole card */
.gallery-card img{
  filter:saturate(1.18) contrast(1.06) brightness(1.16)!important;
}
.gallery-card::after{
  background:
    linear-gradient(180deg,rgba(255,255,255,.02) 0%,rgba(0,55,88,.10) 42%,rgba(0,31,52,.54) 100%)!important;
}
.gallery-card div{
  background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,255,255,.76))!important;
  border:1px solid rgba(255,255,255,.54)!important;
  box-shadow:0 18px 48px rgba(0,45,78,.18)!important;
  backdrop-filter:blur(10px);
}
.gallery-card h3{
  color:var(--blue-dark)!important;
  text-shadow:none!important;
}
.gallery-card p{
  color:#395469!important;
  text-shadow:none!important;
}
.gallery-card span{
  color:var(--orange)!important;
  text-shadow:none!important;
}

/* Disable obsolete V8 mask elements when present in cache/html */
.human-mask-stroke,
.human-pen-dot,
.human-guide-path{
  animation:none!important;
  display:none!important;
}

@media(max-width:620px){
  .header-signature-blue span{
    font-size:14px;
  }
  .true-letter-writing{
    width:min(300px,90%);
  }
  .signature-letters .pre-letter{
    font-size:38px;
  }
}
@media(max-width:390px){
  .header-signature.header-signature-blue{
    display:none;
  }
}
@media (prefers-reduced-motion: reduce){
  .signature-letters .pre-letter{
    animation:none!important;
    stroke-dashoffset:0!important;
    fill:var(--blue)!important;
  }
  .signature-underline{
    animation:none!important;
    stroke-dashoffset:0!important;
  }
  .signature-pen{
    display:none!important;
  }
}


/* V10 fixes: back to scanned handwriting reveal, fast loaders on inner pages, mobile menu, gallery captions */

/* Return to scanned handwriting left-to-right reveal: the original writing is an image scan, not reconstructed letters. */
.classic-scan-writing{
  position:relative;
  width:min(285px,88%);
  display:grid;
  place-items:center;
  overflow:visible;
  margin-top:2px;
}
.classic-scan-writing .preloader-signature{
  width:100% !important;
  max-width:none !important;
  opacity:1 !important;
  clip-path:inset(0 100% 0 0);
  animation:scanSignatureReveal 1.35s cubic-bezier(.22,.86,.28,1) .28s forwards;
  filter:drop-shadow(0 12px 24px rgba(0,61,100,.18)) !important;
}
.classic-scan-writing .writing-cursor{
  position:absolute;
  left:0;
  top:50%;
  width:2px;
  height:62%;
  border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,var(--blue),var(--orange),transparent);
  box-shadow:0 0 16px rgba(0,109,168,.55);
  animation:scanCursorReveal 1.35s cubic-bezier(.22,.86,.28,1) .28s forwards,
            cursorBlink .42s ease-in-out 1.82s 2 alternate;
}
@keyframes scanSignatureReveal{
  from{clip-path:inset(0 100% 0 0)}
  70%{clip-path:inset(0 15% 0 0)}
  to{clip-path:inset(0 0 0 0)}
}
@keyframes scanCursorReveal{
  from{left:0;opacity:.95}
  70%{left:85%;opacity:1}
  to{left:100%;opacity:0}
}

/* Kill the per-letter SVG animation if old browser cache keeps it around. */
.true-letter-writing,
.letter-signature-svg,
.signature-handwrite{
  display:none !important;
}

/* Inner pages should not be forced to wait for a long preloader animation. */
body:not([data-page="home"]) .classic-scan-writing .preloader-signature{
  animation-duration:.48s !important;
  animation-delay:.05s !important;
}
body:not([data-page="home"]) .classic-scan-writing .writing-cursor{
  animation-duration:.48s !important;
  animation-delay:.05s !important;
}

/* Mobile menu hard fix: force the drawer mechanics independent of previous CSS. */
@media(max-width:1180px){
  .desktop-nav,
  .header-phone{
    display:none !important;
  }
  .menu-button{
    display:block !important;
    position:relative;
    z-index:140;
  }
  .mobile-nav{
    position:fixed !important;
    top:calc(var(--header-height, 88px) + 10px) !important;
    right:16px !important;
    left:auto !important;
    width:min(390px,calc(100vw - 32px)) !important;
    max-height:calc(100vh - 118px) !important;
    overflow:auto !important;
    display:flex !important;
    flex-direction:column !important;
    gap:8px !important;
    padding:16px !important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(239,249,255,.97)) !important;
    border:1px solid rgba(0,109,168,.16) !important;
    border-radius:28px !important;
    box-shadow:0 34px 95px rgba(0,45,78,.24) !important;
    transform:translateY(-12px) scale(.96) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transition:.28s var(--ease) !important;
    z-index:130 !important;
  }
  .mobile-nav.open{
    transform:translateY(0) scale(1) !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }
  .menu-backdrop{
    position:fixed !important;
    inset:0 !important;
    background:rgba(3,29,49,.26) !important;
    backdrop-filter:blur(3px) !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transition:.25s var(--ease) !important;
    z-index:120 !important;
  }
  .menu-backdrop.open{
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }
  .menu-button.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-button.open span:nth-child(2){opacity:0}
  .menu-button.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* Gallery: keep the images visible; captions must not strongly cover them. */
.gallery-card img{
  filter:saturate(1.13) contrast(1.04) brightness(1.08) !important;
}
.gallery-card::after{
  background:
    linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,44,72,.05) 45%,rgba(0,24,42,.36) 100%) !important;
}
.gallery-card div{
  left:18px !important;
  right:18px !important;
  bottom:18px !important;
  padding:12px 14px 11px !important;
  border-radius:18px !important;
  background:linear-gradient(180deg,rgba(3,29,49,.34),rgba(3,29,49,.22)) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  box-shadow:0 14px 34px rgba(0,0,0,.16) !important;
  backdrop-filter:blur(5px) !important;
}
.gallery-card h3{
  color:#fff !important;
  text-shadow:0 3px 14px rgba(0,0,0,.75) !important;
  margin-bottom:6px !important;
}
.gallery-card p{
  color:rgba(255,255,255,.90) !important;
  text-shadow:0 2px 10px rgba(0,0,0,.68) !important;
}
.gallery-card span{
  color:#ffe1d0 !important;
  text-shadow:0 2px 10px rgba(0,0,0,.55) !important;
}
@media(max-width:700px){
  .gallery-card div{
    left:14px !important;
    right:14px !important;
    bottom:14px !important;
    padding:11px 12px !important;
  }
}


/* V11 — Header signature scanned + gallery spacing + prestige design boost */

/* Header: use the same scanned handwritten signature as the preloader */
.header-signature.header-signature-scan{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  border-radius:0!important;
  min-width:max-content;
  position:relative;
}
.header-signature-scan::after{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  bottom:-7px;
  height:1px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.38),rgba(242,101,34,.30),transparent);
  opacity:.75;
  transform:scaleX(.72);
  transition:.25s var(--ease);
}
.header-signature-scan:hover::after{
  transform:scaleX(1);
}
.header-signature-scan img{
  height:38px;
  width:auto;
  max-width:292px;
  object-fit:contain;
  filter:drop-shadow(0 9px 18px rgba(0,109,168,.18));
}

/* Gallery caption: small top breathing space while keeping image visible */
.gallery-card div{
  padding-top:18px!important;
  padding-bottom:13px!important;
}
.gallery-card h3{
  margin-top:2px!important;
}

/* Prestige design boost: more refined cinematic depth */
.site-header{
  background:
    linear-gradient(180deg,rgba(255,255,255,.94),rgba(255,255,255,.78))!important;
  box-shadow:0 1px 0 rgba(255,255,255,.9),0 18px 60px rgba(0,61,100,.09)!important;
}
.site-header.is-scrolled{
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(245,252,255,.92))!important;
  box-shadow:0 22px 70px rgba(0,61,100,.15)!important;
}
.desktop-nav{
  background:
    linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.50))!important;
  border-color:rgba(0,109,168,.12)!important;
  backdrop-filter:blur(18px);
}
.desktop-nav a{
  overflow:hidden;
}
.desktop-nav a::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.24),transparent 46%,rgba(255,255,255,.12));
  transform:translateX(-120%);
  transition:.35s var(--ease);
}
.desktop-nav a:hover::before{
  transform:translateX(0);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(115deg,transparent 0%,rgba(255,255,255,.08) 42%,transparent 58%);
  mix-blend-mode:screen;
  animation:heroLightSweep 7s ease-in-out infinite;
  pointer-events:none;
}
@keyframes heroLightSweep{
  0%,100%{transform:translateX(-22%) skewX(-8deg);opacity:.18}
  50%{transform:translateX(22%) skewX(-8deg);opacity:.34}
}
.hero-copy::before{
  border:1px solid rgba(255,255,255,.16)!important;
  box-shadow:
    0 36px 118px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.20),
    inset 0 -1px 0 rgba(255,255,255,.06)!important;
}
.hero-badge{
  position:relative;
}
.hero-badge::after{
  content:"";
  position:absolute;
  inset:12px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.16);
  pointer-events:none;
}
.service-card,
.gallery-card,
.pillar-card,
.feature-card,
.process-card,
.panel,
.contact-card,
.contact-form{
  transition:
    transform .38s var(--ease),
    box-shadow .38s var(--ease),
    border-color .38s var(--ease),
    filter .38s var(--ease);
}
.service-card:hover,
.gallery-card:hover,
.pillar-card:hover,
.feature-card:hover,
.process-card:hover,
.panel:hover{
  border-color:rgba(242,101,34,.22);
  filter:saturate(1.02);
}
.service-card-media,
.gallery-card{
  position:relative;
}
.service-card-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(135deg,rgba(255,255,255,.12),transparent 38%,rgba(242,101,34,.08)),
    linear-gradient(180deg,transparent 48%,rgba(0,45,78,.18));
  pointer-events:none;
}
.gallery-card{
  min-height:360px;
}
.gallery-card:hover img{
  transform:scale(1.075) translateY(-2px);
}
.gallery-card div{
  max-width:88%;
}
.cta{
  isolation:isolate;
}
.cta::before{
  animation:ctaGlow 5.8s ease-in-out infinite alternate;
}
@keyframes ctaGlow{
  from{transform:translate3d(0,0,0) scale(.96);opacity:.75}
  to{transform:translate3d(-28px,18px,0) scale(1.12);opacity:1}
}
.prestige-page-ribbon article{
  transition:.35s var(--ease);
}
.prestige-page-ribbon article:hover{
  transform:translateY(-7px);
  box-shadow:0 32px 86px rgba(0,61,100,.18);
}

/* More refined mobile header */
@media(max-width:1320px){
  .header-signature-scan img{
    height:34px;
    max-width:238px;
  }
}
@media(max-width:620px){
  .header-signature-scan img{
    height:28px;
    max-width:168px;
  }
  .gallery-card div{
    max-width:calc(100% - 28px);
    padding-top:16px!important;
  }
}
@media(max-width:390px){
  .header-signature.header-signature-scan{
    display:none;
  }
}


/* V12 — Animated header signature + MYLE footer credit */
.header-signature-scan{
  overflow:visible;
}
.header-signature-scan img{
  clip-path:inset(0 100% 0 0);
  animation:headerSignatureWrite 1.35s cubic-bezier(.22,.86,.28,1) .28s forwards;
}
.header-signature-scan::before{
  content:"";
  position:absolute;
  left:0;
  top:50%;
  width:2px;
  height:70%;
  border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,var(--blue),var(--orange),transparent);
  box-shadow:0 0 14px rgba(0,109,168,.45);
  animation:headerSignatureCursor 1.35s cubic-bezier(.22,.86,.28,1) .28s forwards;
}
.header-signature-scan:hover img{
  filter:drop-shadow(0 11px 22px rgba(0,109,168,.24)) saturate(1.05);
}
@keyframes headerSignatureWrite{
  0%{clip-path:inset(0 100% 0 0)}
  68%{clip-path:inset(0 16% 0 0)}
  100%{clip-path:inset(0 0 0 0)}
}
@keyframes headerSignatureCursor{
  0%{left:0;opacity:.95}
  68%{left:84%;opacity:1}
  100%{left:100%;opacity:0}
}

/* Footer copyright / By MYLE */
.footer-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.footer-bottom a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin:0;
  color:#fff;
  font-weight:950;
  letter-spacing:.04em;
  padding:9px 13px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 14px 36px rgba(0,0,0,.18);
  transition:.24s var(--ease);
}
.footer-bottom a:hover{
  transform:translateY(-2px);
  color:#fff;
  background:linear-gradient(135deg,var(--blue),var(--orange));
  border-color:transparent;
}
@media(max-width:620px){
  .footer-bottom{
    justify-content:center;
    text-align:center;
  }
}

@media (prefers-reduced-motion: reduce){
  .header-signature-scan img{
    animation:none!important;
    clip-path:none!important;
  }
  .header-signature-scan::before{
    display:none!important;
  }
}


/* V13 — Header signature starts only after preloader + extra luxury prestige */

/* Stop previous header signature animation from running behind the preloader */
.header-signature-scan img{
  clip-path:inset(0 100% 0 0) !important;
  animation:none !important;
}
.header-signature-scan::before{
  opacity:0 !important;
  animation:none !important;
}

/* Triggered by JS only after the preloader has disappeared */
body.signature-ready .header-signature-scan img{
  animation:headerSignatureWriteV13 1.32s cubic-bezier(.22,.86,.28,1) .08s forwards !important;
}
body.signature-ready .header-signature-scan::before{
  opacity:1 !important;
  animation:headerSignatureCursorV13 1.32s cubic-bezier(.22,.86,.28,1) .08s forwards !important;
}
@keyframes headerSignatureWriteV13{
  0%{clip-path:inset(0 100% 0 0);filter:drop-shadow(0 8px 14px rgba(0,109,168,.10))}
  64%{clip-path:inset(0 18% 0 0)}
  100%{clip-path:inset(0 0 0 0);filter:drop-shadow(0 11px 22px rgba(0,109,168,.24))}
}
@keyframes headerSignatureCursorV13{
  0%{left:0;opacity:.95}
  64%{left:82%;opacity:1}
  100%{left:100%;opacity:0}
}

/* In case JavaScript is disabled, show the signature after a graceful fallback */
noscript ~ .bg-aurora .header-signature-scan img{
  clip-path:none!important;
}

/* Ultimate luxury layer */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-4;
  pointer-events:none;
  background:
    linear-gradient(115deg,transparent 0%,rgba(255,255,255,.08) 45%,transparent 60%),
    radial-gradient(circle at 50% 0%,rgba(0,109,168,.08),transparent 36%);
  mix-blend-mode:soft-light;
}

.hero-copy{
  transform-style:preserve-3d;
}
.hero-copy::after{
  content:"";
  position:absolute;
  z-index:-1;
  left:-22px;
  top:-22px;
  width:118px;
  height:118px;
  border-top:2px solid rgba(255,255,255,.34);
  border-left:2px solid rgba(255,255,255,.26);
  border-radius:26px 0 0 0;
  opacity:.78;
}
.hero-actions .btn{
  position:relative;
  overflow:hidden;
}
.hero-actions .btn::after,
.cta .btn::after{
  content:"";
  position:absolute;
  top:-40%;
  bottom:-40%;
  width:42%;
  left:-60%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.32),transparent);
  transform:skewX(-18deg);
  transition:.55s var(--ease);
}
.hero-actions .btn:hover::after,
.cta .btn:hover::after{
  left:120%;
}

/* Travel prestige badges on hero */
.hero .container.hero-grid::after{
  content:"Premium Travel Services";
  position:absolute;
  right:0;
  bottom:clamp(18px,3vh,34px);
  color:rgba(255,255,255,.82);
  font-size:12px;
  letter-spacing:.22em;
  font-weight:950;
  text-transform:uppercase;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
}

/* Page sections with more luxury rhythm */
.section{
  position:relative;
}
.section::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  width:min(980px,78vw);
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.15),rgba(242,101,34,.13),transparent);
  pointer-events:none;
}
.section-title h2,
.text-block h2,
.page-copy h1,
.service-hero h1{
  text-wrap:balance;
}
.section-title::after{
  content:"";
  display:block;
  width:86px;
  height:4px;
  margin:22px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  box-shadow:0 10px 22px rgba(0,109,168,.16);
}

/* More prestigious cards */
.service-card,
.pillar-card,
.feature-card,
.process-card,
.panel,
.contact-card,
.contact-form{
  position:relative;
  overflow:hidden;
}
.service-card::after,
.pillar-card::after,
.feature-card::after,
.process-card::after,
.panel::after,
.contact-card::after,
.contact-form::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(255,255,255,.22),transparent 26%),
    linear-gradient(135deg,rgba(255,255,255,.10),transparent 38%);
  opacity:0;
  transition:opacity .28s var(--ease);
}
.service-card:hover::after,
.pillar-card:hover::after,
.feature-card:hover::after,
.process-card:hover::after,
.panel:hover::after,
.contact-card:hover::after,
.contact-form:hover::after{
  opacity:1;
}
.service-card-content,
.pillar-card div,
.feature-card > *,
.process-card > *,
.panel > *,
.contact-card > *,
.contact-form > *{
  position:relative;
  z-index:2;
}

/* Gallery becomes more travel-magazine premium without hiding the photo */
.gallery-card{
  border:1px solid rgba(255,255,255,.26);
}
.gallery-card div{
  transform:translateY(0);
  transition:.35s var(--ease);
}
.gallery-card:hover div{
  transform:translateY(-5px);
}
.gallery-card::before{
  content:"";
  position:absolute;
  inset:16px;
  z-index:2;
  border:1px solid rgba(255,255,255,.18);
  border-radius:22px;
  pointer-events:none;
  opacity:.78;
}

/* Premium inner-page treatment */
.prestige-page-ribbon article{
  background:
    linear-gradient(180deg,rgba(255,255,255,.96),rgba(249,253,255,.88)),
    radial-gradient(circle at 100% 0%,rgba(242,101,34,.08),transparent 34%);
}
.page-copy h1::after,
.service-hero h1::after{
  content:"";
  display:block;
  width:94px;
  height:4px;
  border-radius:999px;
  margin-top:24px;
  background:linear-gradient(90deg,var(--orange),var(--sky));
  box-shadow:0 14px 26px rgba(0,109,168,.16);
}

/* Footer by MYLE more elegant */
.footer-bottom a{
  position:relative;
  overflow:hidden;
}
.footer-bottom a::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transform:translateX(-120%) skewX(-18deg);
  transition:.5s var(--ease);
}
.footer-bottom a:hover::after{
  transform:translateX(120%) skewX(-18deg);
}

@media(max-width:900px){
  .hero .container.hero-grid::after{
    position:relative;
    right:auto;
    bottom:auto;
    justify-self:start;
    margin-top:4px;
  }
}
@media(max-width:620px){
  body.signature-ready .header-signature-scan img{
    animation-duration:1.05s!important;
  }
  .hero-copy::after{
    width:84px;
    height:84px;
  }
}
@media (prefers-reduced-motion: reduce){
  body.signature-ready .header-signature-scan img{
    animation:none!important;
    clip-path:none!important;
  }
  body.signature-ready .header-signature-scan::before{
    display:none!important;
  }
}


/* V14 — Header signature visible + cursor disappears + Grand Prestige Design */

/* Header signature: guaranteed VATIS blue, visible on white header */
.header-signature-scan img{
  opacity:1 !important;
  filter:drop-shadow(0 10px 20px rgba(0,109,168,.22)) !important;
}

/* The writing cursor must disappear once the signature is fully revealed */
body.signature-finished .header-signature-scan::before{
  opacity:0 !important;
  visibility:hidden !important;
  display:none !important;
  animation:none !important;
}
body.signature-ready .header-signature-scan::before{
  animation:headerSignatureCursorV14 1.25s cubic-bezier(.22,.86,.28,1) .08s forwards !important;
}
@keyframes headerSignatureCursorV14{
  0%{left:0;opacity:.95;visibility:visible}
  62%{left:82%;opacity:1;visibility:visible}
  88%{left:100%;opacity:.35;visibility:visible}
  100%{left:100%;opacity:0;visibility:hidden}
}

/* Stronger finish: keep signature fully displayed after animation */
body.signature-finished .header-signature-scan img{
  clip-path:inset(0 0 0 0) !important;
  animation:none !important;
}

/* Grand Prestige Design: travel-grade polish */
:root{
  --pearl:#f7fcff;
  --champagne:#fff4ea;
}
.site-header::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.28),rgba(242,101,34,.24),transparent);
}
.hero{
  box-shadow:inset 0 -120px 180px rgba(255,255,255,.08);
}
.hero-overlay{
  background:
    radial-gradient(circle at 78% 16%,rgba(242,101,34,.12),transparent 23%),
    radial-gradient(circle at 14% 84%,rgba(0,166,214,.14),transparent 30%),
    linear-gradient(90deg,rgba(0,59,98,.46) 0%,rgba(0,109,168,.18) 44%,rgba(255,255,255,.04) 100%) !important;
}
.hero::before{
  background:
    linear-gradient(115deg,transparent 0%,rgba(255,255,255,.12) 44%,transparent 58%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.045) 0 1px,transparent 1px 96px) !important;
}
.hero::after{
  height:145px !important;
  background:
    linear-gradient(180deg,transparent,rgba(255,255,255,.16)),
    radial-gradient(ellipse at 50% 100%,rgba(255,255,255,.16),transparent 64%) !important;
}

/* Elegant route line overlay in the hero */
.hero .hero-grid::before{
  content:"";
  position:absolute;
  z-index:-1;
  right:6%;
  top:12%;
  width:min(420px,38vw);
  height:min(420px,38vw);
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 50% 50%,transparent 0 44%,rgba(255,255,255,.08) 45%,transparent 46%),
    conic-gradient(from 210deg,transparent 0 18%,rgba(255,255,255,.28) 22%,transparent 34%,transparent 100%);
  filter:drop-shadow(0 26px 60px rgba(0,0,0,.16));
  animation:prestigeCompass 16s linear infinite;
}
@keyframes prestigeCompass{
  to{transform:rotate(360deg)}
}

/* Premium card labels */
.service-card-content::before,
.pillar-card div::before{
  content:"";
  position:absolute;
  top:0;
  left:25px;
  right:25px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.20),transparent);
}
.service-card{
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,252,255,.94)),
    radial-gradient(circle at 100% 0%,rgba(242,101,34,.08),transparent 34%) !important;
}
.service-card h3,
.pillar-card h2,
.feature-card h3,
.process-card h3{
  letter-spacing:-.025em;
}
.service-card:hover h3,
.gallery-card:hover h3{
  color:var(--blue) !important;
}

/* Gallery prestige: brighter photos, minimal caption cover, luxury spacing */
.gallery-card{
  min-height:370px !important;
  box-shadow:0 34px 100px rgba(0,61,100,.15) !important;
}
.gallery-card img{
  filter:saturate(1.16) contrast(1.05) brightness(1.13) !important;
}
.gallery-card::after{
  background:
    linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,44,72,.03) 48%,rgba(0,24,42,.28) 100%) !important;
}
.gallery-card div{
  padding:15px 15px 13px !important;
  padding-top:20px !important;
  background:linear-gradient(180deg,rgba(3,29,49,.24),rgba(3,29,49,.18)) !important;
  border-color:rgba(255,255,255,.15) !important;
  backdrop-filter:blur(4px) !important;
}
.gallery-card h3{
  margin-top:4px !important;
}

/* Inner page elegance */
.page-hero{
  background:
    radial-gradient(circle at 82% 20%,rgba(242,101,34,.12),transparent 25%),
    radial-gradient(circle at 10% 84%,rgba(0,166,214,.14),transparent 30%),
    linear-gradient(135deg,var(--pearl),#ffffff 52%,var(--champagne)) !important;
}
.page-media{
  box-shadow:0 44px 130px rgba(0,61,100,.18) !important;
}
.prestige-page-ribbon article{
  border-color:rgba(0,109,168,.12) !important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,253,255,.90)),
    radial-gradient(circle at 100% 0%,rgba(242,101,34,.08),transparent 34%) !important;
}

/* CTA like a luxury travel invitation */
.cta{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14);
}
.cta h2{
  text-shadow:0 18px 46px rgba(0,0,0,.20);
}
.cta .btn.light{
  color:var(--blue-dark);
  background:
    linear-gradient(180deg,#fff,#f3fbff) !important;
  border:1px solid rgba(255,255,255,.42);
  box-shadow:0 24px 64px rgba(255,255,255,.18),0 18px 48px rgba(0,0,0,.16);
}

/* Footer ultra-class */
.footer{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.footer a:hover{
  color:#fff;
  text-decoration:none;
}

/* Smoother section arrival */
.reveal{
  transition-duration:.86s !important;
}
.reveal.visible{
  animation:prestigeSettle .72s var(--ease) both;
}
@keyframes prestigeSettle{
  0%{filter:blur(2px)}
  100%{filter:blur(0)}
}

@media(max-width:900px){
  .hero .hero-grid::before{
    display:none;
  }
}


/* V15 — True progressive header signature reveal + higher-class luxury design */

/* Header signature reveal rebuilt as an ink layer. During animation, the text is visible progressively. */
.header-signature-reveal{
  position:relative;
  display:inline-grid!important;
  place-items:center;
  width:292px;
  max-width:292px;
  height:42px;
  overflow:visible;
}
.header-signature-reveal .header-signature-ink{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  overflow:hidden;
  clip-path:inset(0 100% 0 0);
  opacity:1;
}
.header-signature-reveal .header-signature-ink img{
  height:38px!important;
  width:auto!important;
  max-width:292px!important;
  object-fit:contain!important;
  clip-path:none!important;
  animation:none!important;
  opacity:1!important;
  filter:drop-shadow(0 10px 20px rgba(0,109,168,.22))!important;
}
.header-signature-reveal .header-signature-cursor{
  position:absolute;
  left:0;
  top:50%;
  width:2px;
  height:72%;
  border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,var(--blue),var(--orange),transparent);
  box-shadow:0 0 15px rgba(0,109,168,.50);
  opacity:0;
  visibility:hidden;
}

/* Only when JS says preloader is gone */
body.signature-ready:not(.signature-finished) .header-signature-reveal .header-signature-ink{
  animation:headerInkRevealV15 1.28s cubic-bezier(.22,.86,.28,1) .08s forwards!important;
}
body.signature-ready:not(.signature-finished) .header-signature-reveal .header-signature-cursor{
  visibility:visible!important;
  opacity:1!important;
  animation:headerInkCursorV15 1.28s cubic-bezier(.22,.86,.28,1) .08s forwards!important;
}
body.signature-finished .header-signature-reveal .header-signature-ink{
  clip-path:inset(0 0 0 0)!important;
  animation:none!important;
}
body.signature-finished .header-signature-reveal .header-signature-cursor{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
}
.header-signature-reveal::before{
  display:none!important;
}
.header-signature-reveal::after{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  bottom:-5px;
  height:1px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.38),rgba(242,101,34,.30),transparent);
  opacity:.75;
  transform:scaleX(.72);
  transition:.25s var(--ease);
}
.header-signature-reveal:hover::after{
  transform:scaleX(1);
}
@keyframes headerInkRevealV15{
  0%{clip-path:inset(0 100% 0 0)}
  25%{clip-path:inset(0 70% 0 0)}
  54%{clip-path:inset(0 38% 0 0)}
  78%{clip-path:inset(0 14% 0 0)}
  100%{clip-path:inset(0 0 0 0)}
}
@keyframes headerInkCursorV15{
  0%{left:0;opacity:.95;visibility:visible}
  25%{left:30%;opacity:1;visibility:visible}
  54%{left:62%;opacity:1;visibility:visible}
  78%{left:86%;opacity:.85;visibility:visible}
  100%{left:100%;opacity:0;visibility:hidden}
}

/* Override older V12/V13/V14 image-based rules */
.header-signature-scan img{
  clip-path:none!important;
}
body.signature-ready .header-signature-scan img,
body.signature-finished .header-signature-scan img{
  animation:none!important;
  clip-path:none!important;
}
body.signature-ready .header-signature-scan::before,
body.signature-finished .header-signature-scan::before{
  display:none!important;
}

/* Classe supérieure: luxury travel editorial system */
body{
  background:
    radial-gradient(circle at 8% 8%,rgba(0,166,214,.11),transparent 28%),
    radial-gradient(circle at 92% 4%,rgba(242,101,34,.10),transparent 26%),
    linear-gradient(180deg,#ffffff 0%,#f2fbff 38%,#ffffff 72%,#fff7f0 100%)!important;
}
.site-header{
  border-bottom:1px solid rgba(0,109,168,.10)!important;
}
.header-inner{
  position:relative;
}
.header-inner::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:10px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.10),transparent);
  pointer-events:none;
}

/* Hero becomes cinematic but still clear */
.hero-video{
  opacity:1!important;
  filter:saturate(1.24) contrast(1.08) brightness(1.12)!important;
}
.hero-overlay{
  background:
    radial-gradient(circle at 77% 18%,rgba(242,101,34,.10),transparent 22%),
    radial-gradient(circle at 16% 84%,rgba(0,166,214,.12),transparent 30%),
    linear-gradient(90deg,rgba(0,46,78,.38) 0%,rgba(0,109,168,.13) 45%,rgba(255,255,255,.02) 100%)!important;
}
.hero-copy::before{
  background:
    linear-gradient(135deg,rgba(0,44,74,.50),rgba(0,109,168,.13))!important;
  border-color:rgba(255,255,255,.20)!important;
  backdrop-filter:blur(4px)!important;
}
.hero h1{
  letter-spacing:-.08em!important;
}
.hero h1 span{
  background:linear-gradient(90deg,#ffe4d3,#ffffff,#ffd9c1);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent!important;
}
.hero .container.hero-grid::after{
  background:rgba(255,255,255,.13)!important;
  border-color:rgba(255,255,255,.24)!important;
  box-shadow:0 18px 46px rgba(0,0,0,.14);
}

/* Luxe navigation details */
.desktop-nav a.active,
.desktop-nav a[aria-current="page"]{
  background:
    radial-gradient(circle at 20% 10%,rgba(255,255,255,.20),transparent 30%),
    linear-gradient(135deg,var(--blue),var(--blue-dark))!important;
}
.language-toggle,
.header-phone{
  background:
    linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,252,255,.86))!important;
}

/* Elevated inner pages and services */
.page-hero{
  border-bottom:1px solid rgba(0,109,168,.08);
}
.page-copy h1,
.service-hero h1{
  max-width:900px;
}
.page-media img,
.service-hero-media>img:first-child{
  transition:transform .65s var(--ease), filter .65s var(--ease);
}
.page-media:hover img,
.service-hero-media:hover>img:first-child{
  transform:scale(1.055);
  filter:saturate(1.08) contrast(1.04);
}

/* Luxury numbered cards */
.service-card-content .card-index{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.service-card-content .card-index::after{
  content:"";
  width:34px;
  height:1px;
  background:linear-gradient(90deg,var(--orange),transparent);
}
.process-card strong{
  box-shadow:0 14px 32px rgba(242,101,34,.25);
}

/* More graceful gallery and magazine style */
.gallery-card{
  min-height:382px!important;
  border-radius:34px!important;
}
.gallery-card div{
  max-width:82%!important;
  border-radius:20px!important;
  background:linear-gradient(180deg,rgba(3,29,49,.22),rgba(3,29,49,.15))!important;
}
.gallery-card h3{
  font-size:clamp(22px,2vw,28px)!important;
}
.gallery-card span{
  letter-spacing:.05em;
  text-transform:uppercase;
  font-size:12px;
}

/* Elegant section titles */
.section-title h2::first-letter,
.text-block h2::first-letter{
  color:var(--blue);
}
.section-title p{
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}

/* CTA gets prestige edge */
.cta-inner{
  position:relative;
}
.cta-inner::before{
  content:"";
  position:absolute;
  left:-22px;
  top:-22px;
  width:92px;
  height:92px;
  border-top:1px solid rgba(255,255,255,.28);
  border-left:1px solid rgba(255,255,255,.22);
  border-radius:26px 0 0 0;
  pointer-events:none;
}

/* Footer refined */
.footer-brand{
  position:relative;
}
.footer-brand::after{
  content:"";
  display:block;
  width:76px;
  height:3px;
  margin-top:20px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--sky));
}

@media(max-width:1320px){
  .header-signature-reveal{
    width:238px;
    max-width:238px;
  }
  .header-signature-reveal .header-signature-ink img{
    height:34px!important;
    max-width:238px!important;
  }
}
@media(max-width:620px){
  .header-signature-reveal{
    width:168px;
    max-width:168px;
    height:32px;
  }
  .header-signature-reveal .header-signature-ink img{
    height:28px!important;
    max-width:168px!important;
  }
  .gallery-card div{
    max-width:calc(100% - 28px)!important;
  }
}
@media(max-width:390px){
  .header-signature-reveal{
    display:none!important;
  }
}
@media (prefers-reduced-motion: reduce){
  .header-signature-reveal .header-signature-ink{
    animation:none!important;
    clip-path:inset(0 0 0 0)!important;
  }
  .header-signature-reveal .header-signature-cursor{
    display:none!important;
  }
}


/* V16 — Header signature animation must visibly start AFTER preloader */
body.v16-signature-reset .header-signature-reveal .header-signature-ink,
body.v16-signature-reset.signature-ready .header-signature-reveal .header-signature-ink,
body.v16-signature-reset.signature-finished .header-signature-reveal .header-signature-ink{
  clip-path:inset(0 100% 0 0) !important;
  animation:none !important;
}
body.v16-signature-reset .header-signature-reveal .header-signature-cursor,
body.v16-signature-reset.signature-ready .header-signature-reveal .header-signature-cursor,
body.v16-signature-reset.signature-finished .header-signature-reveal .header-signature-cursor{
  left:0 !important;
  opacity:0 !important;
  visibility:hidden !important;
  display:block !important;
  animation:none !important;
}

body.v16-signature-writing .header-signature-reveal .header-signature-ink,
body.v16-signature-writing.signature-ready .header-signature-reveal .header-signature-ink,
body.v16-signature-writing.signature-finished .header-signature-reveal .header-signature-ink{
  clip-path:inset(0 100% 0 0) !important;
  animation:v16HeaderInkReveal 2.85s cubic-bezier(.18,.78,.18,1) forwards !important;
}
body.v16-signature-writing .header-signature-reveal .header-signature-cursor,
body.v16-signature-writing.signature-ready .header-signature-reveal .header-signature-cursor,
body.v16-signature-writing.signature-finished .header-signature-reveal .header-signature-cursor{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  animation:v16HeaderInkCursor 2.85s cubic-bezier(.18,.78,.18,1) forwards !important;
}

body.v16-signature-done .header-signature-reveal .header-signature-ink,
body.v16-signature-done.signature-ready .header-signature-reveal .header-signature-ink,
body.v16-signature-done.signature-finished .header-signature-reveal .header-signature-ink{
  clip-path:inset(0 0 0 0) !important;
  animation:none !important;
}
body.v16-signature-done .header-signature-reveal .header-signature-cursor,
body.v16-signature-done.signature-ready .header-signature-reveal .header-signature-cursor,
body.v16-signature-done.signature-finished .header-signature-reveal .header-signature-cursor{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
  animation:none !important;
}

@keyframes v16HeaderInkReveal{
  0%{clip-path:inset(0 100% 0 0)}
  10%{clip-path:inset(0 92% 0 0)}
  24%{clip-path:inset(0 76% 0 0)}
  40%{clip-path:inset(0 58% 0 0)}
  57%{clip-path:inset(0 38% 0 0)}
  73%{clip-path:inset(0 19% 0 0)}
  88%{clip-path:inset(0 6% 0 0)}
  100%{clip-path:inset(0 0 0 0)}
}
@keyframes v16HeaderInkCursor{
  0%{left:0;opacity:.95;visibility:visible}
  10%{left:8%;opacity:1}
  24%{left:24%;opacity:1}
  40%{left:42%;opacity:1}
  57%{left:62%;opacity:1}
  73%{left:81%;opacity:.95}
  88%{left:94%;opacity:.72}
  100%{left:100%;opacity:0;visibility:hidden}
}

/* Small visual cue: keep header steady while the signature writes */
body.v16-signature-writing .header-signature-reveal{
  filter:drop-shadow(0 10px 20px rgba(0,109,168,.18));
}


/* V18 — From V16 only: footer social networks + sequential hero entrance + refined prestige */

/* Footer social networks */
.footer-socials{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.10);
}
.footer-socials h3{
  margin:0 0 12px;
  font-size:18px;
}
.social-links{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.social-links a{
  width:44px;
  height:44px;
  margin:0!important;
  display:grid!important;
  place-items:center;
  border-radius:16px;
  color:#fff;
  background:
    radial-gradient(circle at 28% 18%,rgba(255,255,255,.28),transparent 32%),
    linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 18px 42px rgba(0,0,0,.18);
  transition:.28s var(--ease);
}
.social-links a svg{
  width:23px;
  height:23px;
  fill:currentColor;
}
.social-links a:hover{
  transform:translateY(-4px) scale(1.04);
  background:linear-gradient(135deg,var(--blue),var(--orange));
  border-color:transparent;
  box-shadow:0 24px 58px rgba(0,109,168,.28);
}

/* Hero: avoid brutal appearance. Elements enter one after another after preloader. */
body[data-page="home"] .hero-seq{
  opacity:0;
  transform:translateY(22px) scale(.985);
  filter:blur(5px);
}
body[data-page="home"].hero-sequence-on .hero-seq{
  animation:heroSequenceReveal .82s cubic-bezier(.18,.82,.22,1) forwards;
}
body[data-page="home"].hero-sequence-on .hero-seq-1{animation-delay:.08s}
body[data-page="home"].hero-sequence-on .hero-seq-2{animation-delay:.28s}
body[data-page="home"].hero-sequence-on .hero-seq-3{animation-delay:.52s}
body[data-page="home"].hero-sequence-on .hero-seq-4{animation-delay:.76s}
body[data-page="home"].hero-sequence-on .hero-seq-5{animation-delay:1.02s}
@keyframes heroSequenceReveal{
  0%{opacity:0;transform:translateY(22px) scale(.985);filter:blur(5px)}
  58%{opacity:1;filter:blur(1px)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}

/* Refined prestige without adding the V17 elements */
.hero-copy::before{
  box-shadow:
    0 38px 120px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(255,255,255,.06)!important;
}
.hero-actions .btn{
  position:relative;
  overflow:hidden;
}
.hero-actions .btn::after,
.cta .btn::after{
  content:"";
  position:absolute;
  top:-45%;
  bottom:-45%;
  left:-62%;
  width:44%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);
  transform:skewX(-18deg);
  transition:.58s var(--ease);
}
.hero-actions .btn:hover::after,
.cta .btn:hover::after{
  left:125%;
}
.service-card,
.gallery-card,
.pillar-card,
.feature-card,
.process-card,
.panel,
.contact-card,
.contact-form{
  will-change:transform, box-shadow;
}
.service-card:hover,
.gallery-card:hover,
.pillar-card:hover{
  transform:translateY(-10px) scale(1.008);
}
.service-card-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(135deg,rgba(255,255,255,.12),transparent 38%,rgba(242,101,34,.08)),
    linear-gradient(180deg,transparent 48%,rgba(0,45,78,.16));
  pointer-events:none;
}
.gallery-card img{
  filter:saturate(1.14) contrast(1.04) brightness(1.10)!important;
}
.gallery-card div{
  background:linear-gradient(180deg,rgba(3,29,49,.18),rgba(3,29,49,.10))!important;
  border-color:rgba(255,255,255,.15)!important;
  backdrop-filter:blur(3px)!important;
}
.page-media,
.service-hero-media{
  box-shadow:0 44px 130px rgba(0,61,100,.18)!important;
}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

@media(max-width:900px){
  body[data-page="home"] .hero-seq{
    transform:translateY(16px);
  }
}
@media(max-width:620px){
  .social-links a{
    width:42px;
    height:42px;
    border-radius:15px;
  }
}
@media (prefers-reduced-motion: reduce){
  body[data-page="home"] .hero-seq{
    opacity:1!important;
    transform:none!important;
    filter:none!important;
    animation:none!important;
  }
}


/* V19 — bons réseaux, signature header corrigée sur le bon élément, badge Premium animé */

/* Header signature: new clean element. No old .header-signature-scan rules can override this. */
.header-signature-reveal-v19{
  position:relative!important;
  display:inline-grid!important;
  place-items:center!important;
  width:292px!important;
  max-width:292px!important;
  height:42px!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  overflow:visible!important;
}
.header-signature-reveal-v19 .v19-signature-ink{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  overflow:hidden;
  clip-path:inset(0 100% 0 0);
}
.header-signature-reveal-v19 .v19-signature-ink img{
  height:38px!important;
  max-width:292px!important;
  width:auto!important;
  object-fit:contain!important;
  filter:drop-shadow(0 10px 20px rgba(0,109,168,.22))!important;
}
.header-signature-reveal-v19 .v19-signature-cursor{
  position:absolute;
  left:0;
  top:50%;
  width:2px;
  height:72%;
  border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,var(--blue),var(--orange),transparent);
  box-shadow:0 0 15px rgba(0,109,168,.50);
  opacity:0;
  visibility:hidden;
}
.header-signature-reveal-v19::after{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  bottom:-5px;
  height:1px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.38),rgba(242,101,34,.30),transparent);
  opacity:.75;
  transform:scaleX(.72);
  transition:.25s var(--ease);
}
.header-signature-reveal-v19:hover::after{
  transform:scaleX(1);
}

/* Pending: hidden, with very light ghost so the exact zone is visible */
body.v19-signature-pending .header-signature-reveal-v19 .v19-signature-ink{
  clip-path:inset(0 100% 0 0)!important;
  animation:none!important;
}
body.v19-signature-pending .header-signature-reveal-v19::before{
  content:"";
  position:absolute;
  inset:0;
  background:center/contain no-repeat url("../../images/banner-fr-blue.png");
  opacity:.08;
}
body.v19-signature-pending .header-signature-reveal-v19 .v19-signature-cursor{
  opacity:0!important;
  visibility:hidden!important;
}

/* Writing: really starts after the preloader, slowly enough to be seen */
body.v19-signature-writing .header-signature-reveal-v19::before{
  display:none!important;
}
body.v19-signature-writing .header-signature-reveal-v19 .v19-signature-ink{
  clip-path:inset(0 100% 0 0)!important;
  animation:v19SignatureReveal 4.2s cubic-bezier(.16,.74,.18,1) forwards!important;
}
body.v19-signature-writing .header-signature-reveal-v19 .v19-signature-cursor{
  opacity:1!important;
  visibility:visible!important;
  animation:v19SignatureCursor 4.2s cubic-bezier(.16,.74,.18,1) forwards!important;
}
body.v19-signature-done .header-signature-reveal-v19 .v19-signature-ink{
  clip-path:inset(0 0 0 0)!important;
  animation:none!important;
}
body.v19-signature-done .header-signature-reveal-v19 .v19-signature-cursor{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
}
body.v19-signature-done .header-signature-reveal-v19::before{
  display:none!important;
}

@keyframes v19SignatureReveal{
  0%{clip-path:inset(0 100% 0 0)}
  12%{clip-path:inset(0 91% 0 0)}
  25%{clip-path:inset(0 76% 0 0)}
  39%{clip-path:inset(0 59% 0 0)}
  54%{clip-path:inset(0 42% 0 0)}
  69%{clip-path:inset(0 26% 0 0)}
  84%{clip-path:inset(0 10% 0 0)}
  100%{clip-path:inset(0 0 0 0)}
}
@keyframes v19SignatureCursor{
  0%{left:0;opacity:.95;visibility:visible}
  12%{left:8%;opacity:1}
  25%{left:23%;opacity:1}
  39%{left:40%;opacity:1}
  54%{left:58%;opacity:1}
  69%{left:74%;opacity:.95}
  84%{left:91%;opacity:.70}
  100%{left:100%;opacity:0;visibility:hidden}
}

/* Premium Service Travel badge animation */
.hero .container.hero-grid::after{
  content:"PREMIUM SERVICE TRAVEL"!important;
  right:0!important;
  bottom:clamp(18px,3vh,34px)!important;
  top:auto!important;
  opacity:0!important;
  transform:translateY(-72px) scale(.96)!important;
}
body.hero-sequence-on .hero .container.hero-grid::after{
  animation:premiumBadgeDropV19 1.1s cubic-bezier(.18,.82,.22,1) 1.25s forwards!important;
}
@keyframes premiumBadgeDropV19{
  0%{opacity:0;transform:translateY(-72px) scale(.96);filter:blur(4px)}
  62%{opacity:1;filter:blur(0)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}

/* Footer socials with all provided links */
.footer-socials{
  margin-top:22px!important;
  padding-top:20px!important;
  border-top:1px solid rgba(255,255,255,.10)!important;
}
.footer-socials h3{
  margin:0 0 12px!important;
  font-size:18px!important;
}
.social-links{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  flex-wrap:wrap!important;
}
.social-links a{
  width:44px!important;
  height:44px!important;
  margin:0!important;
  display:grid!important;
  place-items:center!important;
  border-radius:16px!important;
  color:#fff!important;
  background:
    radial-gradient(circle at 28% 18%,rgba(255,255,255,.28),transparent 32%),
    linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.05))!important;
  border:1px solid rgba(255,255,255,.16)!important;
  box-shadow:0 18px 42px rgba(0,0,0,.18)!important;
  transition:.28s var(--ease)!important;
}
.social-links a svg{
  width:23px!important;
  height:23px!important;
  fill:currentColor!important;
}
.social-links a:hover{
  transform:translateY(-4px) scale(1.04)!important;
  background:linear-gradient(135deg,var(--blue),var(--orange))!important;
  border-color:transparent!important;
  box-shadow:0 24px 58px rgba(0,109,168,.28)!important;
}

/* Design upgrade without importing the rejected V17 blocks */
.hero-copy::before{
  background:
    linear-gradient(135deg,rgba(0,42,72,.44),rgba(0,109,168,.12)),
    radial-gradient(circle at 100% 0%,rgba(242,101,34,.10),transparent 34%)!important;
}
.hero h1{
  text-shadow:0 24px 80px rgba(0,0,0,.34),0 1px 0 rgba(255,255,255,.08)!important;
}
.hero-actions .btn{
  position:relative!important;
  overflow:hidden!important;
}
.hero-actions .btn::after,
.cta .btn::after{
  content:"";
  position:absolute;
  top:-45%;
  bottom:-45%;
  left:-62%;
  width:44%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);
  transform:skewX(-18deg);
  transition:.58s var(--ease);
}
.hero-actions .btn:hover::after,
.cta .btn:hover::after{
  left:125%;
}
.service-card:hover,
.gallery-card:hover,
.pillar-card:hover{
  transform:translateY(-10px) scale(1.008)!important;
}
.service-card-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(135deg,rgba(255,255,255,.12),transparent 38%,rgba(242,101,34,.08)),
    linear-gradient(180deg,transparent 48%,rgba(0,45,78,.16));
  pointer-events:none;
}
.gallery-card div{
  background:linear-gradient(180deg,rgba(3,29,49,.18),rgba(3,29,49,.10))!important;
  border-color:rgba(255,255,255,.15)!important;
  backdrop-filter:blur(3px)!important;
}

@media(max-width:1320px){
  .header-signature-reveal-v19{
    width:238px!important;
    max-width:238px!important;
  }
  .header-signature-reveal-v19 .v19-signature-ink img{
    height:34px!important;
    max-width:238px!important;
  }
}
@media(max-width:900px){
  .hero .container.hero-grid::after{
    position:relative!important;
    right:auto!important;
    bottom:auto!important;
    justify-self:start!important;
    margin-top:6px!important;
  }
}
@media(max-width:620px){
  .header-signature-reveal-v19{
    width:168px!important;
    max-width:168px!important;
    height:32px!important;
  }
  .header-signature-reveal-v19 .v19-signature-ink img{
    height:28px!important;
    max-width:168px!important;
  }
}
@media(max-width:390px){
  .header-signature-reveal-v19{
    display:none!important;
  }
}
@media (prefers-reduced-motion: reduce){
  .header-signature-reveal-v19 .v19-signature-ink{
    animation:none!important;
    clip-path:inset(0 0 0 0)!important;
  }
  .header-signature-reveal-v19 .v19-signature-cursor{
    display:none!important;
  }
  .hero .container.hero-grid::after{
    opacity:1!important;
    transform:none!important;
    animation:none!important;
  }
}


/* V20 — signature header corrigée par fenêtre à largeur animée + badge réel + réseaux complets */

/* Real header signature reveal: no clip-path, no old scan rules. The image is fixed left, the window width grows. */
.header-signature-v20{
  position:relative!important;
  display:inline-block!important;
  width:292px!important;
  max-width:292px!important;
  height:42px!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
  overflow:visible!important;
  flex:0 0 auto!important;
}
.header-signature-v20 img{
  height:38px!important;
  max-width:292px!important;
  width:292px!important;
  object-fit:contain!important;
  filter:drop-shadow(0 10px 20px rgba(0,109,168,.22))!important;
}
.v20-signature-ghost{
  position:absolute;
  inset:0;
  display:block;
  opacity:.10;
  pointer-events:none;
}
.v20-signature-window{
  position:absolute;
  left:0;
  top:0;
  width:0;
  height:100%;
  overflow:hidden;
  display:block;
}
.v20-signature-window img{
  position:absolute!important;
  left:0!important;
  top:50%!important;
  transform:translateY(-50%)!important;
}
.v20-signature-cursor{
  position:absolute;
  left:0;
  top:50%;
  width:2px;
  height:72%;
  border-radius:999px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,var(--blue),var(--orange),transparent);
  box-shadow:0 0 15px rgba(0,109,168,.50);
  opacity:0;
  visibility:hidden;
}
.header-signature-v20::after{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  bottom:-5px;
  height:1px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(0,109,168,.38),rgba(242,101,34,.30),transparent);
  opacity:.75;
  transform:scaleX(.72);
  transition:.25s var(--ease);
}
.header-signature-v20:hover::after{
  transform:scaleX(1);
}

/* neutralize all old signature systems */
.header-signature-scan,
.header-signature-reveal,
.header-signature-reveal-v19{
  all:unset;
}
body.signature-ready .header-signature-scan img,
body.signature-finished .header-signature-scan img,
body.v16-signature-writing .header-signature-reveal .header-signature-ink,
body.v19-signature-writing .header-signature-reveal-v19 .v19-signature-ink{
  animation:none!important;
}

/* pending */
body.v20-signature-pending .v20-signature-window{
  width:0!important;
  animation:none!important;
}
body.v20-signature-pending .v20-signature-cursor{
  opacity:0!important;
  visibility:hidden!important;
}

/* writing */
body.v20-signature-writing .v20-signature-window{
  width:0;
  animation:v20WindowWrite 4.2s cubic-bezier(.16,.74,.18,1) forwards!important;
}
body.v20-signature-writing .v20-signature-cursor{
  opacity:1!important;
  visibility:visible!important;
  animation:v20CursorWrite 4.2s cubic-bezier(.16,.74,.18,1) forwards!important;
}
body.v20-signature-writing .v20-signature-ghost{
  opacity:.08;
}

/* done */
body.v20-signature-done .v20-signature-window{
  width:100%!important;
  animation:none!important;
}
body.v20-signature-done .v20-signature-cursor{
  opacity:0!important;
  visibility:hidden!important;
  display:none!important;
}
body.v20-signature-done .v20-signature-ghost{
  opacity:0;
}

@keyframes v20WindowWrite{
  0%{width:0}
  12%{width:9%}
  25%{width:24%}
  39%{width:41%}
  54%{width:58%}
  69%{width:74%}
  84%{width:91%}
  100%{width:100%}
}
@keyframes v20CursorWrite{
  0%{left:0;opacity:.95;visibility:visible}
  12%{left:9%;opacity:1}
  25%{left:24%;opacity:1}
  39%{left:41%;opacity:1}
  54%{left:58%;opacity:1}
  69%{left:74%;opacity:.95}
  84%{left:91%;opacity:.70}
  100%{left:100%;opacity:0;visibility:hidden}
}

/* Real PREMIUM SERVICE TRAVEL badge, no pseudo that can disappear */
.hero .container.hero-grid::after{
  content:none!important;
}
.premium-service-badge-v20{
  justify-self:start;
  align-self:end;
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  max-width:100%;
  color:rgba(255,255,255,.90);
  font-size:12px;
  letter-spacing:.22em;
  font-weight:950;
  text-transform:uppercase;
  padding:11px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 18px 46px rgba(0,0,0,.14);
  backdrop-filter:blur(10px);
  opacity:0;
  transform:translateY(-70px) scale(.96);
  filter:blur(4px);
}
.premium-service-badge-v20::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--orange);
  box-shadow:0 0 0 7px rgba(242,101,34,.15);
}
body.hero-sequence-on .premium-service-badge-v20{
  animation:v20BadgeDrop 1.1s cubic-bezier(.18,.82,.22,1) 1.18s forwards!important;
}
@keyframes v20BadgeDrop{
  0%{opacity:0;transform:translateY(-70px) scale(.96);filter:blur(4px)}
  62%{opacity:1;filter:blur(0)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}

/* Footer socials exact links */
.footer-socials{
  margin-top:22px!important;
  padding-top:20px!important;
  border-top:1px solid rgba(255,255,255,.10)!important;
}
.footer-socials h3{
  margin:0 0 12px!important;
  font-size:18px!important;
}
.social-links{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  flex-wrap:wrap!important;
}
.social-links a{
  width:44px!important;
  height:44px!important;
  margin:0!important;
  display:grid!important;
  place-items:center!important;
  border-radius:16px!important;
  color:#fff!important;
  background:
    radial-gradient(circle at 28% 18%,rgba(255,255,255,.28),transparent 32%),
    linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.05))!important;
  border:1px solid rgba(255,255,255,.16)!important;
  box-shadow:0 18px 42px rgba(0,0,0,.18)!important;
  transition:.28s var(--ease)!important;
}
.social-links a svg{
  width:23px!important;
  height:23px!important;
  fill:currentColor!important;
}
.social-links a:hover{
  transform:translateY(-4px) scale(1.04)!important;
  background:linear-gradient(135deg,var(--blue),var(--orange))!important;
  border-color:transparent!important;
  box-shadow:0 24px 58px rgba(0,109,168,.28)!important;
}

/* Design upgrade, controlled and not V17-like */
.hero-copy::before{
  background:
    linear-gradient(135deg,rgba(0,42,72,.44),rgba(0,109,168,.12)),
    radial-gradient(circle at 100% 0%,rgba(242,101,34,.10),transparent 34%)!important;
}
.hero h1{
  text-shadow:0 24px 80px rgba(0,0,0,.34),0 1px 0 rgba(255,255,255,.08)!important;
}
.hero-actions .btn{
  position:relative!important;
  overflow:hidden!important;
}
.hero-actions .btn::after,
.cta .btn::after{
  content:"";
  position:absolute;
  top:-45%;
  bottom:-45%;
  left:-62%;
  width:44%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);
  transform:skewX(-18deg);
  transition:.58s var(--ease);
}
.hero-actions .btn:hover::after,
.cta .btn:hover::after{
  left:125%;
}
.service-card:hover,
.gallery-card:hover,
.pillar-card:hover{
  transform:translateY(-10px) scale(1.008)!important;
}
.gallery-card div{
  background:linear-gradient(180deg,rgba(3,29,49,.18),rgba(3,29,49,.10))!important;
  border-color:rgba(255,255,255,.15)!important;
  backdrop-filter:blur(3px)!important;
}

@media(max-width:1320px){
  .header-signature-v20{
    width:238px!important;
    max-width:238px!important;
  }
  .header-signature-v20 img{
    height:34px!important;
    width:238px!important;
    max-width:238px!important;
  }
}
@media(max-width:900px){
  .premium-service-badge-v20{
    margin-top:6px;
  }
}
@media(max-width:620px){
  .header-signature-v20{
    width:168px!important;
    max-width:168px!important;
    height:32px!important;
  }
  .header-signature-v20 img{
    height:28px!important;
    width:168px!important;
    max-width:168px!important;
  }
}
@media(max-width:390px){
  .header-signature-v20{
    display:none!important;
  }
}
@media (prefers-reduced-motion: reduce){
  .v20-signature-window{
    width:100%!important;
    animation:none!important;
  }
  .v20-signature-cursor{
    display:none!important;
  }
  .premium-service-badge-v20{
    opacity:1!important;
    transform:none!important;
    filter:none!important;
    animation:none!important;
  }
}


/* V21 — Correction finale signature + hero non désorganisé */

/* Header signature : pas de texte translucide derrière pendant l'animation.
   Seule la partie révélée par la fenêtre d'animation doit apparaître. */
.header-signature-v20 .v20-signature-ghost,
body.v20-signature-pending .header-signature-v20 .v20-signature-ghost,
body.v20-signature-writing .header-signature-v20 .v20-signature-ghost,
body.v20-signature-done .header-signature-v20 .v20-signature-ghost{
  display:none !important;
  opacity:0 !important;
  visibility:hidden !important;
}

/* La signature révélée reste le seul calque visible */
.header-signature-v20 .v20-signature-window{
  background:transparent !important;
}
body.v20-signature-writing .header-signature-v20 .v20-signature-window{
  will-change:width;
}

/* Hero : les éléments gardent exactement leur place.
   L'animation est uniquement visuelle : opacity + petit translateY, sans casser le layout. */
body[data-page="home"] .hero-seq{
  opacity:0;
  transform:translateY(18px);
  filter:blur(3px);
}
body[data-page="home"].hero-sequence-on .hero-seq{
  animation:v21HeroCleanReveal .72s cubic-bezier(.18,.82,.22,1) forwards !important;
}
body[data-page="home"].hero-sequence-on .hero-seq-1{animation-delay:.08s !important}
body[data-page="home"].hero-sequence-on .hero-seq-2{animation-delay:.24s !important}
body[data-page="home"].hero-sequence-on .hero-seq-3{animation-delay:.40s !important}
body[data-page="home"].hero-sequence-on .hero-seq-4{animation-delay:.56s !important}
body[data-page="home"].hero-sequence-on .hero-seq-5{animation-delay:.72s !important}

@keyframes v21HeroCleanReveal{
  from{opacity:0;transform:translateY(18px);filter:blur(3px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}
}

/* PREMIUM SERVICE TRAVEL ne doit pas déplacer les blocs du hero.
   Il est retiré du flux et placé comme l’ancien badge premium. */
.hero-grid{
  position:relative !important;
}
.premium-service-badge-v20{
  position:absolute !important;
  right:0 !important;
  bottom:clamp(18px,3vh,34px) !important;
  z-index:4;
  margin:0 !important;
  justify-self:auto !important;
  align-self:auto !important;
  opacity:0;
  transform:translateY(-58px);
  filter:blur(3px);
}
body.hero-sequence-on .premium-service-badge-v20{
  animation:v21PremiumBadgeDrop .95s cubic-bezier(.18,.82,.22,1) .92s forwards !important;
}
@keyframes v21PremiumBadgeDrop{
  0%{opacity:0;transform:translateY(-58px);filter:blur(3px)}
  70%{opacity:1;filter:blur(0)}
  100%{opacity:1;transform:translateY(0);filter:blur(0)}
}

/* Le badge ne prend pas de place sur mobile non plus */
@media(max-width:900px){
  .premium-service-badge-v20{
    position:relative !important;
    right:auto !important;
    bottom:auto !important;
    margin-top:6px !important;
    justify-self:start !important;
  }
}

/* Réduction mouvement */
@media (prefers-reduced-motion: reduce){
  body[data-page="home"] .hero-seq,
  .premium-service-badge-v20{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    animation:none !important;
  }
}


/* PHP OWASP contact form additions */
.vatis-hp-field{
  position:absolute!important;
  left:-10000px!important;
  top:auto!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
  opacity:0!important;
}
.form-status{
  margin-top:12px;
  padding:14px 16px;
  border-radius:16px;
  font-weight:850;
  line-height:1.5;
}
.form-status.ok{
  background:rgba(25,135,84,.10);
  color:#0f5132;
  border:1px solid rgba(25,135,84,.22);
}
.form-status.ko{
  background:rgba(220,53,69,.10);
  color:#842029;
  border:1px solid rgba(220,53,69,.22);
}
.contact-form button[disabled]{
  opacity:.72;
  cursor:wait;
}


/* V2 PHP fix: Google Translate + footer overflow */
html,
body{
  margin:0 !important;
  padding:0 !important;
  overflow-x:hidden !important;
}
body{
  min-height:100vh;
}
.footer{
  margin-bottom:0 !important;
}
.footer-bottom{
  margin-bottom:0 !important;
  padding-bottom:0 !important;
}
#google_translate_element{
  position:absolute!important;
  left:-9999px!important;
  top:-9999px!important;
  width:1px!important;
  height:0!important;
  max-height:0!important;
  overflow:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
#google_translate_element select,
.goog-te-combo{
  position:absolute!important;
  left:-9999px!important;
  top:-9999px!important;
}
.goog-te-banner-frame,
.goog-te-banner-frame.skiptranslate,
iframe.goog-te-banner-frame,
.goog-te-balloon-frame,
.VIpgJd-ZVi9od-ORHb-OEVmcd,
body > .skiptranslate{
  display:none!important;
  visibility:hidden!important;
  height:0!important;
  max-height:0!important;
  overflow:hidden!important;
}
body{
  top:0!important;
}
.skiptranslate{
  font-size:0!important;
}
.skiptranslate *{
  font-size:0!important;
}
.language-menu{
  direction:ltr;
}
html[dir="rtl"] body{
  direction:rtl;
}
html[dir="rtl"] .desktop-nav,
html[dir="rtl"] .mobile-nav,
html[dir="rtl"] .header-inner,
html[dir="rtl"] .footer-grid,
html[dir="rtl"] .hero-grid{
  direction:rtl;
}
html[dir="rtl"] .language-menu,
html[dir="rtl"] .language-switcher{
  direction:ltr;
}


/* PHP OWASP V3 — language selector clickability + Google Translate working */
.language-switcher{
  position:relative!important;
  z-index:10050!important;
  pointer-events:auto!important;
}
.language-toggle{
  pointer-events:auto!important;
  cursor:pointer!important;
  user-select:none!important;
}
.language-menu{
  position:absolute!important;
  right:0!important;
  top:calc(100% + 12px)!important;
  min-width:210px!important;
  padding:10px!important;
  border-radius:22px!important;
  background:rgba(255,255,255,.99)!important;
  border:1px solid rgba(0,109,168,.16)!important;
  box-shadow:0 30px 90px rgba(0,45,78,.24)!important;
  display:grid!important;
  gap:6px!important;
  z-index:10060!important;
  opacity:0!important;
  visibility:hidden!important;
  transform:translateY(-8px) scale(.96)!important;
  pointer-events:none!important;
  transition:.22s var(--ease)!important;
  direction:ltr!important;
}
.language-switcher.open .language-menu{
  opacity:1!important;
  visibility:visible!important;
  transform:translateY(0) scale(1)!important;
  pointer-events:auto!important;
}
.language-menu button{
  appearance:none!important;
  border:0!important;
  width:100%!important;
  display:flex!important;
  align-items:center!important;
  gap:9px!important;
  padding:12px 13px!important;
  border-radius:15px!important;
  background:transparent!important;
  color:#16364e!important;
  font-weight:850!important;
  cursor:pointer!important;
  text-align:left!important;
  pointer-events:auto!important;
  font-size:14px!important;
}
.language-menu button:hover,
.language-menu button.active{
  background:linear-gradient(135deg,rgba(0,109,168,.11),rgba(242,101,34,.10))!important;
  color:var(--blue-dark)!important;
}
.language-switcher,
.language-switcher *{
  translate:no;
}
#google_translate_element,
#google_translate_element *,
.goog-te-gadget,
.goog-te-combo{
  position:absolute!important;
  left:-9999px!important;
  top:-9999px!important;
  width:1px!important;
  height:1px!important;
  max-height:1px!important;
  overflow:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
iframe.goog-te-banner-frame,
.goog-te-banner-frame,
.goog-te-balloon-frame,
.VIpgJd-ZVi9od-ORHb-OEVmcd,
body > .skiptranslate{
  display:none!important;
  visibility:hidden!important;
  height:0!important;
  max-height:0!important;
  overflow:hidden!important;
}
html,
body{
  top:0!important;
  margin-bottom:0!important;
  padding-bottom:0!important;
  overflow-x:hidden!important;
}
.footer{
  margin-bottom:0!important;
}
.whatsapp{
  bottom:22px!important;
}
@media(max-width:620px){
  .language-menu{
    right:-52px!important;
    min-width:190px!important;
  }
}


/* PHP OWASP V4 — hide temporary Google Translate spinner/loading artifacts */
.goog-te-spinner-pos,
.goog-te-spinner,
.goog-te-spinner-animation,
.goog-te-spinner-animation div,
.goog-te-gadget-icon,
.goog-logo-link,
.goog-te-gadget span,
#goog-gt-tt,
.goog-tooltip,
.goog-tooltip:hover,
.goog-text-highlight{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
  width:0!important;
  height:0!important;
  max-width:0!important;
  max-height:0!important;
  overflow:hidden!important;
  position:absolute!important;
  left:-99999px!important;
  top:-99999px!important;
}
.goog-te-gadget{
  font-size:0!important;
  line-height:0!important;
  color:transparent!important;
}
body > .skiptranslate,
.skiptranslate,
.skiptranslate iframe,
.skiptranslate .goog-te-spinner-pos{
  display:none!important;
  visibility:hidden!important;
  height:0!important;
  max-height:0!important;
  overflow:hidden!important;
}


/* PHP OWASP V5 — multilingual signature images FR/EN */
.vatis-signature-img{
  transition:opacity .22s ease, filter .22s ease;
}
.classic-scan-writing .preloader-signature{
  object-fit:contain!important;
}
.footer-signature-white{
  filter:none!important;
  opacity:.98!important;
}
.footer .footer-signature{
  object-fit:contain!important;
}


/* PHP OWASP V6 — multilingual hero 10 years badge */
.vatis-hero-badge-img{
  transition:opacity .24s ease, transform .24s ease;
}
.hero-badge img.vatis-hero-badge-img{
  object-fit:contain!important;
}
