/* ============================================================
   TheSkil — Custom Theme v3 · Premium Edition
   Fonts: Space Grotesk (display) · Plus Jakarta Sans (body)
   Design: Vivid gradient cards · Animated · Editorial
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ── CSS VARIABLES ───────────────────────────────────────── */
:root {
  --violet:      #7c3aed;
  --violet-light:#a855f7;
  --violet-soft: rgba(124,58,237,0.08);
  --fuchsia:     #d946ef;
  --indigo:      #4f46e5;
  --bg:          #f8f6ff;
  --surface:     #ffffff;
  --text:        #0f0a1e;
  --text-muted:  #6b7280;
  --border:      rgba(124,58,237,0.13);
  --radius-card: 20px;
  --font-display:'Space Grotesk', sans-serif;
  --font-body:   'Plus Jakarta Sans', sans-serif;
}

/* ── ANIMATIONS ─────────────────────────────────────────── */
@keyframes gradientShift {
  0%,100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes floatOrb {
  0%,100% { transform: translateY(0) scale(1); }
  50%      { transform: translateY(-20px) scale(1.07); }
}
@keyframes shimmer {
  0%   { background-position: -300% center; }
  100% { background-position:  300% center; }
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes cardEntrance {
  from { opacity: 0; transform: translateY(28px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes rotateStar {
  to { transform: rotate(360deg); }
}

/* ── BASE ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body) !important;
  background: var(--bg) !important;
  color: var(--text) !important;
  -webkit-font-smoothing: antialiased;
}

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: #f0ebff; }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--violet), var(--fuchsia));
  border-radius: 10px;
}
::selection { background: rgba(124,58,237,0.15); color: #3b0764; }

.container { max-width: 100% !important; padding: 0 !important; }
.main-section { min-height: 100vh; display: flex; flex-direction: column; }

/* ══════════════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════════════ */
header.mainPadding {
  background: rgba(255,255,255,0.93) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: 0 2px 24px rgba(124,58,237,0.07) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  padding: 0 32px !important;
  animation: slideDown 0.5s ease both;
}

nav.navbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 10px 0 !important;
  background: transparent !important;
  border: none !important;
  gap: 14px;
  flex-wrap: nowrap;
  min-height: 64px;
}

.navbar-brand img {
  height: 54px !important;
  width: auto !important;
  transition: transform 0.3s ease, opacity 0.2s;
}
.navbar-brand:hover img { opacity: 0.85; transform: scale(1.04); }

.header-navbar { display: flex !important; flex: 1; }
.header-navbar ul {
  display: flex !important;
  align-items: center !important;
  list-style: none !important;
  margin: 0 !important; padding: 0 !important;
  gap: 2px !important; flex-wrap: wrap;
}
.header-navbar ul li a {
  font-family: var(--font-body) !important;
  display: inline-block;
  padding: 7px 14px !important;
  font-size: 13.5px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  text-decoration: none !important;
  border-radius: 10px !important;
  transition: color 0.2s, background 0.2s !important;
  white-space: nowrap;
}
.header-navbar ul li a:hover {
  color: var(--violet) !important;
  background: var(--violet-soft) !important;
}

#navbar-toggler.nav-btn {
  display: none;
  flex-direction: column; gap: 5px;
  cursor: pointer; padding: 8px;
  border-radius: 10px; background: transparent; border: none;
  transition: background 0.2s;
}
#navbar-toggler.nav-btn:hover { background: var(--violet-soft); }
#navbar-toggler.nav-btn span {
  display: block; width: 22px; height: 2px;
  background: var(--violet); border-radius: 2px;
}

.header-language-btn {
  display: flex !important; align-items: center !important; gap: 6px !important;
  padding: 7px 12px !important; font-size: 12.5px !important; font-weight: 700 !important;
  color: #374151 !important; background: white !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 10px !important; cursor: pointer !important;
  transition: all 0.2s !important; text-decoration: none !important;
  font-family: var(--font-body) !important;
}
.header-language-btn:hover {
  border-color: var(--violet-light) !important;
  background: var(--violet-soft) !important;
  color: var(--violet) !important;
}

.header-language-dd {
  position: absolute !important; top: calc(100% + 8px) !important; right: 0 !important;
  background: white !important; border: 1px solid var(--border) !important;
  border-radius: 14px !important; box-shadow: 0 12px 32px rgba(124,58,237,0.14) !important;
  min-width: 130px !important; padding: 6px !important; z-index: 9999 !important; display: none;
}
.header-language-dd.show { display: block !important; animation: fadeIn 0.15s ease; }
.header-language-dd a {
  display: flex !important; align-items: center !important; gap: 8px !important;
  padding: 9px 11px !important; font-size: 13px !important; color: #374151 !important;
  border-radius: 9px !important; text-decoration: none !important;
  transition: background 0.15s !important; font-weight: 500;
}
.header-language-dd a:hover { background: var(--violet-soft) !important; color: var(--violet) !important; }
.header-language-dd a.active { color: var(--violet) !important; font-weight: 700 !important; background: var(--violet-soft) !important; }

.login-btn-main { position: relative; }
.login-btn {
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 36px !important; height: 36px !important; border-radius: 10px !important;
  background: var(--violet-soft) !important; border: 1.5px solid var(--border) !important;
  text-decoration: none !important; transition: all 0.2s !important;
}
.login-btn:hover { background: rgba(124,58,237,0.14) !important; border-color: var(--violet-light) !important; }
.login-user-icon svg path { fill: var(--violet) !important; }
.login-btn-main ul {
  position: absolute !important; top: calc(100% + 6px) !important; right: 0 !important;
  background: white !important; border: 1px solid var(--border) !important;
  border-radius: 14px !important; box-shadow: 0 12px 28px rgba(124,58,237,0.13) !important;
  min-width: 140px !important; padding: 6px !important; list-style: none !important;
  margin: 0 !important; z-index: 9999 !important;
}
.login-btn-main ul li a {
  display: block !important; padding: 9px 12px !important; font-size: 13px !important;
  color: #374151 !important; border-radius: 9px !important; text-decoration: none !important;
  transition: background 0.15s !important; font-weight: 500;
}
.login-btn-main ul li a:hover { background: var(--violet-soft) !important; color: var(--violet) !important; }

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.hero-section {
  position: relative;
  overflow: hidden;
  padding: 80px 24px 68px;
  text-align: center;
  background:
    radial-gradient(ellipse 80% 60% at 20% -10%, rgba(124,58,237,0.22) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 110%, rgba(217,70,239,0.18) 0%, transparent 55%),
    linear-gradient(165deg, #faf8ff 0%, #f3e8ff 30%, #fdf2f8 60%, #ede9fe 100%) !important;
  background-size: 100%, 100%, 400% 400% !important;
  animation: gradientShift 12s ease infinite !important;
}
.hero-section::before {
  content: '';
  position: absolute;
  width: 480px; height: 480px; top: -160px; right: -120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(168,85,247,0.18) 0%, rgba(217,70,239,0.06) 50%, transparent 70%);
  animation: floatOrb 8s ease-in-out infinite;
  pointer-events: none;
}
.hero-section::after {
  content: '';
  position: absolute;
  width: 320px; height: 320px; bottom: -100px; left: -80px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,70,229,0.15) 0%, transparent 70%);
  animation: floatOrb 10s ease-in-out infinite reverse;
  pointer-events: none;
}
.hero-section > * { position: relative; z-index: 1; }

