/*
Theme Name: Aymen Base44 Portfolio
Theme URI: https://www.linkedin.com/in/aymen-fayda/
Author: Aymen Fayda
Author URI: https://www.linkedin.com/in/aymen-fayda/
Description: One-page portfolio inspired by Base44 (particle background, sticky nav + scrollspy, KPI counters, stack filters, contact form).
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aymen-base44
*/
:root{--bg:#0a0a0f;--bg2:#0d1117;--text:#fff;--muted:#9ca3af;--muted2:#6b7280;--cyan:#22d3ee;--purple:#a78bfa;--radius:18px;--max:1100px;--font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 50%,var(--bg) 100%);color:var(--text);overflow-x:hidden}
a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.section{position:relative;padding:96px 0}
.section h2{font-size:clamp(32px,4vw,54px);margin:14px 0 10px}
.section p.lead{color:var(--muted);max-width:700px;line-height:1.65;margin:0 0 28px}
.badge{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:1px solid rgba(34,211,238,.3);background:rgba(34,211,238,.08);backdrop-filter:blur(8px);color:var(--cyan);font-weight:600;font-size:13px}
.badge .dot{width:8px;height:8px;border-radius:999px;background:var(--cyan);box-shadow:0 0 18px rgba(34,211,238,.65);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.9}50%{transform:scale(1.6);opacity:.35}}
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .25s ease}
.nav.scrolled{background:rgba(10,10,15,.75);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav-inner{height:74px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px}
.logo .mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,#06b6d4,#7c3aed);font-size:13px}
.nav-links{display:none;gap:6px;align-items:center}
.nav-links button{border:0;background:transparent;color:rgba(255,255,255,.65);padding:10px 12px;border-radius:10px;cursor:pointer;font-weight:600;font-size:13px;transition:all .2s ease}
.nav-links button:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-links button.active{background:rgba(34,211,238,.1);color:var(--cyan)}
.nav-cta{display:none}
.btn{border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:14px;padding:14px 18px;font-weight:700;transition:transform .15s ease,box-shadow .25s ease,filter .25s ease,background .25s ease}
.btn.primary{color:#fff;background:linear-gradient(90deg,#06b6d4,#2563eb);box-shadow:0 12px 40px rgba(6,182,212,.22)}
.btn.primary:hover{filter:brightness(1.05);box-shadow:0 18px 55px rgba(6,182,212,.32)}
.btn.outline{color:#fff;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(10px)}
.btn.outline:hover{background:rgba(255,255,255,.07)}
.btn.purple{background:linear-gradient(90deg,#06b6d4,#7c3aed);color:#fff;box-shadow:0 14px 45px rgba(124,58,237,.22)}
.mobile-toggle{display:inline-flex;border:0;background:rgba(255,255,255,.06);color:#fff;border-radius:12px;padding:10px;cursor:pointer}
.mobile-menu{position:fixed;left:0;right:0;top:74px;z-index:40;display:none;background:rgba(10,10,15,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-menu.open{display:block}
.mobile-menu .wrap{padding:18px 20px}
.mobile-menu button{width:100%;text-align:left;border:0;cursor:pointer;background:transparent;color:rgba(255,255,255,.7);padding:12px 12px;border-radius:14px;font-weight:650;font-size:15px}
.mobile-menu button:hover{background:rgba(255,255,255,.06);color:#fff}
.mobile-menu button.active{background:rgba(34,211,238,.1);color:var(--cyan)}
.mobile-menu .cta{margin-top:12px}
.hero{min-height:100vh;display:grid;place-items:center;padding-top:90px}
.hero h1{font-size:clamp(42px,6vw,78px);margin:0 0 14px;font-weight:900;letter-spacing:-.02em}
.gradient-name{background:linear-gradient(90deg,#22d3ee,#3b82f6,#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}
.pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:0 0 14px}
.pill{padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(90deg,rgba(124,58,237,.18),rgba(34,211,238,.18));font-weight:650}
.hero .sub{color:var(--muted);font-size:18px;line-height:1.65;margin:0 auto 24px;max-width:720px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.canvas-bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.glow{position:absolute;border-radius:999px;filter:blur(120px);opacity:.6;pointer-events:none}
.glow.cyan{background:rgba(8,145,178,.26)}.glow.purple{background:rgba(124,58,237,.22)}
.card{border-radius:var(--radius);border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);backdrop-filter:blur(14px);box-shadow:0 12px 36px rgba(0,0,0,.32)}
.card.pad{padding:22px}.card:hover{border-color:rgba(34,211,238,.22)}
.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(1,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(min-width:900px){.nav-links{display:flex}.nav-cta{display:block}.mobile-toggle{display:none}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(min-width:1024px){.grid.about{grid-template-columns:3fr 2fr}}
.kpi{display:flex;flex-direction:column;gap:6px;text-align:center}.kpi .value{font-size:40px;font-weight:900}.kpi .label{font-weight:700}.kpi .sublabel{color:var(--muted2);font-size:13px}
.progress{height:8px;border-radius:999px;background:rgba(255,255,255,.10);overflow:hidden}.progress>span{display:block;height:100%;width:0;border-radius:999px}
.progress.cyan>span{background:linear-gradient(90deg,#06b6d4,#3b82f6)}.progress.purple>span{background:linear-gradient(90deg,#7c3aed,#ec4899)}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 24px}
.filter{padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);color:rgba(255,255,255,.75);cursor:pointer;font-weight:650}
.filter.active{background:linear-gradient(90deg,#7c3aed,#06b6d4);color:#fff;box-shadow:0 12px 35px rgba(124,58,237,.22)}
.tool{padding:18px;border-radius:22px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);position:relative;overflow:hidden;transition:transform .15s ease,border-color .2s ease}
.tool:hover{transform:translateY(-4px);border-color:rgba(34,211,238,.22)}
.tool .icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;margin-bottom:10px;color:#fff}
.tool .name{font-weight:800}.tool .blob{position:absolute;right:-18px;bottom:-18px;width:90px;height:90px;border-radius:999px;filter:blur(18px);opacity:.22}
.form-row{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:700px){.form-row{grid-template-columns:1fr 1fr}}
label{display:block;color:var(--muted);font-size:13px;margin-bottom:8px}
input,textarea{width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);padding:12px 12px;color:#fff;outline:none}
input:focus,textarea:focus{border-color:rgba(34,211,238,.45);box-shadow:0 0 0 4px rgba(34,211,238,.12)}textarea{resize:none}
.notice{padding:14px 16px;border-radius:14px;border:1px solid rgba(34,197,94,.35);background:rgba(34,197,94,.10);color:#bbf7d0}
.footer{padding:40px 0;border-top:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.55)}.small{font-size:13px;color:rgba(255,255,255,.55)}

/* === FORCED DARK MODE === */
html, body {
    background-color: #0a0a0f !important;
    color: #e5e7eb;
}

section {
    background: transparent !important;
}

.hero, .hero-section {
    background: radial-gradient(circle at 30% 30%, rgba(34,211,238,0.15), transparent 40%),
                radial-gradient(circle at 70% 40%, rgba(168,85,247,0.15), transparent 45%),
                #0a0a0f !important;
}

.card, .box, .panel {
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
}

h1, h2, h3, h4 {
    color: #ffffff;
}

a.button, .btn, button {
    background: linear-gradient(90deg, #22d3ee, #8b5cf6);
    color: #ffffff;
}
