/* ================================================================
   WWTEC - Air de neuf 2024
   Design rafraîchi - Typographie, espacements, effets
   ================================================================ */

/* === BASE === */
html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--wwtec-font) !important;
  color: var(--wwtec-text) !important;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.01em;
  background-color: var(--wwtec-bg) !important;
}

/* Fond subtil - motif géométrique léger */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    radial-gradient(ellipse 80% 50% at 50% -20%, var(--wwtec-primary-soft), transparent),
    radial-gradient(ellipse 60% 40% at 100% 100%, var(--wwtec-accent-soft), transparent),
    radial-gradient(ellipse 50% 30% at 0% 80%, rgba(13, 148, 136, 0.04), transparent);
  pointer-events: none;
  z-index: -1;
}

h1, h2, h3, h4, h5, h6,
.heading-block h1,
.heading-block h2,
.heading-block h3,
.display-1, .display-2, .display-3, .display-4 {
  font-family: var(--wwtec-font-heading) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
}

/* === HEADER - Glassmorphism raffiné === */
#header,
#header-wrap {
  background: rgba(255, 255, 255, 0.72) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.6) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset !important;
  transition: all 0.4s var(--wwtec-ease) !important;
}

#header.sticky-header {
  background: rgba(255, 255, 255, 0.88) !important;
  box-shadow: var(--wwtec-shadow-md), 0 1px 0 rgba(255, 255, 255, 0.9) inset !important;
}

#top-bar {
  background: transparent !important;
  border-bottom: 1px solid var(--wwtec-border-light) !important;
}

/* Navigation - Plus épurée */
.primary-menu .menu-link,
#primary-menu .menu-link {
  font-family: var(--wwtec-font-heading) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  padding: 14px 18px !important;
  color: var(--wwtec-text) !important;
  transition: all 0.3s var(--wwtec-ease) !important;
}

.primary-menu .menu-link:hover,
#primary-menu .menu-item:hover > .menu-link {
  color: var(--wwtec-primary) !important;
}

/* Mega menu - Design épuré */
/* Images du menu Services - photos avec cadrage */
.mega-menu-content .mega-menu-column .fbox-icon {
  width: 64px;
  height: 64px;
  overflow: hidden;
  border-radius: 12px;
}
.mega-menu-content .mega-menu-column .fbox-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.primary-menu .mega-menu-content,
.sub-menu-container {
  background: rgba(255, 255, 255, 0.95) !important;
  backdrop-filter: blur(24px) !important;
  border: 1px solid var(--wwtec-border) !important;
  border-radius: var(--wwtec-radius-lg) !important;
  box-shadow: var(--wwtec-shadow-xl) !important;
  padding: 1.5rem !important;
  margin-top: 8px !important;
}

/* === SECTIONS - Espacement généreux === */
.section,
.bg-color-light,
.mb-0 {
  padding: var(--wwtec-section-padding) 0 !important;
}

.container {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

@media (min-width: 1200px) {
  .container { max-width: 1140px; }
}

/* === HEADING BLOCK - Typo raffinée === */
.heading-block h1 { font-size: clamp(2.5rem, 5vw, 3.5rem) !important; }
.heading-block h2 { font-size: clamp(2rem, 4vw, 2.75rem) !important; }
.heading-block h3 { font-size: clamp(1.5rem, 3vw, 2rem) !important; }

.heading-block .lead,
.heading-block p {
  font-size: 1.125rem !important;
  color: var(--wwtec-text-muted) !important;
  max-width: 600px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* === CARDS & FEATURE BOXES === */
.fbox,
.feature-box,
.card,
.modern-card,
.modern-service-card {
  background: var(--wwtec-bg) !important;
  border: 1px solid var(--wwtec-border-light) !important;
  border-radius: var(--wwtec-radius-lg) !important;
  box-shadow: var(--wwtec-shadow-sm) !important;
  transition: all 0.4s var(--wwtec-ease-out) !important;
  overflow: hidden;
}

.fbox:hover,
.feature-box:hover,
.card:hover,
.modern-card:hover,
.modern-service-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--wwtec-shadow-lg) !important;
  border-color: var(--wwtec-border) !important;
}