.hero-small-title {
  display: inline-flex !important; align-items: center !important; gap: 7px !important;
  font-family: var(--font-body) !important;
  font-size: 11px !important; font-weight: 800 !important;
  letter-spacing: 0.12em !important; text-transform: uppercase !important;
  color: var(--violet) !important;
  background: rgba(124,58,237,0.09) !important;
  border: 1.5px solid rgba(124,58,237,0.22) !important;
  padding: 6px 20px !important; border-radius: 100px !important;
  margin-bottom: 22px !important;
  animation: fadeUp 0.5s ease both;
}
.hero-small-title::before {
  content: '✦'; font-size: 9px;
  display: inline-block;
  animation: rotateStar 4s linear infinite;
}

.hero-section h1 {
  font-family: var(--font-display) !important;
  font-size: clamp(28px, 5vw, 54px) !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.1 !important;
  margin: 0 0 20px !important;
  background: linear-gradient(135deg, #3b0764 0%, var(--violet) 30%, var(--fuchsia) 60%, #4f46e5 100%) !important;
  background-size: 300% auto !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  animation: fadeUp 0.6s ease 0.1s both, shimmer 6s linear infinite !important;
}

/* ── INTRO ───────────────────────────────────────────────── */
.intro-text {
  max-width: 800px;
  margin: 28px auto 0 !important;
  padding: 28px 32px !important;
  background: rgba(255,255,255,0.78) !important;
  backdrop-filter: blur(12px) !important;
  border-radius: 20px !important;
  border: 1px solid rgba(124,58,237,0.13) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,0.08), inset 0 1px 0 rgba(255,255,255,0.9) !important;
  text-align: left !important;
  animation: fadeUp 0.7s ease 0.15s both;
}
.intro-text p {
  font-family: var(--font-body) !important;
  color: #4b5563 !important; font-size: 15px !important;
  line-height: 1.7 !important; margin: 0 0 12px !important;
}
.intro-text p:last-child { margin-bottom: 0 !important; }
.intro-text strong { color: var(--violet) !important; font-weight: 700 !important; }
.intro-text ul {
  list-style: none !important; padding: 0 !important; margin: 10px 0 14px !important;
  display: grid !important; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important; gap: 10px !important;
}
.intro-text ul li {
  display: flex !important; align-items: center !important; gap: 8px !important;
  font-family: var(--font-body) !important;
  font-size: 13.5px !important; font-weight: 600 !important; color: #374151 !important;
  background: linear-gradient(135deg, rgba(124,58,237,0.06), rgba(217,70,239,0.04)) !important;
  border: 1px solid rgba(124,58,237,0.11) !important; border-radius: 12px !important;
  padding: 9px 14px !important; transition: transform 0.2s, box-shadow 0.2s;
}
.intro-text ul li:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(124,58,237,0.1); }

