*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--marine: #0D1B2A;--bleu: #1A56C4;--bleu-clair: #4A80E8;--gris-acier: #8C9BAF;--creme: #F4F2EE;--white: #ffffff;--font-heading: "Outfit", system-ui, sans-serif;--font-mono: "Space Mono", monospace}html{scroll-behavior:smooth}body{font-family:var(--font-heading);color:var(--marine);line-height:1.6;background:var(--creme)}a{text-decoration:none;color:inherit}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--marine);color:var(--white);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(26,86,196,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(26,86,196,.06) 1px,transparent 1px);background-size:60px 60px}.hero>*{position:relative;z-index:1}.hero-content{text-align:center;padding:2rem}.hero-logo{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:3rem}.hero-logo img{width:56px;height:56px}.hero-logo-text{font-weight:800;font-size:2.8rem;letter-spacing:-.02em}.hero-logo-dot{color:var(--bleu)}.hero-tagline{font-size:.8rem;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:var(--gris-acier);margin-bottom:3.5rem}.hero-title{font-weight:800;font-size:clamp(2.2rem,5vw,3.5rem);letter-spacing:-.02em;line-height:1.15;margin-bottom:1.5rem}.hero-title span{color:var(--bleu-clair)}.hero-sub{font-size:.95rem;font-weight:400;color:var(--gris-acier);max-width:420px;margin:0 auto;line-height:1.7}.scroll-indicator{position:absolute;bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--gris-acier);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--bleu),transparent);animation:scrollPulse 2s infinite}@keyframes scrollPulse{0%,to{opacity:.3}50%{opacity:1}}.about{padding:6rem 2rem;text-align:center;background:var(--creme)}.about-inner{max-width:520px;margin:0 auto}.section-label{font-size:.7rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--bleu);margin-bottom:2rem}.about-text{font-size:1rem;font-weight:400;color:var(--gris-acier);line-height:1.9}.contact{padding:4rem 2rem 5rem;background:var(--white)}.contact-inner{max-width:440px;margin:0 auto;text-align:center}.contact .section-label{margin-bottom:2.5rem}.contact-form{display:flex;flex-direction:column;gap:.75rem;position:relative}.contact-form input,.contact-form textarea{width:100%;padding:.85rem 1rem;border:1px solid #e0ddd8;background:var(--creme);font-family:var(--font-heading);font-size:.85rem;font-weight:400;color:var(--marine);transition:border-color .3s}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--gris-acier)}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--bleu)}.contact-form textarea{resize:vertical}.contact-form button{margin-top:.5rem;padding:.85rem 2rem;background:var(--bleu);color:var(--white);border:none;font-family:var(--font-heading);font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .3s}.contact-form button:hover{background:var(--marine)}.contact-form button:disabled{opacity:.5;cursor:not-allowed}.form-msg{margin-top:1rem;padding:.75rem;font-size:.85rem}.form-msg--success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.form-msg--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.form-msg--error a{text-decoration:underline}.site-footer{padding:2.5rem 2rem;background:var(--marine);color:var(--gris-acier);text-align:center;font-size:.75rem;letter-spacing:.05em}.footer-inner{max-width:520px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-logo{display:flex;align-items:center;gap:.5rem;color:var(--white)}.footer-logo img{width:24px;height:24px}.footer-logo span{font-weight:800;font-size:1rem}.footer-email{color:var(--bleu-clair);transition:color .3s}.footer-email:hover{color:var(--white)}.footer-copy{color:#8c9baf80}@media(max-width:640px){.hero-logo img{width:40px;height:40px}.hero-logo-text{font-size:2rem}}