.fbox-content h3,
.feature-box h3,
.card h3 {
  font-family: var(--wwtec-font-heading) !important;
  font-weight: 700 !important;
  color: var(--wwtec-text) !important;
}

/* === BOUTONS === */
.button,
.btn,
.btn-wwtec,
.modern-button {
  font-family: var(--wwtec-font-heading) !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  border-radius: var(--wwtec-radius-full) !important;
  padding: 14px 28px !important;
  transition: all 0.35s var(--wwtec-ease-out) !important;
}

.button:hover,
.btn:hover,
.btn-wwtec:hover,
.modern-button:hover {
  transform: translateY(-2px) !important;
}

.button.bg-color,
.btn.bg-color,
.btn-wwtec {
  box-shadow: 0 4px 14px rgba(var(--wwtec-primary-rgb), 0.25) !important;
}

.button.bg-color:hover,
.btn.bg-color:hover,
.btn-wwtec:hover {
  box-shadow: 0 8px 24px rgba(var(--wwtec-primary-rgb), 0.35) !important;
}

/* === HERO / SLIDER === */
.slider-element,
.hero-section,
.modern-services-hero {
  background-size: cover !important;
  background-position: center !important;
}

.slider-title h1,
.hero-title {
  font-family: var(--wwtec-font-heading) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}

/* === FORMULAIRES === */
.form-control,
.form-select,
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  font-family: var(--wwtec-font) !important;
  border-radius: var(--wwtec-radius-sm) !important;
  border: 1.5px solid var(--wwtec-border) !important;
  padding: 14px 18px !important;
  transition: all 0.3s var(--wwtec-ease) !important;
}

.form-control:focus,
.form-select:focus,
input:focus,
textarea:focus {
  border-color: var(--wwtec-primary) !important;
  box-shadow: 0 0 0 4px var(--wwtec-primary-soft) !important;
  outline: none !important;
}

/* === FOOTER === */
#footer,
.dark {
  background: var(--wwtec-secondary) !important;
}

#footer .widget_links a:hover,
#footer a:hover {
  color: var(--wwtec-primary-light, #2dd4bf) !important;
}

/* Footer - Design raffiné */
#footer {
  padding: var(--wwtec-space-3xl) 0 var(--wwtec-space-xl) !important;
}

#footer .widget h4 {
  font-family: var(--wwtec-font-heading) !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
}

/* === SERVICES GRID - Cartes plus aérées === */
.services-grid .feature-box {
  border-radius: var(--wwtec-radius-lg) !important;
  padding: 2.5rem !important;
}

/* === OWL CAROUSEL - Points plus modernes === */
.owl-carousel .owl-dots .owl-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--wwtec-text-light) !important;
  opacity: 0.5 !important;
  transition: all 0.3s var(--wwtec-ease) !important;
}

.owl-carousel .owl-dots .owl-dot.active,
.owl-carousel .owl-dots .owl-dot:hover {
  background: var(--wwtec-primary) !important;
  opacity: 1 !important;
  transform: scale(1.2);
}

/* === DÉCORATIONS SUBTILES === */
.heading-block.border-color::after,
.heading-underline:after {
  background: linear-gradient(90deg, var(--wwtec-primary), var(--wwtec-primary-light)) !important;
  border-radius: var(--wwtec-radius-full) !important;
  height: 4px !important;
}

/* === ANIMATIONS D'ENTRÉE === */
.fade-in-up,
[data-aos] {
  animation: freshFadeInUp 0.6s var(--wwtec-ease-out) forwards;
}

@keyframes freshFadeInUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Override orange in framework (sauf chatbot) */
#gotoTop:hover {
  border-color: var(--wwtec-primary) !important;
  color: var(--wwtec-primary) !important;
  box-shadow: 0 6px 20px rgba(var(--wwtec-primary-rgb), 0.25) !important;
}

/* === SCROLLBAR === */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: var(--wwtec-bg-subtle);
  border-radius: var(--wwtec-radius-full);
}

::-webkit-scrollbar-thumb {
  background: var(--wwtec-text-light);
  border-radius: var(--wwtec-radius-full);
  border: 3px solid var(--wwtec-bg-subtle);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--wwtec-text-muted);
}
