/* =========================================================
   FORGE NewTechnologies — Style global
   Palette 1 (innovation + confiance) : Bleu tech + cyan
   ========================================================= */

/* ---- Couleurs & base Bootstrap overrides ---- */
:root {
  /* Textes sur fond clair */
  --text-dark: #0b2b66;
  --text-muted-dark: #6c757d;

  /* Textes sur fond sombre */
  --text-light: #f4f8ff;
  --text-muted-light: #cfe0ff;

  /* Liens / accents */
  --link-color: var(--bs-info);
  --link-hover: #33cfff;
}

/* Sur fond sombre */
.bg-hero,
[data-bg="dark"] {
  color: var(--text-light);
}
.bg-hero h1, .bg-hero h2, .bg-hero h3,
[data-bg="dark"] h1, [data-bg="dark"] h2, [data-bg="dark"] h3 {
  color: var(--text-light);
}
.bg-hero .text-secondary,
[data-bg="dark"] .text-secondary {
  color: var(--text-muted-light) !important;
}
.bg-hero a,
[data-bg="dark"] a {
  color: var(--link-color);
}
.bg-hero a:hover,
[data-bg="dark"] a:hover {
  color: var(--link-hover);
}

/* Sur fond clair */
[data-bg="light"] {
  color: var(--text-dark);
}
[data-bg="light"] .text-secondary {
  color: var(--text-muted-dark) !important;
}
[data-bg="light"] a {
  color: var(--bs-primary);
}
[data-bg="light"] a:hover {
  color: #003d99;
}

/* ---- Reset & typographie ---- */
* { box-sizing: border-box; }
body { font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif; }
img { max-width: 100%; height: auto; display: block; }

/* ---- Background global (fixe) + Canvas animé en dessous ---- */
body{
  background:
    radial-gradient(1600px 800px at 10% -10%, rgba(var(--bs-primary-rgb), .20), transparent 60%),
    radial-gradient(1600px 800px at 110% -10%, rgba(var(--bs-info-rgb), .18), transparent 60%),
    linear-gradient(180deg, #0b2b66 0%, #0d3d95 55%, #0b2b66 100%) fixed;
  background-attachment: fixed;
}

/* Canvas réseau animé, fixé derrière tout */
#bg-net{
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  z-index: -2;
  pointer-events: none;
  opacity: .25;          /* baisse/monte l’intensité visuelle */
}

/* Respect des préférences d’accessibilité */
@media (prefers-reduced-motion: reduce) {
  #bg-net{ display: none; }
}

/* ---- Utilitaires ---- */
.py-6{ padding-block: 5.5rem; }
.kicker{ letter-spacing: .15em; font-size:.78rem; font-weight:700; color: var(--bs-primary); text-transform: uppercase; }
.text-gradient{
  background: linear-gradient(90deg, var(--bs-primary), var(--bs-info));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
/* remplace tout le bloc .offcanvas par ceci */
.offcanvas {
  --bs-offcanvas-bg: rgba(10, 18, 30, .96);
  backdrop-filter: saturate(100%) blur(8px);
  border: 1px solid rgba(255,255,255,.06);
}

/* sort à droite */
.offcanvas-end {
  border-radius: 1rem 0 0 1rem; /* arrondi à gauche */
}

/* si un jour tu utilises offcanvas-start (côté gauche) */
.offcanvas-start {
  border-radius: 0 1rem 1rem 0; /* arrondi à droite */
}

/* largeur confortable sur mobile */
@media (max-width: 991.98px){
  .offcanvas { width: min(86vw, 380px); }
}

/* Toggler burger lisible en fond sombre */
.header-blur .navbar-toggler {
  border-color: rgba(255,255,255,.25);
}
.header-blur .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}


/* Liens et focus */
a:not(.btn):hover { text-decoration: underline; text-underline-offset: 2px; }
:focus-visible {
  outline: 3px solid rgba(var(--bs-info-rgb), .5);
  outline-offset: 2px;
  border-radius: .5rem;
}

/* Boutons */
.btn-primary:hover { filter: brightness(0.95) saturate(1.05); }
.btn-outline-primary:hover { background-color: rgba(var(--bs-primary-rgb), .08); }

/* ---- Navbar / Offcanvas ---- */
.navbar .navbar-brand img{ border-radius: .25rem; }
.offcanvas {
  --bs-offcanvas-bg: rgba(10, 18, 30, .96);
  backdrop-filter: saturate(100%) blur(8px);
  border-left: 1px solid rgba(255,255,255,.06);
  border-radius: 1rem 0 0 1rem;
}
.offcanvas .nav-link {
  padding: .75rem 0;
}
.offcanvas .dropdown-menu {
  --bs-dropdown-bg: #0b1528;
  --bs-dropdown-link-color: #e2e8f0;
  --bs-dropdown-link-hover-bg: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}

