/* ════════════════════════════════════════
   VARIABLES & RESET
════════════════════════════════════════ */
:root{
  --c1:#00c3ff;
  --c2:#7b2fff;
  --c3:#ff00cc;
  --bg:#1e1e24;
  --panel:rgba(12,12,18,0.75);
  --panel2:rgba(16,16,24,0.85);
  --border:rgba(0,195,255,0.12);
  --border2:rgba(123,47,255,0.15);
  --text:#f0f0ff;
  --text2:rgba(240,240,255,0.65);
  --text3:rgba(240,240,255,0.38);
  --grad:linear-gradient(90deg,var(--c1),var(--c2),var(--c3));
  --font-display:'Syne',sans-serif;
  --font-mono:'Space Mono',monospace;
  --font-body:'Lora',serif;
  --radius:4px;
  --gap:1px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--font-display);
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  max-width:100vw;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:var(--font-display);cursor:pointer}

/* ════════════════════════════════════════
   FOND ALU BROSSÉ
════════════════════════════════════════ */
#bgalu{
  position:fixed;top:0;left:0;
  width:100%;height:100%;
  pointer-events:none;z-index:0;
}
.page{position:relative;z-index:2}

/* ════════════════════════════════════════
   UTILITAIRES
════════════════════════════════════════ */
.gt{
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ════════════════════════════════════════
   CURSEUR CUSTOM (desktop seulement)
════════════════════════════════════════ */
@media(pointer:fine){
  body{cursor:none}
  #cur{width:10px;height:10px;border-radius:50%;background:var(--c2);position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:screen}
  #cur2{width:34px;height:34px;border-radius:50%;border:1px solid rgba(0,195,255,.4);position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left .07s,top .07s}
}

/* ════════════════════════════════════════
   NAVIGATION
════════════════════════════════════════ */
nav{
  display:flex;justify-content:space-between;align-items:center;
  padding:0 40px;height:64px;
  background:rgba(10,10,16,0.94);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:200;
  backdrop-filter:blur(16px);
}
.nav-logo{font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:.08em;white-space:nowrap}
.edu-banner{background:rgba(255,255,255,0.03);border-bottom:1px solid rgba(255,255,255,0.06);overflow:hidden;white-space:nowrap;padding:6px 0}
.edu-banner-track{display:inline-block;animation:scrollBanner 28s linear infinite}
.edu-banner-track span{font-family:'Space Mono',monospace;font-size:10px;color:rgba(240,240,255,0.3);letter-spacing:.14em;text-transform:uppercase;margin:0 56px}
@keyframes scrollBanner{from{transform:translateX(100vw)}to{transform:translateX(-100%)}}
.nav-links{display:none}
.nav-links a{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text3);transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-dropdown{position:static}
.nav-dropdown>a{display:flex;align-items:center;gap:5px;cursor:pointer}
.nav-dropdown>a::after{content:'▾';font-size:8px;opacity:.5;transition:transform .2s;display:inline-block}
.nav-dropdown.open>a::after{transform:rotate(180deg)}
.nav-dropdown.open .dropdown-panel{display:block}
.dropdown-tag{font-family:'Space Mono',monospace;font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:#00c3ff;margin-bottom:10px}
.dropdown-name{font-size:20px;font-weight:800;letter-spacing:-.02em;color:#f0f0ff;margin-bottom:14px}
.dropdown-text{font-size:12px;color:rgba(240,240,255,0.65);line-height:1.85}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-dot{width:8px;height:8px;border-radius:50%;background:var(--grad);animation:pulse 2s infinite;flex-shrink:0}
.lang-switcher{display:flex;gap:3px;align-items:center}
.lang-btn{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.1em;padding:5px 9px;background:transparent;border:1px solid rgba(0,195,255,.2);color:rgba(240,240,255,.45);cursor:pointer;transition:all .2s;text-transform:uppercase;line-height:1}
.lang-btn:hover{border-color:rgba(0,195,255,.55);color:rgba(240,240,255,.9)}
.lang-btn.active{background:rgba(0,195,255,.15);border-color:var(--c1);color:var(--c1)}
@media(max-width:600px){.lang-switcher{display:none}}
.nav-home-btn{display:none;color:var(--text2);transition:color .2s;padding:6px}
.nav-home-btn:hover{color:var(--c1)}
@media(max-width:900px){.nav-home-btn{display:flex;align-items:center}}
.nav-cta{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:9px 20px;border:none;background:var(--grad);color:#fff;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);transition:opacity .2s}
.nav-cta:hover{opacity:.82}
.nav-sep{color:rgba(240,240,255,.15)}
.hamburger{display:flex;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{
  display:none;position:fixed;top:64px;left:0;right:0;bottom:0;
  background:rgba(8,8,14,0.98);
  z-index:190;
  flex-direction:column;justify-content:center;align-items:center;gap:0;
  backdrop-filter:blur(24px);
  overflow-y:auto;padding:24px 32px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-family:var(--font-mono);font-size:20px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text2);transition:color .2s;padding:16px 0;width:100%;text-align:center;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.mobile-menu a:first-child{border-top:1px solid rgba(255,255,255,.04)}
.mobile-menu a:hover{color:var(--text)}
.mobile-menu .nav-cta{font-size:12px;padding:16px 40px;margin-top:28px;width:auto}
.mobile-lang{display:flex;gap:6px;align-items:center;justify-content:center;margin-top:24px;flex-wrap:wrap}
.mobile-lang-label{font-family:var(--font-mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--text3);margin-right:4px}
.mobile-lang-btn{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.1em;padding:8px 14px;background:transparent;border:1px solid rgba(0,195,255,.2);color:rgba(240,240,255,.45);cursor:pointer;transition:all .2s;text-transform:uppercase}
.mobile-lang-btn:hover{border-color:rgba(0,195,255,.55);color:rgba(240,240,255,.9)}
.mobile-lang-btn.active{background:rgba(0,195,255,.15);border-color:var(--c1);color:var(--c1)}
.mobile-bio{width:100%;margin-top:28px;padding-top:28px;border-top:1px solid rgba(0,195,255,.12);text-align:left}
.mobile-bio-title{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--c1);margin-bottom:10px}
.mobile-bio-name{font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:12px}
.mobile-bio-text{font-size:13px;color:var(--text2);line-height:1.75}

/* ════════════════════════════════════════
   HERO
════════════════════════════════════════ */
.hero{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:calc(100vh - 64px);
  border-bottom:1px solid var(--border);
}
.hero-left{
  padding:60px 48px;
  display:flex;flex-direction:column;justify-content:space-between;
  border-right:1px solid var(--border);
  background:var(--panel);
  position:relative;overflow:hidden;
}
.hero-left::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent 0,rgba(255,255,255,.007) 1px,transparent 2px,transparent 8px);
  pointer-events:none;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--c1);margin-bottom:24px;
}
.hero-badge::before{content:'';width:20px;height:1px;background:var(--grad)}
.hero-title{font-size:clamp(36px,5vw,64px);font-weight:800;line-height:.93;letter-spacing:-.03em}
.hero-title .out{-webkit-text-stroke:1.5px rgba(0,195,255,.4);color:transparent;display:block}
.hero-desc{font-size:15px;color:var(--text2);line-height:1.8;margin:28px 0}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.hero-right{position:relative;overflow:hidden;background:#07071a;min-height:300px}
canvas#hero-canvas{width:100%;height:100%;display:block}

/* ════════════════════════════════════════
   TICKER
════════════════════════════════════════ */
.ticker{
  padding:9px 0;overflow:hidden;white-space:nowrap;
  background:rgba(10,10,16,.96);
  border-top:1px solid var(--border2);
  border-bottom:1px solid var(--border2);
}
.ticker-inner{display:inline-block;animation:tick 26s linear infinite}
.ticker-inner span{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;
  color:rgba(240,240,255,.6);text-transform:uppercase;margin:0 28px;
}
.ticker-inner span::before{
  content:'◆';margin-right:10px;font-size:7px;
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}

/* ════════════════════════════════════════
   STATS
════════════════════════════════════════ */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-bottom:1px solid var(--border);
}
.stat{
  padding:28px 24px;border-right:1px solid var(--border);
  background:var(--panel);position:relative;overflow:hidden;
  transition:background .25s;
}
.stat:last-child{border-right:none}
.stat::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .45s;
}
.stat:hover::after{transform:scaleX(1)}
.stat:hover{background:rgba(0,195,255,.04)}
.stat-num{font-family:var(--font-mono);font-size:30px;font-weight:700;line-height:1}
.stat-label{font-size:12px;color:var(--text3);margin-top:6px;letter-spacing:.08em;text-transform:uppercase}

