/* ============================================================
   2D ONLINE — Design System v3 (WonderKids aesthetic)
   Purple · Yellow · White · Playful · Rounded
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,400;0,600;0,700;0,800;0,900;1,700;1,800;1,900&family=Fredoka+One&display=swap');

/* ── Tokens ─────────────────────────────────────────────── */
:root {
  --brand:        #7C3AED;
  --brand-light:  #EDE9FE;
  --brand-mid:    #A78BFA;
  --accent:       #F59E0B;
  --accent-light: #FEF3C7;
  --ink:          #1a1235;
  --radius:       1.25rem;
  --radius-xl:    2rem;
  --radius-pill:  999px;
  --bs-primary:        #7C3AED;
  --bs-primary-rgb:    124,58,237;
  --bs-link-color:     #7C3AED;
  --bs-font-sans-serif: 'Nunito', system-ui, sans-serif;
}

[data-bs-theme="light"] {
  --bs-body-bg:         #f5f3ff;
  --bs-body-color:      #1a1235;
  --bs-secondary-color: rgba(26,18,53,.60);
  --bs-tertiary-bg:     #ede9fe;
  --bs-border-color:    rgba(124,58,237,.14);
}

[data-bs-theme="dark"] {
  --bs-body-bg:         #0f0b1e;
  --bs-body-color:      #f0eaff;
  --bs-secondary-color: rgba(240,234,255,.60);
  --bs-tertiary-bg:     #1e1535;
  --bs-border-color:    rgba(167,139,250,.18);
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--bs-font-sans-serif);
  background-color: var(--bs-body-bg);
  background-image:
    radial-gradient(900px 500px at 5% 0%, rgba(124,58,237,.13), transparent 60%),
    radial-gradient(700px 420px at 92% 8%, rgba(245,158,11,.11), transparent 55%),
    radial-gradient(600px 400px at 50% 95%, rgba(124,58,237,.08), transparent 60%);
}

[data-bs-theme="dark"] body {
  background-image:
    radial-gradient(900px 500px at 5% 0%, rgba(124,58,237,.20), transparent 60%),
    radial-gradient(700px 420px at 92% 8%, rgba(245,158,11,.14), transparent 55%),
    radial-gradient(600px 400px at 50% 95%, rgba(124,58,237,.12), transparent 60%);
}

/* ── Typography ──────────────────────────────────────────── */
.font-display { font-family: 'Fredoka One', cursive; }
.text-brand   { color: var(--brand)  !important; }
.text-accent  { color: var(--accent) !important; }

.italic-accent        { font-style: italic; color: var(--brand);  font-weight: 800; }
.italic-accent-yellow { font-style: italic; color: var(--accent); font-weight: 800; }

/* Squiggle underline */
.underline-sketch { position: relative; display: inline-block; }
.underline-sketch::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0; right: 0;
  height: 6px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 8'%3E%3Cpath d='M2 6 Q30 1 60 6 Q90 11 118 6' stroke='%23F59E0B' stroke-width='2.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") repeat-x center;
  background-size: auto 100%;
}

