/* ════════════════════════════════════════════════════════════
   PORTFOLIO MWINDJOU — style.css
   Stack : Syne (titres) · DM Sans (corps) · JetBrains Mono
   ════════════════════════════════════════════════════════════ */

/* ── 1. VARIABLES DARK (défaut) ─────────────────────────── */
:root {
    --bg-color:     #08080f;
    --card-color:   rgba(255, 255, 255, 0.045);
    --text-main:    #e8e8f0;
    --text-dim:     #6e6e88;
    --accent:       #6366f1;
    --accent-rgb:   99, 102, 241;
    --accent-soft:  rgba(99, 102, 241, 0.10);
    --border-color: rgba(255, 255, 255, 0.07);
    --nav-bg:       rgba(8, 8, 15, 0.82);
    --orb-1:        rgba(99, 102, 241, 0.16);
    --orb-2:        rgba(139, 92, 246, 0.11);
    --orb-3:        rgba(59, 130, 246, 0.09);
}

/* ── 2. VARIABLES LIGHT ─────────────────────────────────── */
[data-theme="light"] {
    --bg-color:     #f6f6fb;
    --card-color:   rgba(255, 255, 255, 0.78);
    --text-main:    #0c0c18;
    --text-dim:     #7878a0;
    --accent:       #4f46e5;
    --accent-rgb:   79, 70, 229;
    --accent-soft:  rgba(79, 70, 229, 0.08);
    --border-color: rgba(0, 0, 0, 0.07);
    --nav-bg:       rgba(246, 246, 251, 0.90);
    --orb-1:        rgba(99, 102, 241, 0.06);
    --orb-2:        rgba(139, 92, 246, 0.04);
    --orb-3:        rgba(59, 130, 246, 0.04);
}

/* ── 3. RESET & BASE ────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    background-color: var(--bg-color);
    color: var(--text-main);
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 15px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    transition: background-color .35s ease, color .35s ease;
}

/* ════════════════════════════════════════════════════════════
   4. NAVIGATION
   ════════════════════════════════════════════════════════════ */
.glass-nav {
    background: var(--nav-bg);
    backdrop-filter: blur(24px) saturate(1.6);
    -webkit-backdrop-filter: blur(24px) saturate(1.6);
    border-bottom: 1px solid var(--border-color);
}

.nav-logo {
    font-family: 'Syne', sans-serif;
    font-weight: 800;
    font-size: 1.18rem;
    letter-spacing: -0.04em;
    color: var(--text-main);
    text-decoration: none;
    transition: color .2s;
}
.nav-logo:hover { color: var(--accent); }

.nav-item {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.82rem;
    font-weight: 500;
    text-decoration: none;
    border-radius: 8px;
    padding: 6px 13px;
    transition: all .18s ease;
    white-space: nowrap;
    border: 1px solid transparent;
}
.nav-item--idle { color: var(--text-dim); background: transparent; }
.nav-item--idle:hover {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.05);
}
[data-theme="light"] .nav-item--idle:hover { background: rgba(0,0,0,0.04); }

.nav-item--active {
    color: var(--accent);
    background: var(--accent-soft);
    border-color: rgba(var(--accent-rgb), 0.18);
}

.nav-sep {
    width: 1px; height: 18px;
    background: var(--border-color);
    margin: 0 8px; flex-shrink: 0;
}

.nav-icon-btn {
    width: 34px; height: 34px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--text-dim);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; text-decoration: none;
    transition: all .18s;
}
.nav-icon-btn:hover {
    color: var(--accent);
    border-color: rgba(var(--accent-rgb), 0.3);
    background: var(--accent-soft);
}

.mobile-panel {
    border-top: 1px solid var(--border-color);
    background: var(--nav-bg);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}
.mobile-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px; border-radius: 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.875rem; font-weight: 500;
    color: var(--text-dim); text-decoration: none;
    transition: all .15s;
}
.mobile-item:hover { background: rgba(255,255,255,.04); color: var(--text-main); }
[data-theme="light"] .mobile-item:hover { background: rgba(0,0,0,.03); }
.mobile-item--active { color: var(--accent); background: var(--accent-soft); }