/* ════════════════════════════════════════
   SECTIONS COMMUNES
════════════════════════════════════════ */
.section{padding:56px 48px;border-bottom:1px solid var(--border)}
.section-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(0,195,255,.6);text-transform:uppercase;margin-bottom:8px}
.section-title{font-size:clamp(20px,3vw,28px);font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:32px}

/* ════════════════════════════════════════
   BRANDS
════════════════════════════════════════ */
.brands{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border)}
.brand{
  padding:44px 48px;position:relative;overflow:hidden;
  border-right:1px solid var(--border);
  background:var(--panel);transition:background .25s;
}
.brand:last-child{border-right:none}
.brand:hover{background:rgba(0,195,255,.03)}
.brand::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .5s;
}
.brand:hover::before{transform:scaleX(1)}
.brand canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.08}
.brand-inner{position:relative;z-index:1}
.brand-pill{
  font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;
  padding:4px 12px;border:1px solid rgba(0,195,255,.2);
  color:var(--c1);text-transform:uppercase;display:inline-block;margin-bottom:14px;
}
.brand-name{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-bottom:12px}
.brand-desc{font-size:14px;color:var(--text2);line-height:1.78;max-width:300px}
.brand-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}
.brand-tag{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;
  padding:4px 12px;border:1px solid rgba(123,47,255,.22);
  color:rgba(200,170,255,.8);text-transform:uppercase;transition:all .2s;
}
.brand-tag:hover{border-color:var(--c2);color:var(--c2)}
.brand-bg{
  position:absolute;bottom:-8px;right:14px;
  font-size:72px;font-weight:800;font-family:var(--font-display);line-height:1;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(0,195,255,.04),rgba(255,0,204,.04));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ════════════════════════════════════════
   SERVICES GRID
════════════════════════════════════════ */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--gap);background:rgba(255,255,255,.04);
  border:1px solid var(--border);
}
.service{
  background:rgba(12,12,18,.94);padding:28px 24px;
  position:relative;overflow:hidden;transition:background .2s;
}
.service:hover{background:rgba(20,20,30,.96)}
.service::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .38s;
}
.service:hover::after{transform:scaleX(1)}
.service-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;margin-bottom:16px}
.service-icon{width:38px;height:38px;margin-bottom:14px;transition:transform .2s}
.service:hover .service-icon{transform:scale(1.1)}
.service-name{font-size:17px;font-weight:700;color:var(--text);margin-bottom:8px}
.service-desc{font-size:14px;color:var(--text2);line-height:1.65}
.service-problem{font-size:13px;color:rgba(0,195,255,0.6);font-family:'Space Mono',monospace;margin-bottom:8px;line-height:1.5}
.service-solution{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:8px}
.service-result{font-size:13px;color:rgba(123,47,255,0.85);font-family:'Space Mono',monospace;line-height:1.5}

