:root{
  --bg:#0A1729;          /* navy profond, presque nuit */
  --bg-2:#0E1E36;        /* panneaux */
  --bg-3:#122643;        /* survol / cartes */
  --line:rgba(170,200,230,.12);
  --line-2:rgba(170,200,230,.2);
  --teal:#2FB7B0;        /* turquoise pétrole, accent principal */
  --teal-soft:#5FD6CF;
  --gold:#C9A24B;        /* touche dorée discrète */
  --paper:#F4EFE6;       /* crème chaud pour le texte clair */
  --ink:#EAF1F8;
  --ink-2:#9FB2C8;
  --ink-3:#6E84A0;
  --head:'Fraunces',Georgia,serif;
  --body:'Inter',-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:72px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{font-family:var(--body);background:var(--bg);color:var(--ink);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
::selection{background:var(--teal);color:var(--bg)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

h1,h2,h3{font-family:var(--head);font-weight:500;letter-spacing:-.01em;line-height:1.1;color:var(--paper)}
h1{font-size:clamp(38px,5.2vw,64px);font-weight:400}
h2{font-size:clamp(28px,3.4vw,42px)}
h3{font-size:20px;font-weight:500}

/* fine ligne dorée décorative en haut */
.topline{height:2px;background:linear-gradient(90deg,var(--teal),var(--gold) 60%,transparent)}

.eyebrow{font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:11px;margin-bottom:16px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--teal)}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:500;font-size:15px;background:var(--teal);color:#04201F;border:1px solid var(--teal);padding:13px 26px;border-radius:3px;cursor:pointer;transition:background .18s,box-shadow .18s}
.btn:hover{background:var(--teal-soft);box-shadow:0 6px 26px rgba(47,183,176,.28)}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn.ghost:hover{background:var(--bg-3);box-shadow:none;border-color:var(--teal)}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(10,23,41,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{height:72px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav .logo img{height:46px;width:auto}
.nav .menu{display:flex;gap:30px}
.nav .menu a{font-size:14.5px;color:var(--ink-2);font-weight:500;position:relative;padding:3px 0}
.nav .menu a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--teal);transition:right .25s}
.nav .menu a:hover{color:var(--ink)}.nav .menu a:hover::after{right:0}
.nav .end{display:flex;align-items:center;gap:18px}
.nav .tel{font-size:14.5px;font-weight:600;color:var(--ink);white-space:nowrap}
.nav .tel:hover{color:var(--teal)}
@media(max-width:940px){.nav .menu,.nav .tel{display:none}}

/* ---------- hero ---------- */
.hero{position:relative;padding:clamp(60px,10vh,120px) 0 clamp(50px,7vh,90px);overflow:hidden}
.hero::before{content:"";position:absolute;top:-30%;right:-10%;width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(47,183,176,.16),transparent 62%);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-20%;left:-12%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,75,.08),transparent 60%);pointer-events:none}
.hero .inner{position:relative;max-width:880px}
.hero h1{margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--teal-soft)}
.hero .lede{font-size:19px;color:var(--ink-2);max-width:54ch;margin-bottom:32px;line-height:1.6}
.hero .acts{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:54px}
.hero .facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
@media(max-width:680px){.hero .facts{grid-template-columns:repeat(2,1fr)}}
.hero .fact{background:var(--bg-2);padding:22px 22px}
.hero .fact .v{font-family:var(--head);font-size:34px;font-weight:500;color:var(--paper);line-height:1}
.hero .fact .v i{font-style:normal;color:var(--teal);font-size:18px}
.hero .fact .l{font-size:13px;color:var(--ink-3);margin-top:8px;letter-spacing:.01em}

/* ---------- bande gamme ---------- */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.strip .wrap{display:flex;flex-wrap:wrap;gap:12px 34px;padding:16px 26px}
.strip span{font-size:13.5px;color:var(--ink-2);display:flex;align-items:center;gap:10px}
.strip span::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold)}

/* ---------- sections ---------- */
section{padding:clamp(64px,9vh,104px) 0}
.s-top{max-width:640px;margin-bottom:44px}
.s-top .lede{color:var(--ink-2);font-size:16.5px;margin-top:10px}