/* ════════════════════════════════════════════════════════════
   5. HERO
   ════════════════════════════════════════════════════════════ */
.hero-wrapper {
    position: relative;
    min-height: 100svh;
    display: flex; align-items: center;
    overflow: hidden;
}
#particle-canvas {
    position: absolute; inset: 0;
    z-index: 0; opacity: .42; pointer-events: none;
}
.orb {
    position: absolute; border-radius: 50%;
    filter: blur(90px); pointer-events: none; z-index: 0;
}
.orb-1 { width:600px;height:600px;top:-150px;left:-80px; background:var(--orb-1); animation:orb-float 20s ease-in-out infinite alternate; }
.orb-2 { width:480px;height:480px;bottom:-90px;right:-60px; background:var(--orb-2); animation:orb-float 26s ease-in-out infinite alternate-reverse; }
.orb-3 { width:320px;height:320px;top:38%;left:52%; background:var(--orb-3); animation:orb-float 17s ease-in-out infinite alternate; }
@keyframes orb-float {
    from { transform: translate(0,0) scale(1); }
    to   { transform: translate(32px,22px) scale(1.07); }
}
.hero-content { position: relative; z-index: 1; }

.hero-title {
    font-family: 'Syne', sans-serif;
    font-size: clamp(3rem, 9vw, 7rem);
    font-weight: 800;
    line-height: 1.0;
    letter-spacing: -0.04em;
    color: var(--text-main);
}
.hero-title .muted { color: var(--text-dim); font-weight: 600; }

.hero-sub {
    font-family: 'DM Sans', sans-serif;
    font-size: clamp(1rem, 2vw, 1.1rem);
    color: var(--text-dim);
    line-height: 1.80; max-width: 430px;
    margin-top: 1.25rem; font-weight: 400;
}

.scroll-hint {
    position: absolute; bottom: 1.75rem; left: 50%;
    transform: translateX(-50%);
    display: flex; flex-direction: column; align-items: center; gap: 5px;
    z-index: 1; animation: hint-bob 3s ease-in-out infinite;
}
.scroll-hint span {
    font-family: 'JetBrains Mono', monospace;
    font-size: .58rem; letter-spacing: .18em; text-transform: uppercase;
    color: var(--text-dim); opacity: .35;
}
.scroll-hint-line {
    width: 1px; height: 34px;
    background: linear-gradient(to bottom, var(--text-dim), transparent);
    opacity: .3;
}
@keyframes hint-bob {
    0%,100% { transform: translateX(-50%) translateY(0); }
    50%      { transform: translateX(-50%) translateY(8px); }
}

/* ════════════════════════════════════════════════════════════
   6. BOUTONS
   ════════════════════════════════════════════════════════════ */
.btn-primary {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 11px 24px; border-radius: 10px;
    background: var(--accent); color: #fff;
    font-family: 'DM Sans', sans-serif;
    font-size: .875rem; font-weight: 600;
    border: none; text-decoration: none;
    cursor: pointer; transition: all .2s ease; white-space: nowrap;
}
.btn-primary:hover {
    opacity: .88; transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(var(--accent-rgb),.28);
}
.btn-primary:active { transform: translateY(0); }

.btn-ghost {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 22px; border-radius: 10px;
    background: transparent; color: var(--text-main);
    font-family: 'DM Sans', sans-serif;
    font-size: .875rem; font-weight: 500;
    border: 1px solid var(--border-color);
    text-decoration: none; cursor: pointer;
    transition: all .2s ease; white-space: nowrap;
}
.btn-ghost:hover {
    border-color: rgba(var(--accent-rgb),.35);
    color: var(--accent); background: var(--accent-soft);
}

/* ════════════════════════════════════════════════════════════
   7. GLASS CARD
   ════════════════════════════════════════════════════════════ */
.glass {
    background: var(--card-color);
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    border: 1px solid var(--border-color);
    transition: border-color .25s, background .25s;
}
.glass:hover {
    border-color: rgba(var(--accent-rgb),.2);
    background: rgba(255,255,255,.065);
}
[data-theme="light"] .glass:hover { background: rgba(255,255,255,.92); }