/* ---- Hero ---- */
.hero-card img{ aspect-ratio: 16/10; object-fit: cover; }
/* On désactive les anciennes formes si elles existent */
.shape-1, .shape-2{ display: none !important; }

/* ---- Logos partenaires ---- */
.logo-cloud img{
  filter: grayscale(1);
  opacity:.8;
  transition: filter .2s ease, opacity .2s ease, transform .2s ease;
  max-height: 36px;
}
.logo-cloud img:hover{ filter:none; opacity:1; transform: translateY(-2px); }

/* ---- Sections (fonds lissés transparents pour laisser voir l’arrière-plan) ---- */
.section-band,
.section-band-2,
.section-blog,
.section-testimonials,
.bg-body-secondary{
  background: transparent !important;
  box-shadow: none;
  border: 0;
}

/* Bloc “papier” pour détacher certains contenus (portfolio, formulaires, etc.) */
.section-paper{
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  border-radius: var(--radius-xxl);
}

/* Séparateur subtil entre blocs */
.section-sep{ border-top: 1px solid rgba(255,255,255,.08); }

/* ---- Cartes ---- */
.card{
  border-radius: var(--radius-xxl);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
  overflow: hidden;
}
.card:hover{ box-shadow: 0 14px 40px rgba(0,0,0,.06); }
.card-img-top{ border-bottom: 1px solid rgba(0,0,0,.06); aspect-ratio: 4/3; object-fit: cover; }


/* ---- Blog ---- */
.section-blog .card:hover{ transform: translateY(-4px); }

/* ---- Back-to-top ---- */
.back-to-top{
  position: fixed; right: 1rem; bottom: 1rem; width: 48px; height: 48px; display:none;
  box-shadow: 0 .5rem 1.25rem rgba(0,0,0,.15);
}

/* ---- Animations ---- */
@keyframes fadeUp{ from{ transform: translateY(12px); opacity: 0 } to{ transform:none; opacity: 1 } }
@keyframes fadeIn{ from{ opacity: 0 } to{ opacity: 1 } }
.animate-fade-up{ animation: fadeUp .7s both; }
.animate-fade-in{ animation: fadeIn .8s both; }
.animate-delay-1{ animation-delay: .12s }
.animate-delay-2{ animation-delay: .24s }
.animate-delay-3{ animation-delay: .36s }

/* ---- Mode sombre (si activé via bouton) ---- */
[data-bs-theme="dark"] body{
  color: #e6eefb;
  --bs-body-bg: #0b1220;
  --bs-body-color: #e6eefb;
  background:
    radial-gradient(1600px 800px at 10% -10%, rgba(0, 140, 255, .22), transparent 60%),
    radial-gradient(1600px 800px at 110% -10%, rgba(0, 184, 217, .20), transparent 60%),
    linear-gradient(180deg, #081734 0%, #0a1f4d 55%, #081734 100%) fixed;
}
[data-bs-theme="dark"] .section-paper{
  background: rgba(15,23,42,.6);
  border-color: rgba(255,255,255,.06);
}
[data-bs-theme="dark"] .card{
  background: rgba(12,18,33,.7);
  border-color: rgba(255,255,255,.06);
}
[data-bs-theme="dark"] .card-img-top{ border-bottom-color: rgba(255,255,255,.06); }
[data-bs-theme="dark"] .header-blur{ background-color: rgba(16,23,42,.5); }
[data-bs-theme="dark"] .header-blur.scrolled{ background-color: rgba(16,23,42,.7); }

#work .card {
  background-color: #fff;
  color: #212529;
}

#work .card .text-secondary {
  color: #555 !important;
}

/* Section métiers sur fond bleu */
#services {
  background: linear-gradient(180deg, #0b2b66 0%, #0d3d95 100%);
  color: #fff;
}

#services .card {
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #fff;
  backdrop-filter: blur(6px);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

#services .card .card-text,
#services .card .text-secondary {
  color: rgba(255,255,255,0.85) !important;
}

#services .btn-outline-primary {
  border-color: #4da3ff;
  color: #4da3ff;
}

#services .btn-outline-primary:hover {
  background-color: #4da3ff;
  color: #fff;
}

#services .card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
}


/* Section métiers sur fond bleu */
#blog {
  background: linear-gradient(180deg, #0b2b66 0%, #0d3d95 100%);
  color: #fff;
}