/* ════════════════════════════════════════
   CARROUSEL PORTFOLIO
════════════════════════════════════════ */
.carousel-wrap{position:relative;overflow:hidden;border:1px solid var(--border);background:#07071a}
.carousel-track{display:flex;transition:transform .5s ease;height:320px}
.carousel-slide{flex:0 0 33.333%;position:relative;overflow:hidden;cursor:pointer}
.carousel-slide img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.carousel-slide:hover img{transform:scale(1.06)}
.carousel-slide-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,15,.9) 0%,transparent 60%);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:14px}
.carousel-slide:hover .carousel-slide-overlay{opacity:1}
.carousel-slide-cat{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px}
.carousel-slide-title{font-size:14px;font-weight:700;color:#fff}
.carousel-controls{display:flex;justify-content:space-between;align-items:center;padding:14px 0 0;flex-wrap:wrap;gap:10px}
.carousel-btn{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:10px 20px;background:transparent;border:1px solid rgba(0,195,255,.22);color:var(--text2);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}
.carousel-btn:hover{border-color:rgba(0,195,255,.6);color:var(--text)}
.carousel-dots{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:160px}
.carousel-dot{width:6px;height:6px;border-radius:50%;background:rgba(240,240,255,.2);cursor:pointer;transition:all .2s}
.carousel-dot.active{background:var(--c1);transform:scale(1.3)}
.carousel-cta{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:10px 20px;background:var(--grad);color:#fff !important;border:none;cursor:pointer;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);transition:opacity .2s}
.carousel-cta:hover{opacity:.82}
@media(max-width:900px){
  .carousel-track{height:240px}
  .carousel-slide{flex:0 0 50%}
}
@media(max-width:768px){.hide-mobile{display:none!important}}
@media(max-width:600px){
  .carousel-track{height:200px}
  .carousel-slide{flex:0 0 100%}
  .carousel-controls{justify-content:center;gap:8px}
  .carousel-btn{font-size:9px;padding:8px 14px}
  .carousel-dots{max-width:120px}
  .carousel-cta{font-size:8px;padding:8px 14px}
}

/* ════════════════════════════════════════
   ÉTUDES DE CAS PREVIEW
════════════════════════════════════════ */
.cases-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.case-card{background:var(--bg);padding:32px 28px;display:flex;flex-direction:column;gap:0;text-decoration:none;transition:background .2s;position:relative;overflow:hidden}
.case-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .38s}
.case-card:hover{background:rgba(12,12,20,.96);text-decoration:none}
.case-card:hover::after{transform:scaleX(1)}
.case-card-num{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--text3);margin-bottom:16px}
.case-card-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--c1);margin-bottom:8px}
.case-card-title{font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:24px}
.case-card-scores{display:flex;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.ccs{display:flex;flex-direction:column;align-items:center;gap:4px}
.ccs-val{font-family:var(--font-mono);font-size:22px;font-weight:700;line-height:1}
.ccs-label{font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.case-card-cta{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);margin-top:auto;transition:color .2s}
.case-card:hover .case-card-cta{color:var(--c1)}
@media(max-width:900px){.cases-preview{grid-template-columns:1fr}}

/* ════════════════════════════════════════
   CONTACT
════════════════════════════════════════ */
.contact{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border)}
.contact-left{padding:56px 48px;border-right:1px solid var(--border);background:var(--panel)}
.contact-title{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-bottom:10px}
.contact-sub{font-size:14px;color:var(--text2);margin-bottom:32px;line-height:1.7}
.contact-links{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.contact-link{
  font-family:var(--font-mono);font-size:13px;
  color:var(--text2);display:flex;align-items:center;gap:10px;
  transition:color .2s;
}
.contact-link:hover{color:var(--text)}
.contact-link svg{flex-shrink:0}
.contact-right{
  position:relative;overflow:hidden;background:#07071a;
  display:flex;align-items:center;justify-content:center;padding:56px;
}
.contact-right canvas{position:absolute;inset:0;width:100%;height:100%}
.contact-visual{position:relative;z-index:1;text-align:center}
.contact-big{font-family:var(--font-mono);font-size:64px;font-weight:700;line-height:1;letter-spacing:-.04em}
.contact-caption{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;color:var(--text3);margin:14px 0 24px;text-transform:uppercase}

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
footer{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 48px;flex-wrap:wrap;gap:10px;
  background:rgba(8,8,14,.96);border-top:1px solid var(--border);
}
.footer-logo{font-family:var(--font-mono);font-size:10px;color:var(--text3);letter-spacing:.08em}
.footer-loc{font-size:10px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase}
.footer-links{display:flex;gap:20px}
.footer-links a{font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;transition:color .2s}
.footer-links a:hover{color:var(--text2)}
.footer-recruiter a{color:var(--c1);text-decoration:none}
.footer-recruiter a:hover{text-decoration:underline}
.footer-recruiter{width:100%;display:flex;align-items:center;justify-content:space-between;padding-top:14px;margin-top:4px;border-top:1px solid rgba(0,195,255,0.12);flex-wrap:wrap;gap:10px}
.footer-recruiter span{font-family:var(--font-mono);font-size:9px;color:rgba(240,240,255,0.45);letter-spacing:.08em}
.footer-recruiter-btn{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:8px 18px;background:linear-gradient(90deg,#00c3ff,#7b2fff,#ff00cc);color:#fff !important;border:none;cursor:pointer;clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,0 100%);text-decoration:none;transition:opacity .2s}
.footer-recruiter-btn:hover{opacity:.82;text-decoration:none}
.footer-admin-btn{font-family:var(--font-mono);font-size:9px;color:rgba(240,240,255,0.08);letter-spacing:.1em;text-decoration:none;transition:color .3s;user-select:none}
.footer-admin-btn:hover{color:rgba(0,195,255,0.35);text-decoration:none}

/* ════════════════════════════════════════
   BOUTONS
════════════════════════════════════════ */
.btn-primary{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:13px 26px;border:none;
  background:var(--grad);color:#fff;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);
  transition:opacity .18s,transform .15s;display:inline-block;
}
.btn-primary:hover{opacity:.82;transform:translateY(-1px)}
.btn-ghost{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:13px 26px;background:transparent;
  color:var(--text2);border:1px solid rgba(0,195,255,.22);
  transition:all .18s;display:inline-block;
}
.btn-ghost:hover{border-color:rgba(0,195,255,.6);color:var(--text)}

/* ════════════════════════════════════════
   ANIMATIONS
════════════════════════════════════════ */
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-badge{animation:fadeUp .5s .2s both}
.hero-title{animation:fadeUp .6s .4s both}
.hero-desc{animation:fadeUp .6s .6s both}
.hero-btns{animation:fadeUp .6s .8s both}

/* ════════════════════════════════════════
   BLOG PREVIEW
════════════════════════════════════════ */
.blog-preview{display:none;border-bottom:1px solid var(--border)}
.blog-preview.loaded{display:block}
.blog-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);background:rgba(255,255,255,.04);border:1px solid var(--border)}
.blog-card{background:rgba(12,12,18,.94);position:relative;overflow:hidden;transition:background .2s;display:flex;flex-direction:column;cursor:pointer}
.blog-card:hover{background:rgba(20,20,30,.98)}
.blog-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .38s}
.blog-card:hover::after{transform:scaleX(1)}
.blog-card-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;background:linear-gradient(135deg,#07071a,rgba(0,195,255,.04),#07071a);display:block}
.blog-card-thumb-ph{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#07071a 0%,rgba(0,195,255,.05) 50%,#07071a 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase}
.blog-card-body{padding:22px;flex:1;display:flex;flex-direction:column}
.blog-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.blog-card-cat{font-family:var(--font-mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;padding:3px 10px;border:1px solid rgba(0,195,255,.22);color:var(--c1)}
.blog-card-date{font-family:var(--font-mono);font-size:8px;color:var(--text3);letter-spacing:.08em}
.blog-card-title{font-size:16px;font-weight:700;line-height:1.25;letter-spacing:-.02em;color:var(--text);margin-bottom:8px;transition:color .2s}
.blog-card:hover .blog-card-title{color:var(--c1)}
.blog-card-excerpt{font-size:13px;color:var(--text2);line-height:1.65;flex:1}
.blog-card-link{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c1);margin-top:14px;display:inline-block;transition:color .2s}
.blog-card:hover .blog-card-link{color:var(--text)}
.blog-cta-wrap{display:flex;justify-content:flex-end;margin-top:16px}

/* ════════════════════════════════════════
   GUIDES HOME
════════════════════════════════════════ */
.guides-home{
  padding:56px 48px;
  border-bottom:1px solid var(--border);
  background:var(--panel);
}
.guides-home .section-kicker{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.2em;
  color:rgba(0,195,255,.6);
  text-transform:uppercase;
  display:block;
  text-align:center;
  margin-bottom:10px;
}
.guides-home .section-title{
  font-family:var(--font-display);
  font-size:clamp(20px,3vw,28px);
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--text);
  text-align:center;
  margin:0 0 12px;
}
.guides-home .section-sub{
  font-family:var(--font-display);
  font-size:14px;
  color:var(--text2);
  text-align:center;
  max-width:520px;
  margin:0 auto 40px;
  line-height:1.7;
}
.guides-home-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1px;
  max-width:1060px;
  margin:0 auto 32px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
}
.guide-home-card{
  background:rgba(12,12,18,.94);
  padding:24px;
  display:flex;flex-direction:column;gap:10px;
  transition:background .2s;
  text-decoration:none;
  position:relative;overflow:hidden;
}
.guide-home-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .38s;
}
.guide-home-card:hover{background:rgba(20,20,30,.98)}
.guide-home-card:hover::after{transform:scaleX(1)}
.guide-home-badge{
  display:inline-block;font-family:var(--font-mono);font-size:9px;
  letter-spacing:.12em;padding:3px 10px;text-transform:uppercase;
  width:fit-content;border:1px solid;
}
.badge-seo{border-color:rgba(0,195,255,.3);color:var(--c1);background:rgba(0,195,255,.06)}
.badge-email{border-color:rgba(123,47,255,.3);color:var(--c2);background:rgba(123,47,255,.06)}
.badge-sea{border-color:rgba(0,195,255,.2);color:#36d6e8;background:rgba(0,195,255,.04)}
.badge-geo{border-color:rgba(123,47,255,.2);color:#a67fff;background:rgba(123,47,255,.04)}
.badge-ecom{border-color:rgba(255,170,0,.25);color:#ffaa33;background:rgba(255,170,0,.06)}
.badge-mktg{border-color:rgba(255,0,204,.25);color:var(--c3);background:rgba(255,0,204,.06)}
.badge-custom{border-color:var(--border);color:var(--text3);background:transparent}
.guide-home-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text);margin:0;line-height:1.2;letter-spacing:-.01em}
.guide-home-brand{font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:.08em;text-transform:uppercase}
.guide-home-desc{font-size:13px;color:var(--text2);line-height:1.65;flex:1}
.guide-home-dl{font-family:var(--font-mono);font-weight:700;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--c1);margin-top:4px;transition:color .2s}
.guide-home-card:hover .guide-home-dl{color:var(--text)}
.guide-skeleton{background:rgba(12,12,18,.94);border:none;padding:24px;min-height:160px;animation:skpulse 1.4s ease-in-out infinite}
@keyframes skpulse{0%,100%{opacity:.3}50%{opacity:.6}}
.guides-home-cta{text-align:center}
.btn-guides-all{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;padding:13px 26px;
  background:transparent;color:var(--text2);
  border:1px solid rgba(0,195,255,.22);transition:all .18s;
  display:inline-block;text-decoration:none;
}
.btn-guides-all:hover{border-color:rgba(0,195,255,.6);color:var(--text)}

