/*
Theme Name:   Foxiz Child — AI Explorer
Theme URI:    https://ai-explorer.io
Description:  Child theme de Foxiz pour aligner le blog AI Explorer sur l'identité visuelle du SaaS (cyber, palette OKLCH bleu cyan, typo monospace pour accessoires). Option B2 — mimétisme structurel.
Author:       Lorn / AI Explorer
Author URI:   https://ai-explorer.io
Template:     foxiz
Version:      1.2.0
Text Domain:  foxiz-child
*/

/* ============================================================
   1. DESIGN TOKENS — synchronisés avec frontend/app/globals.css du SaaS
   ============================================================ */

:root {
  --aix-font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --aix-font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --aix-background: oklch(0.975 0.004 70);
  --aix-foreground: oklch(0.18 0.005 70);
  --aix-card: oklch(1 0 0);
  --aix-muted: oklch(0.955 0.004 70);
  --aix-muted-foreground: oklch(0.48 0.008 70);
  --aix-border: oklch(0.91 0.005 70);
  --aix-primary: oklch(0.48 0.14 245);
  --aix-primary-foreground: oklch(0.99 0.002 70);
  --aix-link: oklch(0.48 0.14 245);
  --aix-link-hover: oklch(0.40 0.14 245);
}

html.theme-dark, html.dark-theme, html.is-dark, html.dark-mode, html.dark, html.ruby-dark-mode, html.foxiz-dark,
body.theme-dark, body.dark-theme, body.is-dark, body.dark-mode, body.dark, body.ruby-dark-mode, body.foxiz-dark,
[data-theme="dark"] {
  --aix-background: oklch(0.125 0.025 262);
  --aix-foreground: oklch(0.985 0 0);
  --aix-card: oklch(0.18 0.025 262);
  --aix-muted: oklch(0.26 0.02 262);
  --aix-muted-foreground: oklch(0.7 0 0);
  --aix-border: oklch(0.32 0.02 262);
  --aix-primary: oklch(0.65 0.18 241.966);
  --aix-primary-foreground: oklch(1 0 0);
  --aix-link: oklch(0.72 0.16 241.966);
  --aix-link-hover: oklch(0.82 0.14 241.966);
}


/* ============================================================
   2. HEADER — desktop
   ============================================================ */

.aix-header {
  position: sticky;
  top: 0;
  z-index: 999;
  width: 100%;
  background: var(--aix-background);
  border-bottom: 1px solid color-mix(in oklch, var(--aix-border) 50%, transparent);
  backdrop-filter: blur(12px) saturate(120%);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
  transition: background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.aix-header.is-scrolled {
  background: color-mix(in oklch, var(--aix-background) 88%, transparent);
  border-bottom-color: color-mix(in oklch, var(--aix-primary) 14%, var(--aix-border));
  box-shadow: 0 10px 30px -22px color-mix(in oklch, var(--aix-primary) 50%, transparent);
}

.aix-header-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1rem;
  height: 64px;
  padding: 0 1rem;
}

/* Logo */
.aix-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--aix-foreground);
  flex-shrink: 0;
}

.aix-logo-mark {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: color-mix(in oklch, var(--aix-primary) 8%, transparent);
  border: 1px solid color-mix(in oklch, var(--aix-primary) 30%, transparent);
  transition: all 0.3s ease;
}

.aix-logo-mark::after {
  content: '';
  position: absolute;
  top: -1px;
  right: -1px;
  width: 5px;
  height: 5px;
  background: var(--aix-primary);
  border-radius: 999px;
  box-shadow: 0 0 8px var(--aix-primary);
  opacity: 0.8;
}

.aix-logo-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--aix-primary);
  box-shadow:
    0 0 8px color-mix(in oklch, var(--aix-primary) 80%, transparent),
    inset 0 0 0 1px color-mix(in oklch, white 30%, transparent);
  animation: aix-blink 2.6s ease-in-out infinite;
}

.aix-logo:hover .aix-logo-mark {
  background: color-mix(in oklch, var(--aix-primary) 14%, transparent);
  border-color: color-mix(in oklch, var(--aix-primary) 55%, transparent);
  box-shadow: 0 0 18px -4px color-mix(in oklch, var(--aix-primary) 50%, transparent);
}

.aix-logo-text {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--aix-font-mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--aix-foreground);
}

.aix-logo-sep {
  color: color-mix(in oklch, var(--aix-primary) 80%, transparent);
  font-weight: 400;
}

