/* ================================================================
   TOKENS
   ================================================================ */
:root{
  --bg:#0b1220;
  --bg2:#101829;
  --bg3:#0a0f1a;
  --card:#111827;
  --card-a:.45;
  --card-bg:rgba(17,24,39,var(--card-a));
  --card-border:rgba(255,255,255,.07);
  --text:#e5e7eb;
  --muted:#94a3b8;
  --line:rgba(31,41,55,.7);
  --header-bg:rgba(11,18,32,.65);
  --header-bg-s:rgba(11,18,32,.92);
  --code-bg:#0f172a;
  --code-bar:#080e1a;
  --cyan:#22d3ee;
  --violet:#a78bfa;
  --green:#34d399;
  --amber:#fbbf24;
  --radius:16px;
  --e:cubic-bezier(.22,.68,.28,1);
  --e-spring:cubic-bezier(.34,1.56,.64,1);
  --hh:68px;
}
body.light{
  --bg:#f1f5f9;--bg2:#e8edf3;--bg3:#f8fafc;
  --card:#ffffff;--card-a:.9;
  --card-bg:rgba(255,255,255,.9);
  --card-border:rgba(15,23,42,.09);
  --text:#0f172a;--muted:#475569;
  --line:rgba(203,213,225,.9);
  --header-bg:rgba(241,245,249,.82);
  --header-bg-s:rgba(241,245,249,.97);
  --code-bg:#1e293b;--code-bar:#0f172a;
  --cyan:#0891b2;--violet:#7c3aed;
  --green:#059669;--amber:#d97706;
}

/* ================================================================
   RESET
   ================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;transition:background .35s,color .2s}
img{max-width:100%;display:block}a{color:inherit}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}
section[id]{scroll-margin-top:var(--hh)}

/* ================================================================
   LAYOUT
   ================================================================ */
.container{width:min(1160px,92%);margin:0 auto}
.narrow{width:min(820px,92%);margin:0 auto}
.center{text-align:center}

/* ================================================================
   SKIP LINK
   ================================================================ */
.skip-link{position:absolute;top:-999px;left:8px;background:var(--cyan);color:#fff;padding:10px 16px;border-radius:8px;font-weight:700;z-index:9999;text-decoration:none}
.skip-link:focus{top:8px}

/* ================================================================
   HEADER
   ================================================================ */
.header{position:sticky;top:0;z-index:999;backdrop-filter:blur(18px) saturate(160%);background:var(--header-bg);border-bottom:1px solid var(--card-border);transition:background .3s,box-shadow .3s}
.header.scrolled{background:var(--header-bg-s);box-shadow:0 4px 30px rgba(0,0,0,.15)}
.header-inner{height:var(--hh);display:flex;align-items:center;justify-content:space-between;gap:16px}

.logo{font-weight:900;font-size:16px;letter-spacing:.4px;text-decoration:none;display:flex;align-items:center;gap:2px;flex-shrink:0;transition:transform .2s var(--e)}
.logo:hover{transform:scale(1.04)}
.logo-bracket{color:var(--cyan);opacity:.75;font-weight:400;transition:opacity .2s}.logo:hover .logo-bracket{opacity:1}
.logo-name{color:var(--text)}

.nav{display:flex;align-items:center;gap:22px}
.nav a{text-decoration:none;font-size:14px;font-weight:600;color:var(--muted);position:relative;padding-bottom:4px;transition:color .22s}
.nav a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--cyan);border-radius:2px;transition:width .22s var(--e)}
.nav a:hover,.nav a.active{color:var(--text)}.nav a:hover::after,.nav a.active::after{width:100%}
.nav a[href*="wordpress"]::after{background:var(--violet)}.nav a[href*="wordpress"]:hover{color:var(--violet)}

.btn-nav{padding:8px 16px;border-radius:10px;border:1.5px solid color-mix(in srgb,var(--cyan) 50%,transparent);background:color-mix(in srgb,var(--cyan) 8%,transparent);font-size:13px;font-weight:700;color:var(--cyan);text-decoration:none;transition:all .22s var(--e)}
.btn-nav:hover{background:color-mix(in srgb,var(--cyan) 15%,transparent);border-color:var(--cyan);transform:translateY(-2px);box-shadow:0 6px 24px color-mix(in srgb,var(--cyan) 20%,transparent)}

.header-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}

