/* ==========================================
   IMPRIM'FLEX — style.css
   Dark premium theme · Glassmorphism
   ========================================== */

/* --- Google Fonts --- */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap');

/* --- Variables --- */
:root {
  /* Brand */
  --blue:         #1AABDB;
  --blue-dark:    #0E8AB8;
  --blue-light:   #4DC3E8;
  --yellow:       #F5C518;
  --yellow-dark:  #D4A800;
  --magenta:      #E63F8C;
  --magenta-dark: #C02E73;
  --cyan:         #00C4E8;
  --purple:       #7B2FBE;
  --green:        #00E8A0;

  /* Dark backgrounds */
  --bg-primary:   #050A12;
  --bg-secondary: #080F1A;
  --bg-card:      rgba(14, 22, 38, 0.85);
  --bg-glass:     rgba(255,255,255,0.04);

  /* Text */
  --text-primary:   #EBF0FF;
  --text-secondary: #8892A4;
  --text-muted:     #455068;

  /* Borders */
  --border-glass: rgba(255,255,255,0.08);
  --border-blue:  rgba(26,171,219,0.35);

  /* Shadows */
  --shadow-glow-blue:    0 0 40px rgba(26,171,219,0.25);
  --shadow-glow-magenta: 0 0 40px rgba(230,63,140,0.25);
  --shadow-glow-yellow:  0 0 40px rgba(245,197,24,0.25);
  --shadow-card:         0 24px 64px rgba(0,0,0,0.45);

  /* Typography */
  --font-heading: 'Outfit', sans-serif;
  --font-body:    'Inter', sans-serif;

  /* Layout */
  --section-padding: 110px 0;
  --container-max:   1200px;

  /* Transitions */
  --tf:  0.2s ease;
  --ts:  0.4s cubic-bezier(.4,0,.2,1);
  --tb:  0.5s cubic-bezier(.34,1.56,.64,1);

  /* Radii */
  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
}

/* --- Reset --- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  background: var(--bg-primary);
  color: var(--text-primary);
  overflow-x: hidden;
  line-height: 1.65;
}

/* Scrollbar */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg-secondary); }
::-webkit-scrollbar-thumb { background: var(--blue); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--blue-light); }

/* --- Container --- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 24px;
}

/* --- Typography --- */
h1,h2,h3,h4,h5 { font-family: var(--font-heading); font-weight: 700; line-height: 1.15; }

