/* CYLABS Base UI — v1.0 (extrait de index(12).html, +helpers génériques) */
* { margin:0; padding:0; box-sizing:border-box; }

:root{
  --primary:#00d4ff; --secondary:#0066ff;
  --dark:#0a0e27; --darker:#050811;
  --light:#ffffff; --gray:#8892b0;
}

/* Base */
body{
  font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background:var(--darker); color:var(--light);
  line-height:1.6; overflow-x:hidden;
}

/* Mise en valeur des mots-clés */
strong {
  color: var(--primary);
  font-weight: 600; /* légèrement renforcé, mais pas trop gras */
}
/* Navbar */
.navbar{
  position:fixed; top:0; width:100%;
  background:rgba(10,14,39,.95); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,212,255,.1);
  z-index:1000; transition:all .3s ease;
}
.navbar.scrolled{ box-shadow:0 10px 30px rgba(0,0,0,.5); }
.nav-container{
  max-width:1400px; margin:0 auto; padding:0 40px;
  display:flex; justify-content:space-between; align-items:center; height:80px;
}
.logo{ display:flex; align-items:center; text-decoration:none; }
.logo img{ height:50px; width:auto; }
.nav-menu{ display:flex; gap:40px; align-items:center; }
.menu-toggle{ display:none; background:transparent; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:5px; }
.menu-toggle span{ width:25px; height:3px; background:var(--primary); transition:all .3s ease; border-radius:2px; }
.menu-toggle.active span:nth-child(1){ transform:rotate(45deg) translate(8px,8px); }
.menu-toggle.active span:nth-child(2){ opacity:0; }
.menu-toggle.active span:nth-child(3){ transform:rotate(-45deg) translate(7px,-7px); }
.nav-link{
  color:var(--gray); text-decoration:none; font-size:15px; font-weight:500; transition:color .3s ease; position:relative;
}
.nav-link::after{
  content:''; position:absolute; bottom:-5px; left:0; width:0; height:2px; background:var(--primary); transition:width .3s ease;
}
.nav-link:hover,
.nav-link.active{
  color: var(--primary);
}
.nav-link:hover::after,
.nav-link.active::after{
  width: 100%;
}
.btn-contact{
  padding:10px 25px; background:linear-gradient(135deg,var(--primary),var(--secondary));
  color:var(--light); border:none; border-radius:5px; font-weight:600; cursor:pointer; text-decoration:none;
  transition:transform .3s ease, box-shadow .3s ease;
}
.btn-contact:hover{ transform:translateY(-2px); box-shadow:0 10px 25px rgba(0,212,255,.3); }

/* Hero */
.hero{
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; padding-top:80px;
}

/* HERO — Vidéo centrée avec vrais bords arrondis */
.hero-bg-wrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  width: min(1100px, 90vw);
  height: min(700px, 60vh);

  border-radius: 32px;                     /* 👉 arrondi visible */
  overflow: hidden;                        /* 👉 coupe la vidéo aux coins */
  z-index: 0;
  pointer-events: none;

  background: rgba(0, 0, 0, 0.6);          /* contraste derrière la vidéo */
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.7);
}
/* L'image elle-même */
.hero-bg-image {
  width: 100%;
  height: 100%;
  background-image: url("../images/Cockpit2.png");  /* 👉 remplace ici */
  background-size: contain;                /* image non rognée */
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.26;                            /* transparence */
  filter: blur(0px);                        /* léger flou optionnel */
}

/* La vidéo suit la forme du wrapper */
.hero-bg-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0.32;                           /* transparence */
  /* border-radius: inherit;  <-- pas obligatoire car overflow fait le job */
  filter: blur(0px);                     /* léger effet “soft” optionnel */
}



.grid-bg{
  position:absolute; inset:0;
   z-index: 0;
  background-image:
    linear-gradient(rgba(0,212,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,.03) 1px, transparent 1px);
  background-size:50px 50px; animation:gridMove 20s linear infinite;
}
@keyframes gridMove{ 0%{transform:translate(0,0);} 100%{transform:translate(50px,50px);} }
.hero-content{ max-width:1280px; text-align:center; z-index:2; padding:0 40px; position: relative; }
.hero-tag{
  display:inline-block; padding:8px 20px; background:rgba(0,212,255,.1);
  border:1px solid var(--primary); border-radius:30px; color:var(--primary);
  font-size:14px; font-weight:600; margin-bottom:30px; letter-spacing:1px;
}
.hero h1{ margin-bottom:20px; line-height:1.2; }
.hero-logo{ height:120px; width:auto; margin-bottom:20px; }
.hero-subtitle{ font-size:22px; color:var(--gray); max-width:800px; margin:0 auto 40px; }