.lang-switcher{position:relative}
.lang-btn{display:flex;align-items:center;gap:5px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:7px 10px;cursor:pointer;font-size:13px;font-weight:700;color:var(--muted);font-family:inherit;transition:border-color .2s,color .2s}
.lang-btn:hover{color:var(--text);border-color:var(--cyan)}
.lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;list-style:none;min-width:130px;box-shadow:0 12px 40px rgba(0,0,0,.25);z-index:100;animation:dd .2s var(--e)}
@keyframes dd{from{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:none}}
.lang-dropdown[hidden]{display:none!important}.lang-dropdown:not([hidden]){display:block}
.lang-dropdown li a{display:block;padding:10px 16px;font-size:14px;font-weight:500;color:var(--muted);text-decoration:none;transition:background .15s,color .15s}
.lang-dropdown li a:hover{color:var(--text);background:rgba(128,128,128,.08)}
.lang-dropdown li[aria-selected="true"] a{color:var(--cyan);font-weight:700}

.theme-toggle{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;color:var(--muted);position:relative;overflow:hidden;transition:border-color .2s,transform .3s var(--e-spring)}
.theme-toggle:hover{border-color:var(--cyan);color:var(--text);transform:rotate(20deg) scale(1.1)}
.theme-icon{position:absolute;display:flex;transition:opacity .25s,transform .3s var(--e)}
.theme-icon--sun{opacity:0;transform:translateY(10px) rotate(-30deg)}.theme-icon--moon{opacity:1;transform:none}
body.light .theme-icon--sun{opacity:1;transform:none}body.light .theme-icon--moon{opacity:0;transform:translateY(10px) rotate(30deg)}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text);border-radius:4px;transition:transform .3s,opacity .3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{flex-direction:column;background:var(--header-bg-s);border-bottom:1px solid var(--card-border)}
.mobile-nav[hidden]{display:none!important}.mobile-nav:not([hidden]){display:flex;animation:mnav .25s var(--e)}
@keyframes mnav{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
.mobile-nav a{text-decoration:none;font-size:15px;font-weight:600;color:var(--muted);padding:14px 24px;border-bottom:1px solid var(--card-border);transition:color .2s,background .2s,padding-left .25s}
.mobile-nav a:hover{color:var(--text);background:rgba(128,128,128,.06);padding-left:32px}

/* ================================================================
   HERO  - gradient mesh bg
   ================================================================ */
.hero{position:relative;padding:100px 0 88px;overflow:hidden;background:radial-gradient(1100px 600px at 20% -5%,rgba(34,211,238,.12),transparent 55%),radial-gradient(800px 500px at 85% 10%,rgba(167,139,250,.1),transparent 55%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:center}

.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:0}
.particle{position:absolute;width:calc(3px + var(--i,0) * .5px);height:calc(3px + var(--i,0) * .5px);border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--violet));opacity:0;animation:fp calc(6s + var(--i,0)*.4s) calc(var(--i,0)*.3s) infinite ease-in-out;left:calc(var(--i,0)*5.7%);top:20%}
.particle:nth-child(4n+1){top:15%}.particle:nth-child(4n+2){top:33%}.particle:nth-child(4n+3){top:51%}.particle:nth-child(4n+4){top:69%}
@keyframes fp{0%{opacity:0;transform:translateY(0) scale(1)}30%{opacity:.5}70%{opacity:.25}100%{opacity:0;transform:translateY(-80px) scale(1.5)}}

.hero-left,.hero-right{position:relative;z-index:1}

.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;border:1px solid rgba(34,211,238,.3);background:rgba(34,211,238,.08);color:var(--cyan);font-size:13px;font-weight:600;margin-bottom:22px;animation:fu .6s var(--e) both}
.hero-tag::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--cyan);animation:pd 2s infinite}
@keyframes pd{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--cyan) 45%,transparent)}50%{box-shadow:0 0 0 6px transparent}}