.gradient-text {
  background: linear-gradient(135deg, var(--blue) 0%, var(--cyan) 45%, var(--magenta) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.section-subtitle {
  color: var(--blue-light);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.section-subtitle::before {
  content: '';
  display: block;
  width: 36px;
  height: 2px;
  background: linear-gradient(to right, var(--blue), var(--magenta));
  border-radius: 2px;
  flex-shrink: 0;
}

.section-title {
  font-size: clamp(1.9rem, 4vw, 3rem);
  font-weight: 900;
  margin-bottom: 18px;
  color: var(--text-primary);
}

.section-desc {
  color: var(--text-secondary);
  font-size: 1.05rem;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.8;
}

.section-header { text-align: center; margin-bottom: 64px; }

/* --- Buttons --- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 13px 26px;
  border-radius: 50px;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: .92rem;
  text-decoration: none;
  transition: var(--ts);
  cursor: pointer;
  border: none;
  position: relative;
  overflow: hidden;
  letter-spacing: .3px;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0);
  transition: background .25s ease;
}
.btn:hover::after { background: rgba(255,255,255,0.08); }

.btn-primary {
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  color: #fff;
  box-shadow: 0 4px 22px rgba(26,171,219,.42);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 10px 36px rgba(26,171,219,.6); }

.btn-secondary {
  background: rgba(26,171,219,.1);
  color: var(--blue);
  border: 1px solid rgba(26,171,219,.3);
}
.btn-secondary:hover { background: rgba(26,171,219,.18); transform: translateY(-2px); }

.btn-outline {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid rgba(255,255,255,.18);
}
.btn-outline:hover { background: rgba(255,255,255,.08); transform: translateY(-2px); }

.btn-magenta {
  background: linear-gradient(135deg, var(--magenta), var(--purple));
  color: #fff;
  box-shadow: 0 4px 22px rgba(230,63,140,.4);
}
.btn-magenta:hover { transform: translateY(-3px); box-shadow: 0 10px 36px rgba(230,63,140,.65); }

/* ==========================================
   NAVIGATION
   ========================================== */
#navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 18px 0;
  transition: var(--ts);
}
#navbar.scrolled {
  background: rgba(5,10,18,.96);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border-bottom: 1px solid var(--border-glass);
  padding: 10px 0;
  box-shadow: 0 4px 40px rgba(0,0,0,.55);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.nav-logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.nav-logo-img { height: 46px; width: auto; filter: drop-shadow(0 0 12px rgba(26,171,219,.45)); }
.nav-logo-text { font-family: var(--font-heading); font-weight: 900; font-size: 1.4rem; }
.nav-logo-text .im { color: var(--blue); }
.nav-logo-text .prim { color: var(--text-primary); }
.nav-logo-text .flex { color: var(--magenta); }

.nav-links { display: flex; align-items: center; gap: 4px; list-style: none; flex: 1; justify-content: center; }
.nav-link {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: .88rem;
  font-weight: 500;
  padding: 8px 14px;
  border-radius: 50px;
  transition: var(--tf);
}
.nav-link:hover, .nav-link.active { color: var(--text-primary); background: rgba(26,171,219,.1); }
.nav-link.active { color: var(--blue); }

.nav-cta { flex-shrink: 0; }

#hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 8px;
  background: none;
  border: none;
}
#hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: var(--ts);
}
#hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
#hamburger.active span:nth-child(2) { opacity: 0; }
#hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

#mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(5,10,18,.98);
  backdrop-filter: blur(24px);
  z-index: 999;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 80px 40px;
}
#mobile-menu.open { display: flex; }
#mobile-menu .nav-link { font-size: 1.4rem; font-family: var(--font-heading); font-weight: 800; }

/* ==========================================
   HERO
   ========================================== */
#hero {
  position: relative;
  height: 100vh;
  min-height: 720px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
#hero-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.hero-bg-gradient {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(26,171,219,.15) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 40%, rgba(230,63,140,.1) 0%, transparent 55%),
    radial-gradient(ellipse at 50% 90%, rgba(245,197,24,.07) 0%, transparent 50%);
}
.hero-content {
  position: relative;
  z-index: 10;
  text-align: center;
  max-width: 950px;
  padding: 0 24px;
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(26,171,219,.12);
  border: 1px solid rgba(26,171,219,.28);
  border-radius: 50px;
  padding: 9px 22px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--blue-light);
  letter-spacing: 2.5px;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.hero-badge .dot {
  width: 8px;
  height: 8px;
  background: var(--blue);
  border-radius: 50%;
  animation: pulse-dot 2s ease infinite;
  flex-shrink: 0;
}
.hero-title {
  font-size: clamp(2.4rem, 6vw, 5rem);
  font-weight: 900;
  line-height: 1.05;
  margin-bottom: 22px;
  color: var(--text-primary);
}
.hero-title .highlight {
  background: linear-gradient(135deg, var(--blue) 0%, var(--cyan) 40%, var(--magenta) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  display: block;
}
.hero-typewriter {
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 14px;
  min-height: 2.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}
.hero-typewriter .prefix { font-weight: 400; }
#typewriter {
  color: var(--yellow);
  font-weight: 800;
  font-family: var(--font-heading);
  border-right: 3px solid var(--yellow);
  padding-right: 3px;
  animation: blink-caret .8s step-end infinite;
}
.hero-desc {
  color: var(--text-secondary);
  font-size: 1rem;
  margin-bottom: 40px;
  line-height: 1.75;
}
.hero-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* Scroll indicator */
.hero-scroll-indicator {
  position: absolute;
  bottom: 120px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: var(--text-muted);
  font-size: .72rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  z-index: 10;
}
.scroll-mouse {
  width: 22px;
  height: 34px;
  border: 2px solid rgba(255,255,255,.2);
  border-radius: 11px;
  display: flex;
  justify-content: center;
  padding-top: 5px;
}
.scroll-wheel {
  width: 3px;
  height: 7px;
  background: var(--blue);
  border-radius: 2px;
  animation: scroll-wheel 2s ease infinite;
}