/* ── SEARCH ──────────────────────────────────────────────── */
.main-search-sec {
  max-width: 600px !important;
  margin: 36px auto !important;
  padding: 0 20px !important;
  animation: fadeUp 0.75s ease 0.2s both;
}
.main-search-sec input[type="text"] {
  width: 100% !important;
  padding: 15px 22px 15px 52px !important;
  font-family: var(--font-body) !important;
  font-size: 15px !important; font-weight: 500 !important;
  border: 2px solid rgba(124,58,237,0.22) !important;
  border-radius: 16px !important; outline: none !important;
  background: white url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%237c3aed' stroke-width='2.2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 18px center !important;
  color: var(--text) !important;
  box-shadow: 0 4px 20px rgba(124,58,237,0.08) !important;
  transition: all 0.25s !important;
}
.main-search-sec input[type="text"]:focus {
  border-color: var(--violet) !important;
  box-shadow: 0 0 0 4px rgba(124,58,237,0.12), 0 6px 24px rgba(124,58,237,0.12) !important;
  transform: translateY(-1px) !important;
}
.main-search-sec input[type="text"]::placeholder { color: #9ca3af !important; font-weight: 400; }

/* ══════════════════════════════════════════════════════════
   GRILLE OUTILS
══════════════════════════════════════════════════════════ */
.content-sec {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 24px 28px 80px !important;
  flex: 1;
}
.content-sec-inner { margin-bottom: 60px !important; animation: fadeUp 0.55s ease both; }

.content-title-sec {
  display: flex !important; align-items: center !important;
  gap: 12px !important; margin-bottom: 24px !important;
  padding-bottom: 16px !important;
  border-bottom: 2px solid transparent !important;
  background: linear-gradient(white, white) padding-box,
              linear-gradient(90deg, var(--violet), var(--fuchsia), transparent) border-box !important;
}
.content-title-sec * {
  font-family: var(--font-display) !important;
  font-size: 18px !important; font-weight: 700 !important;
  color: #0f0a1e !important; letter-spacing: -0.02em !important; margin: 0 !important;
}

.content-cats-sec {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 16px !important;
  width: 100% !important;
}
.content-cats-col,
div[data-tool] {
  min-width: 0 !important;
  width: 100% !important;
}

/* ══════════════════════════════════════════════════════════
   CARDS — Couleurs dynamiques par position
══════════════════════════════════════════════════════════ */
.content-cats-col:nth-child(6n+1) .content-cats-inner,
div[data-tool]:nth-child(6n+1) .content-cats-inner { --c1:#7c3aed; --c2:#a855f7; --rgb:124,58,237; }

.content-cats-col:nth-child(6n+2) .content-cats-inner,
div[data-tool]:nth-child(6n+2) .content-cats-inner { --c1:#d946ef; --c2:#e879f9; --rgb:217,70,239; }

.content-cats-col:nth-child(6n+3) .content-cats-inner,
div[data-tool]:nth-child(6n+3) .content-cats-inner { --c1:#4f46e5; --c2:#818cf8; --rgb:79,70,229; }

.content-cats-col:nth-child(6n+4) .content-cats-inner,
div[data-tool]:nth-child(6n+4) .content-cats-inner { --c1:#0ea5e9; --c2:#38bdf8; --rgb:14,165,233; }

.content-cats-col:nth-child(6n+5) .content-cats-inner,
div[data-tool]:nth-child(6n+5) .content-cats-inner { --c1:#10b981; --c2:#34d399; --rgb:16,185,129; }

.content-cats-col:nth-child(6n+6) .content-cats-inner,
div[data-tool]:nth-child(6n+6) .content-cats-inner { --c1:#f43f5e; --c2:#fb7185; --rgb:244,63,94; }

.content-cats-inner {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  background: white !important;
  border: 1.5px solid rgba(var(--rgb, 124,58,237), 0.14) !important;
  border-radius: var(--radius-card) !important;
  padding: 0 0 16px !important;
  text-decoration: none !important;
  color: inherit !important;
  height: 100% !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1),
              box-shadow 0.3s ease,
              border-color 0.2s ease !important;
  animation: cardEntrance 0.5s ease both;
}

/* Bande colorée animée en haut de chaque card */
.content-cats-inner::before {
  content: '' !important;
  display: block !important;
  flex-shrink: 0 !important;
  width: 100% !important;
  height: 4px !important;
  background: linear-gradient(90deg, var(--c1, #7c3aed), var(--c2, #a855f7), var(--c1, #7c3aed)) !important;
  background-size: 200% auto !important;
  animation: shimmer 3s linear infinite !important;
  border-radius: 0 !important;
}

/* Wash coloré derrière l'icône */
.content-cats-inner::after {
  content: '' !important;
  position: absolute !important;
  top: 0; left: 0; right: 0 !important;
  height: 100px !important;
  background: linear-gradient(180deg, rgba(var(--rgb, 124,58,237), 0.05) 0%, transparent 100%) !important;
  pointer-events: none !important;
  border-radius: var(--radius-card) var(--radius-card) 0 0 !important;
}

.content-cats-inner:hover {
  transform: translateY(-8px) scale(1.018) !important;
  border-color: rgba(var(--rgb, 124,58,237), 0.42) !important;
  box-shadow:
    0 20px 48px rgba(var(--rgb, 124,58,237), 0.2),
    0 4px 14px rgba(var(--rgb, 124,58,237), 0.1) !important;
  text-decoration: none !important;
  color: inherit !important;
}

/* Icône */
.content-cats-inner img,
.content-cats-inner svg,
.content-cats-inner .tool-icon,
.content-cats-inner .icon,
.content-cats-inner [class*="icon"],
.content-cats-inner [class*="img"] {
  max-width: 52px !important;
  max-height: 52px !important;
  width: auto !important; height: auto !important;
  display: block !important;
  margin: 20px 20px 12px !important;
  flex-shrink: 0 !important;
  object-fit: contain !important;
  position: relative; z-index: 1;
  transition: transform 0.3s ease, filter 0.3s ease !important;
  filter: drop-shadow(0 2px 8px rgba(var(--rgb, 124,58,237), 0.28)) !important;
}
.content-cats-inner:hover img,
.content-cats-inner:hover svg,
.content-cats-inner:hover [class*="icon"] {
  transform: translateY(-4px) scale(1.1) !important;
}

/* Titre */
.content-cats-inner h1,
.content-cats-inner h2,
.content-cats-inner h3,
.content-cats-inner h4 {
  font-family: var(--font-display) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.35 !important;
  color: #0f0a1e !important;
  margin: 0 0 8px !important;
  padding: 0 20px !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
  white-space: normal !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: block !important;
  transition: color 0.2s !important;
}
.content-cats-inner:hover h1,
.content-cats-inner:hover h2,
.content-cats-inner:hover h3,
.content-cats-inner:hover h4 {
  color: var(--c1, var(--violet)) !important;
}

/* Description */
.content-cats-inner p,
.content-cats-inner span {
  font-family: var(--font-body) !important;
  font-size: 12.5px !important;
  font-weight: 400 !important;
  color: #6b7280 !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  padding: 0 20px !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
  white-space: normal !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.content-cats-inner.locked { opacity: 0.55 !important; cursor: not-allowed !important; }
.content-cats-inner.locked:hover { transform: none !important; box-shadow: none !important; }

/* Animation décalée */
.content-cats-col:nth-child(1) .content-cats-inner,
div[data-tool]:nth-child(1) .content-cats-inner  { animation-delay: 0.04s; }
.content-cats-col:nth-child(2) .content-cats-inner,
div[data-tool]:nth-child(2) .content-cats-inner  { animation-delay: 0.09s; }
.content-cats-col:nth-child(3) .content-cats-inner,
div[data-tool]:nth-child(3) .content-cats-inner  { animation-delay: 0.14s; }
.content-cats-col:nth-child(4) .content-cats-inner,
div[data-tool]:nth-child(4) .content-cats-inner  { animation-delay: 0.18s; }
.content-cats-col:nth-child(5) .content-cats-inner,
div[data-tool]:nth-child(5) .content-cats-inner  { animation-delay: 0.22s; }
.content-cats-col:nth-child(6) .content-cats-inner,
div[data-tool]:nth-child(6) .content-cats-inner  { animation-delay: 0.27s; }

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.row { margin: 0 !important; }

.home-helping-sec {
  background: linear-gradient(135deg, rgba(124,58,237,0.06), rgba(217,70,239,0.03)) !important;
  border: 1px solid rgba(124,58,237,0.12) !important;
  border-radius: 20px !important;
  padding: 40px 36px !important;
  margin: 24px 16px 24px 28px !important;
}
.home-helping-sec * { color: #374151 !important; font-family: var(--font-body) !important; }
.home-helping-sec h2, .home-helping-sec h3 {
  font-family: var(--font-display) !important;
  font-weight: 700 !important; color: #0f0a1e !important;
  margin-bottom: 12px !important; letter-spacing: -0.02em !important;
}

footer {
  background: white !important;
  border-top: 1px solid rgba(124,58,237,0.08) !important;
  border-radius: 20px 20px 0 0 !important;
  padding: 36px 28px !important;
  margin: 24px 28px 0 16px !important;
}
.footer-logo img { height: 52px !important; width: auto !important; margin-bottom: 18px !important; }
.footer-nav {
  display: flex !important; flex-wrap: wrap !important;
  gap: 4px 2px !important; justify-content: center !important; margin: 16px 0 !important;
}
.footer-nav a {
  font-family: var(--font-body) !important;
  display: inline-block !important; padding: 6px 13px !important;
  font-size: 13px !important; font-weight: 600 !important; color: #111827 !important;
  text-decoration: none !important; border-radius: 9px !important;
  transition: color 0.2s, background 0.2s !important;
}
.footer-nav a:hover { color: var(--violet) !important; background: var(--violet-soft) !important; }
.footer-copyright {
  font-family: var(--font-body) !important;
  font-size: 12px !important; color: #374151 !important;
  text-align: center !important; margin-top: 14px !important;
}
.footer-copyright a { color: var(--violet) !important; text-decoration: none !important; }

/* ══════════════════════════════════════════════════════════
   BOUTONS
══════════════════════════════════════════════════════════ */
.btn.custom--btn, .btn-primary, .button__lg {
  font-family: var(--font-body) !important;
  background: linear-gradient(135deg, var(--violet), var(--fuchsia)) !important;
  color: white !important; border: none !important; border-radius: 14px !important;
  padding: 12px 28px !important; font-size: 14px !important; font-weight: 700 !important;
  cursor: pointer !important; text-decoration: none !important;
  display: inline-flex !important; align-items: center !important; gap: 8px !important;
  box-shadow: 0 4px 18px rgba(124,58,237,0.32) !important;
  transition: transform 0.2s, box-shadow 0.22s !important;
  letter-spacing: -0.01em;
}
.btn.custom--btn:hover, .btn-primary:hover, .button__lg:hover {
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow: 0 10px 30px rgba(124,58,237,0.42) !important;
  color: white !important;
}
.btn__light {
  background: white !important; color: var(--violet) !important;
  border: 2px solid rgba(124,58,237,0.25) !important;
  box-shadow: none !important;
}
.btn__light:hover { background: var(--violet-soft) !important; border-color: var(--violet) !important; color: var(--violet) !important; }

/* ══════════════════════════════════════════════════════════
   COOKIE ALERT
══════════════════════════════════════════════════════════ */
.cookie-alert {
  position: fixed !important; bottom: 20px !important;
  left: 50% !important; transform: translateX(-50%) !important;
  max-width: 500px !important; width: calc(100% - 32px) !important;
  background: white !important; border: 1.5px solid rgba(124,58,237,0.18) !important;
  border-radius: 16px !important; box-shadow: 0 12px 40px rgba(124,58,237,0.16) !important;
  padding: 16px 22px !important;
  font-family: var(--font-body) !important;
  font-size: 13.5px !important; color: #374151 !important;
  z-index: 9999 !important; display: flex !important; align-items: center !important;
  gap: 14px !important; justify-content: space-between !important;
}
.cookie-alert .btn { padding: 8px 18px !important; font-size: 13px !important; flex-shrink: 0 !important; }

/* ══════════════════════════════════════════════════════════
   ADS
══════════════════════════════════════════════════════════ */
.ads-top-banner, .ads-bottom-banner,
[class*="top-banner"], [class*="bottom-banner"] {
  display: block !important; width: 100% !important;
  max-width: 1280px !important; margin: 16px auto !important;
  padding: 8px 28px !important; background: rgba(255,255,255,0.6) !important;
  border: 1px solid rgba(124,58,237,0.07) !important;
  border-radius: 14px !important; text-align: center !important;
  min-height: 90px !important; overflow: hidden !important;
}

/* ══════════════════════════════════════════════════════════
   DARK MODE
══════════════════════════════════════════════════════════ */
body.dark { background: #0b0814 !important; color: #e5e7eb !important; }
body.dark header.mainPadding {
  background: rgba(18,13,30,0.93) !important;
  border-bottom-color: rgba(124,58,237,0.22) !important;
}
body.dark .header-navbar ul li a { color: #d1d5db !important; }
body.dark .header-language-btn {
  background: #1a1228 !important; border-color: rgba(124,58,237,0.28) !important; color: #d1d5db !important;
}
body.dark .content-cats-inner { background: #13102b !important; }
body.dark .content-cats-inner h1, body.dark .content-cats-inner h2,
body.dark .content-cats-inner h3, body.dark .content-cats-inner h4 { color: #f3f4f6 !important; }
body.dark .content-cats-inner p, body.dark .content-cats-inner span { color: #9ca3af !important; }
body.dark .content-cats-inner:hover { background: #1a1535 !important; }
body.dark footer { background: #13102b !important; border-top-color: rgba(124,58,237,0.18) !important; }
body.dark .footer-nav a { color: #9ca3af !important; }
body.dark .intro-text {
  background: rgba(19,16,43,0.8) !important; border-color: rgba(124,58,237,0.22) !important;
}
body.dark .intro-text p { color: #d1d5db !important; }
body.dark .main-search-sec input[type="text"] {
  background: #1a1228 !important; color: #e5e7eb !important; border-color: rgba(124,58,237,0.35) !important;
}
body.dark .content-title-sec {
  background: linear-gradient(#13102b, #13102b) padding-box,
              linear-gradient(90deg, var(--violet), var(--fuchsia), transparent) border-box !important;
}
body.dark .content-title-sec * { color: #f3f4f6 !important; }
body.dark .hero-section {
  background:
    radial-gradient(ellipse 80% 60% at 20% -10%, rgba(124,58,237,0.3) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 110%, rgba(217,70,239,0.22) 0%, transparent 55%),
    linear-gradient(165deg, #0b0814 0%, #130d24 50%, #0d0a1e 100%) !important;
}
body.dark .home-helping-sec {
  background: linear-gradient(135deg, rgba(124,58,237,0.1), rgba(217,70,239,0.06)) !important;
  border-color: rgba(124,58,237,0.2) !important;
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media (max-width: 992px) {
  .header-navbar {
    display: none !important;
    position: absolute !important; top: 64px !important; left: 0 !important; right: 0 !important;
    background: rgba(255,255,255,0.97) !important;
    backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid rgba(124,58,237,0.1) !important;
    box-shadow: 0 12px 28px rgba(124,58,237,0.12) !important;
    padding: 12px 16px !important; z-index: 999 !important;
  }
  .header-navbar.show { display: flex !important; animation: slideDown 0.25s ease both; }
  .header-navbar ul { flex-direction: column !important; width: 100% !important; gap: 4px !important; }
  .header-navbar ul li { width: 100%; }
  .header-navbar ul li a { display: block !important; padding: 11px 16px !important; }
  #navbar-toggler.nav-btn { display: flex !important; }
  header.mainPadding { padding: 0 16px !important; }
  body.dark .header-navbar { background: rgba(18,13,30,0.97) !important; }
}

@media (max-width: 768px) {
  .hero-section { padding: 52px 16px 44px !important; }
  .content-cats-sec { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important; gap: 12px !important; }
  .content-sec { padding: 16px 16px 48px !important; }
  .home-helping-sec { margin: 16px !important; padding: 28px 22px !important; }
  footer { margin: 0 !important; border-radius: 0 !important; }
}

@media (max-width: 480px) {
  .content-cats-sec { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
  .intro-text { padding: 20px 18px !important; }
  .intro-text ul { grid-template-columns: 1fr !important; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