.hero-title{font-size:clamp(32px,3.5vw,52px);line-height:1.1;margin-bottom:22px;letter-spacing:-.5px;display:flex;flex-direction:column;gap:2px}
.hero-title-line{animation:fu .7s var(--e) both}.hero-title-line:nth-child(2){animation-delay:.08s}.hero-title-line:nth-child(3){animation-delay:.16s}
.hero-title-accent{background:linear-gradient(90deg,var(--cyan),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
@keyframes fu{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

.hero-desc{color:var(--muted);font-size:16px;max-width:56ch;margin-bottom:28px;line-height:1.7;animation:fu .8s .2s var(--e) both}

/* ================================================================
   BUTTONS (global)
   ================================================================ */
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px;animation:fu .8s .3s var(--e) both}
.hero-actions a,.btn-primary,.btn-secondary,.btn-cv,.contact-actions__btn,.availability-cta{
  padding:14px 24px;border-radius:12px;text-decoration:none;font-weight:700;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .28s var(--e);border:1.5px solid transparent;cursor:pointer}

.btn-primary{color:#fff;background:linear-gradient(135deg,var(--cyan),color-mix(in srgb,var(--cyan) 70%,var(--violet)));border-color:transparent;box-shadow:0 4px 20px color-mix(in srgb,var(--cyan) 25%,transparent)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 36px color-mix(in srgb,var(--cyan) 35%,transparent)}
body.light .btn-primary{color:#fff}

.btn-secondary{color:var(--violet);border-color:color-mix(in srgb,var(--violet) 45%,transparent);background:color-mix(in srgb,var(--violet) 8%,transparent)}
.btn-secondary:hover{transform:translateY(-3px);box-shadow:0 12px 36px color-mix(in srgb,var(--violet) 20%,transparent);border-color:var(--violet);background:color-mix(in srgb,var(--violet) 14%,transparent)}

/* ================================================================
   HERO METRICS
   ================================================================ */
.hero-metrics{display:flex;gap:14px;flex-wrap:wrap;animation:fu .8s .4s var(--e) both}
.metric{background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;padding:14px 18px;min-width:140px;transition:border-color .25s,transform .3s var(--e-spring)}
.metric:hover{border-color:var(--cyan);transform:translateY(-4px) scale(1.02)}
.metric-n{font-weight:800;font-size:22px;letter-spacing:-.3px;display:block;color:var(--text)}.metric-l{color:var(--muted);font-size:12px;display:block;margin-top:3px}

/* ================================================================
   CODE WINDOW
   ================================================================ */
.code-window{background:var(--code-bg);border:1px solid rgba(255,255,255,.1);border-radius:18px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.4);animation:cf .9s .15s var(--e) both}
@keyframes cf{from{opacity:0;transform:translateY(30px) rotate(1.5deg)}to{opacity:1;transform:none}}
.code-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--code-bar);border-bottom:1px solid rgba(255,255,255,.07)}
.code-dot{width:12px;height:12px;border-radius:50%}.dot-red{background:#ff5f57}.dot-yellow{background:#ffbd2e}.dot-green{background:#28c840}
.code-filename{font-size:12px;color:#64748b;margin-left:6px;font-family:'Fira Code',monospace}
.code-block{padding:22px 24px;font-size:13px;line-height:1.75;overflow-x:auto;font-family:'Fira Code','Cascadia Code','Courier New',monospace;color:#e2e8f0}.code-block code{display:block}
.tk-kw{color:#c792ea}.tk-cl{color:#82aaff}.tk-fn{color:#82aaff}.tk-str{color:#c3e88d}.tk-ty{color:#ffcb6b}.tk-cm{color:#546e7a;font-style:italic}
#code-anim::after{content:'|';color:var(--cyan);margin-left:1px;animation:blink 1.1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ================================================================
   §1 SERVICES - dark/bg2 background with offset card grid
   ================================================================ */
.section-services{padding:100px 0;background:var(--bg2);position:relative;overflow:hidden}
.section-services::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),var(--violet),transparent)}
.section-services::after{content:'';position:absolute;bottom:-200px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--violet) 6%,transparent),transparent 70%);pointer-events:none}
.section-header{margin-bottom:50px}
.section-title{font-size:clamp(24px,2.4vw,36px);margin-bottom:14px;color:var(--text)}
.section-desc{color:var(--muted);font-size:16px;max-width:62ch;margin:0 auto;line-height:1.7}