@keyframes aix-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* Navigation desktop */
.aix-nav {
  display: none;
  align-items: center;
  gap: 4px;
  list-style: none !important;
  margin: 0;
  padding: 0;
}

@media (min-width: 1024px) {
  .aix-nav {
    display: inline-flex;
  }
}

.aix-nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.aix-nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 8px 12px;
  font-family: var(--aix-font-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--aix-muted-foreground) 92%, transparent);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.25s ease;
}

.aix-nav-link::before {
  content: '';
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 2px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--aix-primary), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.35s cubic-bezier(0.2, 0.9, 0.3, 1.2);
}

.aix-nav-link:hover,
.aix-nav-link.is-active {
  color: var(--aix-foreground);
}

.aix-nav-link:hover::before,
.aix-nav-link.is-active::before {
  transform: scaleX(1);
}

.aix-nav-link.is-highlight {
  color: color-mix(in oklch, var(--aix-primary) 90%, var(--aix-foreground));
}

.aix-nav-link.is-highlight::after {
  content: '';
  position: absolute;
  top: 6px;
  right: 6px;
  width: 5px;
  height: 5px;
  background: var(--aix-primary);
  border-radius: 999px;
  box-shadow: 0 0 6px var(--aix-primary);
  animation: aix-blink 2.4s ease-in-out infinite;
}

/* Spacer (pousse les actions à droite en desktop) */
.aix-spacer {
  flex: 1;
}

/* Conteneur des actions (search, fontresize, darkmode, hamburger) */
.aix-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Bouton icône générique (utilisé pour close drawer) */
.aix-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: color-mix(in oklch, var(--aix-muted-foreground) 90%, transparent);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.25s ease;
  text-decoration: none;
}

.aix-icon-btn:hover {
  color: var(--aix-foreground);
  background: color-mix(in oklch, var(--aix-primary) 6%, transparent);
  border-color: color-mix(in oklch, var(--aix-primary) 25%, transparent);
}

.aix-icon-btn svg {
  width: 16px;
  height: 16px;
}

/* Lang toggle (desktop uniquement) */
.aix-lang-btn {
  display: none;
  align-items: center;
  gap: 6px;
  height: 36px;
  padding: 0 12px;
  font-family: var(--aix-font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: color-mix(in oklch, var(--aix-muted-foreground) 95%, transparent);
  background: transparent;
  border: 1px solid color-mix(in oklch, var(--aix-border) 80%, transparent);
  cursor: pointer;
  transition: all 0.25s ease;
  text-decoration: none;
}

@media (min-width: 768px) {
  .aix-lang-btn {
    display: inline-flex;
  }
}

.aix-lang-btn:hover {
  color: var(--aix-foreground);
  border-color: color-mix(in oklch, var(--aix-primary) 40%, transparent);
  background: color-mix(in oklch, var(--aix-primary) 4%, transparent);
}

.aix-lang-current { color: var(--aix-primary); }
.aix-lang-sep { color: color-mix(in oklch, var(--aix-muted-foreground) 60%, transparent); font-weight: 400; }

/* CTA primaire (Premium etc.) */
.aix-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 36px;
  padding: 0 16px;
  font-family: var(--aix-font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--aix-primary-foreground);
  background: linear-gradient(135deg,
    var(--aix-primary),
    color-mix(in oklch, var(--aix-primary) 75%, oklch(0.65 0.2 280) 25%));
  border: 1px solid color-mix(in oklch, var(--aix-primary) 55%, transparent);
  box-shadow:
    0 6px 24px -8px color-mix(in oklch, var(--aix-primary) 60%, transparent),
    inset 0 1px 0 color-mix(in oklch, white 25%, transparent);
  text-decoration: none;
  transition: all 0.25s ease;
}

.aix-cta-primary:hover {
  box-shadow:
    0 10px 32px -6px color-mix(in oklch, var(--aix-primary) 70%, transparent),
    inset 0 1px 0 color-mix(in oklch, white 35%, transparent);
}

/* Bouton hamburger (mobile/tablette) */
.aix-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--aix-foreground);
  cursor: pointer;
}

@media (min-width: 1024px) {
  .aix-menu-toggle {
    display: none;
  }
}


/* ============================================================
   3. DRAWER MOBILE
   ============================================================ */

.aix-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 88vw;
  max-width: 360px;
  background: var(--aix-background);
  border-left: 1px solid color-mix(in oklch, var(--aix-primary) 18%, var(--aix-border));
  z-index: 1000;
  transform: translateX(100%);
  transition: transform 0.3s ease, visibility 0s linear 0.3s;
  overflow-y: auto;
  visibility: hidden;
  pointer-events: none;
}