/* Hero Stats Bar */
.hero-stats {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(5,10,18,.65);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--border-glass);
  display: flex;
  justify-content: center;
  z-index: 10;
}
.hero-stat-item {
  flex: 1;
  max-width: 200px;
  padding: 18px 0;
  text-align: center;
  border-right: 1px solid var(--border-glass);
}
.hero-stat-item:last-child { border-right: none; }
.hero-stat-value {
  font-family: var(--font-heading);
  font-size: 1.7rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  display: block;
}
.hero-stat-label { font-size: .7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }

/* ==========================================
   SERVICES
   ========================================== */
#services {
  padding: var(--section-padding);
  position: relative;
  overflow: hidden;
}
#services::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 900px; height: 900px;
  background: radial-gradient(circle, rgba(26,171,219,.04) 0%, transparent 70%);
  pointer-events: none;
}
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

/* Flip Card */
.service-card { perspective: 1100px; height: 330px; }
.service-card-inner {
  position: relative;
  width: 100%; height: 100%;
  transform-style: preserve-3d;
  transition: transform .75s cubic-bezier(.4,.2,.2,1);
}
.service-card:hover .service-card-inner { transform: rotateY(180deg); }

.service-card-front,
.service-card-back {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: var(--r-lg);
  overflow: hidden;
}

.service-card-front {
  background: var(--bg-glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border-glass);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 38px 28px;
  text-align: center;
  position: relative;
  transition: border-color .3s ease, box-shadow .3s ease;
}
.service-card:hover .service-card-front {
  border-color: var(--border-blue);
  box-shadow: var(--shadow-glow-blue);
}
.service-card-front::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--card-gradient, linear-gradient(90deg, var(--blue), var(--cyan)));
}
.service-card-front::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,rgba(255,255,255,.02) 0%,transparent 60%,rgba(26,171,219,.04) 100%);
  pointer-events: none;
}

.service-icon-wrapper {
  width: 78px; height: 78px;
  border-radius: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  font-size: 2.4rem;
  background: var(--icon-bg, rgba(26,171,219,.12));
  border: 1px solid var(--icon-border, rgba(26,171,219,.22));
  transition: transform .3s ease;
}
.service-card:hover .service-icon-wrapper { transform: scale(1.08) rotate(-3deg); }
.service-card-front h3 { font-size: 1.15rem; font-weight: 700; margin-bottom: 10px; }
.service-card-front p { color: var(--text-secondary); font-size: .875rem; line-height: 1.6; }