.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.service-card{position:relative;background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;padding:32px 28px;transition:transform .3s var(--e),box-shadow .3s;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;border-radius:0 4px 4px 0;background:var(--cyan);transition:width .3s var(--e)}
.service-card:nth-child(2)::before{background:var(--violet)}
.service-card:nth-child(3)::before{background:var(--green)}
.service-card:nth-child(4)::before{background:var(--amber)}
.service-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.2)}
.service-card:hover::before{width:6px}
.service-icon{width:48px;height:48px;border-radius:14px;background:color-mix(in srgb,var(--cyan) 10%,transparent);border:1px solid color-mix(in srgb,var(--cyan) 20%,transparent);display:flex;align-items:center;justify-content:center;color:var(--cyan);margin-bottom:18px;transition:transform .3s var(--e-spring),background .3s}
.service-card:hover .service-icon{transform:scale(1.1) rotate(-5deg)}
.service-card:nth-child(2) .service-icon{background:color-mix(in srgb,var(--violet) 10%,transparent);border-color:color-mix(in srgb,var(--violet) 20%,transparent);color:var(--violet)}
.service-card:nth-child(3) .service-icon{background:color-mix(in srgb,var(--green) 10%,transparent);border-color:color-mix(in srgb,var(--green) 20%,transparent);color:var(--green)}
.service-card:nth-child(4) .service-icon{background:color-mix(in srgb,var(--amber) 10%,transparent);border-color:color-mix(in srgb,var(--amber) 20%,transparent);color:var(--amber)}
.service-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:10px}.service-desc{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:18px}
.service-tags{display:flex;flex-wrap:wrap;gap:6px}
.service-tag{font-size:11px;font-weight:600;letter-spacing:.4px;padding:4px 10px;border-radius:6px;background:color-mix(in srgb,var(--cyan) 8%,transparent);color:var(--cyan);transition:transform .2s}
.service-card:nth-child(2) .service-tag{background:color-mix(in srgb,var(--violet) 8%,transparent);color:var(--violet)}
.service-card:nth-child(3) .service-tag{background:color-mix(in srgb,var(--green) 8%,transparent);color:var(--green)}
.service-card:nth-child(4) .service-tag{background:color-mix(in srgb,var(--amber) 8%,transparent);color:var(--amber)}

/* ================================================================
   §2 PHP - light bg3 with subtle left glow
   ================================================================ */
.split{padding:100px 0;position:relative;overflow:hidden}
.split-php{background:var(--bg3)}
.split-php::before{content:'';position:absolute;top:-100px;left:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--cyan) 10%,transparent),transparent 60%);pointer-events:none}
.split-wp{background:var(--bg2)}
.split-wp::before{content:'';position:absolute;top:-100px;right:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--violet) 10%,transparent),transparent 60%);pointer-events:none}
.split-head{margin-bottom:40px}

.split-kicker{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:3px;margin-bottom:10px;font-weight:600}
.split-title{font-size:clamp(26px,2.6vw,38px);line-height:1.15;margin-bottom:12px;color:var(--text)}
.split-php .split-title{color:var(--cyan)}.split-wp .split-title{color:var(--violet)}
.split-desc{color:var(--muted);max-width:72ch;font-size:16px}

.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.skill-card{position:relative;overflow:hidden;padding:28px 24px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;transition:transform .3s var(--e-spring),border-color .3s,box-shadow .3s}
.skill-card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--cyan) 50%,transparent);box-shadow:0 18px 50px rgba(0,0,0,.15)}
.skill-card--wp:hover{border-color:color-mix(in srgb,var(--violet) 50%,transparent)}
.skill-glow{position:absolute;top:-30px;right:-30px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--cyan) 12%,transparent),transparent 70%)}
.skill-glow--wp{background:radial-gradient(circle,color-mix(in srgb,var(--violet) 12%,transparent),transparent 70%)}
.skill-label{font-size:15px;font-weight:700;margin-bottom:8px;color:var(--cyan)}.skill-card--wp .skill-label{color:var(--violet)}
.skill-desc{font-size:13px;color:var(--muted);line-height:1.6}

/* ================================================================
   §3 METHOD - bg with top gradient stripe, numbered steps
   ================================================================ */
#methode{padding:100px 0;background:var(--bg);position:relative}
#methode::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--cyan),var(--violet),var(--cyan))}