/* ════════════════════════════════════════
   RESPONSIVE — TABLETTE (max 900px)
════════════════════════════════════════ */
@media(max-width:900px){
  nav{padding:0 20px}
  .nav-links{display:none}
  .nav-right .nav-dot{display:none}
  .nav-right .nav-cta{display:none}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:44px 28px;border-right:none;border-bottom:1px solid var(--border)}
  .hero-right{min-height:260px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(3){border-top:1px solid var(--border)}
  .stat:nth-child(4){border-top:1px solid var(--border);border-right:none}
  .brands{grid-template-columns:1fr}
  .brand{border-right:none;border-bottom:1px solid var(--border);padding:36px 28px}
  .brand:last-child{border-bottom:none}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:40px 28px}
  .contact{grid-template-columns:1fr}
  .contact-left{border-right:none;border-bottom:1px solid var(--border);padding:40px 28px}
  .contact-right{min-height:220px;padding:40px 28px}
  footer{padding:16px 28px}
  .footer-links{display:flex;flex-wrap:wrap;gap:10px}
  .blog-cards{grid-template-columns:1fr 1fr}
  .guides-home{padding:40px 28px}
  .guides-home-grid{grid-template-columns:1fr 1fr}
}

/* ════════════════════════════════════════
   RESPONSIVE — MOBILE (max 600px)
════════════════════════════════════════ */
@media(max-width:600px){
  nav{padding:0 16px;height:56px}
  .nav-logo{font-size:11px;letter-spacing:.05em}
  .mobile-menu{top:56px}
  .hero-left{padding:28px 16px}
  .hero-badge{font-size:9px;margin-bottom:18px}
  .hero-title{font-size:clamp(28px,9vw,44px)}
  .hero-desc{font-size:14px;margin:18px 0}
  .hero-btns{flex-direction:column;gap:10px}
  .btn-primary,.btn-ghost{text-align:center;width:100%;padding:14px 20px}
  .hero-right{min-height:200px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat{padding:18px 14px}
  .stat-num{font-size:22px}
  .stat-label{font-size:9px}
  .brand{padding:24px 16px}
  .brand-name{font-size:20px}
  .brand-desc{font-size:13px}
  .brand-bg{display:none}
  .services-grid{grid-template-columns:1fr}
  .section{padding:28px 16px}
  .section-title{font-size:19px;margin-bottom:20px}
  .section-tag{font-size:9px}
  .carousel-controls{justify-content:center;gap:8px;flex-wrap:wrap}
  .carousel-btn{font-size:9px;padding:8px 12px}
  .carousel-cta{font-size:8px;padding:8px 14px}
  .blog-cards{grid-template-columns:1fr}
  .blog-card-title{font-size:15px}
  .blog-cta-wrap{justify-content:center}
  .contact-left{padding:28px 16px}
  .contact-title{font-size:20px}
  .contact-big{font-size:36px}
  .contact-sub{font-size:13px}
  .contact-links{gap:12px}
  .contact-link{font-size:12px}
  .contact-right{padding:28px 16px;min-height:180px}
  footer{padding:14px 16px;flex-direction:column;align-items:flex-start;gap:8px}
  .footer-logo{font-size:9px}
  .footer-loc{font-size:9px}
  .ticker-inner span{font-size:9px;margin:0 14px}
  .guides-home{padding:28px 16px}
  .guides-home-grid{grid-template-columns:1fr}
}
/* ÉTUDES DE CAS */
.page-hero{padding:64px 48px 48px;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0,rgba(255,255,255,.006) 1px,transparent 2px,transparent 48px);pointer-events:none}
.page-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(0,195,255,.6);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.page-tag::before{content:'';width:20px;height:1px;background:var(--grad)}
.page-title{font-size:clamp(36px,5vw,68px);font-weight:800;line-height:.93;letter-spacing:-.03em;margin-bottom:20px}
.page-title .out{-webkit-text-stroke:1.5px rgba(0,195,255,.4);color:transparent;display:block}
.page-desc{font-size:15px;color:var(--text2);line-height:1.8;max-width:600px}
.cases{padding:0 48px 80px}
.case{border-bottom:1px solid var(--border);padding:64px 0}
.case:last-child{border-bottom:none}
.case-header{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:24px;margin-bottom:48px}
.case-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--text3);padding-top:6px}
.case-label{font-family:var(--font-mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--c1);margin-bottom:8px}
.case-title{font-size:clamp(24px,3vw,40px);font-weight:800;letter-spacing:-.02em;line-height:1}
.case-status{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border:1px solid;white-space:nowrap}
.case-status.done{color:#00ff88;border-color:rgba(0,255,136,.3);background:rgba(0,255,136,.06)}
.case-status.live{color:var(--c1);border-color:rgba(0,195,255,.3);background:rgba(0,195,255,.06)}
.case-status.wip{color:#ffaa00;border-color:rgba(255,170,0,.3);background:rgba(255,170,0,.06)}
.case-body{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.case-col{padding:32px;background:var(--bg)}
.case-col-title{font-family:var(--font-mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.scores{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:28px}
.score-block{flex:1;min-width:120px;padding:20px;background:rgba(255,255,255,.03);border:1px solid var(--border);text-align:center}
.score-val{font-family:var(--font-mono);font-size:32px;font-weight:700;line-height:1;margin-bottom:4px}
.score-val.green{color:#00ff88}
.score-val.cyan{color:var(--c1)}
.score-val.mag{color:var(--c3)}
.score-label{font-family:var(--font-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3)}
.steps{display:flex;flex-direction:column;gap:0}
.step{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.step:last-child{border-bottom:none}
.step-icon{width:28px;height:28px;border-radius:2px;background:rgba(0,195,255,.08);border:1px solid rgba(0,195,255,.2);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;margin-top:2px}
.step-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.step-desc{font-size:15px;color:var(--text2);line-height:1.65}
.case-status.done{color:#00ff88;border-color:rgba(0,255,136,.3);background:rgba(0,255,136,.06)}
.case-status.live{color:var(--c1);border-color:rgba(0,195,255,.3);background:rgba(0,195,255,.06)}
.case-status.wip{color:#ffaa00;border-color:rgba(255,170,0,.3);background:rgba(255,170,0,.06)}
.case-body{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.case-col{padding:32px;background:var(--bg)}
.case-col-title{font-family:var(--font-mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.scores{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:28px}
.score-block{flex:1;min-width:120px;padding:20px;background:rgba(255,255,255,.03);border:1px solid var(--border);text-align:center}
.score-val{font-family:var(--font-mono);font-size:32px;font-weight:700;line-height:1;margin-bottom:4px}
.score-val.green{color:#00ff88}
.score-val.cyan{color:var(--c1)}
.score-val.mag{color:var(--c3)}
.score-label{font-family:var(--font-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3)}
.steps{display:flex;flex-direction:column;gap:0}
.step{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.step:last-child{border-bottom:none}
.step-icon{width:28px;height:28px;border-radius:2px;background:rgba(0,195,255,.08);border:1px solid rgba(0,195,255,.2);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;margin-top:2px}
.step-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.step-desc{font-size:15px;color:var(--text2);line-height:1.65}
.ba{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.06);border:1px solid var(--border);margin-bottom:20px}
.ba-col{padding:16px;background:var(--bg)}
.ba-label{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.ba-label.before{color:rgba(255,80,80,.7)}
.ba-label.after{color:#00ff88}
.ba-item{font-size:15px;color:var(--text2);padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);line-height:1.5}
.ba-item:last-child{border-bottom:none}
.ba-item strong{color:var(--text)}
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.tl-item:last-child{border-bottom:none}
.tl-dot{width:8px;height:8px;border-radius:50%;background:var(--grad);flex-shrink:0;margin-top:6px}
.tl-date{font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;color:var(--c1);margin-bottom:4px}
.tl-text{font-size:15px;color:var(--text2);line-height:1.65}
.tl-text strong{color:var(--text)}
.insight{margin-top:28px;padding:20px 24px;border-left:2px solid var(--c1);background:rgba(0,195,255,.04)}
.insight-text{font-size:16px;color:var(--text2);line-height:1.8;font-style:italic}
.insight-label{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3);margin-top:10px}
.csp-note{margin-top:16px;padding:14px 18px;border-left:2px solid rgba(255,170,0,.5);background:rgba(255,170,0,.04);font-family:var(--font-mono);font-size:10px;color:rgba(255,170,0,.8);line-height:1.7;letter-spacing:.04em}
.csp-note-green{border-color:rgba(0,255,136,.5);background:rgba(0,255,136,.04);color:rgba(0,255,136,.8)}
.page-cta{margin:0 48px 80px;padding:48px;border:1px solid var(--border);background:rgba(12,12,18,.6);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.page-cta-title{font-size:clamp(20px,2.5vw,32px);font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.page-cta-sub{font-size:14px;color:var(--text2)}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.tag{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border:1px solid var(--border);color:var(--text3)}
.tag.c1{border-color:rgba(0,195,255,.35);color:var(--c1);background:rgba(0,195,255,.06)}
.tag.c2{border-color:rgba(123,47,255,.35);color:#a67fff;background:rgba(123,47,255,.06)}
.tag.c3{border-color:rgba(255,0,204,.35);color:var(--c3);background:rgba(255,0,204,.06)}
@media(max-width:900px){.page-hero{padding:48px 24px 40px}.cases{padding:0 24px 60px}.case-body{grid-template-columns:1fr}.case-header{grid-template-columns:auto 1fr;gap:16px}.case-status{grid-column:span 2;justify-self:start}.ba{grid-template-columns:1fr}.page-cta{margin:0 24px 60px;padding:32px 24px}.scores{gap:8px}}
@media(max-width:600px){.page-title{letter-spacing:-.02em}.case-col{padding:20px}.scores{gap:5px}.score-block{padding:14px 10px}.score-val{font-size:24px}}
/* À PROPOS */
.about-hero{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 64px);border-bottom:1px solid var(--border)}
.about-hero-left{padding:60px 48px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--border);background:var(--panel)}
.about-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(0,195,255,.6);text-transform:uppercase;margin-bottom:20px}
.about-name{font-size:clamp(48px,7vw,96px);font-weight:800;line-height:.9;letter-spacing:-.04em;margin-bottom:16px}
.about-name .out{-webkit-text-stroke:1.5px rgba(0,195,255,.4);color:transparent;display:block}
.about-title{font-family:var(--font-mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--text2);margin-bottom:24px}
.about-intro{font-size:16px;color:var(--text2);line-height:1.85;max-width:520px}
.about-hero-right{display:flex;align-items:center;justify-content:center;padding:48px;background:rgba(8,8,14,.6)}
.about-photo-wrap{position:relative;display:inline-block}
.about-photo{width:320px;height:400px;object-fit:cover;object-position:top;display:block;filter:grayscale(20%) contrast(1.05)}
.about-photo-frame{position:absolute;inset:-8px;border:1px solid rgba(0,195,255,.2);pointer-events:none}
.about-photo-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3);margin-top:12px;text-align:center}
.section-wrap{padding:56px 48px}
.s-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(0,195,255,.6);text-transform:uppercase;margin-bottom:12px}
.s-title{font-size:clamp(28px,4vw,52px);font-weight:800;line-height:.93;letter-spacing:-.03em;margin-bottom:40px}
.bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.bio-block{padding:32px;background:var(--bg)}
.bio-block-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--text3);margin-bottom:12px}
.bio-block-title{font-size:18px;font-weight:700;letter-spacing:-.01em;margin-bottom:12px}
.bio-block-text{font-size:14px;color:var(--text2);line-height:1.8}
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.skill-item{padding:24px;background:var(--bg)}
.skill-icon{font-size:24px;margin-bottom:12px}
.skill-name{font-size:15px;font-weight:700;margin-bottom:6px}
.skill-desc{font-size:12px;color:var(--text2);line-height:1.6;margin-bottom:14px}
.skill-bar{height:3px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.skill-fill{height:100%;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.skill-fill.animated{transition:transform .8s cubic-bezier(.4,0,.2,1)}
.about-cta{padding:64px 48px;text-align:center;border-bottom:1px solid var(--border)}
.cta-title{font-size:clamp(32px,5vw,64px);font-weight:800;letter-spacing:-.03em;line-height:.93;margin-bottom:16px}
.cta-sub{font-size:15px;color:var(--text2);max-width:480px;margin:0 auto 32px;line-height:1.7}
.btn-grad{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:14px 32px;border:none;background:var(--grad);color:#fff;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);cursor:pointer;transition:opacity .2s}
.btn-grad:hover{opacity:.82}
@media(max-width:900px){.about-hero{grid-template-columns:1fr}.about-hero-left{border-right:none;border-bottom:1px solid var(--border);padding:40px 28px}.about-hero-right{padding:32px}.about-photo{width:240px;height:300px}.section-wrap{padding:40px 28px}.bio-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.about-hero-left{padding:28px 16px}.section-wrap{padding:28px 16px}.about-name{font-size:clamp(36px,10vw,64px)}.bio-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:1fr 1fr}.about-cta{padding:40px 16px}}
/* ════════════════════════════════════════
   BLOG — HERO
════════════════════════════════════════ */
.blog-hero{padding:64px 48px 48px;border-bottom:1px solid var(--border);background:var(--panel);position:relative;overflow:hidden}
.blog-hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0,rgba(255,255,255,.006) 1px,transparent 2px,transparent 8px);pointer-events:none}
.blog-hero-inner{position:relative;z-index:1;max-width:680px}
.blog-hero-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(0,195,255,.6);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.blog-hero-tag::before{content:'';width:20px;height:1px;background:var(--grad)}
.blog-hero-title{font-size:clamp(32px,5vw,56px);font-weight:800;line-height:.95;letter-spacing:-.03em;margin-bottom:18px}
.blog-hero-title .out{-webkit-text-stroke:1.5px rgba(0,195,255,.4);color:transparent;display:block}
.blog-hero-desc{font-size:15px;color:var(--text2);line-height:1.8;max-width:480px}

/* ════════════════════════════════════════
   BLOG — FILTRES & RECHERCHE
════════════════════════════════════════ */
.filters{padding:20px 48px;background:rgba(10,10,16,.8);border-bottom:1px solid var(--border);display:flex;gap:8px;flex-wrap:wrap;align-items:center;position:sticky;top:64px;z-index:100;backdrop-filter:blur(12px)}
.filter-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3);margin-right:6px}
.filter-btn{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;background:transparent;border:1px solid rgba(0,195,255,.18);color:var(--text3);cursor:pointer;transition:all .2s}
.filter-btn:hover{border-color:rgba(0,195,255,.5);color:var(--text2)}
.filter-btn.active{background:rgba(0,195,255,.12);border-color:var(--c1);color:var(--c1)}
.search-wrap{margin-left:auto}
.search-input{font-family:var(--font-mono);font-size:10px;padding:6px 14px;background:rgba(0,0,0,.4);border:1px solid var(--border);color:var(--text);outline:none;width:200px;transition:border-color .2s;letter-spacing:.06em}
.search-input:focus{border-color:rgba(0,195,255,.4)}
.search-input::placeholder{color:var(--text3)}

/* ════════════════════════════════════════
   BLOG — GRILLE ARTICLES
════════════════════════════════════════ */
.blog-main{padding:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border);margin:24px 48px}
.article-card{background:rgba(12,12,18,.94);position:relative;overflow:hidden;transition:background .2s;display:flex;flex-direction:column}
.article-card:hover{background:rgba(20,20,30,.98)}
.article-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .38s}
.article-card:hover::after{transform:scaleX(1)}
.article-thumb{width:100%;aspect-ratio:16/7;object-fit:cover;background:#07071a;display:block}
.article-thumb-placeholder{width:100%;aspect-ratio:16/7;background:linear-gradient(135deg,#07071a 0%,rgba(0,195,255,.05) 50%,#07071a 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase}
.article-body{padding:16px;flex:1;display:flex;flex-direction:column}
.article-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.article-cat{font-family:var(--font-mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;padding:3px 10px;border:1px solid rgba(0,195,255,.22);color:var(--c1)}
.article-date{font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.article-read{font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-left:auto}
.article-title{font-size:14px;font-weight:800;line-height:1.2;letter-spacing:-.02em;margin-bottom:8px;color:var(--text);transition:color .2s}
.article-card:hover .article-title{color:var(--c1)}
.article-excerpt{font-size:12px;color:var(--text2);line-height:1.6;flex:1}
.article-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}
.article-link{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c1);transition:color .2s}
.article-link:hover{color:var(--text)}
.article-num{font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:.08em}

/* ════════════════════════════════════════
   BLOG — EMPTY STATE
════════════════════════════════════════ */
.blog-empty{grid-column:1/-1;padding:80px 40px;text-align:center}
.blog-empty-icon{font-size:48px;margin-bottom:16px;opacity:.3}
.blog-empty-txt{font-family:var(--font-mono);font-size:11px;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;line-height:2}

/* ════════════════════════════════════════
   BLOG — PAGINATION
════════════════════════════════════════ */
.pagination{padding:32px 48px;display:flex;gap:6px;align-items:center;justify-content:center;border-top:1px solid var(--border)}
.page-btn{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.1em;padding:10px 16px;background:transparent;border:1px solid rgba(0,195,255,.18);color:var(--text3);cursor:pointer;transition:all .2s}
.page-btn:hover{border-color:rgba(0,195,255,.5);color:var(--text2)}
.page-btn.active{background:rgba(0,195,255,.12);border-color:var(--c1);color:var(--c1)}
.page-btn:disabled{opacity:.3;cursor:default}

/* ════════════════════════════════════════
   BLOG — RESPONSIVE
════════════════════════════════════════ */
@media(max-width:900px){
  .blog-hero{padding:44px 24px 36px}
  .blog-main{grid-template-columns:repeat(3,1fr);margin:24px}
  .filters{padding:14px 24px}
  .search-wrap{margin-left:0;width:100%}
  .search-input{width:100%}
}
@media(max-width:600px){
  .blog-hero{padding:32px 16px}
  .blog-main{grid-template-columns:1fr;margin:16px;gap:1px}
  .filters{padding:12px 16px;gap:6px}
  .pagination{padding:24px 16px}
}
/* ════════════════════════════════════════
   ARTICLE PAGE
════════════════════════════════════════ */
.breadcrumb{padding:11px 40px;background:rgba(10,10,16,.5);border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.breadcrumb a{color:var(--text3);transition:color .2s}
.breadcrumb a:hover{color:var(--c1)}
.breadcrumb-sep{opacity:.4}
.art-container{max-width:1060px;margin:0 auto;padding:48px 40px 80px}
.art-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);cursor:pointer;transition:color .2s;margin-bottom:28px}
.art-back:hover{color:var(--c1)}
.art-header{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.art-meta-row{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.art-cat{font-family:var(--font-mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase;padding:4px 12px;border:1px solid;color:var(--c1)}
.art-date{font-family:var(--font-mono);font-size:9px;color:var(--text3)}
.art-read{font-family:var(--font-mono);font-size:9px;color:var(--text3)}
.art-title{font-size:clamp(24px,3.8vw,44px);font-weight:800;line-height:1.06;letter-spacing:-.03em;margin-bottom:16px}
.art-excerpt{font-family:var(--font-body);font-size:17px;color:var(--text2);line-height:1.75;max-width:600px;border-left:3px solid var(--c1);padding-left:16px;margin-top:20px}
.art-image{width:auto;max-width:100%;max-height:500px;object-fit:contain;border:1px solid var(--border);display:block;margin:0 auto 40px}
.art-body{display:grid;grid-template-columns:1fr 220px;gap:52px;align-items:start}
.art-content{font-family:var(--font-body);font-size:16px;line-height:1.9;color:var(--text2)}
.art-content h2{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--text);margin:36px 0 12px;letter-spacing:-.02em;padding-bottom:8px;border-bottom:1px solid var(--border)}
.art-content h3{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text);margin:24px 0 8px}
.art-content p{margin-bottom:18px}
.art-content ul,.art-content ol{margin:0 0 18px 20px}
.art-content li{margin-bottom:7px}
.art-content strong{color:var(--text);font-weight:600}
.art-content em{color:var(--c1);font-style:italic}
.art-content a{color:var(--c1);border-bottom:1px solid rgba(0,195,255,.3);transition:border-color .2s}
.art-content a:hover{border-color:var(--c1)}
.art-content blockquote{border-left:3px solid var(--c1);padding:14px 18px;margin:24px 0;background:rgba(0,195,255,.04);font-style:italic;color:var(--text);font-size:15px;line-height:1.7}
.art-content code{font-family:var(--font-mono);font-size:11px;background:rgba(0,0,0,.4);border:1px solid var(--border);padding:2px 6px;color:var(--c1)}
.art-content pre{font-family:var(--font-mono);font-size:11px;background:rgba(0,0,0,.5);border:1px solid var(--border);padding:18px;margin:20px 0;overflow-x:auto;color:var(--text2);line-height:1.7}
.art-content img{max-width:100%;border:1px solid var(--border);margin:20px 0}
.art-content hr{border:none;border-top:1px solid var(--border);margin:32px 0}
.art-sidebar{position:sticky;top:80px}
.sb-block{margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--border)}
.sb-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.sb-label{font-family:var(--font-mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--c1);display:block;margin-bottom:10px}
.toc-link{display:block;font-family:var(--font-mono);font-size:9px;color:var(--text3);cursor:pointer;padding:4px 0 4px 10px;border-left:2px solid transparent;margin-bottom:1px;transition:all .2s;line-height:1.5;letter-spacing:.04em}
.toc-link:hover,.toc-link.active{color:var(--c1);border-left-color:var(--c1)}
.share-btn{font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:8px 10px;background:transparent;border:1px solid var(--border);color:var(--text3);cursor:pointer;display:flex;align-items:center;gap:7px;width:100%;margin-bottom:5px;transition:all .2s}
.share-btn:hover{border-color:rgba(0,195,255,.35);color:var(--text2)}
.rel-item{display:block;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.04);transition:color .2s}
.rel-item:last-child{border-bottom:none}
.rel-cat{font-family:var(--font-mono);font-size:7px;letter-spacing:.12em;color:var(--text3);text-transform:uppercase;margin-bottom:2px}
.rel-title{font-size:11px;font-weight:700;color:var(--text2);line-height:1.35;transition:color .2s}
.rel-item:hover .rel-title{color:var(--c1)}
.btn-cta{font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:10px 12px;background:transparent;border:1px solid rgba(0,195,255,.3);color:var(--c1);cursor:pointer;width:100%;transition:all .2s}
.btn-cta:hover{background:rgba(0,195,255,.08)}
.sb-contact-txt{font-size:12px;color:var(--text2);line-height:1.6;margin-bottom:10px;font-family:var(--font-body)}
.not-found{padding:80px 40px;text-align:center}
@media(max-width:900px){
  .art-container{padding:32px 24px 60px}
  .art-body{grid-template-columns:1fr;gap:0}
  .art-sidebar{position:static;border-top:1px solid var(--border);padding-top:28px;margin-top:40px}
}
@media(max-width:600px){
  .art-container{padding:20px 16px 48px}
  .art-title{font-size:clamp(20px,6.5vw,30px)}
  .art-excerpt{font-size:15px}
  .art-content{font-size:15px;line-height:1.85}
  .art-image{max-height:220px}
}
/* ════════════════════════════════════════
   PAGE RESSOURCES
════════════════════════════════════════ */

/* ── Hero ── */
.res-hero{padding:72px 48px 56px;text-align:center;border-bottom:1px solid var(--border);background:var(--panel);position:relative;overflow:hidden}
.res-hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0,rgba(255,255,255,.005) 1px,transparent 2px,transparent 8px);pointer-events:none}
.res-kicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(0,195,255,.6);text-transform:uppercase;margin-bottom:10px;display:block}
.res-hero h1{font-family:var(--font-display);font-size:clamp(28px,5vw,52px);font-weight:800;line-height:1;letter-spacing:-.03em;margin-bottom:16px}
.res-hero p{font-size:15px;color:var(--text2);max-width:560px;margin:0 auto;line-height:1.8}

/* ── Grille guides ── */
.guides-wrap{max-width:1140px;margin:0 auto;padding:56px 48px}
.guides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.guide-card{background:rgba(12,12,18,.94);display:flex;flex-direction:column;transition:background .2s;position:relative;overflow:hidden}
.guide-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .38s}
.guide-card:hover{background:rgba(20,20,30,.98)}
.guide-card:hover::after{transform:scaleX(1)}
.guide-card-top{padding:24px 22px 16px;border-bottom:1px solid var(--border);flex:1}
.guide-badge{display:inline-block;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;padding:3px 10px;text-transform:uppercase;width:fit-content;margin-bottom:12px;border:1px solid}
.guide-card h2{font-size:16px;font-weight:700;color:var(--text);margin:0 0 6px;letter-spacing:-.01em;line-height:1.2}
.guide-brand{font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.guide-desc{font-size:13px;color:var(--text2);line-height:1.65}
.guide-card-body{padding:16px 22px;border-bottom:1px solid var(--border)}
.modules-label{font-family:var(--font-mono);font-size:8px;letter-spacing:.14em;color:var(--text3);text-transform:uppercase;margin-bottom:8px}
.guide-card-body ul{margin:0;padding:0;list-style:none}
.guide-card-body ul li{font-size:13px;color:var(--text2);padding:3px 0 3px 14px;position:relative;line-height:1.5}
.guide-card-body ul li::before{content:'›';position:absolute;left:0;color:var(--c1)}
.guide-card-footer{padding:16px 22px;display:flex;gap:10px;align-items:center}
.btn-download{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:10px 18px;border:none;background:var(--grad);color:#fff;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);transition:opacity .2s;flex:1;justify-content:center;text-decoration:none}
.btn-download:hover{opacity:.82}
.guide-meta{font-family:var(--font-mono);font-size:8px;color:var(--text3);text-align:right;line-height:1.6;letter-spacing:.06em}
.guides-empty{grid-column:1/-1;text-align:center;padding:60px 20px;font-family:var(--font-mono);font-size:11px;color:var(--text3);letter-spacing:.1em}

/* ── Opt-in ── */
.optin-section{padding:56px 48px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--panel);text-align:center}
.optin-kicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:rgba(255,0,204,.6);text-transform:uppercase;margin-bottom:10px;display:block}
.optin-section h2{font-size:clamp(18px,2.5vw,26px);font-weight:800;letter-spacing:-.02em;margin-bottom:10px}
.optin-section p{font-size:14px;color:var(--text2);max-width:480px;margin:0 auto 28px;line-height:1.7}
.optin-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;max-width:520px;margin:0 auto}
.optin-form input{background:rgba(0,0,0,.4);border:1px solid var(--border);padding:10px 16px;font-family:var(--font-mono);font-size:11px;color:var(--text);outline:none;transition:border-color .2s;min-width:200px;flex:1}
.optin-form input:focus{border-color:rgba(0,195,255,.5)}
.optin-form input::placeholder{color:var(--text3)}
.btn-subscribe{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:10px 22px;background:transparent;border:1px solid rgba(255,0,204,.35);color:var(--c3);cursor:pointer;transition:all .2s;white-space:nowrap}
.btn-subscribe:hover{background:rgba(255,0,204,.1);border-color:var(--c3)}
.optin-note{font-family:var(--font-mono);font-size:8px;color:var(--text3);margin-top:14px;letter-spacing:.06em}
.optin-success{display:none;font-family:var(--font-mono);font-size:11px;color:var(--c1);margin-top:16px;letter-spacing:.08em}