.scroll-indicator{
  position:absolute; bottom:40px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px; cursor:pointer; z-index:10; animation:bounce 2s infinite;
}
.scroll-indicator svg{ width:auto; height:60px; opacity:.6; stroke:var(--primary); fill:none; stroke-width:2; animation:pulse 2s infinite; }
@keyframes bounce{
  0%,20%,50%,80%,100%{ transform:translateX(-50%) translateY(0); }
  40%{ transform:translateX(-50%) translateY(-10px); }
  60%{ transform:translateX(-50%) translateY(-5px); }
}
@keyframes pulse{ 0%,100%{opacity:.6;} 50%{opacity:1;} }

/* Section headers */
.solutions{ padding:40px 40px; max-width:1600px; margin:0 auto; position:relative; }
.solutions::before,
.contact::before{
  content:''; position:absolute; top:-100px; left:0; right:0; height:100px;
  background:linear-gradient(to bottom, transparent, var(--darker)); pointer-events:none;
}
.section-header{ text-align:center; margin-bottom:80px; }
.section-tag{ color:var(--primary); font-size:14px; font-weight:600; letter-spacing:2px; text-transform:uppercase; margin-bottom:15px; }
.section-title{ font-size:48px; font-weight:700; margin-bottom:20px; }
.section-description{ text-align:justify; font-size:18px; color:var(--gray); max-width:900px; margin:0 auto; }
.section-description-short{ text-align:center; font-size:18px; color:var(--gray); max-width:900px; margin:0 auto; }

/* Cards (solutions) */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(420px,1fr));
  gap:30px;
  margin-top:60px;
}
.solution-card{
  background:linear-gradient(135deg, rgba(10,14,39,.9), rgba(5,8,17,.9));
  border:1px solid rgba(0,212,255,.1);
  border-radius:15px;
  padding:40px;
  text-decoration:none;
  color:var(--light);
  transition:all .4s ease;
  position:relative;
  overflow:hidden;
  min-height:250px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.card-background{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:.3; transition:all .4s ease; z-index:0;
}
.solution-card:hover .card-background{ opacity:.5; transform:scale(1.05); }
.solution-card::before{
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(0,212,255,.1), rgba(0,102,255,.1));
  opacity:0; transition:opacity .4s ease; z-index:0;
}
.solution-card:hover{
  transform:translateY(-10px);
  border-color:var(--primary);
  box-shadow:0 20px 40px rgba(0,212,255,.2);
}
.solution-card:hover::before{ opacity:1; }

.card-tag{
  display:inline-block; padding:5px 15px; background:rgba(0,212,255,.1);
  border-radius:20px; color:var(--primary); font-size:12px; font-weight:600; margin-bottom:15px; position:relative; z-index:1;
}
.card-title{ font-size:24px; font-weight:700; margin-bottom:15px; position:relative; z-index:1; }
.card-description{ color:var(--gray); font-size:15px; line-height:1.7; margin-bottom:20px; position:relative; z-index:1; }
.card-link{
  display:inline-flex; align-items:center; gap:8px;
  color:var(--primary); font-weight:600; font-size:14px;
  position:relative; z-index:1;
}
.card-link::after{ content:'→'; transition:transform .3s ease; }
.solution-card:hover .card-link::after{ transform:translateX(5px); }

/* Contact */
.contact{ padding:120px 40px; text-align:center; position:relative; }
.contact-box{
  max-width:800px; margin:0 auto; padding:60px;
  background:linear-gradient(135deg, rgba(10,14,39,.9), rgba(5,8,17,.9));
  border:1px solid rgba(0,212,255,.2); border-radius:20px;
}
.contact h2{ font-size:42px; margin-bottom:20px; }
.contact p{ font-size:18px; color:var(--gray); margin-bottom:40px; }
.contact-email{
  display:inline-block; font-size:28px; color:var(--primary); text-decoration:none; font-weight:600;
  padding:20px 40px; border:2px solid var(--primary); border-radius:10px; transition:all .3s ease;
}
.contact-email:hover{ background:rgba(0,212,255,.1); transform:scale(1.05); }