.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px;counter-reset:step}
.method-card{position:relative;overflow:visible;padding:36px 26px 28px;border-radius:18px;background:var(--card-bg);border:1px solid var(--card-border);transition:all .3s var(--e)}
.method-card::before{counter-increment:step;content:counter(step);position:absolute;top:-16px;left:24px;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--cyan),var(--violet));color:#fff;font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px color-mix(in srgb,var(--cyan) 35%,transparent);transition:transform .3s var(--e-spring)}
.method-card:hover::before{transform:scale(1.15) rotate(-3deg)}
.method-card-glow{position:absolute;top:-40px;left:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--cyan) 8%,transparent),transparent 70%);pointer-events:none}
.method-card:hover{transform:translateY(-7px);border-color:color-mix(in srgb,var(--cyan) 35%,transparent);box-shadow:0 24px 60px rgba(0,0,0,.18)}
.method-card h3{font-size:16px;margin-bottom:10px;font-weight:700;color:var(--text)}
.method-card p{color:var(--muted);font-size:14px;line-height:1.65}

.method-list{list-style:none;display:grid;gap:10px;max-width:700px;margin:0 auto}
.method-list li{position:relative;padding:13px 18px 13px 44px;border-radius:12px;background:var(--card-bg);border:1px solid var(--card-border);color:var(--muted);font-size:14px;transition:all .25s var(--e)}
.method-list li::before{content:'✓';position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:13px;font-weight:800;color:var(--green)}
.method-list li:hover{border-color:color-mix(in srgb,var(--green) 40%,transparent);transform:translateX(4px);color:var(--text)}

/* ================================================================
   §4 PARCOURS - alternating bg with vivid timeline
   ================================================================ */
#parcours{padding:100px 0;background:var(--bg2);position:relative;overflow:hidden}
#parcours::after{content:'';position:absolute;bottom:-200px;left:50%;transform:translateX(-50%);width:800px;height:400px;border-radius:50%;background:radial-gradient(ellipse,color-mix(in srgb,var(--violet) 5%,transparent),transparent 70%);pointer-events:none}

.timeline{list-style:none;position:relative}
.timeline::before{content:'';position:absolute;left:18px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--cyan),var(--violet),var(--cyan));opacity:.35;border-radius:2px}
.timeline-item{display:flex;padding:0 0 48px 52px;position:relative}.timeline-item:last-child{padding-bottom:0}
.timeline-dot{position:absolute;left:10px;top:6px;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--violet));box-shadow:0 0 14px color-mix(in srgb,var(--cyan) 40%,transparent);transition:transform .3s var(--e-spring),box-shadow .3s}
.timeline-item:hover .timeline-dot{transform:scale(1.35);box-shadow:0 0 24px color-mix(in srgb,var(--cyan) 60%,transparent)}
.timeline-content{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:24px 26px;width:100%;transition:all .3s var(--e)}
.timeline-content:hover{border-color:color-mix(in srgb,var(--cyan) 30%,transparent);box-shadow:0 14px 44px rgba(0,0,0,.12);transform:translateX(4px)}
.timeline-period{font-size:12px;color:var(--cyan);font-weight:700;letter-spacing:.5px;display:inline-block;margin-bottom:8px;padding:4px 12px;border-radius:8px;background:color-mix(in srgb,var(--cyan) 10%,transparent)}
.timeline-role{font-size:17px;font-weight:700;margin-bottom:4px;color:var(--text)}.timeline-company{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}
.timeline-location{font-size:13px;color:var(--muted);font-weight:400}
.timeline-points{list-style:none;display:grid;gap:6px;margin-top:8px}
.timeline-points li{position:relative;padding-left:16px;color:var(--muted);font-size:14px;line-height:1.6}
.timeline-points li::before{content:'';position:absolute;left:0;top:9px;width:5px;height:5px;border-radius:50%;background:var(--cyan);opacity:.7}

/* ================================================================
   §5 TESTIMONIALS - bg3 with large quote ornament
   ================================================================ */