.aix-drawer.is-open {
  transform: translateX(0);
  visibility: visible;
  pointer-events: auto;
  transition: transform 0.3s ease, visibility 0s linear 0s;
}

.aix-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.aix-drawer-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

.aix-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid color-mix(in oklch, var(--aix-primary) 18%, var(--aix-border));
}

.aix-drawer-body {
  padding: 20px;
}

.aix-drawer-nav {
  list-style: none !important;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.aix-drawer-nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.aix-drawer-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  font-family: var(--aix-font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: color-mix(in oklch, var(--aix-foreground) 88%, transparent);
  text-decoration: none;
  border: 1px solid transparent;
  transition: all 0.25s ease;
}

.aix-drawer-link:hover,
.aix-drawer-link.is-active {
  background: color-mix(in oklch, var(--aix-primary) 5%, transparent);
  border-color: color-mix(in oklch, var(--aix-primary) 22%, transparent);
  color: var(--aix-foreground);
}

.aix-drawer-link-bracket {
  font-family: var(--aix-font-mono);
  font-size: 14px;
  color: color-mix(in oklch, var(--aix-primary) 70%, transparent);
  flex-shrink: 0;
}

.aix-drawer-link-label {
  flex: 1;
}

.aix-drawer-link-arrow {
  font-family: var(--aix-font-mono);
  color: color-mix(in oklch, var(--aix-muted-foreground) 50%, transparent);
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.aix-drawer-link:hover .aix-drawer-link-arrow,
.aix-drawer-link.is-active .aix-drawer-link-arrow {
  opacity: 1;
  transform: translateX(0);
  color: var(--aix-primary);
}


/* ============================================================
   4. FOOTER
   ============================================================ */

.aix-footer {
  position: relative;
  isolation: isolate;
  border-top: 1px solid color-mix(in oklch, var(--aix-primary) 25%, transparent);
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--aix-primary) 3%, transparent) 0%,
      transparent 40%),
    var(--aix-background);
  color: color-mix(in oklch, var(--aix-foreground) 80%, transparent);
  padding: 48px 0 24px;
  margin-top: 64px;
}

.aix-footer-scan {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 5%, var(--aix-primary) 35%, oklch(0.65 0.2 280) 65%, transparent 95%);
  opacity: 0.5;
  pointer-events: none;
}

.aix-footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1rem;
}

.aix-footer-grid {
  display: grid;
  gap: 32px;
  grid-template-columns: 1fr;
  margin-bottom: 32px;
}

@media (min-width: 768px) {
  .aix-footer-grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }
}

.aix-footer-brand-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.aix-footer-tagline {
  font-size: 13px;
  line-height: 1.6;
  color: color-mix(in oklch, var(--aix-muted-foreground) 95%, transparent);
  max-width: 320px;
}

.aix-footer-section-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--aix-font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--aix-primary) 80%, white 10%);
  margin-bottom: 12px;
}

.aix-footer-links {
  list-style: none !important;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.aix-footer-links li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.aix-footer-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--aix-font-sans);
  font-size: 13px;
  color: color-mix(in oklch, var(--aix-foreground) 75%, transparent);
  text-decoration: none;
  transition: color 0.2s ease;
}

.aix-footer-link:hover {
  color: var(--aix-primary);
}

.aix-footer-link::before {
  content: '→';
  font-family: var(--aix-font-mono);
  color: color-mix(in oklch, var(--aix-primary) 40%, transparent);
  transition: color 0.2s ease, transform 0.2s ease;
}

.aix-footer-link:hover::before {
  color: var(--aix-primary);
  transform: translateX(2px);
}