/* ── Responsive ressources ── */
@media(max-width:900px){
  .res-hero{padding:48px 24px 40px}
  .guides-wrap{padding:40px 24px}
  .guides-grid{grid-template-columns:1fr 1fr}
  .optin-section{padding:40px 24px}
}
@media(max-width:600px){
  .res-hero{padding:32px 16px 28px}
  .guides-wrap{padding:28px 16px}
  .guides-grid{grid-template-columns:1fr}
  .optin-form{flex-direction:column}
}
/* ════════════════════════════════════════
   À PROPOS — TRANSITION DELAYS & UTILITAIRES
════════════════════════════════════════ */

/* Hero delays */
.about-name.reveal        { transition-delay:.1s }
.about-title.reveal       { transition-delay:.2s }
.about-intro.reveal       { transition-delay:.3s }
.about-hero-right.reveal  { transition-delay:.2s }

/* Bio blocks delays */
.bio-block.reveal:nth-child(2) { transition-delay:.1s }
.bio-block.reveal:nth-child(3) { transition-delay:.2s }
.bio-block.reveal:nth-child(4) { transition-delay:.3s }

/* Timeline delays */
.tl-item.reveal:nth-child(2) { transition-delay:.1s }
.tl-item.reveal:nth-child(3) { transition-delay:.2s }
.tl-item.reveal:nth-child(4) { transition-delay:.3s }