.section-testimonials{padding:100px 0;background:var(--bg3);position:relative}
.section-testimonials::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--violet),var(--cyan),transparent)}
.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.testimonial-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;padding:32px 28px;display:flex;flex-direction:column;gap:14px;transition:transform .3s var(--e),border-color .3s,box-shadow .3s;position:relative;overflow:hidden}
.testimonial-card::before{content:'\201C';position:absolute;top:-14px;right:20px;font-size:130px;font-family:Georgia,serif;line-height:1;color:var(--violet);opacity:.05;pointer-events:none;transition:opacity .3s}
.testimonial-card:hover::before{opacity:.1}
.testimonial-card:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--violet) 40%,transparent);box-shadow:0 18px 50px rgba(0,0,0,.12)}
.testimonial-stars{display:flex;gap:3px;color:#f59e0b}
.testimonial-text{font-size:15px;line-height:1.75;color:var(--text);flex:1;font-style:italic}
.testimonial-text::before{content:'\201C'}.testimonial-text::after{content:'\201D'}
.testimonial-footer{display:flex;flex-direction:column;gap:6px;padding-top:14px;border-top:1px solid var(--card-border)}
.testimonial-meta{display:flex;flex-direction:column;gap:2px}
.testimonial-author{font-weight:700;font-size:14px;color:var(--text)}.testimonial-role{font-size:12px;color:var(--violet);font-weight:600}
.testimonial-project{font-size:12px;color:var(--muted);font-style:italic}
.testimonial-source{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}

/* ================================================================
   §6 AVAILABILITY - bg2, full-bleed card with dual glow
   ================================================================ */
.section-availability{padding:100px 0;background:var(--bg2)}
.availability-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:24px;padding:48px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;overflow:hidden}
.availability-card::before{content:'';position:absolute;top:-80px;left:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--cyan) 10%,transparent),transparent 65%);pointer-events:none}
.availability-card::after{content:'';position:absolute;bottom:-80px;right:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--violet) 8%,transparent),transparent 65%);pointer-events:none}
.availability-title{font-size:clamp(22px,2vw,30px);font-weight:800;color:var(--text);margin-bottom:16px}
.availability-status-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.availability-dot{width:12px;height:12px;border-radius:50%;background:#22c55e;animation:pa 2s infinite}
@keyframes pa{0%{box-shadow:0 0 0 0 rgba(34,197,94,.4)}70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.availability-status{font-size:18px;font-weight:700;color:#22c55e}
.availability-detail{font-size:15px;color:var(--muted);line-height:1.6}
.availability-facts{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.availability-facts li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);transition:transform .2s,color .2s}
.availability-facts li:hover{transform:translateX(4px);color:var(--text)}
.availability-facts svg{color:var(--cyan);flex-shrink:0}
.availability-cta{border-radius:12px;color:#fff;background:linear-gradient(135deg,var(--cyan),color-mix(in srgb,var(--cyan) 70%,var(--violet)));border-color:transparent;box-shadow:0 4px 20px color-mix(in srgb,var(--cyan) 20%,transparent)}
.availability-cta:hover{transform:translateY(-3px);box-shadow:0 12px 36px color-mix(in srgb,var(--cyan) 30%,transparent)}
body.light .availability-cta{color:#fff}

/* ================================================================
   §7 CONTACT - bg with centered gradient orb
   ================================================================ */
.section-contact{padding:100px 0;background:var(--bg);position:relative;overflow:hidden}
.section-contact::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--violet) 8%,transparent),transparent 60%);pointer-events:none}
.contact-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:28px;position:relative;z-index:1}
.contact-actions__btn{padding:14px 26px;border-radius:12px;text-decoration:none;font-weight:700;font-size:14px;transition:all .25s var(--e);border:1.5px solid var(--card-border);background:var(--card-bg);color:var(--text);display:inline-flex;align-items:center;gap:8px}
.btn-contact:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--text) 25%,transparent);box-shadow:0 10px 32px rgba(0,0,0,.12)}
.btn-php{color:var(--cyan);border-color:color-mix(in srgb,var(--cyan) 45%,transparent)}
.btn-php:hover{transform:translateY(-3px);box-shadow:0 10px 36px color-mix(in srgb,var(--cyan) 22%,transparent);border-color:var(--cyan)}

.cv-cta{margin-top:48px;position:relative;z-index:1}
.btn-cv{display:inline-flex;align-items:center;gap:10px;padding:18px 34px;border-radius:14px;text-decoration:none;font-weight:700;font-size:16px;background:linear-gradient(135deg,var(--cyan),var(--violet));color:#fff;border:none;box-shadow:0 8px 32px color-mix(in srgb,var(--cyan) 28%,transparent);transition:transform .3s var(--e-spring),box-shadow .3s;position:relative;overflow:hidden}
.btn-cv::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.18) 50%,transparent 60%);transform:translateX(-100%);transition:transform .6s}
.btn-cv:hover::after{transform:translateX(100%)}
body.light .btn-cv{color:#0f172a}
.btn-cv:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 18px 56px color-mix(in srgb,var(--cyan) 38%,transparent)}

/* ================================================================
   FOOTER
   ================================================================ */
