/* ===== Nexus Marine — Design System (shared) ===== */
:root{
  --bg:#0A0A0A;--bg2:#0D0D0D;--bg3:#111;--card:#161616;
  --red:#C0392B;--text:#ECE7DE;--sec:#8A8078;--muted:#555;
  --h:'Cormorant Garamond',serif;--b:'Calibri','Segoe UI',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--b);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}
.en{display:block;color:var(--sec);font-size:.82em;font-style:italic;font-weight:400;margin-top:2px}
/* Buttons */
.btn{display:inline-block;font-family:var(--b);font-weight:600;text-transform:uppercase;letter-spacing:2px;font-size:13px;padding:15px 28px;cursor:pointer;transition:.25s;border:1px solid transparent}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:#a93226;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--text)}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}
.btn-sm{padding:11px 20px;font-size:12px}
/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(10,10,10,.9);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}
.hbar{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;align-items:center;gap:12px}
.logo img{height:34px;width:auto}
.logo .ltxt{font-family:var(--h);font-weight:600;letter-spacing:5px;font-size:21px;text-transform:uppercase}
.logo .ltxt b{color:var(--red);font-weight:600}
nav{display:flex;gap:26px;align-items:center}
nav a.lnk{font-family:var(--h);font-weight:600;font-size:16px;letter-spacing:1px;color:var(--text);transition:.2s}
nav a.lnk:hover{color:var(--red)}
.lang{font-size:12px;letter-spacing:2px;color:var(--sec)}
.lang b{color:var(--text)}
.lang a{color:var(--sec)}.lang a:hover{color:var(--red)}
.htel{display:flex;align-items:center;gap:7px;font-size:15px;font-weight:600;letter-spacing:.5px;color:var(--text);transition:.2s;white-space:nowrap}
.htel:hover{color:var(--red)}
.htel svg{width:15px;height:15px;fill:var(--red)}
.hcta{display:flex;align-items:center;gap:18px}
/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:70px}
.hero-bg{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;filter:grayscale(.12) contrast(1.04) brightness(1.06)}
.hero-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,10,.82) 0%,rgba(10,10,10,.5) 48%,rgba(10,10,10,.28) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.kick{text-transform:uppercase;letter-spacing:3px;font-size:12px;color:var(--red);font-weight:600;margin-bottom:24px}
.hero h1{font-family:var(--h);font-weight:500;font-size:clamp(44px,7vw,90px);line-height:1.02;max-width:14ch}
.hero h1 i{color:var(--red)}
.hero p.lead{max-width:620px;color:var(--text);font-size:18px;margin:30px 0 36px}
.hbtns{display:flex;gap:16px;flex-wrap:wrap}
.kpis{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.1);margin-top:60px;display:grid;grid-template-columns:repeat(4,1fr)}
.kpi{padding:26px 0;border-right:1px solid rgba(255,255,255,.1)}
.kpi:last-child{border-right:none}
.kpi .v{font-family:var(--h);font-style:italic;color:var(--red);font-size:38px;line-height:1}
.kpi .l{text-transform:uppercase;letter-spacing:1.5px;font-size:11px;color:var(--sec);margin-top:6px}
/* Section */
section{padding:100px 0;border-top:1px solid rgba(255,255,255,.05)}
.label{text-transform:uppercase;letter-spacing:3px;font-size:12px;color:var(--red);font-weight:600;margin-bottom:16px}
.rule{width:54px;height:3px;background:var(--red);margin-bottom:26px}
h2{font-family:var(--h);font-weight:500;font-size:clamp(34px,5vw,56px);line-height:1.05;margin-bottom:18px}
h2 i{color:var(--red)}
.lead{color:var(--sec);font-size:18px;max-width:720px;margin-bottom:50px}
/* Positioning */
.pos{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pcard{background:var(--bg3);border:1px solid rgba(255,255,255,.08);padding:34px}
.pcard .pn{font-family:var(--h);font-style:italic;color:var(--red);font-size:24px;margin-bottom:14px}
.pcard h3{font-family:var(--h);font-weight:600;font-size:23px;margin-bottom:10px}
.pcard p{color:var(--sec);font-size:14.5px}
/* Trades */
.trades{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07)}
.trade{background:var(--bg);padding:24px 20px;transition:.25s}
.trade:hover{background:var(--card)}
.trade .tn{font-family:var(--h);font-style:italic;color:var(--red);font-size:14px;display:block;margin-bottom:8px}
.trade h3{font-family:var(--h);font-weight:600;font-size:20px;margin-bottom:4px}
.trade .te{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:1px}
/* Method */
.method{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.mcard{background:var(--bg3);border:1px solid rgba(255,255,255,.08);padding:32px;transition:.25s}
.mcard:hover{border-color:rgba(192,57,43,.5)}
.mcard .mi{width:34px;height:34px;margin-bottom:16px;fill:none;stroke:var(--red);stroke-width:1.6}
.mcard h3{font-family:var(--h);font-weight:600;font-size:24px;margin-bottom:10px}
.mcard p{color:var(--sec);font-size:14.5px}
.appbox{margin-top:22px;background:linear-gradient(135deg,#161616,#0d0d0d);border:1px solid rgba(192,57,43,.35);padding:40px;display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center}
.badge{display:inline-block;background:rgba(192,57,43,.15);color:var(--red);border:1px solid rgba(192,57,43,.4);font-size:11px;text-transform:uppercase;letter-spacing:2px;padding:6px 12px;font-weight:600;margin-bottom:16px}
.appbox h3{font-family:var(--h);font-weight:500;font-size:32px;margin-bottom:12px}
.appbox h3 i{color:var(--red)}
.appbox p{color:var(--sec);font-size:14.5px;margin-bottom:8px}
.applist{list-style:none;margin-top:4px}
.applist li{padding:9px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:14px}
.applist li:before{content:"—";color:var(--red);margin-right:10px}
.applist li:last-child{border-bottom:none}
/* Infra */
.infra{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.icard{background:var(--card);border:1px solid rgba(255,255,255,.08);padding:30px}
.icard .ii{width:30px;height:30px;margin-bottom:14px;fill:none;stroke:var(--red);stroke-width:1.6}
.icard h3{font-family:var(--h);font-weight:600;font-size:22px;margin-bottom:8px}
.icard p{color:var(--sec);font-size:14px}
/* References */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:40px}
.gal figure{position:relative;overflow:hidden;aspect-ratio:4/5}
.gal img{width:100%;height:100%;object-fit:cover;object-position:center;filter:grayscale(.25) contrast(1.03);transition:.4s}
.gal figure:hover img{filter:grayscale(0);transform:scale(1.04)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px;background:linear-gradient(transparent,rgba(10,10,10,.9));font-family:var(--h);font-style:italic;font-size:16px}
.brands{display:flex;flex-wrap:wrap;gap:10px}
.brand{border:1px solid rgba(255,255,255,.12);padding:9px 16px;font-size:13px;letter-spacing:1px;color:var(--sec);transition:.2s}
.brand:hover{border-color:var(--red);color:var(--text)}
/* Testimonials */
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{background:var(--bg3);border:1px solid rgba(255,255,255,.08);padding:32px;position:relative}
.tcard .q{font-family:var(--h);font-style:italic;color:var(--red);font-size:46px;line-height:0;position:absolute;top:30px;left:24px;opacity:.4}
.tcard p{font-family:var(--h);font-style:italic;font-size:21px;line-height:1.4;margin:26px 0 18px}
.tcard .who{font-weight:700;font-size:14px}
.tcard .who span{display:block;color:var(--sec);font-weight:400;font-size:13px}
/* Zones */
.zones{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.zcol h3{font-family:var(--h);font-weight:600;font-size:22px;color:var(--red);margin-bottom:14px}
.zlist{list-style:none}
.zlist li{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:15px}
/* Blog */
.blog{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bcard{background:var(--bg3);border:1px solid rgba(255,255,255,.08);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.bcard:hover{transform:translateY(-4px);border-color:rgba(192,57,43,.5)}
.bcard img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:center;filter:none}
.bcard .bc{padding:24px;flex:1;display:flex;flex-direction:column}
.bcard .cat{text-transform:uppercase;letter-spacing:2px;font-size:11px;color:var(--red);font-weight:600;margin-bottom:10px}
.bcard h3{font-family:var(--h);font-weight:600;font-size:22px;line-height:1.2;margin-bottom:10px}
.bcard p{color:var(--sec);font-size:13.5px;flex:1}
.bcard .more{color:var(--red);font-size:13px;text-transform:uppercase;letter-spacing:1px;margin-top:14px;font-weight:600}
/* Contact */
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:60px}
.cinfo p{margin-bottom:18px}
.cinfo .ct{text-transform:uppercase;letter-spacing:2px;font-size:11px;color:var(--red);font-weight:600;margin-bottom:4px}
.cinfo .cv{font-size:16px;color:var(--text)}
form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
form .full{grid-column:1/3}
input,textarea,select{width:100%;background:var(--bg3);border:1px solid rgba(255,255,255,.12);color:var(--text);font-family:var(--b);font-size:15px;padding:14px 16px}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--red)}
textarea{min-height:120px;resize:vertical}
/* Service / article page body */
.page-hero{padding:150px 0 70px;position:relative;border-bottom:1px solid rgba(255,255,255,.06)}
.crumb{font-size:12px;letter-spacing:1px;color:var(--sec);margin-bottom:18px}
.crumb a:hover{color:var(--red)}
.page-hero h1{font-family:var(--h);font-weight:500;font-size:clamp(38px,6vw,72px);line-height:1.03;max-width:18ch}
.page-hero h1 i{color:var(--red)}
.page-hero .sub{color:var(--sec);font-size:19px;max-width:680px;margin-top:22px}
.article{padding:70px 0 90px}
.article .body{max-width:760px}
.article h2{font-size:clamp(28px,4vw,42px);margin:46px 0 14px}
.article h3{font-family:var(--h);font-weight:600;font-size:26px;color:var(--text);margin:34px 0 10px}
.article p{color:var(--text);font-size:17px;margin-bottom:18px}
.article p.muted{color:var(--sec)}
.article ul{list-style:none;margin:10px 0 24px}
.article ul li{padding:9px 0 9px 22px;position:relative;color:var(--text);font-size:16px;border-bottom:1px solid rgba(255,255,255,.06)}
.article ul li:before{content:"—";color:var(--red);position:absolute;left:0}
.article .callout{border-left:3px solid var(--red);background:var(--bg3);padding:22px 26px;margin:30px 0;font-family:var(--h);font-style:italic;font-size:22px;line-height:1.4}
.article .kgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:30px 0}
.article .kgrid .k{background:var(--bg3);border:1px solid rgba(255,255,255,.08);padding:24px}
.article .kgrid .k .v{font-family:var(--h);font-style:italic;color:var(--red);font-size:32px}
.article .kgrid .k .l{color:var(--sec);font-size:13px;margin-top:6px}
.related{background:var(--bg2);border-top:1px solid rgba(255,255,255,.06);padding:60px 0}
.cardrow{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.lcard{background:var(--bg3);border:1px solid rgba(255,255,255,.08);padding:28px;transition:.25s}
.lcard:hover{border-color:rgba(192,57,43,.5);transform:translateY(-3px)}
.lcard .cat{text-transform:uppercase;letter-spacing:2px;font-size:11px;color:var(--red);font-weight:600;margin-bottom:10px}
.lcard h3{font-family:var(--h);font-weight:600;font-size:21px;line-height:1.2}
.lcard .more{color:var(--red);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-top:14px;font-weight:600}
/* Final band */
.band{background:var(--bg3);padding:90px 0;text-align:center;border-top:1px solid rgba(255,255,255,.07)}
.band h2{margin-bottom:14px}
.band .lead{margin:0 auto 34px}
.btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
/* Footer */
footer{background:var(--bg2);padding:50px 0 30px;border-top:1px solid rgba(255,255,255,.06)}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
.fgrid h4{text-transform:uppercase;letter-spacing:2px;font-size:11px;color:var(--sec);margin-bottom:16px}
.fgrid a{display:block;color:var(--text);font-size:14px;padding:5px 0;transition:.2s}
.fgrid a:hover{color:var(--red)}
.flogo{font-family:var(--h);letter-spacing:5px;font-size:20px;text-transform:uppercase}
.flogo b{color:var(--red)}
.fbot{border-top:1px solid rgba(255,255,255,.06);padding-top:22px;color:var(--muted);font-size:12px;text-align:center}
@media(max-width:980px){
  nav .lnk{display:none}.lang{display:none}
  .htel{font-size:0;gap:0}.htel svg{width:18px;height:18px}
  .logo .ltxt{display:none}
  .kpis,.pos,.trades,.method,.appbox,.infra,.gal,.tg,.zones,.blog,.contact,.fgrid,.cardrow,.article .kgrid{grid-template-columns:1fr 1fr}
  form{grid-template-columns:1fr}form .full{grid-column:1}
  section{padding:72px 0}
}
@media(max-width:600px){
  /* Pile sur 1 colonne pour les blocs riches en texte */
  .pos,.method,.infra,.tg,.zones,.blog,.contact,.fgrid,.cardrow,.article .kgrid{grid-template-columns:1fr}
  /* Mais on garde 2 colonnes pour les listes courtes : métiers, KPI, galerie */
  .trades{grid-template-columns:1fr 1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .gal{grid-template-columns:1fr 1fr}
  .wrap{padding:0 18px}
  section{padding:60px 0}
  /* Métiers : tuiles plus compactes sur mobile */
  .trade{padding:18px 14px}
  .trade h3{font-size:17px;line-height:1.15}
  .trade .tn{font-size:13px;margin-bottom:6px}
  /* Hero : titre adapté + hauteur souple */
  .hero{min-height:auto;padding:110px 0 56px}
  .hero h1{font-size:clamp(34px,9vw,52px)}
  .hero p.lead{font-size:16px}
  .kpi{padding:18px 0}
  .kpi .v{font-size:30px}
  /* KPI : la 2e ligne sans bordure droite qui dépasse */
  .kpi:nth-child(2){border-right:none}
  /* Cartes & sections plus respirantes */
  .appbox{padding:26px}
  .pcard,.mcard,.icard,.tcard{padding:26px}
  h2{font-size:clamp(30px,8vw,40px)}
  .lead{font-size:16px;margin-bottom:36px}
  .page-hero{padding:120px 0 50px}
  .page-hero h1{font-size:clamp(30px,8vw,44px)}
  .svc-photo{max-height:300px}
  /* Header : bouton CTA un peu plus compact */
  .btn-sm{padding:10px 14px;letter-spacing:1.5px}
  .hcta{gap:12px}
}

.svc-photo{width:100%;max-height:480px;object-fit:cover;object-position:center;filter:grayscale(.15) contrast(1.03);display:block}

/* Cookie banner */
#nm-cookie{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:#0D0D0D;border-top:1px solid rgba(192,57,43,.5);box-shadow:0 -8px 30px rgba(0,0,0,.5)}
#nm-cookie .nm-cookie-in{max-width:1280px;margin:0 auto;padding:18px 32px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:space-between}
#nm-cookie p{color:var(--text);font-size:14px;margin:0;max-width:70ch}
#nm-cookie a{color:var(--red);text-decoration:underline}
#nm-cookie .nm-cookie-btns{display:flex;gap:12px;flex-shrink:0}
#nm-cookie button{font-family:var(--b);font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-size:12px;padding:11px 22px;cursor:pointer;border:1px solid var(--text);background:transparent;color:var(--text);transition:.2s}
#nm-cookie .nm-ck-accept{background:var(--red);border-color:var(--red);color:#fff}
#nm-cookie .nm-ck-accept:hover{background:#a93226}
#nm-cookie .nm-ck-refuse:hover{border-color:var(--red);color:var(--red)}
@media(max-width:600px){#nm-cookie .nm-cookie-in{padding:14px 18px;gap:12px}#nm-cookie .nm-cookie-btns{width:100%}#nm-cookie button{flex:1}}