/* services : grille 3 cols, cartes feutrées, accent au survol */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:880px){.svc{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.svc{grid-template-columns:1fr}}
.svc .it{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:28px 26px;transition:border-color .2s,background .2s,transform .2s;position:relative}
.svc .it:hover{border-color:var(--line-2);background:var(--bg-3);transform:translateY(-3px)}
.svc .it .ic{width:46px;height:46px;border-radius:8px;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;margin-bottom:20px;background:rgba(47,183,176,.08)}
.svc .it .ic svg{width:23px;height:23px;stroke:var(--teal-soft);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.svc .it h3{margin-bottom:9px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.svc .it .badge{font-family:var(--body);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(201,162,75,.4);border-radius:99px;padding:2px 9px}
.svc .it p{font-size:14.5px;color:var(--ink-2)}

/* parkings : split sombre + carte feutrée */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:32px}}
.checks{list-style:none;display:grid;gap:13px;margin:20px 0 28px}
.checks li{display:flex;gap:13px;font-size:15.5px;color:var(--ink)}
.checks li::before{content:"";flex:none;width:21px;height:21px;margin-top:1px;border-radius:50%;border:1px solid var(--teal);background:rgba(47,183,176,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235FD6CF' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4 10-10'/%3E%3C/svg%3E") center/11px no-repeat}
.park-card{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:14px}
.bay{display:flex;align-items:center;gap:13px;padding:14px 18px;border-radius:6px;font-size:13px;color:var(--ink-3);border-bottom:1px solid var(--line)}
.bay:last-child{border-bottom:0}
.bay .car{width:44px;height:16px;border-radius:8px 8px 2px 2px;background:#2A3F5F;flex:none}
.bay.live{background:var(--bg-3);color:var(--teal-soft);font-weight:500}
.bay.live .car{background:var(--teal);box-shadow:0 0 14px rgba(47,183,176,.55)}

/* contrats : grille 4, cartes feutrées */
.eng{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
@media(max-width:880px){.eng{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.eng{grid-template-columns:1fr}}
.eng .e{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:24px 22px}
.eng .e .num{font-family:var(--head);font-size:22px;color:var(--teal);margin-bottom:12px}
.eng .e h3{margin-bottom:8px;font-size:18px}
.eng .e p{font-size:13.5px;color:var(--ink-2)}
.eng-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.eng-cta span{font-size:14px;color:var(--ink-3)}

/* zone */
.zone{display:grid;grid-template-columns:1fr 1fr;gap:46px}
@media(max-width:760px){.zone{grid-template-columns:1fr;gap:30px}}
.zone .col .lab{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-2);padding-bottom:14px;border-bottom:1px solid var(--line-2);margin-bottom:18px}
.zone .col .lab .d{width:8px;height:8px;border-radius:50%}
.zone .col .lab .d.f{background:var(--teal);box-shadow:0 0 8px rgba(47,183,176,.7)}
.zone .col .lab .d.s{background:var(--ink-3)}
.zone .cities{display:flex;flex-wrap:wrap;gap:9px}
.zone .cities span{font-size:14.5px;color:var(--ink);background:var(--bg-2);border:1px solid var(--line);border-radius:99px;padding:8px 16px;transition:border-color .15s,color .15s}
.zone .cities span:hover{border-color:var(--teal);color:var(--teal-soft)}
.zone-note{margin-top:28px;font-size:15px;color:var(--ink-2);max-width:62ch}
.zone-note b{color:var(--paper);font-weight:600}

/* contact */
.contact{background:var(--bg-2);border-top:1px solid var(--line)}
.c-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start}
@media(max-width:880px){.c-grid{grid-template-columns:1fr;gap:34px}}
.cform{display:grid;gap:15px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:15px}
@media(max-width:520px){.cform .row2{grid-template-columns:1fr}}
.cform label{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);display:block;margin-bottom:7px}
.cform input,.cform textarea{width:100%;border:1px solid var(--line-2);border-radius:5px;background:var(--bg);font-family:var(--body);font-size:15px;color:var(--ink);padding:12px 14px;transition:border-color .15s}
.cform input::placeholder,.cform textarea::placeholder{color:var(--ink-3)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--teal)}
.cform textarea{min-height:108px;resize:vertical}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.cform-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.cform-status{font-size:14px;margin:0}.cform-status.ok{color:var(--teal-soft)}.cform-status.err{color:#E58A8A}
.btn[disabled]{opacity:.55;cursor:not-allowed}
.c-card{background:var(--bg-3);border:1px solid var(--line);border-radius:10px;padding:28px}
.c-card dl{display:grid;gap:16px}
.c-card dt{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:3px}
.c-card dd{font-size:15.5px;color:var(--ink)}
.c-card dd a{color:var(--ink)}
.c-card dd a:hover{color:var(--teal-soft)}
.c-card .urg{margin-top:20px;padding-top:20px;border-top:1px solid var(--line)}
.c-card .urg .h{font-family:var(--head);font-size:18px;color:var(--paper);display:flex;align-items:center;gap:10px}
.c-card .urg .h::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(47,183,176,.18);animation:beat 2s infinite}
@keyframes beat{50%{box-shadow:0 0 0 9px rgba(47,183,176,0)}}
.c-card .urg p{font-size:13.5px;color:var(--ink-2);margin-top:7px}

footer{background:#081320;border-top:1px solid var(--line)}
footer .in{display:flex;flex-wrap:wrap;gap:14px 30px;justify-content:space-between;align-items:center;padding:26px 26px;font-size:13px;color:var(--ink-3)}
footer img{height:34px;width:auto;opacity:.92}
footer a{color:var(--ink-2)}
footer a:hover{color:var(--teal)}