#blog .card {
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #fff;
  backdrop-filter: blur(6px);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

#blog .card .card-text,
#blog .card .text-secondary {
  color: rgba(255,255,255,0.85) !important;
}

#blog .btn-outline-primary {
  border-color: #4da3ff;
  color: #4da3ff;
}

#blog .btn-outline-primary:hover {
  background-color: #4da3ff;
  color: #fff;
}

#blog .card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
}
/* --- Unifier le style du Portfolio avec la section Métiers --- */


/* Portfolio : pas de soulignement dans les cards */
#work .card a,
#work .card a:hover,
#work .card h3,
#work .card .card-text { text-decoration: none !important; }

/* Harmoniser proportions et layout */
#work .card { display: flex; flex-direction: column; }
#work .card-img-top {
  aspect-ratio: 4 / 3;    /* image stable */
  object-fit: cover;
  display: block;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
#work .card-body { flex: 1; display: flex; flex-direction: column; }

/* Lisibilité en sombre (aligné avec Métiers) */
#work .card {
  background-color: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.15);
  color: #fff;
  backdrop-filter: blur(6px);
  transition: transform .3s ease, box-shadow .3s ease;
}
#work .card:hover { transform: translateY(-5px); box-shadow: 0 12px 32px rgba(0,0,0,.25); }
#work .card h3 { color: #fff; font-weight: 700; }
#work .card .text-secondary { color: rgba(255,255,255,.85) !important; }

/* Champ de filtre en sombre lisible */
#work .filter-group .input-group-text,
#work .filter-group .form-control {
  background: rgba(255,255,255,0.06);
  color: #e6eefb;
  border: 1px solid rgba(255,255,255,0.15);
}
#work .filter-group .form-control::placeholder { color: rgba(230,238,251,0.6); }
/* Contact - harmonisation avec autres cartes */
#contact .card {
  background-color: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.15);
  color: #fff;
  backdrop-filter: blur(6px);
}
#contact .card a {
  color: #4da3ff;
}
#contact .card a:hover {
  color: #33cfff;
}

/* Champs du formulaire en sombre */
#contact .form-control {
  background-color: rgba(255,255,255,0.06);
  color: #e6eefb;
  border: 1px solid rgba(255,255,255,0.15);
}
#contact .form-control::placeholder {
  color: rgba(230,238,251,0.6);
}
#contact .form-label {
  color: #cfe0ff;
}



/* ===== Partenaires ===== */
.partners-carousel{
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
  background: rgba(255,255,255,.04);
  padding: 1rem 0;
  backdrop-filter: saturate(140%) blur(6px);
}

[data-bs-theme="dark"] .partners-carousel{
  background: rgba(8,16,32,.25);
}

/* Voile dégradé aux bords */
.partners-viewport{
  pointer-events: none;
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.35), transparent 80px) left,
    linear-gradient(-90deg, rgba(0,0,0,.35), transparent 80px) right;
  background-repeat: no-repeat;
  z-index: 2;
  mix-blend-mode: multiply;
}

.partners-track{
  display: flex;
  align-items: center;
  gap: 3.5rem;
  will-change: transform;
}

.partner-item{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  height: 64px;
  padding: .25rem .5rem;
  opacity: .9;
  transition: transform .25s ease, opacity .25s ease;
}

.partner-item img{
  display:block;
  max-height: 48px;
  width: auto;
  filter: grayscale(1) contrast(1.05) brightness(.92);
  transition: filter .25s ease, transform .25s ease, opacity .25s ease;
}

.partner-item:hover{
  opacity: 1;
  transform: translateY(-2px);
}
.partner-item:hover img{
  filter: none;
  transform: scale(1.03);
}

/* Animation défilement */
@keyframes partners-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(var(--scroll-end, -50%)); }
}
.partners-carousel.scrolling #partnersTrack{
  animation: partners-scroll var(--scroll-duration, 28s) linear infinite;
}

/* Pause au survol */
.partners-carousel:hover #partnersTrack{
  animation-play-state: paused;
}

/* Accessibilité : désactive les animations si demandé */
@media (prefers-reduced-motion: reduce){
  .partners-carousel.scrolling #partnersTrack{ animation: none; }
  .partners-viewport{ display:none; }
  .partners-track{ flex-wrap: wrap; justify-content: center; }
  .partner-item{ flex: 0 1 160px; }
}

/* Responsive fin */
@media (max-width: 576px){
  .partners-track{ gap: 2rem; }
  .partner-item{ min-width: 128px; height: 56px; }
  .partner-item img{ max-height: 40px; }
}