/* ════════════════════════════════════════════════════════════
   8. SECTION LABELS & TITRES
   ════════════════════════════════════════════════════════════ */
.section-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: .68rem; letter-spacing: .14em;
    text-transform: uppercase; color: var(--accent);
    display: block; margin-bottom: .55rem;
}
.section-title {
    font-family: 'Syne', sans-serif;
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700; letter-spacing: -.03em;
    line-height: 1.1; color: var(--text-main);
}

/* ════════════════════════════════════════════════════════════
   9. SKILL CARDS
   ════════════════════════════════════════════════════════════ */
.skill-card-glass {
    background: var(--card-color);
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    border: 1px solid var(--border-color); border-radius: 14px;
    padding: 1.25rem;
    display: flex; flex-direction: column; align-items: center;
    text-align: center; gap: .65rem; cursor: pointer;
    transition: all .25s cubic-bezier(.4,0,.2,1);
}
.skill-card-glass:hover {
    transform: translateY(-3px);
    border-color: rgba(var(--accent-rgb),.22);
    background: rgba(255,255,255,.07);
    box-shadow: 0 20px 48px rgba(0,0,0,.25);
}
[data-theme="light"] .skill-card-glass:hover {
    background: rgba(255,255,255,.92);
    box-shadow: 0 12px 32px rgba(0,0,0,.07);
}

/* ════════════════════════════════════════════════════════════
   10. FILTER PILLS
   ════════════════════════════════════════════════════════════ */
.filter-pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 16px; border-radius: 8px;
    font-family: 'JetBrains Mono', monospace;
    font-size: .75rem; font-weight: 500;
    border: 1px solid var(--border-color);
    color: var(--text-dim); background: transparent;
    cursor: pointer; transition: all .18s; white-space: nowrap;
}
.filter-pill:hover { border-color: rgba(var(--accent-rgb),.3); color: var(--text-main); }
.filter-pill.active {
    background: var(--accent); border-color: var(--accent); color: #fff;
    box-shadow: 0 4px 14px rgba(var(--accent-rgb),.28);
}

/* ════════════════════════════════════════════════════════════
   11. FORMULAIRE
   ════════════════════════════════════════════════════════════ */
.input-glass {
    width: 100%; background: var(--card-color);
    backdrop-filter: blur(12px);
    border: 1px solid var(--border-color); border-radius: 10px;
    padding: 11px 15px; color: var(--text-main);
    font-family: 'DM Sans', sans-serif; font-size: .875rem;
    transition: border-color .2s, box-shadow .2s;
    outline: none; resize: none;
}
.input-glass::placeholder { color: var(--text-dim); }
.input-glass:focus {
    border-color: rgba(var(--accent-rgb),.45);
    box-shadow: 0 0 0 3px rgba(var(--accent-rgb),.07);
}

/* ════════════════════════════════════════════════════════════
   12. MODALE
   ════════════════════════════════════════════════════════════ */
.modal-glass {
    background: rgba(8,8,16,.94);
    backdrop-filter: blur(32px) saturate(1.5);
    -webkit-backdrop-filter: blur(32px) saturate(1.5);
    border: 1px solid var(--border-color); border-radius: 18px;
}
[data-theme="light"] .modal-glass { background: rgba(250,250,253,.97); }
@keyframes modal-in {
    from { opacity:0; transform:scale(.94) translateY(10px); }
    to   { opacity:1; transform:scale(1) translateY(0); }
}
.modal-animate { animation: modal-in .22s cubic-bezier(.4,0,.2,1) both; }

/* ════════════════════════════════════════════════════════════
   13. REVEAL AU SCROLL
   ════════════════════════════════════════════════════════════ */
.reveal {
    opacity: 0; transform: translateY(20px);
    transition: opacity .65s ease, transform .65s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ════════════════════════════════════════════════════════════
   14. FOOTER
   ════════════════════════════════════════════════════════════ */
footer { position: relative; }
footer::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(var(--accent-rgb),.2), transparent);
}