.aix-footer-bottom {
  border-top: 1px solid color-mix(in oklch, var(--aix-border) 50%, transparent);
  padding-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  font-family: var(--aix-font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: color-mix(in oklch, var(--aix-muted-foreground) 80%, transparent);
}

@media (min-width: 768px) {
  .aix-footer-bottom {
    flex-direction: row;
    justify-content: space-between;
  }
}


/* ============================================================
   5. CONTENU ARTICLE — typo/couleurs alignées SaaS
   ============================================================ */

body {
  font-family: var(--aix-font-sans);
}

.single-content a,
.entry-content a,
.post-content a {
  color: var(--aix-link);
  transition: color 0.2s ease;
}

.single-content a:hover,
.entry-content a:hover,
.post-content a:hover {
  color: var(--aix-link-hover);
}

.single-content h1, .single-content h2, .single-content h3,
.entry-content h1, .entry-content h2, .entry-content h3,
.post-content h1, .post-content h2, .post-content h3 {
  font-family: var(--aix-font-sans);
  letter-spacing: -0.015em;
}

.single-content code,
.entry-content code,
.post-content code {
  font-family: var(--aix-font-mono);
}


/* ============================================================
   6. WRAPPERS FOXIZ — search + fontresize uniquement
   (Le toggle dark/light est laissé en rendu natif Foxiz)
   ============================================================ */

.aix-foxiz-slot {
  display: inline-flex;
  align-items: center;
  height: 36px;
  position: relative;
}

.aix-foxiz-slot .wnav-holder {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 36px;
  position: relative !important;
}

/* --- Search trigger (loupe) --- */
.aix-foxiz-search .search-trigger {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px;
  height: 36px;
  padding: 0 !important;
  margin: 0 !important;
  color: color-mix(in oklch, var(--aix-muted-foreground) 90%, transparent) !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 0 !important;
  transition: all 0.25s ease !important;
}

.aix-foxiz-search .search-trigger:hover {
  color: var(--aix-foreground) !important;
  background: color-mix(in oklch, var(--aix-primary) 6%, transparent) !important;
  border-color: color-mix(in oklch, var(--aix-primary) 25%, transparent) !important;
}

.aix-foxiz-search .search-trigger .rbi-search,
.aix-foxiz-search .search-trigger .wnav-icon {
  font-size: 16px !important;
  color: inherit !important;
}

/* Search dropdown desktop : ancré au bouton */
.aix-foxiz-search .header-dropdown-outer {
  position: relative !important;
}

.aix-foxiz-search .header-dropdown {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  right: 0 !important;
  left: auto !important;
  width: 380px !important;
  max-width: 90vw !important;
  z-index: 1000 !important;
}

/* --- Font Resizer "Aa" --- */
.aix-foxiz-fontresize .font-resizer {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
}

.aix-foxiz-fontresize .font-resizer-trigger {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px;
  height: 36px;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 0 !important;
  color: color-mix(in oklch, var(--aix-muted-foreground) 90%, transparent) !important;
  font-family: var(--aix-font-mono) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  text-decoration: none !important;
  transition: all 0.25s ease !important;
}

.aix-foxiz-fontresize .font-resizer-trigger:hover {
  color: var(--aix-primary) !important;
  background: color-mix(in oklch, var(--aix-primary) 6%, transparent) !important;
  border-color: color-mix(in oklch, var(--aix-primary) 25%, transparent) !important;
}

.aix-foxiz-fontresize .font-resizer-trigger strong {
  font-weight: 600 !important;
  color: inherit !important;
  font-size: 13px !important;
  letter-spacing: 0.02em;
}


/* ============================================================
   7. ACCESSIBILITÉ — reduced motion
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  .aix-logo-dot,
  .aix-nav-link.is-highlight::after,
  .aix-nav-link::before,
  .aix-drawer-link,
  .aix-drawer-link-arrow {
    animation: none !important;
    transition: none !important;
  }
}


/* ============================================================
   8. MOBILE & TABLETTE PORTRAIT (≤ 1023px)
   Toutes les overrides mobile sont ici. Aucune règle hors media-query
   ne touche au layout mobile.
   ============================================================ */

@media (max-width: 1023px) {

  /* Header inner : hauteur + padding réduits + protection flex */
.aix-header-inner {
  height: 56px;
  gap: 0.5rem;
  padding: 0 1rem 0 0.75rem;
  min-width: 0;
}

  /* Actions poussées à droite + gap minimal entre boutons */
  .aix-actions {
    flex-shrink: 0;
    margin-left: auto;
    gap: 2px;
  }

  .aix-menu-toggle {
    flex-shrink: 0;
  }

  /* Boutons d'actions à 36px (sauf toggle dark/light : rendu natif Foxiz) */
  .aix-icon-btn,
  .aix-menu-toggle,
  .aix-foxiz-search .search-trigger,
  .aix-foxiz-fontresize .font-resizer-trigger {
    width: 36px !important;
    height: 36px !important;
  }

  /* Dropdown recherche : fixed dans le viewport, centré horizontalement */
  .aix-foxiz-search .header-dropdown {
    position: fixed !important;
    top: 64px !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-width: none !important;
  }
}