.service-card-back {
  transform: rotateY(180deg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 28px;
  text-align: center;
  color: #fff;
}
.service-card:nth-child(1) .service-card-back { background: linear-gradient(135deg, #1AABDB, #00C4E8); }
.service-card:nth-child(2) .service-card-back { background: linear-gradient(135deg, #E63F8C, #7B2FBE); }
.service-card:nth-child(3) .service-card-back { background: linear-gradient(135deg, #F5C518, #FF8C00); }
.service-card:nth-child(4) .service-card-back { background: linear-gradient(135deg, #7B2FBE, #1AABDB); }
.service-card:nth-child(5) .service-card-back { background: linear-gradient(135deg, #00C4E8, #7B2FBE); }
.service-card:nth-child(6) .service-card-back { background: linear-gradient(135deg, #E63F8C, #F5C518); }

.service-card-back h3 { font-size: 1.2rem; font-weight: 800; margin-bottom: 10px; }
.service-card-back p { font-size: .875rem; opacity: .92; margin-bottom: 16px; line-height: 1.6; }
.service-features { list-style: none; text-align: left; width: 100%; }
.service-features li {
  font-size: .82rem;
  opacity: .9;
  padding: 3px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.service-features li::before { content: '✓'; font-weight: 700; opacity: .7; }

/* ==========================================
   PROCESSUS
   ========================================== */
#processus {
  padding: var(--section-padding);
  background: var(--bg-secondary);
  position: relative;
  overflow: hidden;
}
.process-track {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-top: 60px;
}
.process-track::before {
  content: '';
  position: absolute;
  top: 38px;
  left: 12%;
  right: 12%;
  height: 2px;
  background: linear-gradient(to right, var(--blue), var(--cyan), var(--magenta), var(--yellow));
  z-index: 0;
}
.process-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}
.process-icon {
  width: 76px; height: 76px;
  border-radius: 50%;
  background: var(--bg-primary);
  border: 3px solid var(--process-color, var(--blue));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  margin-bottom: 20px;
  box-shadow: 0 0 28px var(--process-glow, rgba(26,171,219,.3));
  transition: var(--ts);
  position: relative;
}
.process-step:hover .process-icon {
  transform: scale(1.1);
  box-shadow: 0 0 52px var(--process-glow, rgba(26,171,219,.5));
}
.process-number {
  position: absolute;
  top: -8px; right: -8px;
  width: 26px; height: 26px;
  background: var(--process-color, var(--blue));
  border-radius: 50%;
  font-weight: 800;
  font-size: .78rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.process-step h3 { font-size: 1rem; font-weight: 700; margin-bottom: 8px; }
.process-step p { font-size: .83rem; color: var(--text-secondary); max-width: 160px; margin: 0 auto; }

/* ==========================================
   PORTFOLIO
   ========================================== */
#portfolio { padding: var(--section-padding); }

.portfolio-filters {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 44px;
}
.filter-btn {
  padding: 8px 20px;
  border-radius: 50px;
  background: transparent;
  border: 1px solid var(--border-glass);
  color: var(--text-secondary);
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  transition: var(--tf);
  font-family: var(--font-body);
}
.filter-btn:hover, .filter-btn.active {
  background: rgba(26,171,219,.15);
  border-color: var(--blue);
  color: var(--blue);
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.portfolio-item {
  position: relative;
  border-radius: var(--r-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
  opacity: 0;
  transform: scale(.96);
  transition: opacity .4s ease, transform .4s ease, box-shadow .3s ease;
}
.portfolio-item.visible { opacity: 1; transform: scale(1); }
.portfolio-item:hover { box-shadow: 0 20px 50px rgba(0,0,0,.6); }
.portfolio-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .55s ease;
}
.portfolio-item:hover img { transform: scale(1.1); }

/* CSS fallback gradients for items without images */
.portfolio-item:nth-child(1) { background: linear-gradient(135deg, #0E2A3A, #1AABDB); }
.portfolio-item:nth-child(2) { background: linear-gradient(135deg, #2A0E1A, #E63F8C); }
.portfolio-item:nth-child(3) { background: linear-gradient(135deg, #2A1E00, #F5C518); }
.portfolio-item:nth-child(4) { background: linear-gradient(135deg, #1A0E2A, #7B2FBE); }
.portfolio-item:nth-child(5) { background: linear-gradient(135deg, #001A2A, #00C4E8); }
.portfolio-item:nth-child(6) { background: linear-gradient(135deg, #2A0E20, #E63F8C); }

.portfolio-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,10,18,.9) 0%, transparent 55%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 22px;
  opacity: 0;
  transition: opacity .3s ease;
}
.portfolio-item:hover .portfolio-overlay { opacity: 1; }
.portfolio-category { font-size: .68rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--blue-light); margin-bottom: 4px; }
.portfolio-overlay h4 { font-size: .95rem; font-weight: 700; color: #fff; }

/* ==========================================
   STATS / WHY US
   ========================================== */
#stats {
  padding: var(--section-padding);
  background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(26,171,219,.04) 50%, var(--bg-secondary) 100%);
}
.stats-container { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.stats-left h2 { font-size: clamp(1.8rem,3.5vw,2.6rem); font-weight: 900; margin-bottom: 18px; }
.stats-left > p { color: var(--text-secondary); margin-bottom: 32px; line-height: 1.8; }

.features-list { list-style: none; display: flex; flex-direction: column; gap: 16px; }
.features-list li { display: flex; align-items: flex-start; gap: 14px; color: var(--text-secondary); font-size: .9rem; }
.feature-icon {
  width: 38px; height: 38px;
  border-radius: 11px;
  background: rgba(26,171,219,.12);
  border: 1px solid rgba(26,171,219,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .95rem;
  flex-shrink: 0;
}
.features-list strong { color: var(--text-primary); display: block; margin-bottom: 3px; }

.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.stat-card {
  background: var(--bg-glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-lg);
  padding: 28px;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: var(--ts);
}
.stat-card:hover {
  border-color: var(--border-blue);
  transform: translateY(-6px);
  box-shadow: var(--shadow-glow-blue);
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--magenta));
}
.stat-emoji { font-size: 1.5rem; display: block; margin-bottom: 10px; }
.stat-number {
  display: block;
  font-family: var(--font-heading);
  font-size: 2.6rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
  margin-bottom: 8px;
}
.stat-card p { color: var(--text-secondary); font-size: .82rem; }

/* ==========================================
   TESTIMONIALS
   ========================================== */
#temoignages { padding: var(--section-padding); background: var(--bg-secondary); overflow: hidden; }

.testimonials-wrapper { position: relative; max-width: 840px; margin: 0 auto; }
.testimonial-card {
  display: none;
  background: var(--bg-glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-xl);
  padding: 52px 56px;
  text-align: center;
  animation: fadeInUp .5s ease;
  position: relative;
}
.testimonial-card.active { display: block; }
.testimonial-card::before {
  content: '"';
  position: absolute;
  top: 12px; left: 36px;
  font-size: 9rem;
  font-family: var(--font-heading);
  color: var(--blue);
  opacity: .1;
  line-height: 1;
  pointer-events: none;
}
.testimonial-stars { color: var(--yellow); letter-spacing: 3px; font-size: .9rem; margin-bottom: 20px; }
.testimonial-text {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--text-secondary);
  margin-bottom: 32px;
  font-style: italic;
  position: relative;
  z-index: 1;
}
.testimonial-author { display: flex; align-items: center; justify-content: center; gap: 16px; }
.author-avatar {
  width: 54px; height: 54px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue), var(--magenta));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  font-weight: 800;
  color: #fff;
  font-family: var(--font-heading);
  flex-shrink: 0;
}
.author-name { font-weight: 700; font-size: .98rem; color: var(--text-primary); }
.author-company { color: var(--text-muted); font-size: .82rem; }

.carousel-controls { display: flex; align-items: center; justify-content: center; gap: 20px; margin-top: 36px; }
.carousel-btn {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: rgba(26,171,219,.1);
  border: 1px solid rgba(26,171,219,.22);
  color: var(--blue);
  font-size: 1.3rem;
  cursor: pointer;
  transition: var(--tf);
  display: flex;
  align-items: center;
  justify-content: center;
}
.carousel-btn:hover { background: rgba(26,171,219,.22); transform: scale(1.1); }
#carousel-dots { display: flex; gap: 8px; }
.carousel-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--border-glass);
  border: none;
  cursor: pointer;
  transition: var(--tf);
}
.carousel-dot.active { background: var(--blue); transform: scale(1.4); }

/* ==========================================
   DEVIS FORM
   ========================================== */
#devis { padding: var(--section-padding); }
.devis-container { max-width: 800px; margin: 0 auto; }

/* Progress */
.form-progress {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin-bottom: 48px;
}
.form-progress::before {
  content: '';
  position: absolute;
  top: 19px; left: 20px; right: 20px;
  height: 2px;
  background: var(--border-glass);
  z-index: 0;
}
.step-indicator { display: flex; flex-direction: column; align-items: center; gap: 8px; position: relative; z-index: 1; }
.step-number {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 2px solid var(--border-glass);
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; font-weight: 700; color: var(--text-muted);
  transition: var(--ts);
}
.step-label { font-size: .72rem; color: var(--text-muted); transition: var(--ts); }
.step-indicator.active .step-number {
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  border-color: var(--blue);
  color: #fff;
  box-shadow: var(--shadow-glow-blue);
}
.step-indicator.active .step-label { color: var(--blue); font-weight: 600; }
.step-indicator.completed .step-number {
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  border-color: var(--blue);
  color: #fff;
}
.step-indicator.completed .step-number span { display: none; }
.step-indicator.completed .step-number::before { content: '✓'; font-weight: 800; }

/* Steps */
.form-step { display: none; animation: fadeInUp .4s ease; }
.form-step.active { display: block; }

/* Form card */
.form-card {
  background: var(--bg-glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-xl);
  padding: 40px;
}
.form-card h3 { font-size: 1.25rem; font-weight: 800; margin-bottom: 28px; }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px; }
.form-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.form-group label { font-size: .82rem; font-weight: 500; color: var(--text-secondary); }

.form-control {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-sm);
  padding: 12px 16px;
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: .9rem;
  transition: var(--tf);
  width: 100%;
}
.form-control:focus {
  outline: none;
  border-color: var(--blue);
  background: rgba(26,171,219,.05);
  box-shadow: 0 0 0 3px rgba(26,171,219,.1);
}
.form-control::placeholder { color: var(--text-muted); }
textarea.form-control { resize: vertical; min-height: 100px; }

/* Service type grid */
.service-type-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 24px; }
.service-type-btn {
  padding: 16px 10px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border-glass);
  color: var(--text-secondary);
  cursor: pointer;
  text-align: center;
  transition: var(--tf);
  font-size: .82rem;
  font-family: var(--font-body);
  font-weight: 500;
}
.service-type-btn:hover { border-color: var(--blue); background: rgba(26,171,219,.06); color: var(--blue); }
.service-type-btn.selected { border-color: var(--blue); background: rgba(26,171,219,.15); color: var(--blue-light); }
.service-type-icon { font-size: 1.6rem; display: block; margin-bottom: 6px; }

.form-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 24px; gap: 16px; }

/* Success */
#form-success {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 40px;
  background: var(--bg-glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-xl);
  gap: 18px;
}
.success-icon {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem;
  box-shadow: var(--shadow-glow-blue);
  animation: pop-in .6s var(--tb);
}
#form-success h3 { font-size: 1.5rem; font-weight: 800; }
#form-success p { color: var(--text-secondary); max-width: 380px; }

/* ==========================================
   CONTACT
   ========================================== */
#contact { padding: var(--section-padding); background: var(--bg-secondary); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 56px; align-items: start; }

.contact-info { display: flex; flex-direction: column; gap: 16px; }
.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-md);
  transition: var(--ts);
}
.contact-info-item:hover { border-color: var(--border-blue); transform: translateX(8px); box-shadow: var(--shadow-glow-blue); }
.contact-icon {
  width: 46px; height: 46px;
  border-radius: 13px;
  background: rgba(26,171,219,.12);
  border: 1px solid rgba(26,171,219,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem;
  flex-shrink: 0;
}
.contact-info-item h4 { font-size: .7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 4px; }
.contact-info-item p, .contact-info-item a {
  color: var(--text-primary);
  font-weight: 500;
  text-decoration: none;
  font-size: .92rem;
}
.contact-info-item a:hover { color: var(--blue); }

.social-links { display: flex; gap: 10px; flex-wrap: wrap; }
.social-link {
  width: 42px; height: 42px;
  border-radius: 11px;
  background: rgba(26,171,219,.1);
  border: 1px solid rgba(26,171,219,.2);
  color: var(--blue);
  text-decoration: none;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  transition: var(--tf);
}
.social-link:hover { background: rgba(26,171,219,.25); transform: translateY(-3px); box-shadow: var(--shadow-glow-blue); }

.hours-grid { display: flex; flex-direction: column; gap: 7px; }
.hours-row { display: flex; justify-content: space-between; font-size: .85rem; padding: 5px 0; border-bottom: 1px solid rgba(255,255,255,.04); }
.hours-row span:first-child { color: var(--text-secondary); }
.hours-row span:last-child { color: var(--text-primary); font-weight: 600; }

.contact-map {
  margin-top: 4px;
  border-radius: var(--r-md);
  height: 160px;
  background: linear-gradient(135deg, rgba(26,171,219,.1), rgba(230,63,140,.1));
  border: 1px solid var(--border-glass);
  display: flex;
  align-items: center; justify-content: center;
  flex-direction: column;
  gap: 10px;
  color: var(--text-secondary);
  cursor: pointer;
  transition: var(--ts);
  text-decoration: none;
}
.contact-map:hover { border-color: var(--border-blue); box-shadow: var(--shadow-glow-blue); transform: translateY(-3px); }
.contact-map span { font-size: .85rem; }

/* ==========================================
   FOOTER
   ========================================== */
footer {
  background: rgba(0,0,0,.45);
  border-top: 1px solid var(--border-glass);
  padding: 64px 0 28px;
}
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 56px; margin-bottom: 48px; }
.footer-brand p { color: var(--text-muted); font-size: .875rem; line-height: 1.75; margin: 14px 0 22px; max-width: 280px; }
.footer-logo { height: 40px; filter: drop-shadow(0 0 8px rgba(26,171,219,.4)); }
.footer-logo-text { font-family: var(--font-heading); font-weight: 900; font-size: 1.5rem; }

.footer-col h4 {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 20px;
}
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-links a {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: .875rem;
  transition: var(--tf);
  display: inline-block;
}
.footer-links a:hover { color: var(--blue); transform: translateX(5px); }

.footer-bottom {
  border-top: 1px solid var(--border-glass);
  padding-top: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.footer-bottom p { color: var(--text-muted); font-size: .78rem; }

/* ==========================================
   RESPONSIVE
   ========================================== */
@media (max-width: 1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-container { grid-template-columns: 1fr; gap: 52px; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  :root { --section-padding: 72px 0; }
  .nav-links, .nav-cta { display: none; }
  #hamburger { display: flex; }
  .services-grid { grid-template-columns: 1fr; }
  .process-track { flex-direction: column; align-items: flex-start; gap: 36px; }
  .process-track::before { top: 0; bottom: 0; left: 37px; right: auto; width: 2px; height: auto; }
  .process-step { flex-direction: row; text-align: left; align-items: flex-start; gap: 16px; }
  .process-step p { max-width: 100%; }
  .portfolio-grid { grid-template-columns: 1fr 1fr; }
  .service-type-grid { grid-template-columns: repeat(2, 1fr); }
  .form-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .hero-stats { display: none; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .testimonial-card { padding: 30px 24px; }
  .hero-scroll-indicator { bottom: 30px; }
}

@media (max-width: 480px) {
  .portfolio-grid { grid-template-columns: 1fr; }
  .hero-btns { flex-direction: column; align-items: center; }
  .devis-container { padding: 0; }
  .form-card { padding: 28px 20px; }
  .service-type-grid { grid-template-columns: repeat(2, 1fr); }
}