/* ── Navbar ──────────────────────────────────────────────── */
.navbar-glass {
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: color-mix(in oklab, var(--bs-body-bg) 88%, transparent);
  border-bottom: 1px solid var(--bs-border-color);
  padding-top: .75rem;
  padding-bottom: .75rem;
}
.brand-logo { height: 28px; width: auto; max-width: 170px; }
.brand-mark { width:14px; height:14px; background: url('/assets/img/favicon.png') no-repeat center/14px; display:inline-block; }
.navbar .nav-link {
  font-weight: 700;
  border-radius: var(--radius-pill);
  padding: .4rem .9rem;
  transition: background .15s, color .15s;
}
.navbar .nav-link:hover,
.navbar .nav-link.active {
  background: var(--brand-light);
  color: var(--brand) !important;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn-primary {
  --bs-btn-bg:           var(--brand);
  --bs-btn-border-color: var(--brand);
  --bs-btn-hover-bg:     #6d28d9;
  --bs-btn-hover-border-color: #6d28d9;
  --bs-btn-active-bg:    #5b21b6;
  --bs-btn-color:        #fff;
  --bs-btn-hover-color:  #fff;
  border-radius: var(--radius-pill);
  font-weight: 700;
}
.btn-outline-primary {
  --bs-btn-color:        var(--brand);
  --bs-btn-border-color: var(--brand);
  --bs-btn-hover-bg:     var(--brand);
  --bs-btn-hover-color:  #fff;
  border-radius: var(--radius-pill);
  font-weight: 700;
}
.btn-outline-secondary { border-radius: var(--radius-pill); font-weight: 700; }

.btn-accent {
  background: var(--accent); border-color: var(--accent);
  color: #1a1235; border-radius: var(--radius-pill);
  font-weight: 800; padding: .65rem 1.8rem;
  transition: transform .15s, box-shadow .15s;
}
.btn-accent:hover {
  background: #d97706; border-color: #d97706; color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(245,158,11,.35);
}
.btn-icon { width:42px; height:42px; display:inline-flex; align-items:center; justify-content:center; border-radius:var(--radius-pill); }

/* ── Section kicker ──────────────────────────────────────── */
.section-kicker {
  font-size: .78rem; letter-spacing: .12em; text-transform: uppercase;
  font-weight: 800; color: var(--brand); margin-bottom: .35rem; display: inline-block;
}

/* ── Tag chips ───────────────────────────────────────────── */
.tag-chip {
  display: inline-block;
  background: #fff; border: 1.5px solid rgba(124,58,237,.18);
  border-radius: var(--radius-pill); padding: .3rem .9rem;
  font-size: .82rem; font-weight: 700; color: var(--ink);
  box-shadow: 0 2px 8px rgba(124,58,237,.08);
}
.tag-chip.yellow { background: var(--accent-light); border-color: rgba(245,158,11,.3); color: #92400e; }
.tag-chip.purple { background: var(--brand-light);  border-color: rgba(124,58,237,.3); color: var(--brand); }

/* ── Cards ───────────────────────────────────────────────── */
.card-soft {
  border: 1.5px solid var(--bs-border-color);
  border-radius: var(--radius-xl);
  background: color-mix(in oklab, var(--bs-body-bg) 96%, white);
  box-shadow: 0 4px 24px rgba(124,58,237,.07);
}
[data-bs-theme="light"] .card-soft { background: #fff; box-shadow: 0 4px 32px rgba(124,58,237,.09); }
.card-hover { transition: transform .2s ease, box-shadow .2s ease; }
.card-hover:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(124,58,237,.14); }

.card-purple { background: var(--brand) !important; border-color: var(--brand) !important; color: #fff; border-radius: var(--radius-xl); }
.card-yellow { background: var(--accent) !important; border-color: var(--accent) !important; color: #1a1235; border-radius: var(--radius-xl); }
.card-light-purple { background: var(--brand-light) !important; border-color: rgba(124,58,237,.2) !important; border-radius: var(--radius-xl); }

/* ── Hero ────────────────────────────────────────────────── */
.hero { position: relative; overflow: hidden; padding-top: 4rem; padding-bottom: 4rem; }
.hero::before {
  content: '';
  position: absolute; inset: -30%;
  background:
    radial-gradient(600px 350px at 25% 20%, rgba(124,58,237,.18), transparent 60%),
    radial-gradient(500px 300px at 78% 15%, rgba(245,158,11,.15), transparent 60%);
  filter: blur(30px);
  pointer-events: none;
}
.hero > .container { position: relative; z-index: 1; }

/* ── Stats ───────────────────────────────────────────────── */
.stat-card { background: #fff; border-radius: var(--radius); padding: 1.25rem 1.5rem; border: 1.5px solid var(--bs-border-color); text-align: center; }
[data-bs-theme="dark"] .stat-card { background: var(--bs-tertiary-bg); }
.stat-number { font-family: 'Fredoka One', cursive; font-size: 2rem; color: var(--brand); line-height: 1; }
.stat-label  { font-size: .82rem; font-weight: 700; color: var(--bs-secondary-color); }

/* ── Feature icon ────────────────────────────────────────── */
.feature-icon {
  width: 52px; height: 52px; border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; background: var(--brand-light); color: var(--brand); flex-shrink: 0;
}
.card-purple .feature-icon { background: rgba(255,255,255,.18); color: #fff; }
.card-yellow .feature-icon { background: rgba(255,255,255,.35); color: #92400e; }

/* ── Solutions section ───────────────────────────────────── */
.section-solutions { background: var(--brand); color: #fff; }
.section-solutions .section-kicker       { color: rgba(255,255,255,.75); }
.section-solutions .text-body-secondary  { color: rgba(255,255,255,.75) !important; }
.section-solutions .card-soft            { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.22); color: #fff; }
.section-solutions .card-soft li         { color: rgba(255,255,255,.85); }

/* ── Badges ──────────────────────────────────────────────── */
.badge-soft   { background: var(--brand-light); color: var(--brand); border: 1.5px solid rgba(124,58,237,.22); font-weight: 700; border-radius: var(--radius-pill); }
.badge-dev    { background: rgba(245,158,11,.15); color: #92400e; border: 1px solid rgba(245,158,11,.3); font-weight: 700; }
.badge-ended  { background: rgba(148,163,184,.18); color: #64748b; border: 1px solid rgba(148,163,184,.28); font-weight: 700; }

/* ── Avatar circles ──────────────────────────────────────── */
.avatar-circle { width:52px; height:52px; border-radius:var(--radius-pill); display:inline-flex; align-items:center; justify-content:center; font-size:1.4rem; border:2px solid var(--bs-border-color); background:var(--brand-light); color:var(--brand); }

/* ── Budget ──────────────────────────────────────────────── */
:root { --budget-admin:#dc2626; --budget-servers:#7C3AED; --budget-domains:#10b981; --budget-misc:#94a3b8; }
[data-bs-theme="dark"] { --budget-admin:#f87171; --budget-servers:#a78bfa; --budget-domains:#6ee7b7; --budget-misc:#cbd5e1; }
.budget-legend { border:1.5px dashed var(--bs-border-color); border-radius:var(--radius); padding:1rem; background:color-mix(in oklab,var(--bs-body-bg) 92%,transparent); }
.legend-dot { width:12px; height:12px; border-radius:var(--radius-pill); display:inline-block; }
.dot-admin{background:var(--budget-admin);} .dot-servers{background:var(--budget-servers);} .dot-domains{background:var(--budget-domains);} .dot-misc{background:var(--budget-misc);}

/* ── Footer ──────────────────────────────────────────────── */
.footer { background: color-mix(in oklab, var(--bs-body-bg) 95%, transparent); border-top: 1.5px solid var(--bs-border-color); }

/* ── Prose ───────────────────────────────────────────────── */
.prose h1, .prose h2, .prose h3 { letter-spacing: -.02em; font-weight: 800; }
.prose p { color: var(--bs-secondary-color); }
.anchor-offset { scroll-margin-top: 88px; }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

/* ── Meta rows ───────────────────────────────────────────── */
.meta-row { display:flex; gap:.75rem; padding:.75rem; border-radius:var(--radius); border:1.5px solid var(--bs-border-color); background:color-mix(in oklab,var(--bs-body-bg) 92%,transparent); }
.meta-icon { width:34px; height:34px; border-radius:var(--radius-pill); display:flex; align-items:center; justify-content:center; background:var(--brand-light); color:var(--brand); flex:0 0 auto; }
.meta-body { flex:1; min-width:0; }
.meta-label { font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--bs-secondary-color); margin-bottom:.1rem; }
.meta-value { font-weight:700; color:var(--bs-body-color); }

/* ── Project ─────────────────────────────────────────────── */
.project-logo-xl { height:60px; object-fit:cover; }
.project-logo-slot { display:flex; justify-content:center; align-items:center; min-height:120px; }
.project-logo-plain { display:block; width:min(520px,100%); max-height:270px; height:auto; object-fit:contain; border:0!important; background:transparent!important; box-shadow:none!important; }

/* ── News cards ──────────────────────────────────────────── */
.news-card { background:#fff; border-radius:var(--radius-xl); border:1.5px solid var(--bs-border-color); overflow:hidden; transition:transform .2s,box-shadow .2s; }
[data-bs-theme="dark"] .news-card { background:var(--bs-tertiary-bg); }
.news-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(124,58,237,.14); }
.news-card-kicker { font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--brand); }

/* ── Mobile nav ──────────────────────────────────────────── */

/* ── Fix décalage Bootstrap offcanvas ───────────────────────
   Bootstrap injecte padding-right sur <body> via JS pour compenser
   la scrollbar quand l'offcanvas est ouvert. Sur mobile (pas de
   scrollbar fixe) cela décale le contenu vers la droite.
   Solution : bloquer overflow-x + annuler le padding injecté.
────────────────────────────────────────────────────────────── */
html { overflow-x: hidden; width: 100%; }
body { overflow-x: hidden; width: 100%; }

/* Neutralise l'injection JS de Bootstrap: style="padding-right: Xpx" */
body[style*="padding-right"] { padding-right: 0 !important; }

/* =========================
   NAVCANVAS — BASE
========================= */
#navCanvas {
  --bs-offcanvas-width: min(92vw, 420px);
  border-left: 1.5px solid var(--bs-border-color);
  /* Pas de backdrop-filter ici : il rendrait le panneau transparent */
}
#navCanvas .offcanvas-header {
  border-bottom: 1.5px solid var(--bs-border-color);
}

/* =========================
   DESKTOP (≥992px) :
   Le panneau est inline dans la navbar → fond transparent
========================= */
@media (min-width: 992px) {
  #navCanvas,
  #navCanvas.offcanvas {
    background: transparent !important;
    background-color: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;
    visibility: visible !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    overflow: visible !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  #navCanvas .offcanvas-header { display: none !important; }
  #navCanvas .offcanvas-body {
    display: flex !important;
    align-items: center;
    justify-content: flex-end !important;
    padding: 0 !important;
    overflow: visible !important;
    background: transparent !important;
  }
  #navCanvas .navbar-nav {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: .75rem;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }
}

/* =========================
   MOBILE (<992px) :
   Fond blanc/sombre SOLIDE — pas de transparence
========================= */
@media (max-width: 991.98px) {
  #navCanvas,
  #navCanvas.offcanvas {
    /* Fond SOLIDE — la semi-transparence avec backdrop-filter
       cause des artefacts sur de nombreux mobiles */
    background-color: #ffffff !important;
    background-image: none !important;
    color: var(--bs-body-color) !important;
    width: min(92vw, 420px) !important;
    height: 100dvh !important;
    box-shadow: -8px 0 32px rgba(0, 0, 0, .12);
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  [data-bs-theme="dark"] #navCanvas,
  [data-bs-theme="dark"] #navCanvas.offcanvas {
    background-color: #0f0b1e !important;
    color: rgba(255, 255, 255, .92) !important;
  }
  #navCanvas .offcanvas-body {
    flex-grow: 1 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding-top: .75rem;
    padding-bottom: calc(1rem + env(safe-area-inset-bottom));
  }
  #navCanvas .navbar-nav { width: 100%; gap: .4rem; }
  #navCanvas .nav-link {
    padding: .85rem 1rem;
    border-radius: var(--radius);
    background-color: var(--bs-tertiary-bg);
    border: 1.5px solid var(--bs-border-color);
  }
  #navCanvas .nav-link:hover { background: var(--brand-light); color: var(--brand); }
  #navCanvas .navbar-nav .btn { width: 100%; justify-content: center; border-radius: var(--radius); padding: .85rem 1rem; }
  #navCanvas .navbar-nav .btn-icon { width: 100%; height: auto; border-radius: var(--radius); }
}

/* ── Animations ──────────────────────────────────────────── */
@keyframes fadeInUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.fade-in-up { animation: fadeInUp .5s ease both; }
.delay-1{animation-delay:.1s} .delay-2{animation-delay:.2s} .delay-3{animation-delay:.3s} .delay-4{animation-delay:.4s}

@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.float-anim { animation: float 4s ease-in-out infinite; }

@keyframes spin { to{transform:rotate(360deg)} }

/* ── Dark mode: texte forcé sur cartes à fond clair ─────────
   .card-light-purple a toujours un fond #EDE9FE → texte toujours sombre.
   .card-on-light = utilitaire pour tout fond blanc/clair inline.
   ─────────────────────────────────────────────────────────── */

/* card-light-purple : fond violet pâle fixe → texte toujours ink */
.card-light-purple,
.card-light-purple .fw-black,
.card-light-purple .fw-bold,
.card-light-purple h1,.card-light-purple h2,.card-light-purple h3 {
  color: var(--ink) !important;
}
.card-light-purple .text-body-secondary { color: rgba(26,18,53,.62) !important; }
.card-light-purple .italic-accent       { color: var(--brand)  !important; }
.card-light-purple .italic-accent-yellow{ color: var(--accent) !important; }

/* Utilitaire générique pour tout fond blanc/clair en dark mode */
[data-bs-theme="dark"] .card-on-light,
[data-bs-theme="dark"] .card-on-light .fw-black,
[data-bs-theme="dark"] .card-on-light .fw-bold,
[data-bs-theme="dark"] .card-on-light h1,
[data-bs-theme="dark"] .card-on-light h2,
[data-bs-theme="dark"] .card-on-light h3 { color: var(--ink) !important; }
[data-bs-theme="dark"] .card-on-light .text-body-secondary { color: rgba(26,18,53,.62) !important; }
[data-bs-theme="dark"] .card-on-light .italic-accent        { color: var(--brand)  !important; }
[data-bs-theme="dark"] .card-on-light .italic-accent-yellow { color: var(--accent) !important; }
[data-bs-theme="dark"] .card-on-light .section-kicker       { color: var(--brand)  !important; }

/* Donate card : toujours blanche → texte toujours sombre */
.donate-card, .donate-card .fw-black, .donate-card .fw-bold,
.donate-card h1,.donate-card h2,.donate-card h3 { color: var(--ink) !important; }
.donate-card p { color: rgba(26,18,53,.62) !important; }

/* Hosting logo wrap : fond adaptatif en dark mode */
[data-bs-theme="dark"] .hosting-logo-wrap { background: var(--bs-tertiary-bg) !important; border-color: var(--bs-border-color) !important; }
[data-bs-theme="dark"] .hosting-logo-wrap.green-wrap { background: #052e16 !important; }

/* Green card (fond #f0fdf4) : toujours texte sombre */
.card-green-light,
.card-green-light .fw-black,.card-green-light .fw-bold,
.card-green-light h1,.card-green-light h2,.card-green-light h3 { color: var(--ink) !important; }
.card-green-light .text-body-secondary { color: rgba(26,18,53,.62) !important; }
