/* LNG INFORMATIQUE — lnginfo.net
   Palette et voix typographique dérivées du logo (lettrage rétro 1970s)
   et de la bannière de marque : fond gris froid, bleu « vous », corail crayon. */

:root {
  --fond: #eef0f2;
  --blanc: #ffffff;
  --noir: #161616;
  --encre: #2b3440;
  --gris: #55606b;
  --bleu: #2e63a4;
  --corail: #d9543e;
  --filet: #d5dae0;
  --mono: "IBM Plex Mono", "Courier New", monospace;
  --sans: "IBM Plex Sans", "Segoe UI", system-ui, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .hero-in { animation: none !important; }
}

body {
  font-family: var(--sans);
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--encre);
  background: var(--fond);
}

a { color: var(--bleu); }
a:focus-visible, button:focus-visible {
  outline: 3px solid var(--bleu);
  outline-offset: 3px;
}

.wrap { max-width: 62rem; margin: 0 auto; padding: 0 1.25rem; }

/* ---- header ---- */
.top {
  border-bottom: 1px solid var(--filet);
  background: var(--fond);
}
.top-in {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 0.85rem 0;
}
.top-brand {
  display: flex; align-items: center; gap: 0.65rem;
  font-family: var(--mono); font-weight: 700; font-size: 0.95rem;
  color: var(--noir); text-decoration: none; letter-spacing: 0.02em;
  white-space: nowrap;
}
.top-brand img { width: 34px; height: 34px; }
.top nav { display: flex; gap: 1.4rem; }
.top nav a {
  font-family: var(--mono); font-size: 0.85rem; text-decoration: none;
  color: var(--gris);
}
.top nav a:hover { color: var(--noir); }
@media (max-width: 44rem) {
  .top-in { gap: 0.6rem; }
  .top-brand { font-size: 0.78rem; gap: 0.45rem; }
  .top-brand img { width: 28px; height: 28px; }
  .top nav { gap: 0.75rem; }
  .top nav a { font-size: 0.75rem; }
}

/* ---- hero ---- */
.hero { text-align: center; padding: 4.5rem 0 4rem; }
.hero-in { animation: rise 0.7s ease-out both; }
@keyframes rise {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}
.hero img.logo { width: min(190px, 46vw); height: auto; }
.hero h1 {
  font-family: var(--mono); font-weight: 700;
  font-size: clamp(1.35rem, 3.6vw, 2.1rem);
  color: var(--noir); margin-top: 1.6rem; letter-spacing: -0.01em;
}
/* le geste signature : « vous » bleu, souligné au crayon corail */
.vous {
  color: var(--bleu); font-style: normal; position: relative; white-space: nowrap;
}
.vous svg {
  position: absolute; left: -2%; bottom: -0.38em; width: 104%; height: 0.4em;
}
.hero p.pitch {
  max-width: 36rem; margin: 1.4rem auto 0; color: var(--gris);
}
.hero .depuis {
  display: inline-block; margin-top: 1.6rem;
  font-family: var(--mono); font-size: 0.85rem; color: var(--encre);
  border: 1px solid var(--filet); background: var(--blanc);
  padding: 0.45rem 0.95rem; border-radius: 999px;
}
.hero .actions { margin-top: 2.2rem; }
.btn {
  display: inline-block; font-family: var(--mono); font-weight: 600;
  font-size: 0.95rem; text-decoration: none;
  background: var(--noir); color: var(--blanc);
  padding: 0.8rem 1.5rem; border-radius: 6px;
}
.btn:hover { background: var(--bleu); }

/* ---- sections ---- */
section { padding: 3.5rem 0; }
.sec-label {
  font-family: var(--mono); font-size: 0.85rem; font-weight: 600;
  color: var(--corail); letter-spacing: 0.08em; text-transform: uppercase;
}
section h2 {
  font-family: var(--mono); font-size: clamp(1.25rem, 2.6vw, 1.6rem);
  color: var(--noir); margin: 0.4rem 0 1.8rem;
}

/* services */
.services { background: var(--blanc); border-top: 1px solid var(--filet); border-bottom: 1px solid var(--filet); }
.cards {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem;
}
@media (max-width: 44rem) { .cards { grid-template-columns: 1fr; } }
.card {
  border: 1px solid var(--filet); border-radius: 8px;
  padding: 1.4rem 1.5rem; background: var(--fond);
}
.card h3 {
  font-family: var(--mono); font-size: 1rem; color: var(--noir);
  margin-bottom: 0.5rem;
}
.card p { font-size: 0.97rem; color: var(--gris); }

/* société */
.faits {
  display: flex; gap: 2.5rem; flex-wrap: wrap; margin-top: 1.8rem;
}
.fait { font-family: var(--mono); }
.fait strong { display: block; font-size: 1.5rem; color: var(--noir); }
.fait span { font-size: 0.85rem; color: var(--gris); }
.societe p + p { margin-top: 1rem; }
.societe p { max-width: 44rem; }

/* contact */
.contact { background: var(--blanc); border-top: 1px solid var(--filet); }
.contact-grid { display: flex; gap: 3rem; flex-wrap: wrap; }
.contact-bloc { font-size: 1rem; }
.contact-bloc .k {
  font-family: var(--mono); font-size: 0.8rem; color: var(--gris);
  text-transform: uppercase; letter-spacing: 0.07em; display: block;
  margin-bottom: 0.25rem;
}
.contact-bloc a { font-family: var(--mono); }

/* footer */
footer {
  border-top: 1px solid var(--filet); padding: 1.6rem 0 2.2rem;
  font-size: 0.85rem; color: var(--gris);
}
footer .wrap { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
footer a { color: var(--gris); }
footer a:hover { color: var(--noir); }

/* pages légales */
.legal { max-width: 46rem; margin: 0 auto; padding: 3rem 1.25rem 4rem; }
.legal h1 { font-family: var(--mono); font-size: 1.5rem; color: var(--noir); margin-bottom: 1.5rem; }
.legal h2 { font-family: var(--mono); font-size: 1.05rem; color: var(--noir); margin: 1.8rem 0 0.6rem; }
.legal p, .legal li { color: var(--encre); }
.legal ul { padding-left: 1.2rem; margin: 0.5rem 0; }
.legal .retour { display: inline-block; margin-bottom: 2rem; font-family: var(--mono); font-size: 0.85rem; }