/* Footer */
.footer{ padding:40px; text-align:center; border-top:1px solid rgba(0,212,255,.1); color:var(--gray); font-size:14px; }
.footer-links{ margin-top:15px; }
.footer-links a{ color:var(--gray); text-decoration:none; margin:0 15px; transition:color .3s ease; }
.footer-links a:hover{ color:var(--primary); }

/* --- Helpers génériques ajoutés --- */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:30px; }
@media (max-width:900px){ .grid-2{ grid-template-columns:1fr; } }



.content-card{
  background:linear-gradient(135deg, rgba(10,14,39,.9), rgba(5,8,17,.9));
  border:1px solid rgba(0,212,255,.1);
  border-radius:15px; padding:24px; position:relative; overflow:hidden;
}
.content-card h3{ font-size:24px; margin-bottom:10px; }
.content-card h4{ font-size:18px; margin-bottom:8px; }
.content-card img{
  width: 100%;
  height: auto;
  object-fit: contain;
}
.content-card .lead{ color:var(--gray); margin-bottom:12px; }
.media{ border-radius:12px; overflow:hidden; border:1px solid rgba(0,212,255,.1); }
.media img,.media video{ width:100%; height:auto; display:block; }

/* Iframe shell (fusion des 2 versions) */
.iframe-shell{
  border:1px solid rgba(0,212,255,.1);
  border-radius:12px;
  overflow:hidden;
  background:rgba(10,14,39,.5);
  display:flex;
  justify-content:center;
  align-items:center;
  margin:40px auto;
  width:100%;
}
.iframe-shell iframe{
  width:100%;
  height:90vh;
  border:none;
  border-radius:12px;
  background:rgba(0,0,0,0.1);
  box-shadow:0 0 20px rgba(0,0,0,0.4);
  display:block;
}
@media (max-width:900px){
  .iframe-shell iframe{
    width:100%;
    height:80vh;
  }
}

/* Responsive global */
@media (max-width:768px){
  .menu-toggle{ display:flex; }
  .nav-menu{
    position:fixed; top:80px; left:-100%; width:100%; height:calc(100vh - 80px);
    background:rgba(10,14,39,.98); backdrop-filter:blur(10px);
    flex-direction:column; justify-content:flex-start; padding:40px; gap:30px; transition:left .3s ease;
    border-top:1px solid rgba(0,212,255,.1);
  }
  .nav-menu.active{ left:0; }
  .nav-link{ font-size:20px; width:100%; text-align:center; padding:15px 0; }
  .btn-contact{ width:100%; text-align:center; padding:15px 25px; }
  .hero-logo{ height:80px; }
  .hero-subtitle{ font-size:16px; }
  .scroll-indicator{ bottom:30px; }
  .scroll-indicator svg{ width:30px; height:30px; }
  .cards-grid{ grid-template-columns:1fr; }
  .section-title{ font-size:28px; }
  .solution-card{ min-height:250px; }
  .nav-container{ padding:0 20px; }
  .solutions{ padding:40px 20px; }
  .hero{ min-height:100vh; padding:100px 20px 60px; }
  .contact{ padding:80px 20px; }
  .contact-box{ padding:40px 25px; }
  .contact h2{ font-size:32px; }
  .contact p{ font-size:16px; }
  .contact-email{ font-size:20px; padding:15px 30px; }
}

/* 2 grosses cards dans la grille */
.cards-grid.feature-cards{
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}

/* Variante "media" : image / vidéo en haut, contenu qui commence en haut */
.solution-card.solution-card-media{
  min-height:50;
  justify-content:flex-start;
  padding:32px;
}

/* Variante "info" : pas d'interaction, pas d'effet de survol */
.solution-card.info-card{
  cursor:default;
}
.solution-card.info-card:hover{
  transform:none;
  border-color:rgba(0,212,255,.1);
  box-shadow:none;
}
.solution-card.info-card:hover::before{
  opacity:0;
}
.solution-card.info-card:hover .card-background{
  opacity:.3;
  transform:none;
}

/* Bloc media en haut de la card (image ou vidéo) */
.solution-media{
  border-radius:12px;
  overflow:hidden;
  border:1px solid rgba(0,212,255,.15);
  margin-bottom:24px;
}
.solution-media img,
.solution-media video,
.solution-media iframe{
  width:100%;
  height:auto;
  display:block;
}

