/* v3 — matches provided mockup: dark hero + light content + blue enterprise */
:root{
  --blue:#0a84ff;
  --blue2:#5bb1ff;
  --heroInk:#eaf1ff;
  --heroMuted: rgba(234,241,255,0.72);
  --heroLine: rgba(255,255,255,0.14);
  --ink:#0b1220;
  --muted: rgba(11,18,32,0.70);
  --line: rgba(11,18,32,0.10);
  --card: rgba(255,255,255,0.86);
  --shadow: 0 20px 70px rgba(11,18,32,0.14);
  --radius: 18px;
  --radius2: 22px;
  --max: 1180px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--ink);
  background: #f4f7fb;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
.container{ max-width: var(--max); margin: 0 auto; padding: 0 22px; }

/* HERO WRAP */
.heroWrap{
  position: relative;
  color: var(--heroInk);
  padding-bottom: 28px;
  overflow:hidden;
}
.heroBg{
  position:absolute; inset:0;
  background:
    radial-gradient(1000px 520px at 20% 20%, rgba(10,132,255,0.40), transparent 58%),
    radial-gradient(900px 560px at 70% 40%, rgba(91,177,255,0.18), transparent 62%),
    linear-gradient(180deg, rgba(5,8,16,0.94) 0%, rgba(9,13,24,0.86) 55%, rgba(9,13,24,0.10) 100%);
  filter:saturate(1.08);
}
.heroWrap .container{ position:relative; z-index:1; }

/* TOPBAR */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  gap: 18px;
  padding: 18px 0 12px;
}
.brand{ display:flex; align-items:center; gap: 12px; }
.brand__mark{
  width: 44px; height: 44px; color: var(--blue);
  display:grid; place-items:center;
}
.brand__mark svg{ width: 44px; height: 44px; }
.brand__text{ display:flex; flex-direction:column; line-height:1.15; }
.brand__title{ font-weight: 700; letter-spacing:-0.3px; }
.brand__sub{ color: rgba(234,241,255,0.70); font-size: 12px; letter-spacing: 0.16em; text-transform: lowercase; }

.nav{ display:flex; gap: 18px; align-items:center; }
.nav__link{
  color: rgba(234,241,255,0.75);
  font-size: 14px;
  padding: 10px 10px;
  border-radius: 999px;
  transition: 160ms ease;
}
.nav__link:hover{ color: var(--heroInk); background: rgba(255,255,255,0.06); }
.nav__link.is-active{ color: var(--heroInk); }
.topbar__cta{ display:flex; align-items:center; gap: 10px; }
.pillBtn{
  display:inline-flex; align-items:center; gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  color: var(--heroInk);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 14px 50px rgba(10,132,255,0.22);
}
.pillBtn span{ color: rgba(234,241,255,0.85); }
.pillBtn:hover{ border-color: rgba(10,132,255,0.45); background: rgba(10,132,255,0.10); }

.burger{
  display:none;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  cursor:pointer;
}
.burger span{
  display:block; width: 18px; height:2px; margin:4px auto;
  background: rgba(234,241,255,0.85); border-radius: 99px;
}
.mobileNav{
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
}
.mobileNav__link{
  display:block; padding: 12px 10px; border-radius: 12px;
  color: rgba(234,241,255,0.82);
}
.mobileNav__link:hover{ background: rgba(255,255,255,0.08); }

/* HERO GRID */
.hero{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 26px;
  align-items:center;
  padding: 22px 0 10px;
}
h1{
  margin:0 0 14px;
  font-size: 56px;
  line-height: 1.05;
  letter-spacing: -1.2px;
}
.blue{ color: var(--blue2); }
.hero__line{ margin: 0 0 6px; color: rgba(234,241,255,0.82); }
.hero__line--muted{ color: rgba(234,241,255,0.68); }
.pin{ opacity:0.9; margin-right:6px; }

.hero__actions{ display:flex; gap: 12px; flex-wrap:wrap; margin: 18px 0 16px; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  color: var(--heroInk);
  transition: 170ms ease;
}
.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,0.08); }
.btn--primary{
  border-color: rgba(10,132,255,0.55);
  background: linear-gradient(180deg, rgba(10,132,255,1), rgba(10,132,255,0.80));
  box-shadow: 0 20px 70px rgba(10,132,255,0.20);
}
.btn--primary:hover{ box-shadow: 0 26px 90px rgba(10,132,255,0.26); }
.btn--ghost{ }
.btn__muted{ font-weight: 500; color: rgba(234,241,255,0.72); }

.hero__badges{
  display:flex; gap: 14px; flex-wrap:wrap;
  color: rgba(234,241,255,0.78);
}
.badge{
  display:inline-flex; align-items:center; gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.05);
}

/* RIGHT VISUAL CARD */
.deskCard{
  position:relative;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  box-shadow: 0 30px 120px rgba(0,0,0,0.42);
  overflow:hidden;
}
.deskCard__glow{
  position:absolute; inset:-60px;
  background: radial-gradient(circle at 55% 35%, rgba(10,132,255,0.25), transparent 55%);
  pointer-events:none;
}
.deskCard__inner{ position:relative; padding: 16px; }
.deskHeader{ display:flex; align-items:center; gap: 12px; margin-bottom: 12px; }
.deskLogo{
  width: 40px; height: 40px; border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(10,132,255,0.16);
  border: 1px solid rgba(10,132,255,0.25);
  font-weight: 800;
}
.deskMeta__title{ font-weight: 700; }
.deskMeta__sub{ font-size: 12px; color: rgba(234,241,255,0.72); margin-top: 2px; }