.footer{border-top:1px solid var(--line);padding:28px 0;background:var(--bg3)}
.footer-inner{text-align:center;color:var(--muted);font-size:14px}
.footer-legal{margin-top:8px;font-size:12px;display:flex;justify-content:center;align-items:center;gap:8px}
.footer-legal a{color:var(--muted);text-decoration:none;transition:color .2s}.footer-legal a:hover{color:var(--cyan)}
.footer-sep{color:var(--muted);opacity:.4}

/* ================================================================
   LEGAL PAGES
   ================================================================ */
.legal-page{padding:80px 0 60px;background:var(--bg);min-height:60vh}
.legal-back{display:inline-flex;align-items:center;gap:6px;text-decoration:none;font-size:13px;color:var(--muted);margin-bottom:32px;transition:color .2s}.legal-back:hover{color:var(--cyan)}
.legal-page h1{font-size:clamp(24px,2.4vw,34px);margin-bottom:8px;color:var(--text)}
.legal-updated{font-size:13px;color:var(--muted);margin-bottom:32px}
.legal-page h2{font-size:16px;font-weight:700;color:var(--text);margin-top:28px;margin-bottom:10px}
.legal-page p{font-size:14px;color:var(--muted);line-height:1.75;margin-bottom:12px}
.legal-page p a{color:var(--cyan);text-decoration:underline;text-underline-offset:2px}
.legal-page ul{list-style:none;margin:8px 0 16px;display:grid;gap:6px}
.legal-page ul li{position:relative;padding-left:18px;font-size:14px;color:var(--muted);line-height:1.6}
.legal-page ul li::before{content:'';position:absolute;left:0;top:9px;width:5px;height:5px;border-radius:50%;background:var(--cyan)}
.legal-page strong{color:var(--text)}

/* ================================================================
   ANIMATIONS
   ================================================================ */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .75s var(--e),transform .75s var(--e)}
.reveal.in-view{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-36px);transition:opacity .75s var(--e),transform .75s var(--e)}.reveal-left.in-view{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(36px);transition:opacity .75s var(--e),transform .75s var(--e)}.reveal-right.in-view{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.9);transition:opacity .75s var(--e),transform .75s var(--e)}.reveal-scale.in-view{opacity:1;transform:none}

/* Stagger */
.skills-grid .skill-card:nth-child(1),.method-grid .method-card:nth-child(1),.services-grid .service-card:nth-child(1){transition-delay:0s}
.skills-grid .skill-card:nth-child(2),.method-grid .method-card:nth-child(2),.services-grid .service-card:nth-child(2){transition-delay:.1s}
.skills-grid .skill-card:nth-child(3),.method-grid .method-card:nth-child(3),.services-grid .service-card:nth-child(3){transition-delay:.2s}
.skills-grid .skill-card:nth-child(4),.services-grid .service-card:nth-child(4){transition-delay:.3s}
.skills-grid .skill-card:nth-child(5){transition-delay:.4s}.skills-grid .skill-card:nth-child(6){transition-delay:.5s}
.testimonials-grid .testimonial-card:nth-child(1){transition-delay:0s}.testimonials-grid .testimonial-card:nth-child(2){transition-delay:.12s}
.timeline .timeline-item:nth-child(1){transition-delay:0s}.timeline .timeline-item:nth-child(2){transition-delay:.12s}.timeline .timeline-item:nth-child(3){transition-delay:.24s}
.method-list li:nth-child(1){transition-delay:0s}.method-list li:nth-child(2){transition-delay:.06s}.method-list li:nth-child(3){transition-delay:.12s}.method-list li:nth-child(4){transition-delay:.18s}

/* ================================================================
   REDUCED MOTION
   ================================================================ */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1024px){.hero-grid{grid-template-columns:1fr;gap:48px}.hero-right{display:none}.skills-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.nav{display:none}.nav-toggle{display:flex}.method-grid,.skills-grid,.services-grid,.testimonials-grid{grid-template-columns:1fr}.availability-card{grid-template-columns:1fr;gap:32px;padding:28px}.timeline::before{left:10px}.timeline-item{padding-left:38px}.timeline-dot{left:2px;width:14px;height:14px}}
@media(max-width:480px){.hero-actions a,.contact-actions__btn,.btn-cv,.availability-cta{width:100%;text-align:center;justify-content:center}.header-controls{gap:5px}.hero{padding:64px 0 56px}.hero-metrics{flex-direction:column}}