/* ════════════════════════════════════════════════════════════
   15. OVERRIDES TAILWIND
   ════════════════════════════════════════════════════════════ */
.bg-tech-card       { background-color: var(--card-color) !important; }
.bg-tech-bg         { background-color: var(--bg-color) !important; }
.border-tech-border { border-color: var(--border-color) !important; }
.text-tech-text     { color: var(--text-main) !important; }
.text-tech-dim      { color: var(--text-dim) !important; }
.text-tech-accent   { color: var(--accent) !important; }

/* ════════════════════════════════════════════════════════════
   16. SAFELIST COULEURS JS DYNAMIQUES
   ════════════════════════════════════════════════════════════ */
.text-purple-400{color:#c084fc;} .bg-purple-500\/10{background:rgba(168,85,247,.10);} .border-purple-500\/20{border-color:rgba(168,85,247,.20);} .border-purple-500{border-color:#a855f7;}
.text-green-400{color:#4ade80;}  .bg-green-500\/10{background:rgba(34,197,94,.10);}   .border-green-500\/20{border-color:rgba(34,197,94,.20);}   .border-green-500{border-color:#22c55e;}
.text-blue-400{color:#60a5fa;}   .bg-blue-500\/10{background:rgba(59,130,246,.10);}   .border-blue-500\/20{border-color:rgba(59,130,246,.20);}   .border-blue-500{border-color:#3b82f6;}
.text-orange-400{color:#fb923c;} .bg-orange-500\/10{background:rgba(249,115,22,.10);} .border-orange-500\/20{border-color:rgba(249,115,22,.20);} .border-orange-500{border-color:#f97316;}
.text-yellow-400{color:#facc15;} .bg-yellow-500\/10{background:rgba(234,179,8,.10);}  .border-yellow-500\/20{border-color:rgba(234,179,8,.20);}  .border-yellow-500{border-color:#eab308;}
.text-pink-400{color:#f472b6;}   .bg-pink-400\/10{background:rgba(244,114,182,.10);}  .border-pink-400\/20{border-color:rgba(244,114,182,.20);}
.text-sky-400{color:#38bdf8;}    .bg-sky-400\/10{background:rgba(56,189,248,.10);}    .border-sky-400\/20{border-color:rgba(56,189,248,.20);}

/* ════════════════════════════════════════════════════════════
   17. ANIMATIONS UTILITAIRES
   ════════════════════════════════════════════════════════════ */
.animate-ping { animation: ping 1s cubic-bezier(0,0,.2,1) infinite; }
@keyframes ping { 75%,100% { transform:scale(2); opacity:0; } }

.animate-pulse { animation: pulse-a 2s cubic-bezier(.4,0,.6,1) infinite; }
@keyframes pulse-a { 0%,100% { opacity:1; } 50% { opacity:.45; } }

/* ════════════════════════════════════════════════════════════
   18. SCROLLBAR & SELECTION
   ════════════════════════════════════════════════════════════ */
::-webkit-scrollbar             { width: 5px; }
::-webkit-scrollbar-track       { background: var(--bg-color); }
::-webkit-scrollbar-thumb       { background: var(--border-color); border-radius: 100px; }
::-webkit-scrollbar-thumb:hover { background: rgba(var(--accent-rgb),.3); }
::selection { background: rgba(var(--accent-rgb),.22); color: var(--text-main); }

/* ════════════════════════════════════════════════════════════
   19. RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .orb-1 { width:250px; height:250px; }
    .orb-2 { width:200px; height:200px; }
    .orb-3 { display:none; }
    #particle-canvas { opacity:.18; }
}

/* ════════════════════════════════════════════════════════════
   20. TRANSITIONS GLOBALES THÈME
   ════════════════════════════════════════════════════════════ */
body, nav, .glass, footer,
.modal-glass, .skill-card-glass,
.input-glass, .filter-pill,
.nav-item, .nav-icon-btn, .mobile-item {
    transition:
        background-color .32s ease,
        background       .32s ease,
        border-color     .32s ease,
        color            .32s ease;
}