/* Section separator */
.section-sep { border-bottom:1px solid var(--border) }

/* CTA s-tag centré */
.s-tag--center { justify-content:center;margin-bottom:16px }

/* Nav logo séparateur × */
.nav-logo-sep { color:rgba(240,240,255,.15) }

/* Skill bars — animation via custom property (CSP-safe) */
.skill-fill[data-animated] { transform:scaleX(var(--bar-w,0)) }
/* ════════════════════════════════════════
   À PROPOS — TIMELINE VERTICALE (isolée)
════════════════════════════════════════ */
.about-timeline{position:relative;padding-left:32px}
.about-timeline::before{
  content:'';position:absolute;left:0;top:8px;bottom:8px;
  width:1px;
  background:linear-gradient(180deg,var(--c1),var(--c2),rgba(0,0,0,0));
}
.about-timeline .tl-item{
  display:block !important;
  position:relative;
  margin-bottom:36px;
  padding:0 0 36px 0;
  border-bottom:1px solid var(--border);
  gap:unset !important;
}
.about-timeline .tl-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.about-timeline .tl-dot{
  position:absolute !important;
  left:-38px !important;top:4px !important;
  width:12px !important;height:12px !important;
  border-radius:50% !important;
  background:var(--grad) !important;
  border:2px solid var(--bg) !important;
  flex-shrink:unset !important;margin-top:0 !important;
}
.about-timeline .tl-period{
  font-family:var(--font-mono);font-size:8px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--c1);margin-bottom:6px;
  display:block;
}
.about-timeline .tl-role{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.about-timeline .tl-company{
  font-family:var(--font-mono);font-size:9px;color:var(--text3);
  letter-spacing:.08em;margin-bottom:10px;display:block;
}
.about-timeline .tl-desc{font-size:13px;color:var(--text2);line-height:1.75}

@media(max-width:600px){
  .about-timeline{padding-left:20px}
  .about-timeline .tl-dot{left:-26px !important}
  .about-timeline .tl-role{font-size:14px}
  .about-timeline .tl-desc{font-size:12px}
}
/* ─── INDEX — utilitaires inline supprimés ─── */
.brand-pill-rbl{color:var(--c3);border-color:rgba(255,0,204,.2)}
.section-pt0{padding-top:0}
.section-pb0{padding-bottom:0}
.btn-ghost-cta{margin-top:16px;margin-bottom:0}
.ccs-val.green{color:#00ff88}
.ccs-val.cyan{color:var(--c1)}
.ccs-val.purple{color:var(--c2)}
.ccs-val.red{color:#ff5050}
.ccs-val.orange{color:#ffaa00}
.contact-logo-img{width:180px;height:auto;margin:0 auto 16px;display:block;filter:drop-shadow(0 0 20px rgba(0,195,255,0.3))}
/* ─── INDEX — utilitaires ─── */
.brand-pill-rbl{color:var(--c3);border-color:rgba(255,0,204,.2)}
.section-pt0{padding-top:0}
.section-pb0{padding-bottom:0}
.btn-ghost-cta{margin-top:16px;margin-bottom:0}
.ccs-val.green{color:#00ff88}
.ccs-val.cyan{color:var(--c1)}
.ccs-val.purple{color:var(--c2)}
.ccs-val.red{color:#ff5050}
.ccs-val.orange{color:#ffaa00}
.contact-logo-img{width:180px;height:auto;margin:0 auto 16px;display:block;filter:drop-shadow(0 0 20px rgba(0,195,255,0.3))}
/* ─── ABOUT-TIMELINE ─── */
.about-timeline{position:relative;padding-left:32px}
.about-timeline::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,var(--c1),var(--c2),rgba(0,0,0,0))}
.about-timeline .tl-item{display:block !important;position:relative;margin-bottom:36px;padding:0 0 36px 0;border-bottom:1px solid var(--border);gap:unset !important}
.about-timeline .tl-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.about-timeline .tl-dot{position:absolute !important;left:-38px !important;top:4px !important;width:12px !important;height:12px !important;border-radius:50% !important;background:var(--grad) !important;border:2px solid var(--bg) !important;flex-shrink:unset !important;margin-top:0 !important}
.about-timeline .tl-period{font-family:var(--font-mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--c1);margin-bottom:6px;display:block}
.about-timeline .tl-role{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.about-timeline .tl-company{font-family:var(--font-mono);font-size:9px;color:var(--text3);letter-spacing:.08em;margin-bottom:10px;display:block}
.about-timeline .tl-desc{font-size:13px;color:var(--text2);line-height:1.75}
@media(max-width:600px){.about-timeline{padding-left:20px}.about-timeline .tl-dot{left:-26px !important}.about-timeline .tl-role{font-size:14px}.about-timeline .tl-desc{font-size:12px}}