.solution-mediasm img{
  width:20%;
    height:auto;
  display:flex;
  border:2px solid rgba(0,212,255,.35);
  justify-content:center;
  align-items:center;
}

/* Bloc texte sous le media */
.solution-copy{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* Sous-titre léger sous le titre */
.card-subtitle{
  font-size:14px;
  color:var(--gray);
  margin-bottom:4px;
}

/* Section "no-code" (Qlik style adapté CYLABS) */
.no-code-section{
  padding-top:80px;
}
.no-code-grid{
  align-items:center;
  margin-bottom:50px;
  margin-left:0px;
}

.no-code-text{

  max-width:620px;
  margin-left:20px;
}
.no-code-title{
  font-size:44px;
  line-height:1.15;
  font-weight:700;
  margin-bottom:20px;
}
.no-code-lead{
  font-size:17px;
  color:var(--gray);
 align-items:center;
  margin-bottom:0px;
  margin-left:20px;
}
.no-code-visual{
  max-width:800px;
  margin-left:auto;
}
.no-code-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:24px;
}
.no-code-card{
  background:rgba(10,14,39,.35);
  border:1px solid rgba(0,212,255,.18);
  border-radius:15px;
  padding:24px 26px;
  box-shadow:0 12px 30px rgba(0,0,0,.4);
}
.no-code-card h3{
  font-size:18px;
  font-weight:700;
  margin-bottom:10px;
}
.no-code-card p{
  font-size:15px;
  color:var(--gray);
}

.no-code-logos{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
  align-items:center;
}

.no-code-logos img{
  height:22px;         /* taille des logos */
  width:auto;
  display:block;
  opacity:0.9;         /* léger adoucissement */
}

@media (max-width:900px){
  .no-code-section{
    padding:80px 20px;
  }
  .no-code-grid{
    margin-bottom:40px;
  }
  .no-code-title{
    font-size:32px;
  }
}

/* ===== PAGE CONTACT — compléments ===== */

.page-contact {
  background: var(--darker);
}

/* Mise en forme du formulaire */

.contact-form {
  margin-top: 30px;
  text-align: left;
}

.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.field label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gray);
}

.field input,
.field textarea {
  border-radius: 8px;
  border: 1px solid rgba(0, 212, 255, 0.25);
  background: rgba(5, 8, 17, 0.9);
  padding: 10px 12px;
  color: var(--light);
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  resize: vertical;
}

.field textarea {
  min-height: 110px;
}

.field input::placeholder,
.field textarea::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.field input:focus,
.field textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.4);
  background: rgba(10, 14, 39, 0.95);
}

.field--full {
  margin-bottom: 20px;
}

/* Champ honeypot (caché à l’écran) */
.hp-field {
  position: absolute;
  left: -9999px;
  opacity: 0;
  visibility: hidden;
}

/* Bouton */
.contact-submit {
  margin-top: 5px;
  width: 100%;
  text-align: center;
}

/* Texte de confidentialité */
.contact-privacy {
  margin-top: 12px;
  font-size: 12px;
  color: var(--gray);
}

/* Messages de statut (succès / erreur) */

.contact-status-wrapper {
  margin-top: 15px;
}

.contact-status {
  font-size: 14px;
  padding: 10px 12px;
  border-radius: 8px;
  margin: 0 0 10px;
}

.contact-status--success {
  background: rgba(0, 180, 110, 0.08);
  border: 1px solid rgba(0, 180, 110, 0.4);
  color: #8ce0b5;
}

.contact-status--error {
  background: rgba(255, 80, 80, 0.08);
  border: 1px solid rgba(255, 80, 80, 0.4);
  color: #ff9b9b;
}

/* Bloc contact direct */

.contact-direct {
  margin-top: 30px;
  text-align: center;
}

.contact-direct p {
  margin-bottom: 8px;
  font-size: 14px;
  color: var(--gray);
}

.contact-email {
  font-weight: 600;
  text-decoration: none;
  color: var(--primary);
}

.contact-email:hover {
  text-decoration: underline;
}

/* Responsive */

@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .contact-submit {
    width: 100%;
  }

  .contact-box {
    padding: 30px 20px;
  }

  .contact h2 {
    font-size: 26px;
  }

  .contact p {
    font-size: 15px;
  }
}

.intro-badge, .chip { display:inline-block; font-size:12px; padding:6px 10px; border:1px solid var(--border); border-radius:999px; background: rgba(255,255,255,.94); color: #0a0e27; }