.deskArt{ border-radius: 18px; overflow:hidden; border: 1px solid rgba(255,255,255,0.12); background: rgba(0,0,0,0.12); }
.art{ width: 100%; height: auto; display:block; }

.deskStats{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  margin-top: 12px;
}
.stat{
  padding: 10px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.05);
}
.stat__k{ font-size: 12px; color: rgba(234,241,255,0.72); }
.stat__v{ font-weight: 800; letter-spacing:-0.2px; }

/* PAGE LIGHT */
.page{ padding-bottom: 30px; }
.split{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 18px;
  margin-top: -18px; /* pull into hero like screenshot */
}
.split__left, .split__right{ align-self:start; }

h2{
  margin: 0 0 12px;
  font-size: 24px;
  letter-spacing:-0.4px;
}
/* WHY cards */
.whyCards{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.wcard{
  display:flex; gap: 12px;
  padding: 16px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.wcard__icon{
  width: 44px; height: 44px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(10,132,255,0.10);
  border: 1px solid rgba(10,132,255,0.20);
}
.wcard h3{ margin: 0 0 6px; font-size: 16px; }
.wcard ul{ margin:0; padding-left: 18px; color: var(--muted); }
.wcard li{ margin: 6px 0; }

/* FORM CARD */
.formCard{
  padding: 18px;
  border-radius: 26px;
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.formCard h3{ margin: 0 0 12px; font-size: 20px; }
#contactForm{ display:flex; flex-direction:column; gap: 10px; }
#contactForm input, #contactForm select, #contactForm textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(11,18,32,0.14);
  background: #fff;
  outline:none;
  font-size: 14px;
}
#contactForm input:focus, #contactForm select:focus, #contactForm textarea:focus{
  border-color: rgba(10,132,255,0.50);
  box-shadow: 0 0 0 4px rgba(10,132,255,0.12);
}
#contactForm textarea{ min-height: 110px; resize: vertical; }
.btn--block{ width:100%; justify-content:center; }
.fineRow{ font-size: 13px; color: rgba(11,18,32,0.60); text-align:center; margin-top: 2px; }
.status{ font-size: 13px; color: rgba(11,18,32,0.70); text-align:center; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* SERVICES */
#services{ margin-top: 26px; }
.serviceRow{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.svc{
  grid-column: span 1;
  padding: 16px;
  border-radius: var(--radius2);
  background: #0b1220;
  color: #eaf1ff;
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 22px 70px rgba(11,18,32,0.18);
}
.svc--focus{
  background: linear-gradient(135deg, rgba(10,132,255,0.30), rgba(11,18,32,1) 60%);
  border-color: rgba(10,132,255,0.30);
}
.svc__hdr{ display:flex; align-items:center; gap: 10px; margin-bottom: 10px; }
.svc__icon{
  width: 38px; height: 38px; border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(10,132,255,0.18);
  border: 1px solid rgba(10,132,255,0.25);
}
.svc h3{ margin:0; font-size: 16px; }
.svc ul{ margin: 10px 0 0; padding-left: 18px; color: rgba(234,241,255,0.78); }
.svc li{ margin: 8px 0; }

/* make 3 cards wide like screenshot */
.serviceRow{ grid-template-columns: repeat(3, 1fr); }

/* STEPS */
.steps{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 8px; }
.step{
  display:flex; gap: 12px;
  padding: 16px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.step__n{
  width: 40px; height: 40px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(10,132,255,0.10);
  border: 1px solid rgba(10,132,255,0.20);
  font-weight: 800;
  color: var(--blue);
}
.step h3{ margin:0 0 6px; font-size: 16px; }
.step p{ margin:0; color: var(--muted); }

/* TARIFS */
.tarifGrid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 8px; }
.tarifCard{
  padding: 16px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.tarifCard--accent{
  background: linear-gradient(180deg, rgba(10,132,255,0.10), rgba(255,255,255,0.92));
  border-color: rgba(10,132,255,0.22);
}
.tarifTop{ display:flex; align-items:baseline; justify-content:space-between; gap: 10px; }
.tarifPrice .big{ font-size: 28px; font-weight: 800; letter-spacing:-0.6px; }
.tarifPrice .small{ color: rgba(11,18,32,0.55); font-weight: 600; }
.tarifCard ul{ margin: 10px 0 0; padding-left: 18px; color: var(--muted); }
.tarifCard li{ margin: 8px 0; }

/* Footer */
.footer{ margin-top: 26px; padding: 20px 0 10px; color: rgba(11,18,32,0.65); }
.footer__in{ display:flex; align-items:center; justify-content:space-between; gap: 12px; flex-wrap:wrap; }
.footer__muted a{ color: rgba(11,18,32,0.75); text-decoration: underline; text-decoration-color: rgba(10,132,255,0.30); }

/* responsive */
@media (max-width: 1050px){
  .hero{ grid-template-columns: 1fr; }
  h1{ font-size: 46px; }
  .split{ grid-template-columns: 1fr; margin-top: 10px; }
  .whyCards{ grid-template-columns: 1fr; }
  .serviceRow{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: 1fr; }
  .tarifGrid{ grid-template-columns: 1fr; }
}
@media (max-width: 860px){
  .nav{ display:none; }
  .burger{ display:inline-grid; place-items:center; }
}
