/* =====================================================================
   Lyno — Marketing design system (sous-pages : tarifs, contact, légales)
   Organic Precision. Fonts auto-hébergées, zéro CDN. Cohérent avec la home.
   ===================================================================== */

/* ---- Fonts (self-hosted, latin subset) ---- */
@font-face { font-family:'Almarai'; font-style:normal; font-weight:400; font-display:swap; src:url('./fonts/almarai-400.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Almarai'; font-style:normal; font-weight:700; font-display:swap; src:url('./fonts/almarai-700.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Almarai'; font-style:normal; font-weight:800; font-display:swap; src:url('./fonts/almarai-800.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Instrument Serif'; font-style:normal; font-weight:400; font-display:swap; src:url('./fonts/instrument-serif-400.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Instrument Serif'; font-style:italic; font-weight:400; font-display:swap; src:url('./fonts/instrument-serif-400-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap; src:url('./fonts/inter-400.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap; src:url('./fonts/inter-500.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap; src:url('./fonts/inter-600.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap; src:url('./fonts/inter-700.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }

/* ---- Tokens ---- */
:root {
  --bg: #0b0b0d;
  --panel: #141416;
  --panel-2: #1a1a1a;
  --cream: #E1E0CC;
  --cream-soft: rgba(225,224,204,0.72);
  --cream-mute: rgba(225,224,204,0.55);
  --lime: #c7f33c;
  --ink: #111111;
  --ease-cine: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-card: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---- Reset / base ---- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0;
  background: var(--bg);
  color: var(--cream);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
::selection { background: var(--cream); color: #000; }
a { color: inherit; text-decoration: none; }
img, svg, video { display: block; max-width: 100%; }
h1, h2, h3 { font-family: 'Almarai', sans-serif; font-weight: 800; letter-spacing: -0.02em; line-height: 1.08; text-wrap: balance; margin: 0; }
p { text-wrap: pretty; }
.serif-it { font-family: 'Instrument Serif', serif; font-style: italic; font-weight: 400; letter-spacing: -0.005em; }
.tnum { font-variant-numeric: tabular-nums; }

a:focus-visible, button:focus-visible, summary:focus-visible {
  outline: 2px solid var(--lime); outline-offset: 3px; border-radius: 6px;
}
.skip-link {
  position: fixed; top: 12px; left: 12px; z-index: 200;
  background: var(--lime); color: #111; font-weight: 700; font-size: 14px;
  padding: 10px 18px; border-radius: 999px; transform: translateY(-200%);
}
.skip-link:focus-visible { transform: none; }

/* ---- Page shell ---- */
.mk {
  position: relative;
  min-height: 100vh;
  background:
    radial-gradient(1100px 600px at 50% -5%, rgba(199,243,60,0.05), transparent 60%),
    linear-gradient(180deg, #0e0e11 0%, var(--bg) 30%, var(--bg) 100%);
}
.mk-container { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.mk-narrow { max-width: 820px; }

/* ---- Nav (pill noire suspendue, identique à la home : défile avec la page) ---- */
.mk-nav-wrap {
  position: absolute; top: 0; left: 0; right: 0; z-index: 90;
  padding: 16px 16px 0;
  pointer-events: none;
}
@media (min-width: 768px) { .mk-nav-wrap { padding: 24px 32px 0; } }
.mk-nav {
  pointer-events: auto;
  max-width: 980px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 8px 8px 8px 20px;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 999px;
}
@media (min-width: 768px) { .mk-nav { padding: 9px 9px 9px 26px; } }
.mk-brand { font-family: 'Almarai', sans-serif; font-weight: 800; font-size: 19px; color: var(--cream); letter-spacing: -0.03em; display: inline-flex; align-items: baseline; gap: 1px; }
.mk-brand .ast { color: var(--lime); font-size: 13px; transform: translateY(-2px); display: inline-block; }
.mk-nav-links { display: none; gap: 4px; align-items: center; }
@media (min-width: 900px) { .mk-nav-links { display: inline-flex; } }
.mk-nav-links a { color: rgba(225,224,204,0.78); font-size: 13.5px; padding: 8px 14px; border-radius: 999px; transition: color 0.2s, background 0.2s; white-space: nowrap; }
.mk-nav-links a:hover, .mk-nav-links a[aria-current="page"] { color: var(--cream); background: rgba(255,255,255,0.06); }
.mk-nav-actions { display: inline-flex; align-items: center; gap: 14px; }
.mk-login { color: rgba(225,224,204,0.82); font-size: 13.5px; font-weight: 500; padding: 8px 4px; white-space: nowrap; transition: color 0.2s; }
.mk-login:hover { color: var(--cream); }
.mk-cta {
  color: #000; background: var(--cream);
  padding: 9px 9px 9px 18px; border-radius: 999px;
  font-size: 13.5px; font-weight: 700;
  display: inline-flex; align-items: center; gap: 10px;
  transition: gap 0.25s var(--ease-card), background 0.25s var(--ease-card), transform 0.15s var(--ease-card);
}
.mk-cta:hover { background: #fff; gap: 12px; }
.mk-cta:active { transform: scale(0.98); }
.mk-cta .sq { width: 28px; height: 28px; background: #000; color: var(--lime); border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; }
.mk-cta .sq svg { width: 13px; height: 13px; }
@media (max-width: 600px) { .mk-login { display: none; } }

/* ---- Nav-mini (identique à la home : réapparaît au scroll-up délibéré) ---- */
.mk-mini {
  position: fixed;
  top: 14px; left: 50%;
  z-index: 96;
  transform: translate(-50%, -22px);
  opacity: 0;
  pointer-events: none;
  display: flex; align-items: center; gap: 18px;
  padding: 7px 7px 7px 20px;
  background: rgba(8, 8, 9, 0.82);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 999px;
  box-shadow: 0 22px 60px -28px rgba(0,0,0,0.7);
  transition: transform 0.55s var(--ease-cine), opacity 0.4s ease;
  will-change: transform, opacity;
}
.mk-mini.show { transform: translate(-50%, 0); opacity: 1; pointer-events: auto; }
.mk-mini .mk-brand { font-size: 17px; }
.mk-mini .mk-brand .ast { font-size: 12px; }
.mk-mini-links { display: none; gap: 2px; }
@media (min-width: 720px) { .mk-mini-links { display: inline-flex; } }
.mk-mini-links a {
  color: rgba(225,224,204,0.78); font-size: 13px; padding: 7px 12px;
  border-radius: 999px; transition: color 0.15s ease, background 0.15s ease;
  white-space: nowrap;
}
.mk-mini-links a:hover, .mk-mini-links a[aria-current="page"] { color: var(--cream); background: rgba(255,255,255,0.06); }
.mk-mini .mk-nav-actions { gap: 10px; }
.mk-mini .mk-login { font-size: 13px; }
.mk-mini .mk-cta { padding: 8px 8px 8px 16px; font-size: 13px; gap: 9px; }
.mk-mini .mk-cta .sq { width: 25px; height: 25px; border-radius: 7px; }
.mk-mini .mk-cta .sq svg { width: 12px; height: 12px; }
@media (prefers-reduced-motion: reduce) { .mk-mini { transition: none; } }

/* ---- Page header (titre de section) ---- */
.mk-head { padding: clamp(70px, 11vw, 130px) 0 clamp(30px, 5vw, 56px); text-align: center; }
.mk-kicker { font-size: 12.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--cream-mute); margin-bottom: 22px; }
.mk-h1 {
  font-size: clamp(34px, 5.2vw, 60px);
  line-height: 1.04;
  color: var(--cream);
  margin: 0 auto;
  max-width: 22ch;
}
.mk-lead {
  margin: 26px auto 0;
  max-width: 64ch;
  font-size: 18px;
  line-height: 1.68;
  color: var(--cream-soft);
}

/* ---- Editorial article chrome ---- */
.article-crumbs {
  display: inline-flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 10px;
  margin: 0 auto 24px; color: rgba(225,224,204,0.52); font-size: 13px;
}
.article-crumbs a { color: rgba(225,224,204,0.72); transition: color 0.18s ease; }
.article-crumbs a:hover { color: var(--cream); }
.article-crumbs span[aria-hidden="true"] {
  width: 4px; height: 4px; border-radius: 50%; background: var(--lime);
}
.article-tags {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 9px;
  margin: 26px auto 0; max-width: 760px;
}
.article-tag {
  display: inline-flex; align-items: center; min-height: 30px; padding: 7px 11px;
  border-radius: 999px; background: rgba(225,224,204,0.1); color: rgba(225,224,204,0.78);
  font-size: 12px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase;
}
.article-tag.accent { background: var(--lime); color: var(--ink); }
.article-crumbs ~ .mk-kicker { margin-top: 34px; }

/* ---- Buttons (inline) ---- */
.mk-btn {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--lime); color: #111; font-weight: 700; font-size: 16px;
  padding: 14px 26px; border-radius: 999px; border: 0; cursor: pointer;
  transition: gap 0.25s var(--ease-card), filter 0.25s var(--ease-card), transform 0.15s var(--ease-card);
}
.mk-btn:hover { gap: 13px; filter: brightness(1.04); }
.mk-btn:active { transform: scale(0.98); }
.mk-btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--cream); font-weight: 600; font-size: 16px;
  padding: 14px 22px; border-radius: 999px; border: 1px solid rgba(225,224,204,0.2);
  transition: border-color 0.2s, background 0.2s, transform 0.15s var(--ease-card);
}
.mk-btn-ghost:hover { border-color: rgba(225,224,204,0.4); background: rgba(255,255,255,0.03); }
.mk-btn-ghost:active { transform: scale(0.98); }

/* ---- Sections (sous-pages) ---- */
.sec { padding: clamp(64px, 9vw, 110px) 0 0; }
.sec-h2 { font-size: clamp(26px, 3.4vw, 40px); color: var(--cream); text-align: center; }
.sec-sub { margin: 14px auto 0; max-width: 56ch; text-align: center; font-size: 16px; line-height: 1.55; color: var(--cream-soft); }
.sec-src { margin: 18px auto 0; max-width: 60ch; text-align: center; font-size: 12px; color: rgba(225,224,204,0.4); }
.sec .prose,
.sec > p,
.sec > ul,
.sec > ol {
  margin-left: auto;
  margin-right: auto;
}
.sec .prose {
  max-width: min(72ch, 100%);
}

/* ---- Cards ---- */
.mk-card {
  background: linear-gradient(165deg, rgba(255,255,255,0.05), rgba(255,255,255,0.012));
  border: 1px solid rgba(225,224,204,0.09);
  border-radius: 20px; padding: 30px;
}

/* ---- Footer ---- */
.footer { background: #060607; padding: 56px 24px 32px; margin-top: clamp(70px, 10vw, 120px); border-top: 1px solid rgba(225,224,204,0.06); }
.footer-grid { max-width: 1080px; margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 36px; padding-bottom: 28px; }
@media (min-width: 760px) { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 24px; } }
.footer-brand .mark { font-family: 'Almarai', sans-serif; font-weight: 800; font-size: 21px; color: var(--cream); }
.footer-brand .ast { color: var(--lime); }
.footer-brand p { margin: 14px 0 0; font-size: 13.5px; line-height: 1.55; color: var(--cream-mute); max-width: 30ch; }
.footer-brand .footer-host { font-size: 12px; color: rgba(225,224,204,0.4); }
.footer-col { display: grid; gap: 11px; align-content: start; }
.footer-col strong { font-size: 11.5px; text-transform: uppercase; letter-spacing: 0.14em; color: rgba(225,224,204,0.42); margin-bottom: 4px; }
.footer-col a { font-size: 13.5px; color: var(--cream-mute); transition: color 0.15s; width: fit-content; }
.footer-col a:hover { color: var(--cream); }
.footer-base { max-width: 1080px; margin: 0 auto; padding-top: 22px; border-top: 1px solid rgba(225,224,204,0.07); font-size: 12px; color: rgba(225,224,204,0.55); }

/* ---- Prose (pages légales) ---- */
.legal { padding-bottom: 40px; }
.legal-prose { max-width: 760px; margin: 0 auto; color: var(--cream-soft); font-size: 16px; line-height: 1.7; }
.legal-prose h2 { font-size: 24px; color: var(--cream); margin: 44px 0 14px; letter-spacing: -0.015em; }
.legal-prose h3 { font-size: 18px; font-weight: 700; font-family: 'Inter', sans-serif; color: var(--cream); margin: 30px 0 10px; letter-spacing: -0.01em; }
.legal-prose h4 { font-size: 15.5px; font-weight: 600; font-family: 'Inter', sans-serif; color: var(--cream); margin: 22px 0 8px; letter-spacing: -0.01em; }
.legal-prose p { margin: 0 0 16px; }
.legal-prose ul, .legal-prose ol { margin: 0 0 18px; padding-left: 22px; }
.legal-prose li { margin: 0 0 8px; }
.legal-prose a { color: var(--lime); text-decoration: underline; text-underline-offset: 2px; }
.legal-prose strong { color: var(--cream); font-weight: 700; }
.legal-prose hr { border: 0; border-top: 1px solid rgba(225,224,204,0.1); margin: 36px 0; }
.legal-meta { font-size: 13px; color: var(--cream-mute); margin-bottom: 36px; }

/* ---- Motion partagé (sous-pages) ---- */
/* Reveal : animation (pas transition) pour ne jamais entrer en conflit avec les
   transitions de hover. Le keyframe final omet transform : après l'entrée, les
   lifts de hover transitionnent librement. Stagger via --rd inline. */
@keyframes rvIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; }
}
.rv { opacity: 0; }
.rv.in { animation: rvIn 0.85s var(--ease-cine) both; animation-delay: var(--rd, 0s); }

/* Entrée de page : nav + en-tête orchestrés au chargement */
@keyframes navIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; }
}
.mk-nav { animation: navIn 0.7s var(--ease-cine) both; }
.mk-head > * { animation: rvIn 0.9s var(--ease-cine) both; }
.mk-head > *:nth-child(2) { animation-delay: 0.08s; }
.mk-head > *:nth-child(3) { animation-delay: 0.16s; }
.legal .legal-prose { animation: rvIn 0.9s var(--ease-cine) 0.18s both; }

/* Barre de progression de lecture (pages longues) */
.read-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 300;
  background: var(--lime); transform: scaleX(0); transform-origin: 0 50%;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
  .rv { opacity: 1; }
}
