.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;isolation:isolate;overflow:hidden;background:radial-gradient(1100px 700px at 78% 18%,rgba(77,124,255,.16),transparent 60%),radial-gradient(900px 600px at 12% 92%,rgba(255,122,69,.12),transparent 60%),var(--ink)}.hero:before{content:"";position:absolute;inset:0;z-index:-1;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:56px 56px;-webkit-mask-image:radial-gradient(circle at 60% 40%,#000 0%,transparent 78%);mask-image:radial-gradient(circle at 60% 40%,#000 0%,transparent 78%);opacity:.5}.glow{position:absolute;z-index:-1;width:560px;height:560px;border-radius:50%;top:-8%;right:6%;background:radial-gradient(circle,rgba(77,124,255,.3),transparent 65%);filter:blur(36px);animation:drift 18s ease-in-out infinite}@keyframes drift{50%{transform:translate(-40px,50px) scale(1.08)}}nav{width:100%;max-width:var(--maxw);margin:0 auto;padding:26px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;animation:fadeDown .7s .1s both}.brand{display:flex;align-items:center;gap:11px;font-weight:600;letter-spacing:-.01em}.brand svg{width:30px;height:auto}.brand span b{color:var(--orange);font-weight:700}.nav-links{display:flex;gap:30px;list-style:none}.nav-links a{color:var(--muted);text-decoration:none;font-size:.93rem;transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-cta{color:var(--text);text-decoration:none;font-size:.9rem;font-weight:600;padding:9px 16px;border:1px solid var(--line);border-radius:10px;transition:border-color .2s,background .2s}.nav-cta:hover{border-color:var(--orange);background:#ff7a4514}.wrap{flex:1;width:100%;max-width:var(--maxw);margin:0 auto;padding:24px 32px 64px;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:56px}.eyebrow{font-family:JetBrains Mono,monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:10px;margin-bottom:26px;animation:fadeUp .7s .25s both}.eyebrow:before{content:"";width:26px;height:1px;background:var(--blue);display:inline-block}h1{font-family:Bricolage Grotesque,sans-serif;font-weight:800;font-size:clamp(2.4rem,5.4vw,4.3rem);line-height:1.02;letter-spacing:-.025em;margin-bottom:24px;max-width:13ch}h1 .accent{background:linear-gradient(100deg,var(--orange),#FFB07A);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}h1 .line{display:block;overflow:hidden}h1 .line>span{display:block;transform:translateY(110%);animation:rise .9s cubic-bezier(.22,1,.36,1) both}h1 .line:nth-child(1)>span{animation-delay:.35s}h1 .line:nth-child(2)>span{animation-delay:.46s}h1 .line:nth-child(3)>span{animation-delay:.57s}.sub{color:var(--muted);font-size:clamp(1rem,1.25vw,1.15rem);line-height:1.65;max-width:46ch;margin-bottom:36px;animation:fadeUp .7s .7s both}.actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;animation:fadeUp .7s .8s both}.btn{font:inherit;font-size:.97rem;font-weight:600;padding:14px 24px;border-radius:12px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:9px;border:1px solid transparent;transition:transform .15s,box-shadow .2s,background .2s,border-color .2s}.btn-primary{background:linear-gradient(100deg,var(--orange),#FF935F);color:#1a0e06;box-shadow:0 8px 30px -8px #ff7a458c}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 36px -8px #ff7a45a6}.btn-primary svg{transition:transform .2s}.btn-primary:hover svg{transform:translate(4px)}.btn-ghost{color:var(--text);border-color:var(--line);background:transparent}.btn-ghost:hover{border-color:var(--muted);background:#ffffff08}.stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:34px;animation:fadeUp .7s .95s both}.chip{font-family:JetBrains Mono,monospace;font-size:.72rem;color:var(--muted);padding:6px 12px;border:1px solid var(--line);border-radius:999px}.chip b{color:var(--text);font-weight:500}.visual{position:relative;aspect-ratio:1/1;width:100%;animation:fadeIn 1s .3s both}.visual svg{width:100%;height:100%;overflow:visible}.mono path,.mono line{fill:none;stroke:url(#grad);stroke-width:5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:400;stroke-dashoffset:400;animation:draw 1.3s cubic-bezier(.65,0,.35,1) forwards;filter:drop-shadow(0 0 8px rgba(255,122,69,.35))}.mono .s1{animation-delay:.5s}.mono .s2{animation-delay:.72s}.mono .s3{animation-delay:.92s}.mono .s4{animation-delay:1.1s}.link{stroke:var(--line);stroke-width:1.5;stroke-dasharray:6 6;opacity:0;animation:fadeIn .8s 1.4s forwards}.node{opacity:0;animation:pop .6s cubic-bezier(.22,1.4,.4,1) forwards}.node:nth-of-type(1){animation-delay:1.5s}.node:nth-of-type(2){animation-delay:1.62s}.node:nth-of-type(3){animation-delay:1.74s}.node:nth-of-type(4){animation-delay:1.86s}.node circle{fill:var(--surface);stroke:var(--blue);stroke-width:1.5}.node .dot{fill:var(--blue)}.node text{fill:var(--muted);font-family:JetBrains Mono,monospace;font-size:9px}.pulse{fill:none;stroke:var(--blue);stroke-width:1.5;transform-origin:center;transform-box:fill-box;animation:pulse 3s ease-out infinite}.node:nth-of-type(2) .pulse{animation-delay:.7s}.node:nth-of-type(3) .pulse{animation-delay:1.4s}.node:nth-of-type(4) .pulse{animation-delay:2.1s}@keyframes draw{to{stroke-dashoffset:0}}@keyframes rise{to{transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}@keyframes fadeDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(3.2)}}@media(max-width:900px){.wrap{grid-template-columns:1fr;gap:28px;padding-top:8px}.visual{order:-1;max-width:360px;margin:0 auto}.nav-links{display:none}h1{max-width:none}}@media(max-width:520px){nav{padding:20px}.wrap{padding:16px 20px 48px}.actions{width:100%}.btn{flex:1;justify-content:center}}@media(prefers-reduced-motion:reduce){*{animation:none!important}h1 .line>span{transform:none}.mono path,.mono line{stroke-dashoffset:0}.node,.link,.eyebrow,.sub,.actions,.stack,nav{opacity:1!important;transform:none!important}}.services{padding:96px 32px;background:var(--ink-2);position:relative}.services-wrap{max-width:var(--maxw);margin:0 auto}.section-header{text-align:center;margin-bottom:64px}.section-header h2{font-family:Bricolage Grotesque,sans-serif;font-weight:800;font-size:clamp(2rem,4vw,3.2rem);line-height:1.1;letter-spacing:-.02em;margin:16px 0}.section-sub{color:var(--muted);font-size:1.05rem;line-height:1.65;max-width:52ch;margin:0 auto}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.service-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:border-color .25s,transform .2s}.service-card:hover{border-color:var(--blue);transform:translateY(-3px)}.service-icon{width:44px;height:44px;background:#4d7cff1f;border:1px solid rgba(77,124,255,.25);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue);margin-bottom:18px}.service-card h3{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1.15rem;margin-bottom:10px}.service-card p{color:var(--muted);font-size:.93rem;line-height:1.6;margin-bottom:18px}.service-tags{display:flex;flex-wrap:wrap;gap:6px;list-style:none}.service-tags li{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--muted);padding:4px 10px;border:1px solid var(--line);border-radius:999px}.service-card--cta{background:linear-gradient(135deg,#ff7a4514,#4d7cff14);border-color:#ff7a4540;display:flex;flex-direction:column;justify-content:center;gap:12px}.service-card--cta:hover{border-color:var(--orange)}.service-card--cta h3{font-size:1.3rem}@media(max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:580px){.services{padding:64px 20px}.services-grid{grid-template-columns:1fr}}.realisations{padding:96px 32px;background:var(--ink);position:relative}.realisations-wrap{max-width:var(--maxw);margin:0 auto}.realisations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.projet-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .25s,transform .2s;display:flex;flex-direction:column}.projet-card:hover{border-color:var(--orange);transform:translateY(-3px)}.projet-image{width:100%;aspect-ratio:16/7;overflow:hidden;background:var(--ink-2)}.projet-image img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s ease}.projet-card:hover .projet-image img{transform:scale(1.06)}.projet-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--line);background:linear-gradient(135deg,var(--ink-2),var(--surface))}.projet-body{padding:24px;display:flex;flex-direction:column;flex:1;gap:10px}.projet-body h3{font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1.2rem}.projet-body p{color:var(--muted);font-size:.92rem;line-height:1.6;flex:1}.projet-tags{display:flex;flex-wrap:wrap;gap:6px;list-style:none;margin-top:4px}.projet-tags li{font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--muted);padding:4px 10px;border:1px solid var(--line);border-radius:999px}.projet-link{display:inline-flex;align-items:center;gap:6px;color:var(--orange);text-decoration:none;font-size:.88rem;font-weight:600;margin-top:8px;transition:gap .2s}.projet-link:hover{gap:10px}@media(max-width:900px){.realisations-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:580px){.realisations{padding:64px 20px}.realisations-grid{grid-template-columns:1fr}}.projet-actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}.projet-demo{display:flex;align-items:flex-start;gap:7px;color:var(--muted);font-size:.8rem;line-height:1.5;padding:10px 12px;background:#4d7cff0f;border:1px solid rgba(77,124,255,.15);border-radius:8px}.projet-demo svg{color:var(--blue);flex-shrink:0;margin-top:2px}.projet-demo code{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text);background:#ffffff0f;padding:1px 5px;border-radius:4px}.image-overlay{position:fixed;inset:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:zoom-out}.image-overlay.active{opacity:1;pointer-events:all}.image-overlay img{max-width:85vw;max-height:85vh;border-radius:var(--radius);box-shadow:0 32px 80px #0009;transform:scale(.92);transition:transform .3s cubic-bezier(.22,1,.36,1);object-fit:contain}.image-overlay.active img{transform:scale(1)}.partenaires{padding:96px 32px;background:var(--ink-2);position:relative}.partenaires-wrap{max-width:var(--maxw);margin:0 auto}.partenaires .section-header{text-align:center;margin-bottom:56px}.partenaires-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.partenaire-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:36px 48px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-width:220px;transition:border-color .25s,transform .2s}.partenaire-card:hover{border-color:var(--blue);transform:translateY(-3px)}.partenaire-logo span{font-family:Bricolage Grotesque,sans-serif;font-size:1.4rem;font-weight:500;color:var(--muted);letter-spacing:-.01em;transition:color .2s}.partenaire-logo span b{color:var(--text);font-weight:800}.partenaire-card:hover .partenaire-logo span{color:var(--text)}.partenaire-desc{font-size:.8rem;color:var(--muted);font-family:JetBrains Mono,monospace;letter-spacing:.05em}.partenaire-card--cta{border-style:dashed;border-color:var(--line);background:transparent;gap:16px}.partenaire-card--cta:hover{border-color:var(--orange)}.partenaire-card--cta p{color:var(--muted);font-size:.95rem}@media(max-width:580px){.partenaires{padding:64px 20px}.partenaire-card{width:100%}}.contact{padding:96px 32px;background:var(--ink)}.contact-wrap{max-width:var(--maxw);margin:0 auto}.contact .section-header{text-align:center;margin-bottom:64px}.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}.contact-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.88rem;font-weight:500;color:var(--text)}.form-group input,.form-group textarea{font-family:Inter,sans-serif;font-size:.95rem;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px 16px;outline:none;transition:border-color .2s,box-shadow .2s;resize:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted);opacity:.6}.form-group input:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #4d7cff1f}.form-error{font-size:.8rem;color:#ff6b6b}.form-alert{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:10px;font-size:.92rem;margin-bottom:8px}.form-alert--success{background:#48c78e1a;border:1px solid rgba(72,199,142,.3);color:#48c78e}.form-alert--error{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);color:#ff6b6b}.contact-info{display:flex;flex-direction:column;gap:16px}.contact-info-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:border-color .2s}.contact-info-card:hover{border-color:var(--blue)}.contact-info-icon{width:42px;height:42px;background:#4d7cff1a;border:1px solid rgba(77,124,255,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue);flex-shrink:0}.contact-info-label{font-size:.78rem;color:var(--muted);font-family:JetBrains Mono,monospace;letter-spacing:.05em;margin-bottom:4px}.contact-info a{color:var(--text);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s}.contact-info a:hover{color:var(--orange)}.contact-disponibilite{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--muted);padding:16px 20px;background:#48c78e0f;border:1px solid rgba(72,199,142,.2);border-radius:var(--radius)}.dispo-dot{width:8px;height:8px;border-radius:50%;background:#48c78e;box-shadow:0 0 0 3px #48c78e40;animation:blink 2s ease-in-out infinite;flex-shrink:0}.dispo-dot--indisponible{width:8px;height:8px;border-radius:50%;background:#e22807;box-shadow:0 0 0 3px #e2280740;animation:blink 2s ease-in-out infinite;flex-shrink:0}@keyframes blink{50%{box-shadow:0 0 0 6px #48c78e1a}}@media(max-width:900px){.contact-grid{grid-template-columns:1fr}.contact-info{order:-1}}@media(max-width:580px){.contact{padding:64px 20px}.form-row{grid-template-columns:1fr}}.footer{background:var(--ink-2);border-top:1px solid var(--line);padding:64px 32px 32px}.footer-wrap{max-width:var(--maxw);margin:0 auto}.footer-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--line)}.footer-brand .brand{margin-bottom:16px}.footer-brand p{color:var(--muted);font-size:.9rem;line-height:1.65}.footer-nav h4{font-family:JetBrains Mono,monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}.footer-nav ul{list-style:none;display:flex;flex-direction:column;gap:10px}.footer-nav a{color:var(--muted);text-decoration:none;font-size:.92rem;transition:color .2s}.footer-nav a:hover{color:var(--orange)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;color:var(--muted);font-size:.83rem}.footer-bottom b{color:var(--text);font-weight:600}@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:1 / -1}}@media(max-width:580px){.footer{padding:48px 20px 24px}.footer-top{grid-template-columns:1fr}.footer-brand{grid-column:auto}.footer-bottom{flex-direction:column;gap:8px;text-align:center}}:root{--ink: #0C1322;--ink-2: #0A0F1C;--surface: #15203A;--line: #233052;--text: #F5F3EF;--muted: #9AA6C0;--orange: #FF7A45;--blue: #4D7CFF;--radius: 16px;--maxw: 1180px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,sans-serif;background:var(--ink);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:6px}
